/* GHFO — Gallery Home Furniture Outlet — Master Stylesheet */
/* Design: Plus Jakarta Sans / DM Sans / Playfair Display / Pink & Dark */


/* ── RESET & BASE ─────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --black:#1A1A1A;--black-s:#2D2D2D;
  --pink:#E91E7B;--pink-lt:#F06AA0;--pink-dk:#C4176A;--lime:#D8F0A0;--green:#2EAD6A;--gold-badge:#F0D060;
  --white:#ffffff;--off:#fafafa;
  --g1:#F8F7F4;--g2:#E8E8E8;--g3:#AAAAAA;--g4:#7A7A7A;
  --grey-100:#f4f4f2;--grey-200:#e8e8e8;--grey-300:#ddd;
  --text-light:#7A7A7A;--text-muted:#999;--success:#2EAD6A;--error:#c0392b;--gold:#C6973F;
  --font-body:'DM Sans','Plus Jakarta Sans',sans-serif;--font-heading:'Playfair Display',serif;
  --red:#E91E7B;--radius:10px;--tx:.22s ease;
}
html{scroll-behavior:smooth}
body{font-family:'DM Sans','Plus Jakarta Sans',sans-serif;color:var(--black);background:var(--white);font-size:15px;line-height:1.65;-webkit-font-smoothing:antialiased}
a{color:var(--black);text-decoration:none;transition:color var(--tx)}
a:hover{color:var(--pink)}
img{display:block;max-width:100%}
ul{list-style:none}

/* ── TOPBAR ─────────────────────────────────────────────────*/
/* ── TOP BANNER + SALE STRIP ── */
.ghfo-wrap{max-width:1600px;margin:0 auto;padding:0 32px}
.ghfo-topbar{background:#2D2D2D}
.ghfo-topbar__row{display:flex;justify-content:space-between;align-items:center;padding:7px 0;font-size:12px;color:rgba(255,255,255,.6)}
.ghfo-topbar__row a{color:rgba(255,255,255,.7);transition:color .2s}
.ghfo-topbar__row a:hover{color:#D8F0A0}
.ghfo-topbar__left{display:flex;align-items:center;gap:4px}
.ghfo-topbar__left svg{width:13px;height:13px;stroke:rgba(255,255,255,.5)}
.ghfo-topbar__right{display:flex;align-items:center;gap:6px}
.ghfo-topbar__right span{color:rgba(255,255,255,.3)}
.ghfo-sale-strip{background:var(--pink);text-align:center;padding:9px 20px;font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:13px;font-weight:700;color:#fff;letter-spacing:.5px}
.ghfo-sale-strip span{color:#E8F5C8}
/* ── HEADER ── */
.ghfo-header{background:var(--white);border-bottom:1px solid var(--g2);position:sticky;top:0;z-index:200}
.ghfo-header__row{display:flex;align-items:center;justify-content:space-between;height:60px}
/* Header logo — matches footer */
.ghfo-logo-wrap{display:inline-flex;align-items:center;gap:8px;text-decoration:none;flex-shrink:0}
.ghfo-logo-box{background:#E91E7B;color:#fff;font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-weight:900;font-size:20px;letter-spacing:-1px;padding:4px 8px;border-radius:3px;line-height:1.1}
.ghfo-logo-text{display:flex;flex-direction:column;line-height:1.15}
.ghfo-logo-text span{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-weight:700;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:#1A1A1A}
.ghfo-logo-text .pink{font-size:9px;color:#E91E7B;letter-spacing:2px}
.ghfo-search{flex:1;max-width:480px;margin:0 32px;display:flex;align-items:center;background:var(--g1);border:1px solid var(--g2);border-radius:8px;overflow:hidden;transition:border-color .2s}
.ghfo-search:focus-within{border-color:var(--pink)}
.ghfo-search input{flex:1;border:none;background:none;padding:10px 14px;font-family:'DM Sans',sans-serif;font-size:13px;outline:none}
.ghfo-search button{background:var(--pink);border:none;padding:10px 16px;cursor:pointer;display:flex;align-items:center}
.ghfo-search button svg{stroke:#fff}
.ghfo-header__utils{display:flex;align-items:center;gap:2px;flex-shrink:0}
.ghfo-nav-toggle{display:none;align-items:center;justify-content:center;width:44px;height:44px;margin-left:-8px;border:none;background:none;border-radius:8px;cursor:pointer;color:#1A1A1A;flex-shrink:0}
.ghfo-nav-toggle svg{width:22px;height:22px;stroke:currentColor}
.ghfo-nav-toggle:hover{background:var(--g1)}
.ghfo-search-mob{display:none}
.ghfo-hbtn.ghfo-search-mob{display:none}
.ghfo-hbtn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 10px;border-radius:8px;font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:12px;font-weight:600;color:#4A4A4A;cursor:pointer;transition:background .2s;background:none;border:none;text-decoration:none;box-sizing:border-box;min-width:40px;min-height:40px}
.ghfo-hbtn:hover{background:var(--g1)}
.ghfo-hbtn svg{width:18px;height:18px;stroke:#4A4A4A;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.ghfo-hbtn__label{white-space:nowrap}
.ghfo-count-badge{position:absolute;top:2px;right:0;min-width:16px;height:16px;padding:0 4px;border-radius:999px;font-size:10px;font-weight:700;line-height:16px;text-align:center;color:#fff;pointer-events:none}
.ghfo-count-badge--wl{background:var(--pink);color:#fff}
.ghfo-count-badge--cart{background:#2E7D32;color:#fff}
.ghfo-hbtn--cart{background:rgba(46,125,50,.08);color:#2E7D32}
.ghfo-hbtn--cart svg{stroke:#2E7D32}
.ghfo-cart-count{font-weight:700;color:#2E7D32}
.ghfo-backtotop{
  position:fixed;
  right:16px;
  bottom:84px;
  z-index:2105;
  width:42px;
  height:42px;
  border:none;
  border-radius:999px;
  background:#1a1a1a;
  color:#fff;
  font-size:20px;
  line-height:1;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 8px 18px rgba(0,0,0,.22);
  cursor:pointer;
  opacity:0;
  transform:translateY(10px);
  pointer-events:none;
  transition:opacity .18s ease, transform .18s ease, background .18s ease;
}
.ghfo-backtotop:hover{background:var(--pink)}
.ghfo-backtotop.is-visible{opacity:1;transform:translateY(0);pointer-events:auto}
.icon-btn{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--black);transition:background var(--tx);position:relative}
.icon-btn:hover{background:var(--g1)}
.icon-btn svg{width:20px;height:20px}
/* ── CATEGORY NAV ── */
.ghfo-catnav{background:var(--white);border-top:1px solid var(--g2)}
.ghfo-catnav__row{display:flex;gap:0;justify-content:center;flex-wrap:wrap}
.ghfo-catnav__link{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:13px;font-weight:600;color:#4A4A4A;padding:11px 20px;white-space:nowrap;transition:all .2s;border-bottom:2px solid transparent}
.ghfo-catnav__link:hover{color:var(--pink)}
.ghfo-catnav__link--sale{color:var(--pink);border-bottom-color:var(--pink)}
.ghfo-catnav__mobile-head{display:none}

/* ── MEGA MENU ── */
.mm-wrap{position:static !important;display:inline-flex}
.mm-trigger{display:inline-flex;align-items:center;padding:11px 20px;font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:13px;font-weight:600;color:#4A4A4A;text-decoration:none;position:relative;transition:all .2s;white-space:nowrap;border-bottom:2px solid transparent}
.mm-wrap:hover .mm-trigger{color:#E91E7B;border-bottom-color:#E91E7B}
.mm-trigger::before{content:'';position:absolute;bottom:-14px;left:0;right:0;height:14px}
.mm-panel{position:absolute;left:0;right:0;top:100%;background:#fff;border-top:1px solid #E8E8E8;box-shadow:0 16px 48px rgba(0,0,0,.08);opacity:0;visibility:hidden;transform:translateY(-4px);transition:opacity .22s,visibility .22s,transform .22s;z-index:999}
.mm-wrap:hover .mm-panel{opacity:1;visibility:visible;transform:translateY(0)}
.mm-inner{max-width:1400px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:0}
.mm-col{padding:28px;border-right:1px solid #f4f4f2}
.mm-col:last-child{border-right:none}
.mm-heading{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:13px;font-weight:700;color:#1A1A1A;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid #f4f4f2;margin-top:20px}
.mm-heading:first-child{margin-top:0}
.mm-links{list-style:none;padding:0;margin:0 0 4px}
.mm-links a{display:flex;align-items:center;gap:8px;padding:5px 0;font-size:13px;color:#4A4A4A;text-decoration:none;transition:color .15s}
.mm-links a:hover{color:#E91E7B}
.mm-dot{width:14px;height:14px;border-radius:50%;flex-shrink:0;border:1px solid rgba(0,0,0,.08)}
.mm-col--featured{background:#FAFAF8;display:flex;flex-direction:column;gap:16px;padding:24px}
.mm-promo{display:block;text-decoration:none;border-radius:6px;overflow:hidden;transition:transform .2s}
.mm-promo:hover{transform:translateY(-2px)}
.mm-promo-label{display:block;padding:10px 0 0;font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:11px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:#1A1A1A}
.mm-mobile-all-link{display:none}

/* ── CATEGORY STRIP ─────────────────────────────────────── */
.cat-strip{border-bottom:1px solid var(--g2);overflow-x:auto;scrollbar-width:none}
.cat-strip::-webkit-scrollbar{display:none}
.cat-strip__inner{max-width:1600px;margin:0 auto;display:flex;justify-content:center}
.cat-pill{display:flex;flex-direction:column;align-items:center;gap:10px;padding:20px 30px 16px;min-width:100px;border-right:1px solid var(--g2);cursor:pointer;text-decoration:none;color:var(--black);position:relative;transition:background var(--tx)}
.cat-pill:last-child{border-right:none}
.cat-pill::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--pink);transform:scaleX(0);transition:transform .2s}
.cat-pill:hover{background:var(--g1);color:var(--black)}
.cat-pill:hover::after{transform:scaleX(1)}
.cat-pill__icon{width:58px;height:58px;border-radius:50%;overflow:hidden;background:var(--g1);border:2px solid transparent;transition:border-color .2s;display:flex;align-items:center;justify-content:center;font-size:1.4rem}
.cat-pill:hover .cat-pill__icon{border-color:var(--pink)}
.cat-pill__name{font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600}
.cat-pill--sale .cat-pill__name{color:var(--red)}

/* ── HERO ────────────────────────────────────────────────── */
.hero{position:relative;overflow:hidden;background:var(--black-s);min-height:62.5vh}
/* All slides fill the hero — do NOT use position:relative on :first-child or the bg only covers text height and min-height shows as empty grey band */
.hero__slide{position:absolute;inset:0;opacity:0;transition:opacity .8s ease;z-index:1}
.hero__slide.active{opacity:1;z-index:2}
.hero__bg{position:absolute;inset:0;background-size:cover;background-position:center;background-repeat:no-repeat}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(26,26,26,.7) 0%,rgba(26,26,26,.3) 100%)}
.hero__content{position:relative;z-index:2;padding:85px 100px 95px;max-width:760px}
.hero__eyebrow{font-size:.6rem;letter-spacing:.24em;text-transform:uppercase;color:#D8F0A0;font-weight:600;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.hero__eyebrow::before{content:'';width:20px;height:1px;background:#D8F0A0}
.hero__h1{font-family:'Playfair Display',serif;font-size:3.2rem;font-weight:700;color:#fff;line-height:1.05;margin-bottom:12px}
.hero__h1 em{font-style:italic;color:#D8F0A0}
.hero__p{font-size:.9rem;color:rgba(255,255,255,.7);line-height:1.7;margin-bottom:24px;max-width:460px}
.hero__actions{display:flex;gap:10px;flex-wrap:wrap}
.hero__stats{position:absolute;bottom:0;right:0;z-index:2;display:flex;background:var(--black)}
.hero__stat{padding:18px 28px;border-right:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;align-items:center;gap:3px}
.hero__stat:last-child{border-right:none}
.stat-val{font-family:'Playfair Display',serif;font-size:1.6rem;font-weight:700;color:var(--pink-lt);line-height:1}
.stat-lbl{font-size:.55rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.35)}

/* ── BUTTONS ─────────────────────────────────────────────── */
.btn-gold{display:inline-flex;align-items:center;gap:10px;background:var(--pink);color:var(--black)!important;padding:14px 32px;border-radius:var(--radius);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;border:none;cursor:pointer;transition:background var(--tx),transform var(--tx),box-shadow var(--tx);font-family:'DM Sans','Plus Jakarta Sans',sans-serif}
.btn-gold:hover{background:var(--pink-lt);transform:translateY(-2px);box-shadow:0 8px 24px rgba(233,30,123,.3);color:var(--black)!important}
.btn-outline-w{display:inline-flex;align-items:center;gap:10px;border:1px solid rgba(255,255,255,.35);color:var(--white)!important;padding:13px 30px;border-radius:var(--radius);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;font-weight:500;transition:all var(--tx)}
.btn-outline-w:hover{border-color:var(--pink);color:var(--pink)!important}
.btn-black{display:inline-flex;align-items:center;gap:10px;background:var(--black);color:var(--white)!important;padding:13px 30px;border-radius:var(--radius);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;border:none;cursor:pointer;transition:background var(--tx);font-family:'DM Sans','Plus Jakarta Sans',sans-serif}
.btn-black:hover{background:var(--pink);color:var(--black)!important}

/* ── TRUST BAR ───────────────────────────────────────────── */
.trust-bar{border-top:1px solid var(--g2);border-bottom:1px solid var(--g2)}
.trust-bar__inner{max-width:1600px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr)}
.trust-cell{display:flex;align-items:center;gap:16px;padding:26px 32px;border-right:1px solid var(--g2)}
.trust-cell:last-child{border-right:none}
.trust-icon{width:42px;height:42px;flex-shrink:0;color:var(--pink)}
.trust-icon svg{width:100%;height:100%}
.trust-label{font-size:.56rem;letter-spacing:.18em;text-transform:uppercase;color:var(--g4);font-weight:600;margin-bottom:2px}
.trust-val{font-size:.86rem;font-weight:700;color:var(--black)}

/* ── SECTIONS ────────────────────────────────────────────── */
.section{padding:48px 0 72px}
.section--grey{background:var(--g1)}
.section--white{background:#fff}
.section--black{background:var(--black)}
.section--off{background:var(--off)}
.container{max-width:1600px;margin:0 auto;padding:0 40px}
.section-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:40px;flex-wrap:wrap;gap:16px}
.section-tag{font-size:.6rem;letter-spacing:.26em;text-transform:uppercase;color:var(--pink);font-weight:600;margin-bottom:8px;display:flex;align-items:center;gap:8px}
.section-tag::before{content:'';width:22px;height:1px;background:var(--pink)}
.section-title{font-family:'Playfair Display',serif;font-size:clamp(1.7rem,2.5vw,2.5rem);font-weight:700;line-height:1.12;color:var(--black);margin:0}
.section-title em{font-style:italic;color:var(--pink)}
.section-title--white{color:var(--white)}
.link-all{font-size:.65rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;color:var(--black);border-bottom:2px solid var(--black);padding-bottom:2px;transition:all var(--tx);display:inline-flex;align-items:center;gap:6px;white-space:nowrap}
.link-all:hover{color:var(--pink);border-color:var(--pink)}
.link-all--white{color:rgba(255,255,255,.6);border-color:rgba(255,255,255,.25)}
.link-all--white:hover{color:var(--pink-lt);border-color:var(--pink-lt)}

/* ── PROMO TILES ─────────────────────────────────────────── */
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.cat-tile{position:relative;overflow:hidden;border-radius:var(--radius);display:flex;min-height:280px;text-decoration:none;cursor:pointer}
.cat-tile--lg{grid-column:span 2}
.cat-tile__img{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .5s ease}
.cat-tile:hover .cat-tile__img{transform:scale(1.04)}
.cat-tile__overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(17,17,17,.55) 0%,rgba(17,17,17,.05) 50%,transparent 100%)}
.cat-tile__body{position:absolute;bottom:0;left:0;right:0;padding:22px 24px;z-index:2;display:flex;flex-direction:column;align-items:flex-start;gap:6px}
.cat-tile__label{font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;font-weight:700;color:var(--white)}
.cat-tile__promo{font-family:'Playfair Display',serif;font-size:1.6rem;font-weight:700;color:var(--white);line-height:1.1}
.cat-tile--lg .cat-tile__promo{font-size:2.2rem}
.cat-tile__link{font-size:.56rem;letter-spacing:.16em;text-transform:uppercase;font-weight:700;color:var(--white);padding:6px 0;border-bottom:1px solid rgba(255,255,255,.4);transition:border-color .2s}
.cat-tile:hover .cat-tile__link{border-color:#fff}
.fp-scroller-wrap{overflow:hidden;position:relative;margin:0 -4px}
.fp-scroller{display:flex;gap:16px;transition:transform .4s ease;padding:4px}
.fp-card{min-width:calc(20% - 13px);max-width:calc(20% - 13px);flex-shrink:0}
.fp-arrow{width:38px;height:38px;border-radius:50%;border:1.5px solid var(--g2);background:var(--white);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.3rem;color:var(--black);transition:all .2s;flex-shrink:0}
.fp-arrow:hover{border-color:var(--pink);color:var(--pink);background:rgba(233,30,123,.03)}
.promo-link{font-size:.63rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;color:var(--white);border-bottom:1px solid rgba(255,255,255,.3);padding-bottom:2px;display:inline-flex;align-items:center;gap:6px;transition:all var(--tx)}
.promo-link:hover{color:var(--pink-lt);border-color:var(--pink-lt)}

/* ── PRODUCT GRID ────────────────────────────────────────── */
/* ── PRODUCT CARD — Concept 3 exact ── */
.products-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;align-items:stretch}
.products-grid > .pc{align-self:stretch;min-height:0}
.pc{border-radius:8px;overflow:hidden;border:1px solid #E8E8E8;background:#fff;transition:box-shadow .2s,transform .2s;display:flex;flex-direction:column;height:100%;min-height:0}
.pc:hover{box-shadow:0 4px 16px rgba(0,0,0,.06);transform:translateY(-2px)}
.pc__img{display:block;flex-shrink:0;height:200px;background:#f4f3f0;position:relative;overflow:hidden}
.pc__img img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.pc:hover .pc__img img{transform:scale(1.04)}
.pc__badge{position:absolute;top:10px;left:10px;padding:4px 10px;border-radius:12px;font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:11px;font-weight:700;z-index:2}
.pc__badge--sale{background:#E91E7B;color:#fff}
.pc__badge--new{background:#2D2D2D;color:#fff}
.pc__badge--best{background:#B8D878;color:#2D2D2D}
.pc__badge--clear{background:#FF7F50;color:#fff}
.pc__wl{position:absolute;top:10px;right:10px;width:32px;height:32px;background:rgba(255,255,255,.92);border-radius:50%;display:flex;align-items:center;justify-content:center;border:1px solid #E8E8E8;cursor:pointer;z-index:2;transition:all .2s}
.pc__wl:hover,.pc__wl.active{background:#E91E7B;border-color:#E91E7B}
.pc__wl:hover svg,.pc__wl.active svg{stroke:#fff}
.pc__wl.active svg{fill:#fff}
.pc__wl svg{width:15px;height:15px;stroke:#999;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.ghfo-wl-count{font-weight:700;color:var(--pink)}
.pc__body{padding:14px 16px 16px;display:flex;flex-direction:column;flex:1 1 auto;min-height:0}
.pc__cat{font-size:10px;text-transform:uppercase;letter-spacing:1.2px;color:#999;margin-bottom:4px;font-weight:500}
.pc__title{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:14px;font-weight:600;color:#1A1A1A;margin-bottom:8px;line-height:1.35;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;text-decoration:none}
.pc__title:hover{color:#E91E7B}
.pc__price{display:flex;align-items:baseline;gap:6px;flex-wrap:wrap;margin-bottom:0}
.pc__price-now{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:20px;font-weight:700;color:#E91E7B}
.pc__price-was{font-size:13px;color:#999;text-decoration:line-through}
.pc__price-save{font-size:11px;font-weight:600;color:#2EAD6A}
.pc__cta{display:flex;gap:6px;justify-content:center;align-items:stretch;margin-top:auto;padding-top:12px}
.pc__btn{display:inline-flex;align-items:center;justify-content:center;font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-weight:600;font-size:11px;padding:7px 14px;border-radius:4px;border:1.5px solid transparent;cursor:pointer;transition:all .15s;text-decoration:none;text-align:center;white-space:nowrap;min-height:36px;box-sizing:border-box}
.pc__btn--pink{background:#E91E7B;color:#fff;border-color:#E91E7B}
.pc__btn--pink:hover{background:#C4176A;border-color:#C4176A}
.pc__btn--outline{background:transparent;color:#1A1A1A;border-color:#D0D0D0}
.pc__btn--outline:hover{border-color:#1A1A1A}
/* Flash Deals header */
.flash-header{display:flex;align-items:center;flex-wrap:wrap;gap:16px}
.flash-header__left{display:flex;align-items:center;gap:10px}
.flash-live{background:#E91E7B;color:#fff;font-family:var(--font-heading,'Plus Jakarta Sans',sans-serif);font-size:11px;font-weight:700;padding:5px 12px;border-radius:4px;text-transform:uppercase;letter-spacing:.5px}
.flash-icon{font-size:28px;line-height:1}
.flash-title{font-family:var(--font-heading,'Plus Jakarta Sans',sans-serif);font-size:32px;font-weight:800;color:#1A1A1A;letter-spacing:-1px}
.flash-header__sub{font-size:14px;color:#7A7A7A;flex:1}
.flash-link{font-family:var(--font-heading,'Plus Jakarta Sans',sans-serif);font-size:13px;font-weight:700;color:#E91E7B;text-decoration:none;letter-spacing:.3px;white-space:nowrap;margin-left:auto}
.flash-link:hover{text-decoration:underline}
.flash-divider{height:2px;background:linear-gradient(90deg,#1A1A1A 0%,#E8E8E8 100%);margin-top:14px;border-radius:2px}

/* ── MARQUEE ─────────────────────────────────────────────── */
.marquee{background:var(--black);padding:18px 0;overflow:hidden}
.marquee__track{display:flex;white-space:nowrap;animation:marquee 24s linear infinite}
.marquee__track:hover{animation-play-state:paused}
.marquee__item{display:inline-flex;align-items:center;gap:14px;padding:0 42px;font-size:.63rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.45);font-weight:600;border-right:1px solid rgba(233,30,123,.15);flex-shrink:0}
.marquee__dot{width:5px;height:5px;border-radius:50%;background:var(--pink);flex-shrink:0}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ── FULL-WIDTH SALE BANNER ──────────────────────────────── */
.sale-banner{position:relative;height:440px;overflow:hidden;display:flex;align-items:center;cursor:pointer;background:var(--black-s)}
.sale-banner:hover .sale-banner__bg{transform:scale(1.03)}
.sale-banner__bg{position:absolute;inset:0;background:linear-gradient(135deg,#2a1c0a 0%,#1a1208 40%,#0e0a06 100%);transition:transform .6s ease;display:flex;align-items:center;justify-content:flex-end;overflow:hidden}
.sale-banner__overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(17,17,17,.92) 0%,rgba(17,17,17,.55) 50%,transparent 100%)}
.sale-banner__content{position:relative;z-index:2;padding:0 100px;max-width:620px}
.sale-pill{display:inline-block;background:var(--pink);color:var(--black);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;padding:5px 14px;border-radius:20px;margin-bottom:14px}
.sale-tag{font-size:.6rem;letter-spacing:.26em;text-transform:uppercase;color:var(--pink);font-weight:600;margin-bottom:10px}
.sale-title{font-family:'Playfair Display',serif;font-size:2.5rem;font-weight:700;color:var(--white);line-height:1.08;margin-bottom:10px}
.sale-title em{font-style:italic;color:var(--pink-lt)}
.sale-sub{font-size:.86rem;color:rgba(255,255,255,.58);font-weight:300;margin-bottom:28px;line-height:1.65}
/* Big sofa silhouette for sale banner */
.sale-banner__art{position:absolute;right:60px;top:50%;transform:translateY(-50%);opacity:.12;pointer-events:none}

/* ── PROMISE STRIP ───────────────────────────────────────── */
.promise-strip{background:var(--pink)}
.promise-strip__inner{max-width:1600px;margin:0 auto;display:flex}
.promise-item{flex:1;padding:30px 36px;border-right:1px solid rgba(0,0,0,.1);display:flex;align-items:center;gap:16px}
.promise-item:last-child{border-right:none}
.promise-icon svg{width:30px;height:30px;color:rgba(0,0,0,.55)}
.promise-text strong{display:block;font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;font-weight:800;color:var(--black);margin-bottom:2px}
.promise-text span{font-size:.7rem;color:rgba(0,0,0,.55)}

/* Homepage: promise strip + Trustpilot — same fill/borders as .trust-bar */
.home-green-band{background:var(--white);border-top:1px solid var(--g2);border-bottom:1px solid var(--g2)}
.home-green-band .promise-strip{border-bottom:1px solid var(--g2)}
.section--home-trust{background:transparent}

/* ── HOMES / UGC GRID ────────────────────────────────────── */
.homes-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin-top:40px}
.home-tile{position:relative;aspect-ratio:1;overflow:hidden;cursor:pointer;background:var(--g1)}
.home-tile:hover .home-tile__img{transform:scale(1.06)}
.home-tile:hover .home-tile__overlay{opacity:1}
.home-tile__img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;display:flex;align-items:center;justify-content:center}
.home-tile__overlay{position:absolute;inset:0;background:rgba(17,17,17,.62);opacity:0;transition:opacity .3s;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px}
.home-tile__overlay-txt{font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--white);font-weight:600}
.home-tile__overlay svg{width:22px;height:22px;color:var(--pink-lt)}
.home-tile__user{position:absolute;bottom:0;left:0;right:0;padding:8px 10px;font-size:.6rem;color:var(--white);background:linear-gradient(to top,rgba(0,0,0,.65),transparent);font-weight:500;letter-spacing:.05em}

/* ── REVIEWS ─────────────────────────────────────────────── */
/* ── REVIEWS (Trustpilot widget) ── */
.tp-section{display:grid;grid-template-columns:260px 1fr;gap:40px;align-items:start}
.tp-summary{text-align:center;padding:28px 20px;background:#fff;border:1px solid #E8E8E8;border-radius:10px}
.tp-logo{display:flex;align-items:center;justify-content:center;gap:6px;margin-bottom:14px}
.tp-logo span{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:18px;font-weight:700;color:#1A1A1A}
.tp-score-row{display:flex;justify-content:center;gap:3px;margin-bottom:10px}
.tp-star-boxes{display:flex;gap:3px}
.tp-star-box{width:28px;height:28px;background:#00b67a;color:#fff;display:flex;align-items:center;justify-content:center;font-size:15px;border-radius:3px}
.tp-star-box--sm{width:22px;height:22px;font-size:12px}
.tp-rating-text{font-size:14px;color:#1A1A1A;margin-bottom:4px}
.tp-rating-text strong{font-weight:700}
.tp-based-on{font-size:12px;color:#999}
.tp-based-on strong{color:#1A1A1A}
.tp-slider{min-width:0;overflow:hidden}
.tp-cards{display:flex;gap:16px;transition:transform .35s ease;will-change:transform}
.tp-card{flex:0 0 calc((100% - 32px)/3)}
.tp-card{background:#fff;border:1px solid #E8E8E8;border-radius:10px;padding:22px 24px;display:flex;flex-direction:column}
.tp-card__stars{display:flex;gap:2px;margin-bottom:12px}
.tp-card__title{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:14px;font-weight:700;color:#1A1A1A;margin-bottom:6px}
.tp-card__text{font-size:13px;color:#4A4A4A;line-height:1.65;flex:1;margin-bottom:14px}
.tp-card__footer{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding-top:12px;border-top:1px solid #f0f0f0}
.tp-card__author{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:12px;font-weight:700;color:#1A1A1A}
.tp-card__location{font-size:11px;color:#999}
.tp-card__verified{font-size:10px;font-weight:600;color:#00b67a;margin-left:auto;display:flex;align-items:center;gap:3px}
.tp-slider__controls{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:14px}
.tp-slider__arrow{width:34px;height:34px;border-radius:999px;border:1px solid #e5e5e5;background:#fff;color:#1a1a1a;cursor:pointer;font-size:20px;line-height:1;display:flex;align-items:center;justify-content:center}
.tp-slider__arrow:hover{border-color:#e91e7b;color:#e91e7b}
.tp-slider__dots{display:flex;align-items:center;gap:6px}
.tp-slider__dot{width:8px;height:8px;border-radius:999px;border:none;background:#d3d3d3;cursor:pointer;padding:0}
.tp-slider__dot.is-active{background:#e91e7b;transform:scale(1.15)}
@media(max-width:1100px){
  .tp-section{grid-template-columns:1fr}
  .tp-summary{max-width:300px;margin:0 auto}
  .tp-card{flex-basis:calc((100% - 16px)/2)}
}
@media(max-width:768px){
  .tp-card{flex-basis:100%}
}

/* ── SHOWROOM ────────────────────────────────────────────── */
.showroom-wrap{display:grid;grid-template-columns:1fr 1fr;background:var(--black)}
.showroom-map{position:relative;min-height:480px;background:linear-gradient(135deg,#1a1a18 0%,#2a2820 40%,#1a1612 100%);display:flex;align-items:center;justify-content:center;overflow:hidden}
.showroom-map--embed{display:block;padding:0;background:#1a1a18}
.showroom-map__iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.showroom-map__art{opacity:.22}
.showroom-pin{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2;background:var(--pink);width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 0 0 14px rgba(233,30,123,.18),0 0 0 28px rgba(233,30,123,.07)}
.showroom-pin svg{width:24px;height:24px;color:var(--black)}
.showroom-content{padding:72px 64px;display:flex;flex-direction:column;justify-content:center}
.showroom-tag{font-size:.6rem;letter-spacing:.26em;text-transform:uppercase;color:var(--pink);font-weight:600;margin-bottom:14px}
.showroom-title{font-family:'Playfair Display',serif;font-size:2.2rem;font-weight:700;color:var(--white);line-height:1.12;margin-bottom:18px}
.showroom-title em{font-style:italic;color:var(--pink-lt)}
.showroom-desc{font-size:.82rem;color:rgba(255,255,255,.5);line-height:1.85;font-weight:300;margin-bottom:32px}
.showroom-details{display:flex;gap:44px;margin-bottom:36px}
.showroom-detail label{font-size:.54rem;letter-spacing:.22em;text-transform:uppercase;color:var(--pink);font-weight:600;display:block;margin-bottom:4px}
.showroom-detail p{font-size:.78rem;color:rgba(255,255,255,.65);line-height:1.85;font-weight:300}

/* ── EMAIL SIGNUP ────────────────────────────────────────── */
/* ── FOOTER ──────────────────────────────────────────────── */
.ghfo-footer{background:#18181B;color:#fff;padding-top:0;border-top:4px solid var(--pink)}
.ghfo-footer__inner{max-width:1600px;margin:0 auto;padding:0 32px}

/* Signup row — simple */
.ghfo-footer__signup{display:flex;flex-direction:column;align-items:center;text-align:center;gap:16px;padding:34px 16px;border-bottom:1px solid rgba(255,255,255,.08)}
.ghfo-footer__signup-title{font-family:'Playfair Display',Georgia,serif;font-size:clamp(1.45rem,3vw,1.85rem);font-weight:700;margin-bottom:8px;line-height:1.2;color:#fff}
.ghfo-footer__signup-title span{color:var(--pink)}
.ghfo-footer__signup-text{max-width:560px}
.ghfo-footer__signup-text p{font-size:14px;color:rgba(255,255,255,.55);line-height:1.65;margin:0}
.ghfo-footer__signup-form{width:100%;max-width:560px;display:flex;flex-direction:column;align-items:center}
.ghfo-footer__signup-form form{display:flex;width:100%;max-width:560px;align-items:stretch}
.ghfo-footer__signup-form input{flex:1;min-width:0;padding:18px 20px;border-radius:10px 0 0 10px;border:none;font-size:16px;outline:none;font-family:'DM Sans',sans-serif;color:var(--black);background:#fff}
.ghfo-footer__signup-form input::placeholder{color:var(--g4)}
.ghfo-footer__signup-form input:focus{box-shadow:inset 0 0 0 2px var(--pink)}
#footer-newsletter-form button[type="submit"],
.ghfo-footer__signup-form button{-webkit-appearance:none;appearance:none;background-color:#E91E7B;background-color:var(--pink);color:#fff!important;border:none;border-radius:0 10px 10px 0;font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-weight:700;font-size:15px;letter-spacing:.02em;padding:18px 32px;cursor:pointer;transition:background-color .2s;white-space:nowrap;line-height:1.2;min-height:56px}
#footer-newsletter-form button[type="submit"]:hover,
.ghfo-footer__signup-form button:hover{background-color:#D81B60}
#footer-newsletter-form button:disabled{opacity:.65;cursor:not-allowed}
.ghfo-footer__signup-legal{font-size:12px;color:rgba(255,255,255,.45);margin-top:8px;line-height:1.5;max-width:480px}
.ghfo-footer__signup-legal a{color:rgba(255,255,255,.65);text-decoration:underline}
.ghfo-footer__signup-legal a:hover{color:var(--pink)}
.ghfo-footer__signup-disabled{font-size:13px;color:rgba(255,255,255,.45);margin:0}

/* Grid */
.ghfo-footer__grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr;gap:34px;padding:34px 0}
.ghfo-footer__brand p{font-size:13px;color:rgba(255,255,255,.4);line-height:1.7;margin-bottom:24px;max-width:360px}

/* Logo in footer */
.ghfo-footer__logo-wrap{display:inline-flex;align-items:center;gap:8px;text-decoration:none;margin-bottom:20px}
.ghfo-footer__logo-box{background:var(--pink);color:#fff;font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-weight:900;font-size:22px;letter-spacing:-1px;padding:4px 8px;border-radius:3px}
.ghfo-footer__logo-text{display:flex;flex-direction:column;line-height:1.15}
.ghfo-footer__logo-text span{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-weight:700;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:#fff}
.ghfo-footer__logo-text .pink{font-size:9px;color:var(--pink);letter-spacing:2px}

/* Social icons */
.ghfo-footer__socials{display:flex;gap:10px}
.ghfo-footer__socials a{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.5);transition:all .2s}
.ghfo-footer__socials a:hover{background:var(--pink);color:#fff}
.ghfo-footer__socials a svg{width:18px;height:18px}

/* Columns */
.ghfo-footer__col h4,
.ghfo-footer__toggle{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:2px;color:#fff;margin-bottom:16px}
.ghfo-footer__toggle{width:100%;text-align:left;background:none;border:none;padding:0;cursor:pointer;display:block}
.ghfo-footer__col ul{list-style:none;padding:0;margin:0}
.ghfo-footer__col li{margin-bottom:10px}
.ghfo-footer__col a{font-size:13px;color:rgba(255,255,255,.4);transition:color .2s;text-decoration:none}
.ghfo-footer__col a:hover{color:var(--pink)}

/* Bottom bar */
.ghfo-footer__bottom{border-top:1px solid rgba(255,255,255,.08);padding:16px 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
.ghfo-footer__bottom p{font-size:11px;color:rgba(255,255,255,.3)}
.ghfo-footer__payments{display:flex;align-items:center;flex-wrap:wrap;gap:10px;opacity:.88;transition:opacity .3s}
.ghfo-footer__payments:hover{opacity:1}
.ghfo-footer__paylogo{height:28px;width:auto;display:block;object-fit:contain;background:#fff;border-radius:4px;padding:4px 8px;box-sizing:content-box;box-shadow:0 1px 2px rgba(0,0,0,.12)}

/* Footer responsive */
@media(max-width:1100px){
  .ghfo-footer__grid{grid-template-columns:1fr 1fr 1fr 1fr}
  .ghfo-footer__brand{grid-column:span 4}
}
@media(max-width:768px){
  .ghfo-footer__signup{padding:24px 12px;gap:12px}
  .ghfo-footer__signup-title{font-size:1.2rem}
  .ghfo-footer__signup-text p{font-size:13px;line-height:1.45}
  .ghfo-footer__signup-form form{flex-direction:column;border-radius:10px;overflow:hidden}
  .ghfo-footer__signup-form input{border-radius:10px 10px 0 0}
  #footer-newsletter-form button{border-radius:0 0 10px 10px;width:100%;min-height:52px}
  .ghfo-footer__inner{padding:0 20px}
  .ghfo-footer__grid{grid-template-columns:1fr 1fr;gap:22px;padding:22px 0}
  .ghfo-footer__brand{grid-column:span 2}
  .ghfo-footer__brand p{margin-bottom:12px}
  .ghfo-footer__col h4,.ghfo-footer__toggle{margin-bottom:0}
  .ghfo-footer__toggle{
    position:relative;
    padding:10px 0;
    border-top:1px solid rgba(255,255,255,.1);
  }
  .ghfo-footer__toggle::after{
    content:'+';
    position:absolute;
    right:0;
    top:50%;
    transform:translateY(-50%);
    color:rgba(255,255,255,.7);
    font-size:16px;
    line-height:1;
  }
  .ghfo-footer__col.is-open .ghfo-footer__toggle::after{content:'−'}
  .ghfo-footer__col ul{display:none;padding:6px 0 4px}
  .ghfo-footer__col.is-open ul{display:block}
  .ghfo-footer__col li{margin-bottom:6px}
  .ghfo-footer__bottom{flex-direction:column;text-align:center;gap:10px}
}

/* ── OUTLET CLEARANCE BANNER ──────────────────────────── */
.outlet-banner{border-top:1px solid rgba(0,0,0,.06);border-bottom:1px solid rgba(0,0,0,.06)}
.outlet-banner__inner{display:flex;align-items:center;justify-content:space-between;gap:40px;padding:48px 0}
.outlet-banner__text{flex:1;max-width:680px}
.outlet-banner__badge{display:inline-block;background:var(--black);color:#fff;font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:12px;font-weight:700;padding:5px 14px;border-radius:4px;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:16px}
.outlet-banner__title{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:clamp(1.8rem,4vw,3rem);font-weight:800;color:#111;line-height:1.08;margin-bottom:14px;text-transform:uppercase}
.outlet-banner__title .pink{color:var(--pink)}
.outlet-banner__desc{font-size:16px;color:#333;font-weight:500;line-height:1.6;max-width:520px;margin-bottom:22px}
.outlet-banner__btn{display:inline-flex;align-items:center;gap:8px;background:#111;color:#fff;font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-weight:700;font-size:16px;padding:16px 32px;border-radius:8px;text-decoration:none;transition:background .2s}
.outlet-banner__btn:hover{background:var(--pink)}
.outlet-banner__img-wrap{flex-shrink:0}
.outlet-banner__circle{position:relative;width:336px;height:336px;background:#fff;border-radius:50%;padding:28px;box-shadow:0 20px 60px rgba(0,0,0,.08);transform:rotate(3deg)}
.outlet-banner__circle img{width:100%;height:100%;object-fit:cover;object-position:left center;border-radius:50%}
.outlet-banner__disc{position:absolute;top:-18px;right:-18px;width:96px;height:96px;background:var(--pink);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-weight:900;font-size:1.55rem;box-shadow:0 8px 24px rgba(233,30,123,.3);border:3px solid #fff;transform:rotate(12deg);z-index:2}
@media(max-width:768px){
  .outlet-banner__inner{flex-direction:column;text-align:center;gap:24px;padding:36px 0}
  .outlet-banner__desc{margin:0 auto 22px}
  .outlet-banner__circle{width:240px;height:240px;padding:20px;margin:0 auto}
  .outlet-banner__disc{width:88px;height:88px;font-size:1.28rem;top:-14px;right:-14px}
}

/* ── ABOUT / SEO TEXT ──────────────────────────────────── */
.about-seo{background:var(--g1);padding:56px 0;border-top:1px solid var(--g2)}
.about-seo__inner{max-width:800px;margin:0 auto;padding:0 32px;text-align:center}
.about-seo__title{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:clamp(1.3rem,2.5vw,1.7rem);font-weight:700;color:#111;margin-bottom:20px}
.about-seo__content{font-size:14px;color:#555;line-height:1.8;font-weight:500}
.about-seo__content p{margin-bottom:14px}
.about-seo__content p:last-child{margin-bottom:0}

/* ── REVEAL ANIMATIONS ───────────────────────────────────── */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .65s ease,transform .65s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal:nth-child(2){transition-delay:.08s}
.reveal:nth-child(3){transition-delay:.16s}
.reveal:nth-child(4){transition-delay:.24s}
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}

/* ── SVG PLACEHOLDERS (same style as listing/PDP) ─────────── */
.ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center}

/* ── RESPONSIVE ──────────────────────────────────────────── */
@media(max-width:1400px){
  .products-grid{grid-template-columns:repeat(4,1fr)}
  .related-grid{grid-template-columns:repeat(4,1fr)}
  .fp-card{min-width:calc(25% - 12px);max-width:calc(25% - 12px)}
}
@media(max-width:1100px){
  .cat-grid{grid-template-columns:repeat(2,1fr)}
  .cat-tile--lg{grid-column:span 2}
  .products-grid{grid-template-columns:repeat(3,1fr)}
  .related-grid{grid-template-columns:repeat(3,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .showroom-wrap{grid-template-columns:1fr}
  .showroom-map{min-height:320px}
  .homes-grid{grid-template-columns:repeat(4,1fr)}
}
.ghfo-mnav-overlay{display:none}

@media(max-width:768px){
  .ghfo-mnav-overlay{display:block}
  .ghfo-search{display:none}
  .ghfo-hbtn.ghfo-search-mob{display:inline-flex}
  .ghfo-topbar{display:none}
  .ghfo-nav-toggle{display:inline-flex}
  .ghfo-hbtn__label{display:none}
  .ghfo-wrap{padding:0 16px}
  .ghfo-header__row{gap:4px;flex-wrap:nowrap}
  .ghfo-logo-wrap{min-width:0;flex:1}
  .ghfo-logo-text{display:none}
  .ghfo-logo-text span{font-size:10px;letter-spacing:1px}
  .ghfo-logo-box{font-size:17px;padding:3px 6px}
  /* Mobile category drawer overlay */
  body.ghfo-mnav-open{overflow:hidden;touch-action:none}
  .ghfo-mnav-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:10010;opacity:0;pointer-events:none;transition:opacity .25s}
  .ghfo-mnav-overlay.open{opacity:1;pointer-events:auto}
  .ghfo-header.ghfo-header--nav-open{z-index:10030}
  .ghfo-header>.ghfo-wrap:first-of-type{position:relative;z-index:320;background:var(--white)}
  .ghfo-catnav{display:block;position:fixed;top:60px;left:0;bottom:0;width:min(86vw,360px);max-width:min(86vw,360px);background:#fff;z-index:10020;overflow-y:auto;-webkit-overflow-scrolling:touch;transform:translateX(-102%);transition:transform .28s ease;box-shadow:8px 0 32px rgba(0,0,0,.12);border-right:1px solid var(--g2);padding-top:0}
  .ghfo-header--nav-open .ghfo-catnav{transform:translateX(0)}
  body.ghfo-mnav-open .ghfo-site-active,
  body.ghfo-mnav-open .fin-fab{display:none!important}
  .ghfo-catnav__inner{padding:0;min-height:100%}
  .ghfo-catnav .ghfo-wrap{max-width:none;padding:0}
  .ghfo-catnav__mobile-head{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--g2);font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-weight:700;letter-spacing:.06em;text-transform:uppercase;font-size:12px;color:var(--g4)}
  .ghfo-catnav__close{width:34px;height:34px;border:1px solid var(--g2);border-radius:8px;background:#fff;color:#1A1A1A;display:flex;align-items:center;justify-content:center;cursor:pointer}
  .ghfo-catnav__close svg{stroke:currentColor}
  .ghfo-catnav__row{flex-direction:column;flex-wrap:nowrap;align-items:stretch;justify-content:flex-start;padding:0 0 8px;gap:0}
  .ghfo-catnav__link{width:100%;box-sizing:border-box;padding:14px 20px;border-bottom:1px solid var(--g2);text-align:left}
  .mm-wrap{display:block;width:100%;border-bottom:1px solid var(--g2)}
  .mm-trigger{display:flex;width:100%;box-sizing:border-box;justify-content:space-between;align-items:center;padding:14px 20px;border-bottom:none;text-align:left}
  .mm-trigger::before{display:none}
  .mm-trigger::after{content:'+';font-size:18px;font-weight:600;color:var(--g3);flex-shrink:0;margin-left:12px}
  .mm-wrap.mm-open .mm-trigger::after{content:'–'}
  .mm-panel{position:static!important;left:auto!important;right:auto!important;top:auto!important;opacity:1!important;visibility:visible!important;transform:none!important;display:none;width:100%;max-height:none;overflow:visible;border:none;box-shadow:none;background:#fafafa}
  .mm-wrap:hover .mm-panel{display:none!important}
  .mm-wrap.mm-open .mm-panel{display:block!important}
  .mm-mobile-all-link{display:block;padding:14px 20px;font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:13px;font-weight:700;color:var(--pink);text-decoration:none;border-bottom:1px solid #eee;background:#fff}
  .mm-mobile-all-link:hover{color:var(--pink-dk)}
  .mm-inner{display:flex;flex-direction:column;padding:0 0 12px}
  .mm-col{padding:16px 16px 8px;border-right:none;border-bottom:1px solid #eee}
  .mm-col--featured{background:#f6f6f4}
  .cat-strip__inner{justify-content:flex-start}
  .hero__slide .hero__content{padding:55px 24px 65px}
  .container{padding:0 20px}
  .section{padding:40px 0 48px}
  .cat-grid{grid-template-columns:1fr;gap:12px}
  .cat-tile--lg{grid-column:span 1}
  .cat-tile{min-height:230px}
  .cat-tile__body{padding:16px 16px 14px;gap:4px}
  .cat-tile__label{font-size:.58rem;letter-spacing:.14em}
  .cat-tile__promo{font-size:1.8rem;line-height:1.06}
  .cat-tile--lg .cat-tile__promo{font-size:2rem}
  .cat-tile__link{font-size:.52rem;letter-spacing:.12em;padding:4px 0}
  .products-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .pc__cta{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:8px;
    width:100%;
  }
  .pc__cta .pc__btn{
    width:100%;
    min-width:0;
    height:42px;
    font-size:0;
    line-height:1;
    padding:0;
    border-radius:8px;
    display:flex;
    align-items:center;
    justify-content:center;
  }
  .pc__cta .pc__btn::before{
    content:'';
    width:20px;
    height:20px;
    display:block;
    background-repeat:no-repeat;
    background-position:center;
    background-size:20px 20px;
  }
  .pc__cta .pc__btn--pink::before{
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2.1' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='9' cy='20' r='1.4'/%3E%3Ccircle cx='18' cy='20' r='1.4'/%3E%3Cpath d='M2 3h3l2.5 11.5a2 2 0 0 0 2 1.6h8.8a2 2 0 0 0 2-1.6L22 7H7.2'/%3E%3C/svg%3E");
  }
  .pc__cta .pc__btn--outline::before{
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231a1a1a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M1.5 12s3.8-6.5 10.5-6.5S22.5 12 22.5 12 18.7 18.5 12 18.5 1.5 12 1.5 12Z'/%3E%3Ccircle cx='12' cy='12' r='3.2'/%3E%3C/svg%3E");
  }
  .pc__cta .pc__btn--outline{border-width:1.8px}
  .related-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .fp-card{min-width:calc(50% - 8px);max-width:calc(50% - 8px)}
  .trust-bar__inner{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;gap:0;-ms-overflow-style:none;scrollbar-width:none}
  .trust-bar__inner::-webkit-scrollbar{display:none}
  .trust-cell{min-width:100%;scroll-snap-align:start;border-right:1px solid var(--g2)}
  .trust-cell:last-child{border-right:none}
  .promise-strip__inner{flex-direction:column}
  .homes-grid{grid-template-columns:repeat(2,1fr)}
  .tp-cards{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .sale-banner__content{padding:0 24px}
  .showroom-content{padding:40px 24px}
  .signup{padding:40px 20px}
  .cart-drawer{width:80vw;max-width:80vw}
}

@media (max-width: 420px) {
  .ghfo-backtotop{right:12px;bottom:78px}
}


/* ══ SHOP / LISTING PAGE ══ */
/* ── BREADCRUMB ── */
.breadcrumb{max-width:1600px;margin:0 auto;padding:14px 40px;display:flex;gap:6px;align-items:center;font-size:.7rem;color:var(--g4)}
.breadcrumb a{color:var(--g4);transition:color var(--tx)}
.breadcrumb a:hover{color:var(--pink)}
.breadcrumb span{color:var(--g3)}

/* ── CATEGORY HERO ── */
.cat-hero{background:var(--black);overflow:hidden;position:relative}
.cat-hero.cat-hero--with-sofa-dock{overflow:visible;padding-bottom:0}
.cat-hero-inner{max-width:1600px;margin:0 auto;padding:48px 40px;display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:48px}
.cat-hero-text{}
.cat-tag{font-size:.6rem;letter-spacing:.26em;text-transform:uppercase;color:var(--pink);font-weight:600;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.cat-tag::before{content:'';width:22px;height:1px;background:var(--pink)}
.cat-hero-title{font-family:'Playfair Display',serif;font-size:3rem;font-weight:700;color:var(--white);line-height:1.05;margin-bottom:14px}
.cat-hero-title em{font-style:italic;color:var(--pink-lt)}
.cat-hero-desc{font-size:.85rem;color:rgba(255,255,255,.5);line-height:1.8;font-weight:300;margin-bottom:28px;max-width:380px}
.cat-hero-stats{display:flex;gap:36px}
.hero-stat-val{font-family:'Playfair Display',serif;font-size:1.8rem;font-weight:700;color:var(--pink-lt);line-height:1}
.hero-stat-label{font-size:.58rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-top:3px}
.cat-hero-img{position:relative;height:280px;border-radius:var(--radius);overflow:hidden;background:var(--black-s)}
.cat-hero-img--has-photo{background-size:cover;background-position:center}
.cat-hero-img--has-photo::after{content:'';position:absolute;inset:0;background:linear-gradient(105deg,rgba(26,26,26,.55) 0%,rgba(26,26,26,.12) 45%,transparent 70%);pointer-events:none}
.cat-hero-img-bg{width:100%;height:100%;background-image:url("img/hero4.png");background-size:cover;background-position:center;display:flex;align-items:center;justify-content:center;position:relative}
.cat-hero-img-bg::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23C6973F' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}
/* Sofa illustration placeholder */
.sofa-placeholder{width:220px;height:120px;position:relative;z-index:1}
.sofa-body{width:220px;height:70px;background:linear-gradient(160deg,#8b6914,#6b4f0e);border-radius:12px 12px 4px 4px;position:absolute;bottom:20px}
.sofa-back{width:220px;height:45px;background:linear-gradient(160deg,#9a7518,#7a5c12);border-radius:8px 8px 0 0;position:absolute;bottom:70px}
.sofa-arm-l,.sofa-arm-r{width:22px;height:50px;background:linear-gradient(160deg,#8b6914,#6b4f0e);border-radius:6px;position:absolute;bottom:20px}
.sofa-arm-l{left:0}
.sofa-arm-r{right:0}
.sofa-leg{width:10px;height:18px;background:#4a3a08;position:absolute;bottom:0;border-radius:0 0 3px 3px}
.sofa-leg.l1{left:20px}.sofa-leg.l2{right:20px}
.sofa-cushion{width:86px;height:28px;background:linear-gradient(160deg,#a07822,#7a5c12);border-radius:6px;position:absolute;bottom:36px}
.sofa-cushion.c1{left:12px}.sofa-cushion.c2{left:112px}

/* ── SOFA DOCK (centered, overlaps hero) ── */
.sofa-dock-outer{max-width:1600px;margin:-52px auto 0;padding:0 40px 28px;position:relative;z-index:15;display:flex;justify-content:center;pointer-events:none}
.sofa-dock-outer *{pointer-events:auto}
.sofa-dock{width:100%;max-width:min(920px,100%);background:linear-gradient(165deg,#fff 0%,#faf8f5 55%,#f5f2ec 100%);border:1px solid rgba(0,0,0,.08);border-radius:20px;box-shadow:0 28px 56px rgba(0,0,0,.12),0 0 0 1px rgba(255,255,255,.85) inset,0 1px 0 rgba(255,255,255,.55) inset,0 0 40px rgba(233,30,123,.06);padding:20px 22px 22px;text-align:center;position:relative}
.sofa-dock__head{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:10px 16px;margin-bottom:16px}
.sofa-dock__eyebrow{font-family:'Playfair Display',Georgia,serif;font-size:1.05rem;font-weight:600;color:var(--black);letter-spacing:.02em}
.sofa-dock__shop-all{font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--pink);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .2s,color .2s}
.sofa-dock__shop-all:hover{border-bottom-color:var(--pink)}
.sofa-dock__sep{width:1px;height:14px;background:linear-gradient(180deg,transparent,rgba(0,0,0,.12),transparent);flex-shrink:0}
.sofa-dock__nav{display:flex;flex-wrap:wrap;justify-content:center;align-items:stretch;gap:10px 8px}
.sofa-dock__link{display:flex;flex-direction:column;align-items:center;gap:8px;min-width:92px;max-width:120px;padding:12px 10px 10px;border-radius:14px;text-decoration:none;color:var(--black);background:rgba(255,255,255,.65);border:1px solid rgba(0,0,0,.06);transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease,background .22s ease}
.sofa-dock__link:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(233,30,123,.12);border-color:rgba(233,30,123,.35);background:#fff}
.sofa-dock__link.is-active{box-shadow:0 0 0 2px var(--pink);border-color:var(--pink);background:#fff}
.sofa-dock__icon-ring{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,rgba(233,30,123,.12),rgba(198,151,63,.08));box-shadow:0 4px 12px rgba(0,0,0,.06);transition:transform .22s ease,box-shadow .22s ease}
.sofa-dock__link:hover .sofa-dock__icon-ring{transform:scale(1.06);box-shadow:0 8px 20px rgba(233,30,123,.18)}
.sofa-dock__icon{display:inline-flex;color:var(--pink)}
.sofa-dock__icon svg{width:20px;height:20px}
.sofa-dock__label{font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;font-weight:700;line-height:1.25;color:var(--g4);transition:color .2s}
.sofa-dock__link:hover .sofa-dock__label{color:var(--black)}
.sofa-dock__link.is-active .sofa-dock__label{color:var(--black)}

/* ── SUB-CATEGORIES ── */
.subcat-strip{border-bottom:1px solid var(--g2);overflow-x:auto;scrollbar-width:none}
.subcat-strip::-webkit-scrollbar{display:none}
.subcat-inner{max-width:1600px;margin:0 auto;padding:0 40px;display:flex;gap:0;white-space:nowrap}
.subcat-link{display:inline-flex;align-items:center;gap:6px;padding:14px 20px;font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;font-weight:600;color:var(--g4);border-bottom:2px solid transparent;transition:all var(--tx);white-space:nowrap}
.subcat-link:hover,.subcat-link.active{color:var(--black);border-color:var(--pink)}
.subcat-count{background:var(--g1);color:var(--g4);padding:1px 7px;border-radius:20px;font-size:.55rem;font-weight:700;letter-spacing:.06em}
.subcat-link.active .subcat-count{background:var(--pink);color:var(--black)}

/* ── TOOLBAR ── */
.toolbar{max-width:1600px;margin:0 auto;padding:22px 40px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--g2)}
.toolbar-left{display:flex;align-items:center;gap:16px}
.result-count{font-size:.78rem;color:var(--g4)}
.result-count strong{color:var(--black);font-weight:700}
.filter-toggle{display:flex;align-items:center;gap:8px;background:var(--black);color:var(--white);border:none;padding:9px 18px;border-radius:var(--radius);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;font-weight:700;cursor:pointer;transition:background var(--tx);font-family:'DM Sans','Plus Jakarta Sans',sans-serif}
.filter-toggle:hover{background:var(--pink);color:var(--black)}
.filter-toggle svg{width:14px;height:14px}
.active-filters{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.filter-tag{display:inline-flex;align-items:center;gap:6px;background:var(--g1);border:1px solid var(--g2);padding:5px 10px;border-radius:20px;font-size:.62rem;font-weight:600;color:var(--black)}
.filter-tag button{background:none;border:none;cursor:pointer;color:var(--g4);line-height:1;padding:0;font-size:.75rem}
.filter-tag button:hover{color:var(--red)}
.filter-tag--fabric-colour .filter-tag__swatch{width:18px;height:18px;border-radius:3px;flex-shrink:0;box-shadow:inset 0 0 0 .5px rgba(0,0,0,.1);background:var(--g2)}
.filter-tag__lbl{line-height:1.2}
.shop-filters-toggle{display:none;margin-left:14px;padding:7px 14px;font-size:.68rem;font-weight:600;font-family:'DM Sans','Plus Jakarta Sans',sans-serif;border:1px solid var(--g2);background:var(--white);border-radius:var(--radius);cursor:pointer;color:var(--black);transition:border-color var(--tx),color var(--tx);white-space:nowrap}
.shop-filters-toggle:hover{border-color:var(--pink);color:var(--pink)}
@media(min-width:1025px){.shop-filters-toggle{display:inline-flex;align-items:center}}
.toolbar-right{display:flex;align-items:center;gap:14px}
.sort-label{font-size:.68rem;color:var(--g4);white-space:nowrap}
.sort-select{border:1px solid var(--g2);background:var(--white);padding:8px 14px;font-size:.74rem;font-family:'DM Sans','Plus Jakarta Sans',sans-serif;color:var(--black);border-radius:var(--radius);cursor:pointer;outline:none;min-width:170px}
.sort-select:focus{border-color:var(--pink)}
.view-toggle{display:flex;gap:4px}
.view-btn{width:34px;height:34px;border:1px solid var(--g2);background:var(--white);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--g3);transition:all var(--tx)}
.view-btn.active,.view-btn:hover{background:var(--black);color:var(--white);border-color:var(--black)}
.view-btn svg{width:15px;height:15px}

/* ── SHOP: toolbar wrap + top filter bar + drawer ── */
.shop-toolbar-wrap{max-width:1600px;margin:0 auto;border-bottom:1px solid var(--g2);background:var(--white)}
.shop-toolbar-wrap .toolbar{border-bottom:none;padding-bottom:18px}
.shop-active-filters{display:inline-flex;flex-wrap:wrap;gap:6px;align-items:center;flex:1;min-width:0;margin-left:8px}
.shop-filter-drawer-trigger{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;font-size:.72rem;font-weight:700;font-family:'Plus Jakarta Sans','DM Sans',sans-serif;letter-spacing:.06em;text-transform:uppercase;border:1.5px solid var(--black);background:var(--white);border-radius:8px;cursor:pointer;color:var(--black);transition:all .2s;white-space:nowrap}
.shop-filter-drawer-trigger:hover{background:var(--black);color:var(--white)}
.shop-filter-drawer-trigger--ghost{font-weight:600;text-transform:none;letter-spacing:0;border-color:var(--g2);color:var(--g4)}
.shop-filter-drawer-trigger--ghost:hover{border-color:var(--pink);color:var(--pink);background:rgba(233,30,123,.04)}
.toolbar-right--compact{display:none}
@media(min-width:900px){.toolbar-right--compact{display:flex}}

.shop-filter-bar{max-width:1600px;margin:0 auto;padding:14px 40px 18px;display:flex;align-items:flex-start;justify-content:space-between;gap:20px;flex-wrap:wrap;border-top:1px solid var(--g2)}
.shop-filter-bar__quick{display:flex;flex-wrap:wrap;align-items:center;gap:8px;flex:1;min-width:0}
.shop-filter-bar__meta{display:flex;align-items:center;gap:16px;flex-shrink:0}
.shop-filter-bar__count{font-size:.78rem;color:var(--g4)}
.shop-filter-bar__count strong{color:var(--black);font-weight:700}

.shop-qfilter{position:relative}
.shop-qfilter__btn{display:inline-flex;align-items:center;gap:6px;padding:9px 14px;font-size:.78rem;font-weight:600;font-family:'DM Sans','Plus Jakarta Sans',sans-serif;color:var(--black);background:var(--white);border:1px solid var(--g2);border-radius:8px;cursor:pointer;transition:border-color .2s,box-shadow .2s}
.shop-qfilter__btn:hover,.shop-qfilter.is-open .shop-qfilter__btn{border-color:var(--black)}
.shop-qfilter__btn svg{flex-shrink:0;color:var(--g3);transition:transform .2s}
.shop-qfilter.is-open .shop-qfilter__btn svg{transform:rotate(180deg)}
.shop-qfilter__panel{position:absolute;top:calc(100% + 6px);left:0;min-width:240px;max-width:min(320px,92vw);max-height:min(340px,50vh);overflow-y:auto;background:var(--white);border:1px solid var(--g2);border-radius:10px;box-shadow:0 12px 40px rgba(26,26,26,.12);z-index:450;padding:10px 0}
.shop-qfilter__panel--narrow{min-width:180px}
.shop-qfilter__link{display:flex;align-items:center;gap:10px;padding:10px 16px;font-size:.8rem;color:var(--black);text-decoration:none;transition:background .15s}
.shop-qfilter__link:hover{background:var(--g1)}
.shop-qfilter__check{display:flex;align-items:flex-start;gap:10px;padding:8px 16px;font-size:.8rem;color:var(--g4);cursor:pointer;margin:0}
.shop-qfilter__check input{accent-color:var(--pink);margin-top:3px;flex-shrink:0}
.shop-qfilter__check em{font-style:normal;color:var(--g3);font-size:.72rem}

.shop-filter-more-btn{padding:9px 16px;font-size:.78rem;font-weight:700;font-family:'Plus Jakarta Sans','DM Sans',sans-serif;border:1px solid var(--g2);background:var(--white);border-radius:8px;cursor:pointer;color:var(--black);transition:all .2s}
.shop-filter-more-btn:hover{border-color:var(--pink);color:var(--pink)}
/* Category filters drawer is mobile-only */
@media (min-width: 769px){
  .shop-filter-drawer-trigger,
  .shop-filter-more-btn{display:none !important}
}
@media (max-width: 768px){
  .shop-filter-drawer-trigger,
  .shop-filter-more-btn{display:inline-flex}
}

.shop-view-toggle{display:flex;gap:4px;border:1px solid var(--g2);border-radius:8px;padding:3px;background:var(--g1)}
.shop-view-btn{width:36px;height:34px;border:none;background:transparent;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--g3);transition:all .2s}
.shop-view-btn:hover{color:var(--black)}
.shop-view-btn.active{background:var(--white);color:var(--black);box-shadow:0 1px 4px rgba(0,0,0,.08)}

.shop-filter-overlay{position:fixed;inset:0;background:rgba(26,26,26,.5);z-index:2098;opacity:0;pointer-events:none;transition:opacity .3s ease;backdrop-filter:blur(2px)}
.shop-filter-overlay.is-open{opacity:1;pointer-events:auto}

.shop-filter-drawer{position:fixed;top:0;right:0;bottom:0;width:min(440px,100vw);max-width:100%;background:var(--white);z-index:2099;transform:translateX(100%);transition:transform .32s cubic-bezier(.32,.72,0,1);display:flex;flex-direction:column;box-shadow:-12px 0 48px rgba(0,0,0,.1)}
.shop-filter-drawer.is-open{transform:translateX(0)}
.shop-filter-drawer__inner{display:flex;flex-direction:column;height:100%;min-height:0}
.shop-filter-drawer__head{flex-shrink:0;display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:20px 22px 18px;border-bottom:1px solid var(--g2);background:var(--white)}
.shop-filter-drawer__head h2{margin:0;padding-top:2px;font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:1.05rem;font-weight:700;color:var(--black);letter-spacing:-.02em;line-height:1.25}
.shop-filter-drawer__close{flex-shrink:0;width:36px;height:36px;border:none;background:transparent;border-radius:8px;font-size:1.35rem;line-height:1;cursor:pointer;color:var(--g3);transition:background .2s,color .2s;display:flex;align-items:center;justify-content:center}
.shop-filter-drawer__close:hover{background:var(--g1);color:var(--black)}

.shop-filter-drawer__sort{flex-shrink:0;padding:18px 22px 22px;border-bottom:1px solid var(--g2);background:var(--white)}
.shop-sort-label{display:block;font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;font-weight:700;color:var(--g4);margin-bottom:12px}
.shop-sort-pills{display:flex;flex-wrap:wrap;gap:6px}
.shop-sort-pill{padding:9px 15px;font-size:.74rem;font-weight:600;font-family:'DM Sans','Plus Jakarta Sans',sans-serif;border:1px solid var(--g2);border-radius:999px;background:var(--g1);color:var(--black);cursor:pointer;transition:background .2s,border-color .2s,box-shadow .2s}
.shop-sort-pill:hover{background:var(--white);border-color:var(--g3)}
.shop-sort-pill.is-active{background:var(--white);border-color:var(--black);box-shadow:0 0 0 1px var(--black)}
.shop-sort-select-native{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

.shop-filter-drawer__body{flex:1;overflow-y:auto;min-height:0;padding:14px 16px 8px;background:var(--off);-webkit-overflow-scrolling:touch}
.shop-filter-drawer__aside{border:none;padding:0;margin:0;width:100%;max-width:none}
.shop-drawer-divider{border:none;border-top:1px solid var(--g2);margin:6px 0 14px}

.shop-filter-drawer__aside .filter-group{border:none;padding:0 0 14px;margin:0 0 10px;background:var(--white);border-radius:12px;border:1px solid var(--g2);box-shadow:0 1px 0 rgba(0,0,0,.04);overflow:hidden}
.shop-filter-drawer__aside .filter-group-title{margin:0;padding:14px 16px 12px;font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--black);border-bottom:1px solid transparent;transition:border-color .2s}
.shop-filter-drawer__aside .filter-group.open .filter-group-title{border-bottom-color:var(--g2)}
.shop-filter-drawer__aside .filter-group:not(.open) .filter-group-title{padding-bottom:14px}
.shop-filter-drawer__aside .filter-group-title svg{width:14px;height:14px;color:var(--g3);flex-shrink:0}
.shop-filter-drawer__aside .filter-options{padding:4px 8px 12px 12px;gap:2px}
.shop-filter-drawer__aside .filter-group.open .filter-options{max-height:min(52vh,520px);overflow-y:auto;overflow-x:hidden}
.shop-filter-drawer__aside .filter-opt{align-items:center;gap:10px;padding:9px 8px;margin:0 0 2px;border-radius:8px;font-size:.8rem;color:var(--black);line-height:1.35}
.shop-filter-drawer__aside .filter-opt:hover{background:var(--g1);color:var(--black)}
.shop-filter-drawer__aside a.filter-link{text-decoration:none;color:inherit;display:flex;align-items:center;gap:10px}
.shop-filter-drawer__aside a.filter-link.active{font-weight:600;color:var(--pink)}
.shop-filter-drawer__aside a.filter-link .filter-link-check{width:15px;height:15px;margin-left:auto;flex-shrink:0;color:var(--pink)}
.shop-filter-drawer__aside .shop-drawer-group--brand{border-color:rgba(233,30,123,.22);box-shadow:0 0 0 1px rgba(233,30,123,.06)}
.shop-filter-drawer__aside .shop-drawer-price-options{gap:14px;padding-top:4px}
.shop-drawer-price-row{display:flex;gap:10px;align-items:flex-end}
.shop-drawer-price-field{flex:1;min-width:0}
.shop-drawer-price-label{display:block;font-size:.58rem;letter-spacing:.08em;text-transform:uppercase;font-weight:600;color:var(--g4);margin-bottom:5px}
.shop-drawer-price-input{width:100%;font-size:.8rem!important;padding:9px 11px!important;border:1px solid var(--g2)!important;border-radius:8px!important;background:var(--white)!important}
.shop-drawer-price-input:focus{outline:none;border-color:var(--pink)!important}
.shop-drawer-price-dash{color:var(--g3);padding-bottom:10px;font-size:.9rem;flex-shrink:0}
.shop-drawer-price-slider{width:100%;accent-color:var(--pink);margin-top:2px}

.shop-drawer-actions{margin-top:6px;padding:4px 0 8px;display:flex;flex-direction:column;gap:8px;align-items:stretch}
.shop-drawer-clear-btn{width:100%;padding:12px 16px;font-size:.72rem;font-weight:700;font-family:'Plus Jakarta Sans','DM Sans',sans-serif;letter-spacing:.06em;text-transform:uppercase;border:1px solid var(--g2);border-radius:10px;background:var(--white);color:var(--black);cursor:pointer;transition:border-color .2s,background .2s,color .2s}
.shop-drawer-clear-btn:hover{border-color:var(--pink);color:var(--pink);background:rgba(233,30,123,.04)}
.shop-drawer-back-link{display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 12px;font-size:.78rem;font-weight:600;color:var(--g4);text-decoration:none;border-radius:8px;transition:color .2s,background .2s}
.shop-drawer-back-link:hover{color:var(--pink);background:var(--g1)}

.shop-filter-drawer__foot{flex-shrink:0;padding:14px 20px calc(18px + env(safe-area-inset-bottom,0));border-top:1px solid var(--g2);background:var(--white);box-shadow:0 -4px 24px rgba(0,0,0,.04)}
.shop-filter-apply{width:100%;display:flex;align-items:center;justify-content:center;padding:15px 22px;font-size:.8rem;font-weight:800;font-family:'Plus Jakarta Sans','DM Sans',sans-serif;letter-spacing:.06em;text-transform:uppercase;border:none;border-radius:10px;background:var(--black-s);color:#fff;cursor:pointer;transition:background .2s,transform .12s}
.shop-filter-apply:hover{background:var(--pink)}
.shop-filter-apply:active{transform:scale(.992)}

.cat-layout--full{grid-template-columns:1fr!important;gap:0;padding-top:12px}
@media(max-width:768px){.shop-filter-bar{padding-left:20px;padding-right:20px}.shop-toolbar-wrap .toolbar{padding-left:20px;padding-right:20px}}
.products-grid--listing.products-grid--cols-3{grid-template-columns:repeat(3,1fr)!important}
@media(max-width:900px){.products-grid--listing.products-grid--cols-3{grid-template-columns:repeat(2,1fr)!important}}
@media(max-width:600px){.products-grid--listing.products-grid--cols-3{grid-template-columns:1fr!important}}

/* ── MAIN LAYOUT ── */
.cat-layout{max-width:1600px;margin:0 auto;padding:28px 40px 72px;display:grid;grid-template-columns:244px 1fr;gap:36px}

/* Listing grid — fewer columns because sidebar takes space */
.products-grid.products-grid--listing{align-items:stretch}
.products-grid--listing{grid-template-columns:repeat(4,1fr)!important}
@media(max-width:1200px){.products-grid--listing{grid-template-columns:repeat(3,1fr)!important}}
@media(max-width:900px){.products-grid--listing{grid-template-columns:repeat(2,1fr)!important}}

/* Full-width listing: sidebar hidden — same column count as with sidebar, so each card is wider; taller images */
.cat-layout--filters-hidden{grid-template-columns:1fr!important;gap:0}
.cat-layout--filters-hidden #filter-sidebar{display:none!important}
.cat-layout--filters-hidden .products-grid--listing{gap:20px}
.cat-layout--filters-hidden .card-img,.cat-layout--filters-hidden .product-ph{height:280px}

/* AJAX-rendered product cards (shop.php filter results) */
.product-card{border-radius:8px;overflow:hidden;border:1px solid #E8E8E8;background:#fff;transition:box-shadow .2s,transform .2s}
.product-card:hover{box-shadow:0 4px 16px rgba(0,0,0,.06);transform:translateY(-2px)}
.product-card a{text-decoration:none;color:inherit;display:block}
.card-img{height:200px;background:#f4f3f0;position:relative;overflow:hidden}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.product-card:hover .card-img img{transform:scale(1.04)}
.card-badges{position:absolute;top:10px;left:10px;display:flex;gap:6px;flex-wrap:wrap}
.badge{padding:4px 10px;border-radius:12px;font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:11px;font-weight:700;display:inline-block}
.badge-sale{background:#E91E7B;color:#fff}
.badge-black{background:#2D2D2D;color:#fff}
.badge-gold{background:#B8D878;color:#2D2D2D}
.card-info{padding:14px 16px 16px}
.card-brand{font-size:10px;text-transform:uppercase;letter-spacing:1.2px;color:#999;margin-bottom:4px;font-weight:500}
.card-name{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:14px;font-weight:600;color:#1A1A1A;margin-bottom:8px;line-height:1.35}
.card-price-row{display:flex;align-items:baseline;gap:6px;flex-wrap:wrap;margin-bottom:6px}
.card-price{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:20px;font-weight:700;color:#E91E7B}
.card-old{font-size:13px;color:#999;text-decoration:line-through}
.card-saving{font-size:11px;font-weight:600;color:#2EAD6A}
.card-delivery{font-size:11px;color:#999;margin-top:4px}
.product-ph{height:200px;background:#f4f3f0;display:flex;align-items:center;justify-content:center}

/* ── SIDEBAR FILTERS ── */
.sidebar{}
.filter-group{border-bottom:1px solid var(--g2);padding-bottom:20px;margin-bottom:20px}
.filter-group:last-child{border-bottom:none}
.filter-group-title{font-size:.64rem;letter-spacing:.18em;text-transform:uppercase;font-weight:700;color:var(--black);margin-bottom:14px;display:flex;justify-content:space-between;align-items:center;cursor:pointer}
.filter-group-title svg{width:12px;height:12px;color:var(--g3);transition:transform .2s}
.filter-group.open .filter-group-title svg{transform:rotate(180deg)}
.filter-options{display:flex;flex-direction:column;gap:9px}
.filter-opt{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:.76rem;color:var(--g4);transition:color var(--tx)}
.filter-opt:hover{color:var(--black)}
.filter-opt input[type=checkbox]{appearance:none;width:16px;height:16px;border:1.5px solid var(--g2);border-radius:2px;cursor:pointer;flex-shrink:0;position:relative;transition:all var(--tx)}
.filter-opt input[type=checkbox]:checked{background:var(--pink);border-color:var(--pink)}
.filter-opt input[type=checkbox]:checked::after{content:'✓';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.58rem;color:var(--black);font-weight:900}
.filter-opt-count{margin-left:auto;font-size:.68rem;color:var(--g3);font-variant-numeric:tabular-nums;white-space:nowrap}
.filter-opt-count::before{content:'('}
.filter-opt-count::after{content:')'}
.filter-opt-note{font-size:.65rem;color:var(--g3);margin:0 4px}
.filter-opt--fabric-colour .filter-opt-fcc-label{flex:1;min-width:0;line-height:1.35}
.filter-fabric-swatch{width:26px;height:26px;border-radius:7px;flex-shrink:0;background-size:cover;background-position:center;border:1px solid rgba(0,0,0,.12);box-shadow:inset 0 0 0 .5px rgba(255,255,255,.12)}
.filter-fabric-swatch--hex{box-shadow:inset 0 0 0 .5px rgba(0,0,0,.06)}
.shop-qfilter__check--fabric-colour{align-items:center;gap:10px}
.shop-qfilter__check--fabric-colour .filter-fabric-swatch--qfilter{width:22px;height:22px;border-radius:6px;flex-shrink:0}
.shop-qfilter__check--fabric-colour .shop-qfilter__check-text{flex:1;min-width:0;line-height:1.35}
.fabric-colour-preview-wrap{margin-top:10px;padding:12px 14px;background:#fbfaf8;border:1px solid var(--g2);border-radius:10px}
.fabric-colour-preview-head{display:flex;flex-direction:column;gap:4px;margin-bottom:8px}
.fabric-colour-preview-title{font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--g4)}
.fabric-colour-preview-hint{font-size:.68rem;color:var(--g3);line-height:1.35;font-weight:400;text-transform:none;letter-spacing:0;max-width:52ch}
.fabric-colour-preview-swatches{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.fabric-colour-preview-btn{position:relative;display:inline-block;border:none;padding:0;margin:0;cursor:pointer;border-radius:9px;background:transparent;line-height:0;box-shadow:0 2px 8px rgba(0,0,0,.06);transition:box-shadow .15s ease,transform .15s ease}
.fabric-colour-preview-btn:focus-visible{outline:2px solid var(--pink);outline-offset:2px}
.fabric-colour-preview-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.1)}
.fabric-colour-preview-btn.is-selected{box-shadow:0 0 0 2px var(--pink),0 2px 10px rgba(0,0,0,.12)}
.fabric-colour-preview-img{display:block;width:48px;height:48px;object-fit:cover;border-radius:9px;border:1px solid rgba(0,0,0,.1)}
.swatch-group{display:flex;flex-wrap:wrap;gap:8px}
.colour-swatch{width:26px;height:26px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:all var(--tx);position:relative}
.colour-swatch:hover,.colour-swatch.active{border-color:var(--pink);transform:scale(1.15)}
.price-range{padding:4px 0}
.price-range-row{display:flex;justify-content:space-between;margin-bottom:10px;font-size:.7rem;color:var(--g4)}
.range-track{width:100%;height:3px;background:var(--g2);border-radius:2px;position:relative}
.range-fill{position:absolute;left:15%;right:30%;top:0;height:100%;background:var(--pink);border-radius:2px}
.range-thumb{position:absolute;width:14px;height:14px;background:var(--white);border:2px solid var(--pink);border-radius:50%;top:-5.5px;cursor:grab}
.range-thumb.t1{left:14%}.range-thumb.t2{right:29%}

/* ── PRODUCT GRID ── */
.products-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;align-items:stretch}

/* Product image placeholders */





/* ── PAGINATION ── */
.pagination{margin-top:44px;display:flex;justify-content:space-between;align-items:center;padding-top:24px;border-top:1px solid var(--g2)}
.page-info{font-size:.72rem;color:var(--g4)}
.page-btns{display:flex;gap:4px}
.page-btn{width:36px;height:36px;border:1px solid var(--g2);background:var(--white);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.78rem;font-weight:600;color:var(--black);transition:all var(--tx);font-family:'DM Sans','Plus Jakarta Sans',sans-serif}
.page-btn:hover{border-color:var(--pink);color:var(--pink)}
.page-btn.active{background:var(--pink);color:var(--black);border-color:var(--pink)}
.page-btn.arrow{color:var(--g3)}
.page-btn.arrow:hover{color:var(--pink)}

/* ── FOOTER STRIP ── */
.footer-strip{background:var(--black-s);color:rgba(255,255,255,.35);padding:28px 40px;text-align:center;font-size:.68rem;letter-spacing:.08em;border-top:1px solid rgba(255,255,255,.06)}
.footer-strip a{color:rgba(255,255,255,.35);transition:color var(--tx)}
.footer-strip a:hover{color:var(--pink)}

/* ── RESPONSIVE ── */
@media(max-width:1024px){.cat-layout{grid-template-columns:1fr}.cat-layout:not(.cat-layout--full) .sidebar{display:none}.products-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:640px){.cat-hero-inner{grid-template-columns:1fr}.cat-hero-img{display:none}.products-grid{grid-template-columns:repeat(2,1fr);gap:10px}.cat-hero-title{font-size:2.2rem}.sofa-dock-outer{margin-top:-44px;padding:0 16px 48px}.sofa-dock{padding:16px 18px 18px;border-radius:16px}.sofa-dock__eyebrow{font-size:.9rem}.sofa-dock__nav{gap:8px}.sofa-dock__link{min-width:calc(33.33% - 8px);max-width:none;flex:1 1 calc(33.33% - 8px);padding:10px 6px 8px}.sofa-dock__icon-ring{width:44px;height:44px}.sofa-dock__icon svg{width:18px;height:18px}.sofa-dock__label{font-size:.52rem;letter-spacing:.08em}}

/* ══ PRODUCT DETAIL PAGE ══ */
.pdp-breadcrumb{max-width:1600px;margin:0 auto;padding:14px 40px;display:flex;gap:8px;align-items:center;font-size:13px;color:#999}
.pdp-breadcrumb a{color:#999;transition:color .2s;text-decoration:none}
.pdp-breadcrumb a:hover{color:#E91E7B}
.pdp-breadcrumb span{color:#ccc}
.pdp-breadcrumb strong{color:#1A1A1A;font-weight:600}
.pdp-layout{max-width:1600px;margin:0 auto;padding:0 40px 56px;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
/* Wide screens: fixed 900px gallery column so main image can render at full 900×900 (50/50 grid was ~736px max) */
@media (min-width:1400px){
  .pdp-layout{grid-template-columns:900px minmax(0,1fr)}
}

/* Gallery — main image 900×900 when column allows; square, scales down on smaller breakpoints */
.pdp-gallery{width:100%;max-width:900px;display:flex;flex-direction:column;align-items:stretch;gap:0}
.pdp-gallery__main-wrap{position:relative;width:100%;max-width:900px}
.pdp-gallery__arrow{
  position:absolute;top:50%;transform:translateY(-50%);z-index:3;
  width:42px;height:42px;border-radius:50%;padding:0;margin:0;
  border:1px solid #E8E8E8;background:rgba(255,255,255,.94);cursor:pointer;
  font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:1.35rem;line-height:1;font-weight:600;color:#1A1A1A;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 2px 10px rgba(0,0,0,.08);transition:border-color .2s,color .2s,background .2s
}
.pdp-gallery__arrow:hover{border-color:#E91E7B;color:#E91E7B}
.pdp-gallery__arrow--prev{left:12px}
.pdp-gallery__arrow--next{right:12px}
.pdp-gallery__arrow--zoom{z-index:10002;top:50%;width:48px;height:48px;background:rgba(30,30,30,.55);border-color:rgba(255,255,255,.25);color:#fff;backdrop-filter:blur(4px)}
.pdp-gallery__arrow--zoom:hover{background:rgba(233,30,123,.85);border-color:transparent;color:#fff}
.pdp-gallery__arrow--zoom.pdp-gallery__arrow--prev{left:max(16px, env(safe-area-inset-left, 0px))}
.pdp-gallery__arrow--zoom.pdp-gallery__arrow--next{right:max(16px, env(safe-area-inset-right, 0px))}
.pdp-gallery__main{
  position:relative;overflow:hidden;background:#f4f3f0;border-radius:10px;
  box-sizing:border-box;
  width:100%;max-width:900px;
  aspect-ratio:1/1;
  border:1px solid #E8E8E8;cursor:zoom-in;
  display:flex;align-items:center;justify-content:center
}
/* Full image visible in frame — no cropping (was cover). Scales down to fit 900×900 area. */
.pdp-gallery__main img{
  max-width:100%;
  max-height:100%;
  width:auto;
  height:auto;
  object-fit:contain;
  object-position:center;
  display:block
}
.pdp-gallery__main--empty{cursor:default}
.pdp-gallery__placeholder{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;
  width:100%;height:100%;min-height:200px;padding:32px;box-sizing:border-box;
  color:#9a958c;font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:15px;font-weight:600
}
.pdp-gallery__placeholder-icon{font-size:3rem;line-height:1;opacity:.45}
.pdp-gallery__placeholder-txt{font-size:.82rem;letter-spacing:.06em;text-transform:uppercase}
.pdp-gallery__badge{position:absolute;top:16px;left:16px;background:#E91E7B;color:#fff;font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:13px;font-weight:700;padding:6px 14px;border-radius:8px;z-index:2}
.pdp-gallery__zoom-hint{position:absolute;bottom:12px;right:12px;background:rgba(0,0,0,.5);color:#fff;font-size:11px;padding:5px 10px;border-radius:6px;opacity:0;transition:opacity .2s;pointer-events:none}
.pdp-gallery__main:hover .pdp-gallery__zoom-hint{opacity:1}
/* Zoom overlay */
.pdp-zoom-overlay{position:fixed;inset:0;background:rgba(0,0,0,.9);z-index:9999;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s}
.pdp-zoom-overlay.open{opacity:1;pointer-events:all}
.pdp-zoom-overlay img{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:4px;position:relative;z-index:10001;cursor:default}
.pdp-zoom__close{position:absolute;top:20px;right:24px;background:none;border:none;color:#fff;font-size:36px;cursor:pointer;width:48px;height:48px;display:flex;align-items:center;justify-content:center;transition:opacity .2s}
.pdp-zoom__close:hover{opacity:.7}
.pdp-gallery__thumbs-outer{display:flex;align-items:center;gap:6px;margin-top:10px;width:100%;min-width:0}
.pdp-gallery__thumbs-arrow{
  flex-shrink:0;width:36px;height:36px;border-radius:50%;border:1px solid #E8E8E8;background:#fff;cursor:pointer;
  font-size:1.1rem;line-height:1;color:#1A1A1A;display:flex;align-items:center;justify-content:center;
  transition:border-color .2s,color .2s
}
.pdp-gallery__thumbs-arrow:hover{border-color:#E91E7B;color:#E91E7B}
.pdp-gallery__thumbs{
  flex:1;min-width:0;display:flex;flex-direction:row;gap:8px;overflow-x:auto;scroll-behavior:smooth;
  scrollbar-width:thin;-webkit-overflow-scrolling:touch;padding-bottom:4px
}
.pdp-gallery__thumbs::-webkit-scrollbar{height:5px}
.pdp-gallery__thumbs::-webkit-scrollbar-thumb{background:#d8d8d8;border-radius:3px}
.pdp-thumb{
  flex:0 0 calc((100% - 32px) / 5);width:calc((100% - 32px) / 5);min-width:calc((100% - 32px) / 5);
  aspect-ratio:1;overflow:hidden;border-radius:8px;cursor:pointer;border:2px solid #E8E8E8;transition:border-color .2s;background:#f4f3f0;box-sizing:border-box
}
.pdp-thumb.active,.pdp-thumb:hover{border-color:#E91E7B}
.pdp-thumb img{width:100%;height:100%;object-fit:contain;background:#f4f3f0}

/* Live activity — fixed bottom-right on PDP, stacked above sitewide site-active chip */
.pdp-live-strip{
  position:fixed;
  right:max(14px, env(safe-area-inset-right, 0px));
  bottom:calc(76px + max(0px, env(safe-area-inset-bottom, 0px)));
  z-index:175;
  width:min(312px, calc(100vw - 28px));
  margin:0;
  padding:14px 18px 16px 16px;
  border-radius:14px;
  background:linear-gradient(155deg, #1c1b22 0%, #2a2630 42%, #18161c 100%);
  border:1px solid rgba(233,30,123,.42);
  box-shadow:
    0 0 0 1px rgba(255,255,255,.06) inset,
    0 10px 36px rgba(0,0,0,.35),
    0 0 52px rgba(233,30,123,.14),
    0 4px 14px rgba(233,30,123,.12);
  font-family:'Plus Jakarta Sans','DM Sans',sans-serif;
  font-size:13px;
  font-weight:600;
  color:rgba(248,246,252,.88);
  line-height:1.45;
  backdrop-filter:saturate(140%) blur(10px);
  -webkit-backdrop-filter:saturate(140%) blur(10px);
  animation:pdpLiveStripIn .55s cubic-bezier(.22,1,.36,1) both;
}
.pdp-live-strip::before{
  content:'';
  position:absolute;
  right:0;top:10px;bottom:10px;width:4px;border-radius:4px 0 0 4px;
  background:linear-gradient(180deg, #E91E7B 0%, #ff6b9d 50%, #b3126d 100%);
  box-shadow:0 0 16px rgba(233,30,123,.45);
}
@keyframes pdpLiveStripIn{
  from{opacity:0;transform:translateY(12px) scale(.98)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
.pdp-live-strip__row{display:flex;align-items:flex-start;gap:11px;position:relative}
.pdp-live-strip__row + .pdp-live-strip__row{margin-top:11px;padding-top:12px;border-top:1px dashed rgba(255,255,255,.14)}
.pdp-live-strip__text{min-width:0;text-shadow:0 1px 0 rgba(0,0,0,.35)}
.pdp-live-strip__text strong{color:#fff;font-weight:800;font-variant-numeric:tabular-nums;font-size:1.08em}
.pdp-live-strip__pulse{
  width:10px;height:10px;border-radius:50%;
  background:#3dd884;
  flex-shrink:0;
  margin-top:3px;
  box-shadow:0 0 0 3px rgba(61,216,132,.35), 0 0 14px rgba(61,216,132,.45);
  animation:pdpLivePulse 2.2s ease-in-out infinite;
}
.pdp-live-strip__pulse--site{background:#5eeadb;box-shadow:0 0 0 3px rgba(94,234,219,.32), 0 0 14px rgba(94,234,219,.4);animation-delay:.35s}
@keyframes pdpLivePulse{
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.88;transform:scale(.9)}
}
@media (max-width:480px){
  .pdp-live-strip{
    width:min(288px, calc(100vw - 20px));
    right:max(10px, env(safe-area-inset-right, 0px));
    bottom:calc(72px + max(0px, env(safe-area-inset-bottom, 0px)));
    padding:12px 16px 14px 14px;
    font-size:12.5px
  }
}
body:has(.pdp-zoom-overlay.open) .pdp-live-strip{visibility:hidden;pointer-events:none}
@media print{.pdp-live-strip{display:none !important}}

/* Sitewide “shoppers active on site” (includes/header.php) — bottom-right corner */
.ghfo-site-active{
  position:fixed;
  right:max(14px, env(safe-area-inset-right, 0px));
  bottom:max(16px, env(safe-area-inset-bottom, 0px));
  z-index:174;
  display:flex;
  align-items:flex-start;
  gap:10px;
  width:min(300px, calc(100vw - 28px));
  margin:0;
  padding:12px 17px 12px 16px;
  border-radius:12px;
  background:linear-gradient(155deg, #1c1b22 0%, #2a2630 45%, #18161c 100%);
  border:1px solid rgba(78,205,196,.45);
  box-shadow:
    0 0 0 1px rgba(255,255,255,.06) inset,
    0 10px 32px rgba(0,0,0,.32),
    0 0 40px rgba(78,205,196,.12);
  font-family:'Plus Jakarta Sans','DM Sans',sans-serif;
  font-size:12.5px;
  font-weight:600;
  color:rgba(248,246,252,.9);
  line-height:1.4;
  backdrop-filter:saturate(140%) blur(10px);
  -webkit-backdrop-filter:saturate(140%) blur(10px);
  animation:pdpLiveStripIn .5s cubic-bezier(.22,1,.36,1) both;
}
.ghfo-site-active::before{
  content:'';
  position:absolute;
  right:0;top:8px;bottom:8px;width:3px;border-radius:3px 0 0 3px;
  background:linear-gradient(180deg, #4ECDC4 0%, #7ee8e0 50%, #2a9d8f 100%);
  box-shadow:0 0 14px rgba(78,205,196,.4);
}
.ghfo-site-active__txt{position:relative;min-width:0;text-shadow:0 1px 0 rgba(0,0,0,.35)}
.ghfo-site-active__txt strong{color:#fff;font-weight:800;font-variant-numeric:tabular-nums;font-size:1.07em}
.ghfo-site-active__pulse{
  width:10px;height:10px;border-radius:50%;
  background:#5eeadb;
  flex-shrink:0;
  margin-top:2px;
  box-shadow:0 0 0 3px rgba(94,234,219,.32), 0 0 12px rgba(94,234,219,.38);
  animation:pdpLivePulse 2.2s ease-in-out infinite;
  animation-delay:.2s;
}
body:has(.pdp-zoom-overlay.open) .ghfo-site-active{visibility:hidden;pointer-events:none}
@media (max-width:480px){
  .ghfo-site-active{
    width:min(272px, calc(100vw - 20px));
    right:max(10px, env(safe-area-inset-right, 0px));
    bottom:max(12px, env(safe-area-inset-bottom, 0px));
    padding:10px 15px 10px 13px;
    font-size:12px
  }
}
@media print{.ghfo-site-active{display:none !important}}

/* Badges */
.pdp-badges{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.pdp-badge{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:12px;font-weight:600;padding:5px 12px;border-radius:6px;display:inline-flex;align-items:center;gap:4px}
.pdp-badge--sale{background:#E91E7B;color:#fff}
.pdp-badge--stock{background:#fff;color:#2EAD6A;border:1.5px solid #2EAD6A}
.pdp-badge--delivery{background:#fff;color:#4A4A4A;border:1.5px solid #E8E8E8}

/* Title */
.pdp-title{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:28px;font-weight:800;color:#1A1A1A;line-height:1.15;margin-bottom:10px}

/* Rating */
.pdp-rating{display:flex;align-items:center;gap:8px;margin-bottom:20px}
.pdp-rating__stars{color:#E91E7B;font-size:16px;letter-spacing:1px}
.pdp-rating__score{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:14px;font-weight:700;color:#1A1A1A}
.pdp-rating__link{font-size:13px;color:#E91E7B;font-weight:600;text-decoration:none}
.pdp-rating__link:hover{text-decoration:underline}

/* Price */
.pdp-price{display:flex;align-items:baseline;gap:10px;margin-bottom:8px}
.pdp-price__now{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:36px;font-weight:800;color:#E91E7B;line-height:1}
.pdp-price__was{font-size:18px;color:#999;text-decoration:line-through}
.pdp-saving{display:inline-flex;align-items:center;gap:6px;background:rgba(233,30,123,.06);color:#E91E7B;padding:6px 14px;border-radius:20px;font-size:13px;font-weight:600;margin-bottom:20px}
.pdp-saving svg{stroke:#E91E7B;flex-shrink:0}

/* Description */
.pdp-desc{font-size:14px;color:#4A4A4A;line-height:1.75;margin-bottom:24px}
.pdp-desc p{margin-bottom:10px}

/* Options */
/* Fabric-led PDP: keep variant DOM for cart/JS, hide visually */
.pdp-options-stack--fabric-only-hidden{display:none!important}
/* Multi-variant: collapsed configuration (opens for Colour / Size / variant “Fabric”, etc.) */
.pdp-options-advanced{margin:0 0 18px;border:1px solid #E8E8E8;border-radius:10px;background:#FAFAFA;overflow:hidden}
.pdp-options-advanced__summary{cursor:pointer;list-style:none;padding:12px 14px;font-size:14px;font-weight:700;color:#1A1A1A;font-family:'Plus Jakarta Sans','DM Sans',sans-serif}
.pdp-options-advanced__summary::-webkit-details-marker{display:none}
.pdp-options-advanced__hint{display:block;font-weight:500;color:#888;font-size:12px;margin-top:4px}
.pdp-options-advanced[open] .pdp-options-advanced__hint{color:#666}
.pdp-options-stack--in-advanced{padding:0 14px 14px;border-top:1px solid #EEE;background:#fff}
.pdp-option{margin-bottom:20px}
.pdp-option__label{font-size:14px;color:#1A1A1A;margin-bottom:10px}
.pdp-option__label strong{font-weight:700}
.pdp-option__label span{color:#999;font-weight:400}
.pdp-swatches{display:flex;flex-wrap:wrap;gap:10px}
.pdp-swatch{width:40px;height:40px;border-radius:50%;cursor:pointer;border:3px solid transparent;transition:all .2s;position:relative}
.pdp-swatch.active,.pdp-swatch:hover{border-color:#E91E7B;transform:scale(1.1)}
.pdp-swatch.active::after{content:'✓';position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:12px;color:#fff;font-weight:900;text-shadow:0 0 3px rgba(0,0,0,.5)}
.pdp-configs{display:flex;gap:8px;flex-wrap:wrap}
.pdp-config{padding:10px 20px;border:1.5px solid #E8E8E8;background:#fff;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;font-family:'Plus Jakarta Sans','DM Sans',sans-serif;color:#1A1A1A}
.pdp-config:hover{border-color:#E91E7B;color:#E91E7B}
.pdp-config.active{background:#fff;color:#E91E7B;border-color:#E91E7B}

/* Add to Cart row */
.pdp-edit-basket-notice{margin-bottom:14px;padding:12px 14px;background:rgba(233,30,123,.08);border:1px solid rgba(233,30,123,.22);border-radius:10px;font-size:.88rem;line-height:1.45;color:var(--text-muted)}
.pdp-edit-basket-notice strong{color:var(--black)}
.pdp-atc-row{display:flex;gap:10px;margin-bottom:28px;align-items:stretch}
.cart-flash{margin:0 0 20px;padding:12px 16px;border-radius:10px;font-size:.9rem;font-weight:600}
.cart-flash--success{background:rgba(22,101,52,.1);border:1px solid rgba(22,101,52,.25);color:#166534}
.cart-item--updated{
  background:linear-gradient(90deg,rgba(22,163,74,.14) 0%,rgba(22,163,74,.06) 14%,rgba(22,101,52,.05) 100%);
  border-left:4px solid #16a34a;
  box-shadow:inset 0 0 0 1px rgba(22,163,74,.2),0 4px 18px rgba(22,101,52,.14);
  border-radius:0 12px 12px 0;
  transition:background .4s ease,box-shadow .4s ease,border-color .4s ease;
}
.cart-item-updated-msg{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  font-size:.78rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;
  color:#fff;
  background:linear-gradient(145deg,#15803d 0%,#22c55e 55%,#16a34a 100%);
  border:1px solid rgba(255,255,255,.4);
  border-radius:999px;padding:8px 14px;
  box-shadow:0 2px 10px rgba(22,101,52,.4),0 0 0 1px rgba(21,128,61,.35);
  animation:cart-updated-pop .5s cubic-bezier(.34,1.56,.64,1);
  transition:opacity .38s ease,transform .38s ease;
}
.cart-item-updated-msg--leaving{opacity:0;transform:scale(.9) translateY(-2px);pointer-events:none}
.cart-item--updated-leaving{
  background:transparent!important;
  border-left-color:transparent!important;
  box-shadow:none!important;
}
@keyframes cart-updated-pop{
  0%{opacity:0;transform:scale(.82) translateY(6px)}
  70%{transform:scale(1.04) translateY(0)}
  100%{opacity:1;transform:scale(1) translateY(0)}
}
.cart-flash--leaving{opacity:0;transition:opacity .4s ease;pointer-events:none}
.cart-item__actions-btns{display:inline-flex;align-items:center;gap:6px}
.cart-item-edit{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border:1.5px solid var(--grey-200);border-radius:8px;background:var(--white);color:var(--text-muted);text-decoration:none;transition:background .15s,border-color .15s,color .15s,box-shadow .15s}
.cart-item-edit:hover{color:var(--pink);border-color:rgba(233,30,123,.45);background:rgba(233,30,123,.06);box-shadow:0 0 0 3px rgba(233,30,123,.1)}
.cart-item-edit:focus-visible{outline:2px solid var(--pink);outline-offset:2px}
.cart-item-edit svg{display:block;flex-shrink:0}
.pdp-qty{display:flex;align-items:center;border:1.5px solid #E8E8E8;border-radius:8px;overflow:hidden}
.pdp-qty button{width:40px;height:48px;background:none;border:none;cursor:pointer;font-size:18px;color:#1A1A1A;transition:background .15s;font-family:'Plus Jakarta Sans','DM Sans',sans-serif}
.pdp-qty button:hover{background:#f4f3f0}
.pdp-qty input{width:44px;height:48px;border:none;border-left:1.5px solid #E8E8E8;border-right:1.5px solid #E8E8E8;text-align:center;font-size:15px;font-weight:700;font-family:'Plus Jakarta Sans','DM Sans',sans-serif;color:#1A1A1A;background:#fff}
.pdp-qty input:focus{outline:none}
.pdp-atc-btn{flex:1;background:#E91E7B;color:#fff;border:none;padding:0 28px;height:48px;border-radius:8px;font-size:15px;font-weight:700;cursor:pointer;transition:all .2s;font-family:'Plus Jakarta Sans','DM Sans',sans-serif;display:flex;align-items:center;justify-content:center;gap:10px}
.pdp-atc-btn:hover{background:#C4176A;transform:translateY(-1px);box-shadow:0 6px 20px rgba(233,30,123,.25)}
.pdp-atc-btn svg{flex-shrink:0}
.pdp-wish-btn{width:48px;height:48px;border:1.5px solid #E8E8E8;background:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#999;transition:all .2s;flex-shrink:0}
.pdp-wish-btn:hover,.pdp-wish-btn.active{border-color:#E91E7B;color:#E91E7B;background:rgba(233,30,123,.04)}
.pdp-wish-btn.active svg{fill:#E91E7B}

/* Trust card — buy box facts + service promises */
.pdp-trust{margin-top:4px;border:1px solid #E8E8E8;border-radius:12px;overflow:hidden;background:#fff}
.pdp-trust__item{display:flex;align-items:flex-start;gap:18px;padding:22px 24px 24px;border-bottom:1px solid #ececec}
.pdp-trust__item:last-child{border-bottom:none}
.pdp-trust__icon{flex-shrink:0;margin-top:4px}
.pdp-trust__text{flex:1;min-width:0}
.pdp-trust__text strong{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:15px;font-weight:700;color:#1A1A1A;display:block;line-height:1.35;letter-spacing:-.01em}
.pdp-trust__text span{font-size:13px;color:#777;display:block;margin-top:8px;line-height:1.55;max-width:38rem}
.pdp-trust__item--fact .pdp-trust__text span{color:#6a6a6a}
.pdp-trust__item--service{padding-top:24px;padding-bottom:26px}
.pdp-trust__link{color:var(--pink);font-weight:600;text-decoration:none;border-bottom:1px solid transparent;transition:border-color .2s,color .2s}
.pdp-trust__link:hover{color:var(--pink-dk,#C4176A);border-bottom-color:rgba(233,30,123,.35)}
.pdp-trust__link--muted{font-weight:500;color:var(--g4)}
.pdp-trust__link--muted:hover{color:var(--pink)}
.pdp-trust__sep{display:block;height:1px;margin:10px 24px 12px;border:0;padding:0;background:linear-gradient(90deg,transparent,rgba(0,0,0,.08),transparent)}

/* Tabs */
.pdp-tabs{max-width:1600px;margin:0 auto;padding:0 40px 56px}
.pdp-tabs__nav{display:flex;border-bottom:2px solid #E8E8E8;margin-bottom:28px}
.pdp-tabs__btn{padding:14px 24px;font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:13px;letter-spacing:.5px;text-transform:uppercase;font-weight:700;color:#999;background:none;border:none;cursor:pointer;position:relative;transition:color .2s}
.pdp-tabs__btn::after{content:'';position:absolute;bottom:-2px;left:0;right:0;height:2px;background:#E91E7B;transform:scaleX(0);transition:transform .2s}
.pdp-tabs__btn.active,.pdp-tabs__btn:hover{color:#1A1A1A}
.pdp-tabs__btn.active::after{transform:scaleX(1)}
.pdp-tabs__panel{display:none}
.pdp-tabs__panel.active{display:block}
.pdp-desc-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px}
.pdp-desc-body{font-size:14px;line-height:1.85;color:#4A4A4A}
.pdp-desc-body p{margin-bottom:14px}
.pdp-desc-body h3{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:16px;font-weight:700;margin:24px 0 12px;color:#1A1A1A}
/* Rich description HTML: reset global ul{list-style:none} inside product copy */
.pdp-desc-body ul,.pdp-desc-body ol{margin:0 0 14px;padding-left:1.35em;color:#4A4A4A}
.pdp-desc-body ul{list-style:disc}
.pdp-desc-body ol{list-style:decimal}
.pdp-desc-body ul ul{list-style:circle;margin-bottom:6px}
.pdp-desc-body li{margin-bottom:6px;line-height:1.6}
.pdp-desc-body li::marker{color:#1A1A1A}
.pdp-features{list-style:none;padding:0}
.pdp-features li{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:#4A4A4A;margin-bottom:10px;line-height:1.5}
.pdp-features li::before{content:'✦';color:#E91E7B;font-size:11px;flex-shrink:0;margin-top:3px}

/* What you need to know — standalone section */
.pdp-know-section{max-width:1600px;margin:0 auto;padding:48px 40px;background:#FAFAF8;border-top:1px solid #E8E8E8;border-bottom:1px solid #E8E8E8}
.pdp-know-section__title{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:22px;font-weight:800;color:#1A1A1A;text-align:center;margin-bottom:32px}
.pdp-know__table{max-width:800px;margin:0 auto}
.pdp-know__row{display:grid;grid-template-columns:200px 1fr;gap:24px;padding:14px 0;border-bottom:1px solid #E8E8E8}
.pdp-know__row:last-child{border-bottom:none}
.pdp-know__label{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:14px;font-weight:700;color:#1A1A1A}
.pdp-know__value{font-size:14px;color:#4A4A4A;line-height:1.6}

/* Dimensions — standalone section (Loaf style) */
.pdp-dims-section{max-width:1600px;margin:0 auto;padding:48px 40px;background:#FAFAF8;border-top:1px solid #E8E8E8}
.pdp-dims-section__title{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:26px;font-weight:800;color:#1A1A1A;text-align:center;margin-bottom:30px}
.pdp-dims-section__layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(300px,420px);gap:28px;align-items:start;max-width:1160px;margin:0 auto}
.pdp-dims-section__left,.pdp-dims-section__right{background:#fff;border:1px solid #ece9e2;border-radius:14px;padding:14px 16px;box-shadow:0 10px 30px rgba(26,26,26,.04)}
.pdp-dims-section__table{width:100%;border-collapse:separate;border-spacing:0 8px}
.pdp-dims-section__table thead th{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#8a867f;padding:0 12px 6px;border:none;text-align:left;font-family:'Plus Jakarta Sans','DM Sans',sans-serif}
.pdp-dims-section__table thead th:last-child{text-align:right}
.pdp-dims-section__table tbody tr{background:#faf8f4}
.pdp-dims-section__table td{padding:11px 12px;font-size:14px;color:#4A4A4A;border-top:1px solid #efece5;border-bottom:1px solid #efece5}
.pdp-dims-section__table td:first-child{border-left:1px solid #efece5;border-radius:10px 0 0 10px;color:#1A1A1A;font-family:'Plus Jakarta Sans','DM Sans',sans-serif}
.pdp-dims-section__table td:last-child{border-right:1px solid #efece5;border-radius:0 10px 10px 0;text-align:right;font-weight:700;color:#1A1A1A}
.pdp-dims-section__table td strong{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:7px;background:#f0ece4;color:#1A1A1A;font-weight:800;margin-right:8px;font-size:.82rem}
.pdp-dims-section__note{font-size:12px;color:#8f8a82;margin-top:10px;font-style:italic}
.pdp-dims-section__right{display:flex;flex-direction:column;gap:14px}
.pdp-dims-section__img{text-align:center;border-radius:10px;overflow:hidden;background:#f8f6f1;border:1px solid #ece9e2}
.pdp-dims-section__img img{display:block;width:100%;max-height:280px;object-fit:contain;padding:10px}
.pdp-dims-section__caption{font-size:11px;color:#9a958c;font-style:italic;text-align:center;margin-top:2px}
@media(max-width:920px){.pdp-dims-section__layout{grid-template-columns:1fr}.pdp-dims-section__right{max-width:560px;margin:0 auto;width:100%}}
@media(max-width:768px){.pdp-dims-section{padding:28px 16px}.pdp-dims-section__title{font-size:22px;margin-bottom:20px}.pdp-dims-section__left,.pdp-dims-section__right{padding:12px}.pdp-dims-section__table td{font-size:13px;padding:10px}.pdp-know-section{padding:32px 16px}.pdp-know__row{grid-template-columns:1fr;gap:4px}}
.pdp-dims-table{width:100%;max-width:500px;border-collapse:collapse}
.pdp-dims-table tr{border-bottom:1px solid #E8E8E8}
.pdp-dims-table tr:last-child{border-bottom:none}
.pdp-dims-table td{padding:12px 0;font-size:14px}
.pdp-dims-table td:first-child{color:#999;font-weight:600;font-size:12px;letter-spacing:.5px;text-transform:uppercase;width:40%}
.pdp-dims-table td:last-child{color:#1A1A1A;font-weight:600}
.pdp-review{border:1px solid #E8E8E8;border-radius:10px;padding:22px;margin-bottom:14px}
.pdp-review__top{display:flex;justify-content:space-between;margin-bottom:10px}
.pdp-review__author{font-size:14px;font-weight:700;color:#1A1A1A}
.pdp-review__date{font-size:12px;color:#999;margin-top:2px}
.pdp-review__stars{color:#E91E7B;font-size:14px}
.pdp-review__title{font-weight:700;margin-bottom:8px;color:#1A1A1A}
.pdp-review__text{font-size:14px;line-height:1.75;color:#4A4A4A}

/* Related */
.pdp-related{max-width:1600px;margin:0 auto;padding:0 40px 56px}

/* More from collection — horizontal scroller */
.pdp-collection{max-width:1600px;margin:0 auto;padding:32px 40px 48px;border-top:1px solid #E8E8E8}
.pdp-collection__head{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}
.pdp-collection__title{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:22px;font-weight:800;color:#1A1A1A}
.pdp-collection__name{color:var(--pink);font-weight:900}
.pdp-collection__arrows{display:flex;gap:8px}
.pdp-coll-arrow{width:36px;height:36px;border-radius:50%;border:1.5px solid #E8E8E8;background:#fff;display:flex;align-items:center;justify-content:center;font-size:1.3rem;color:#1A1A1A;cursor:pointer;transition:all .2s}
.pdp-coll-arrow:hover{border-color:#E91E7B;color:#E91E7B}
.pdp-collection__scroll{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:4px}
.pdp-collection__scroll::-webkit-scrollbar{display:none}
.pdp-collection__scroll .pc{min-width:280px;max-width:280px;scroll-snap-align:start;flex-shrink:0}

/* Why we love it */
.pdp-whylove{max-width:1600px;margin:0 auto;padding:0 40px 56px;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.pdp-whylove__img{border-radius:12px;overflow:hidden;aspect-ratio:4/3}
.pdp-whylove__img img{width:100%;height:100%;object-fit:cover}
.pdp-whylove__placeholder{width:100%;height:100%;min-height:220px;background:#f4f3f0;display:flex;align-items:center;justify-content:center;font-size:2.75rem;opacity:.4}
.pdp-whylove__text h2{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:26px;font-weight:800;color:#1A1A1A;line-height:1.2;margin-bottom:14px}
.pdp-whylove__text p{font-size:15px;color:#4A4A4A;line-height:1.75}

/* What you need to know — specs */
.pdp-specs{max-width:1600px;margin:0 auto;padding:48px 40px;background:#FAFAF8;border-top:1px solid #E8E8E8;border-bottom:1px solid #E8E8E8}
.pdp-specs__title{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:22px;font-weight:800;color:#1A1A1A;text-align:center;margin-bottom:32px}
.pdp-specs__group{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:1rem;font-weight:700;color:#1A1A1A;margin:28px auto 12px;max-width:800px;padding-top:8px;border-top:1px solid #E8E8E8}
.pdp-specs__table > .pdp-specs__group:first-child{border-top:none;margin-top:0;padding-top:0}
.pdp-specs__table{max-width:800px;margin:0 auto}
.pdp-spec-row{display:grid;grid-template-columns:200px 1fr;gap:24px;padding:14px 0;border-bottom:1px solid #E8E8E8}
.pdp-spec-row:last-child{border-bottom:none}
.pdp-spec-label{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:14px;font-weight:700;color:#1A1A1A}
.pdp-spec-value{font-size:14px;color:#4A4A4A;line-height:1.6}

/* Dimensions */
.pdp-dimensions{max-width:1600px;margin:0 auto;padding:48px 40px;text-align:center}
.pdp-dimensions__title{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:22px;font-weight:800;color:#1A1A1A;margin-bottom:28px}
.pdp-dimensions__grid{max-width:600px;margin:0 auto}
.pdp-dimensions__table{width:100%;border-collapse:collapse;text-align:left}
.pdp-dimensions__table th{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#999;padding:10px 16px;border-bottom:2px solid #E8E8E8}
.pdp-dimensions__table td{font-size:14px;padding:12px 16px;border-bottom:1px solid #f0f0f0;color:#4A4A4A}
.pdp-dimensions__table td:first-child{color:#1A1A1A}
.pdp-dimensions__note{font-size:12px;color:#999;margin-top:12px;font-style:italic}

/* PDP Responsive */
@media(max-width:1024px){
  .pdp-layout{grid-template-columns:1fr;gap:32px}
  .pdp-desc-grid{grid-template-columns:1fr}
  .pdp-whylove{grid-template-columns:1fr}
  .pdp-spec-row{grid-template-columns:140px 1fr}
}
@media(max-width:640px){
  .pdp-layout{padding:0 16px 40px}
  .pdp-tabs,.pdp-related,.pdp-breadcrumb,.pdp-collection,.pdp-whylove,.pdp-specs,.pdp-dimensions{padding-left:16px;padding-right:16px}
  .pdp-title{font-size:22px}
  .pdp-price__now{font-size:28px}
  .pdp-thumb{flex-basis:calc((100% - 24px) / 4);width:calc((100% - 24px) / 4);min-width:calc((100% - 24px) / 4)}
  .pdp-spec-row{grid-template-columns:1fr;gap:4px}
}

/* ── CATEGORY FAQ ── */
.cat-faq{background:#F4F3F0;padding:56px 0}
.cat-faq__inner{max-width:1600px;margin:0 auto;padding:0 40px;display:grid;grid-template-columns:320px 1fr;gap:56px;align-items:start}
.cat-faq__title{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:24px;font-weight:800;color:#1A1A1A;line-height:1.2;margin-bottom:14px}
.cat-faq__hint{font-size:13px;color:#999;line-height:1.6}
.cat-faq__hint a{color:#1A1A1A;text-decoration:underline;font-weight:600}
.cat-faq__item{border-bottom:1px solid #E8E8E8}
.cat-faq__q{display:flex;justify-content:space-between;align-items:center;padding:18px 0;cursor:pointer;list-style:none;font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:15px;font-weight:700;color:#1A1A1A;transition:color .15s}
.cat-faq__q:hover{color:#E91E7B}
.cat-faq__q::-webkit-details-marker{display:none}
.cat-faq__icon{font-size:20px;color:#999;flex-shrink:0;margin-left:16px;transition:transform .2s}
details[open] .cat-faq__icon{transform:rotate(45deg)}
.cat-faq__a{padding:0 0 18px;font-size:14px;color:#4A4A4A;line-height:1.75}
@media(max-width:900px){.cat-faq__inner{grid-template-columns:1fr;gap:24px}}

/* ══ ADMIN ADDITIONS ══ */
.admin-layout{display:flex;min-height:100vh;min-width:0;max-width:100%;overflow-x:hidden}
@supports (overflow:clip){
  /* clip suppresses horizontal bleed without breaking descendant position:sticky (Chromium quirk with hidden) */
  .admin-layout{overflow-x:clip}
}
.admin-layout{
  /* Softer overall background for admin area */
  background:linear-gradient(180deg,#fbfaf8 0%,#f6f4ef 100%);
}
.admin-sidebar{width:260px;background:linear-gradient(180deg,#151515 0%,#101010 100%);flex-shrink:0;position:fixed;top:0;left:0;bottom:0;overflow-y:auto;overflow-x:visible;z-index:100}
.admin-sidebar-header{padding:24px 20px;border-bottom:1px solid rgba(255,255,255,.06)}
.admin-sidebar-tagline{
  display:block;
  margin-top:6px;
  font-size:.62rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  font-weight:600;
  font-family:'DM Sans','Plus Jakarta Sans',system-ui,sans-serif;
  color:rgba(214,184,120,.88);
  line-height:1.4;
  -webkit-font-smoothing:antialiased;
}
.admin-nav{padding:20px 0;position:relative;overflow:visible;font-family:'DM Sans','Plus Jakarta Sans',system-ui,sans-serif}
.admin-nav a{display:flex;align-items:center;gap:12px;padding:11px 20px;font-size:.92rem;font-weight:500;line-height:1.45;color:rgba(255,255,255,.88);transition:.22s ease;border-left:3px solid transparent;-webkit-font-smoothing:antialiased}
.admin-nav a:hover{background:rgba(255,255,255,.06);color:#fff;border-left-color:#C6973F}
.admin-nav a.active{background:rgba(198,151,63,.14);color:#fff;border-left-color:#C6973F;font-weight:600}
.admin-nav-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.78);padding:11px 20px;background:none;border:none;cursor:pointer;font-family:'DM Sans','Plus Jakarta Sans',system-ui,sans-serif;text-align:left;line-height:1.35;-webkit-font-smoothing:antialiased}
.admin-nav-toggle:hover{color:rgba(255,255,255,.95)}
.admin-nav-toggle::after{content:'▾';font-size:.95rem;letter-spacing:0;color:rgba(255,255,255,.45)}
.admin-nav-section.open .admin-nav-toggle::after{content:'▸'}
.admin-nav-section.has-active .admin-nav-toggle{
  color:rgba(255,255,255,.92);
  background:rgba(198,151,63,.12);
  border-left:3px solid #C6973F;
  padding-left:17px; /* keep alignment with border */
}
.admin-nav-toggle-left{display:inline-flex;align-items:center;gap:10px}
.admin-nav-toggle-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;opacity:.9;letter-spacing:0}

/* Flyout submenu (desktop): opens to the right of sidebar */
.admin-nav-section{position:relative}
/* Desktop: submenu is rendered in a fixed-position flyout (JS portal) */
.admin-nav-submenu{display:none}
.admin-nav-flyout-backdrop{
  position:fixed;
  inset:0;
  background:rgba(15,15,15,.46);
  z-index:990;
  opacity:0;
  pointer-events:none;
  transition:opacity .2s ease;
}
.admin-nav-flyout-backdrop.is-open{
  opacity:1;
  pointer-events:auto;
}
.admin-nav-flyout{
  position:fixed;
  width:312px;
  background:#2a2a2a;
  border-left:1px solid rgba(255,255,255,.08);
  box-shadow:24px 0 60px rgba(0,0,0,.45);
  border-radius:0;
  padding:10px 10px 12px;
  z-index:1000;
  overflow:hidden;
  display:flex;
  flex-direction:column;
}
.admin-nav-flyout-header{
  height:48px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 10px;
  border-bottom:1px solid rgba(255,255,255,.08);
  color:rgba(255,255,255,.9);
}
.admin-nav-flyout-title{
  font-size:.82rem;
  letter-spacing:.06em;
  text-transform:uppercase;
  font-weight:700;
  font-family:'DM Sans','Plus Jakarta Sans',system-ui,sans-serif;
  color:rgba(255,255,255,.95);
  line-height:1.3;
}
.admin-nav-flyout-close{
  width:34px;
  height:34px;
  border-radius:8px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.15);
  color:rgba(255,255,255,.85);
  cursor:pointer;
  font-size:1.4rem;
  line-height:1;
}
.admin-nav-flyout-close:hover{background:rgba(0,0,0,.28)}

.admin-nav-flyout-body{padding:12px 6px 6px;overflow:auto}
.admin-nav-flyout .admin-nav-flyout-col a{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  font-size:.91rem;
  font-weight:500;
  line-height:1.45;
  color:rgba(255,255,255,.9);
  text-decoration:none;
  border-radius:0;
  border-left:3px solid transparent;
  -webkit-font-smoothing:antialiased;
}
.admin-nav-flyout .admin-nav-submenu-icon{
  flex-shrink:0;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:1.75em;
  font-size:1.05em;
  line-height:1;
}
.admin-nav-flyout .admin-nav-submenu-label{flex:1;min-width:0}
.admin-nav-flyout .admin-nav-flyout-col a:hover{background:rgba(255,255,255,.06);color:#fff;border-left-color:#C6973F}
.admin-nav-flyout .admin-nav-flyout-col a.active{
  background:rgba(198,151,63,.22) !important;
  color:#fff !important;
  font-weight:600 !important;
  border-left-color:#C6973F !important;
  box-shadow:inset 0 0 0 1px rgba(198,151,63,.22);
}
/* Channels / Suppliers: tier 1 = row → tier 2 flyout / mobile drill-down */
.admin-nav-submenu--channels,
.admin-nav-submenu--suppliers{padding:0}
.admin-nav-channel-tier--root{display:flex;flex-direction:column;gap:0}
.admin-nav-channel-picker{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin:0;
  padding:11px 20px 11px 16px;
  font:inherit;
  font-size:.8rem;
  letter-spacing:.06em;
  text-transform:uppercase;
  font-weight:700;
  font-family:'DM Sans','Plus Jakarta Sans',system-ui,sans-serif;
  color:rgba(255,255,255,.82);
  line-height:1.35;
  background:none;
  border:none;
  border-left:3px solid transparent;
  cursor:pointer;
  text-align:left;
  transition:color .2s ease,background .2s ease,border-color .2s ease;
  -webkit-font-smoothing:antialiased;
}
.admin-nav-channel-picker:hover{
  color:#fff;
  background:rgba(255,255,255,.06);
}
.admin-nav-channel-picker--current{
  color:rgba(255,255,255,.92)!important;
  background:rgba(198,151,63,.1)!important;
  border-left-color:rgba(198,151,63,.55)!important;
}
.admin-nav-channel-picker-label{flex:1;min-width:0}
.admin-nav-channel-picker-more{
  font-size:.9rem;
  letter-spacing:0;
  color:rgba(255,255,255,.5);
  flex-shrink:0;
}
.admin-nav-channel-panels{display:contents}
.admin-nav-channel-panel{padding:0 0 8px}
.admin-nav-channel-mobile-back{
  display:none;
  width:100%;
  margin:0 0 6px;
  padding:11px 20px;
  font:inherit;
  font-size:.86rem;
  font-weight:600;
  font-family:'DM Sans','Plus Jakarta Sans',system-ui,sans-serif;
  color:rgba(255,255,255,.88);
  line-height:1.4;
  background:rgba(255,255,255,.08);
  border:none;
  border-left:3px solid transparent;
  cursor:pointer;
  text-align:left;
  -webkit-font-smoothing:antialiased;
}
.admin-nav-channel-mobile-back:hover{color:#fff;background:rgba(255,255,255,.12)}
@media(max-width:768px){
  .admin-nav-channel-mobile-back{display:flex;align-items:center;gap:8px}
}
/* Nested flyout (desktop): marketplace tools */
.admin-nav-flyout--nested{z-index:1001}
.admin-nav-flyout-header--nested{
  display:grid;
  grid-template-columns:40px 1fr 40px;
  align-items:center;
  gap:6px;
  padding:0 4px;
  height:48px;
}
.admin-nav-flyout-header--nested .admin-nav-flyout-title--nested{
  font-size:.84rem;
  letter-spacing:.02em;
  text-transform:none;
  font-weight:700;
  color:rgba(255,255,255,.96);
  text-align:center;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  padding:0 4px;
  line-height:1.3;
}
.admin-nav-flyout-back{
  width:34px;
  height:34px;
  border-radius:8px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.15);
  color:rgba(255,255,255,.85);
  cursor:pointer;
  font-size:1.1rem;
  line-height:1;
  display:flex;
  align-items:center;
  justify-content:center;
}
.admin-nav-flyout-back:hover{background:rgba(0,0,0,.28)}
@media(min-width:769px){
  .admin-nav-flyout .admin-nav-channel-mobile-back{display:none!important}
}
.admin-nav-flyout .admin-nav-channel-picker{
  padding:10px 12px 10px 10px;
  font-size:.78rem;
}
.admin-nav-logout{margin-top:8px;padding:16px 0 8px;border-top:1px solid rgba(255,255,255,.08)}
.admin-nav-logout a{display:flex;align-items:center;gap:10px;padding:11px 20px;font-size:.9rem;font-weight:500;color:rgba(255,255,255,.78)!important;border-left:3px solid transparent;transition:.22s ease;line-height:1.45;-webkit-font-smoothing:antialiased}
.admin-nav-logout a:hover{background:rgba(255,255,255,.06);color:#fff!important;border-left-color:#C6973F}
.admin-main{margin-left:260px;flex:1 1 auto;min-width:0;max-width:100%}
.admin-topbar{background:rgba(255,255,255,.92);backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid #efece6;padding:0 clamp(14px,3vw,32px);height:64px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50;min-width:0}
.admin-logout-btn{display:inline-flex;align-items:center;padding:8px 16px;font-size:.78rem;font-weight:600;font-family:'DM Sans','Plus Jakarta Sans',sans-serif;color:#111!important;text-decoration:none;border:1.5px solid #e8e6e0;border-radius:6px;background:#fff;transition:border-color .2s,color .2s,background .2s}
.admin-logout-btn:hover{border-color:#C6973F;color:#C6973F!important;background:rgba(198,151,63,.06)}
.admin-content{padding:clamp(16px,3vw,32px);min-width:0;max-width:100%;box-sizing:border-box}
.admin-page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px}
.admin-page-header h1{font-family:'Playfair Display',serif;font-size:1.8rem;font-weight:700}

/* Admin: Tools pages (Import / Export, Sitemap, Feeds) */
.admin-tools-page{max-width:980px;margin:0 auto}
.admin-tools-hero{
  margin-bottom:28px;
  padding:clamp(20px,4vw,28px) clamp(20px,3vw,32px);
  background:linear-gradient(145deg, #fdfcfa 0%, #f8f5f0 42%, #fff 100%);
  border:1px solid #efece6;
  border-radius:16px;
  box-shadow:0 14px 48px rgba(26,26,26,.06);
  position:relative;
  overflow:hidden;
}
.admin-tools-hero::before{
  content:'';
  position:absolute;left:0;top:0;bottom:0;width:4px;
  background:linear-gradient(180deg,#C6973F 0%,#c45a7e 55%,#E91E7B 100%);
  border-radius:16px 0 0 16px;
}
.admin-tools-hero__inner{padding-left:12px;position:relative}
.admin-tools-hero__kicker{
  font-size:.62rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:rgba(17,17,17,.42);
  margin-bottom:10px;
}
.admin-tools-hero h1{
  font-family:'Playfair Display',serif;font-size:clamp(1.45rem,2.8vw,1.95rem);font-weight:700;margin:0 0 14px;
  line-height:1.12;color:#111;
}
.admin-tools-hero__lede{
  margin:0;max-width:52rem;font-size:.91rem;line-height:1.65;color:rgba(17,17,17,.58);
}
.admin-tools-hero__lede code{font-size:.8rem;background:rgba(198,151,63,.12);padding:2px 7px;border-radius:5px;color:#1a1a1a;font-weight:500}
.admin-tools-hero__lede strong{color:rgba(17,17,17,.78)}
.admin-tools-hero__lede a{color:#9a7b2d;font-weight:600;text-decoration:none;border-bottom:1px solid rgba(154,123,45,.32)}
.admin-tools-hero__lede a:hover{color:#E91E7B;border-bottom-color:rgba(233,30,123,.38)}
.admin-tools-stats{display:flex;flex-wrap:wrap;gap:12px;margin-top:20px}
.admin-tools-stat{
  min-width:118px;padding:12px 18px;background:#fff;border:1px solid #efece6;border-radius:12px;
  box-shadow:0 4px 16px rgba(17,17,17,.04);
}
.admin-tools-stat b{font-family:'Playfair Display',serif;font-size:1.4rem;display:block;line-height:1.1;color:#111}
.admin-tools-stat span{font-size:.62rem;text-transform:uppercase;letter-spacing:.1em;color:var(--g4);font-weight:700}
.admin-tools-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-bottom:8px}
@media (max-width:860px){.admin-tools-grid{grid-template-columns:1fr}}
.admin-tools-panel{
  background:rgba(255,255,255,.97);
  border:1px solid #efece6;
  border-radius:14px;
  padding:clamp(18px,3vw,26px);
  box-shadow:0 8px 36px rgba(17,17,17,.055);
  min-width:0;
}
.admin-tools-panel__head{display:flex;align-items:flex-start;gap:14px;margin-bottom:14px}
.admin-tools-panel__icon{
  width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;
  font-size:1.28rem;line-height:1;flex-shrink:0;
  background:linear-gradient(145deg, rgba(198,151,63,.14) 0%, rgba(233,30,123,.09) 100%);
  border:1px solid rgba(198,151,63,.22);
}
.admin-tools-panel__title{margin:0;font-size:1.06rem;font-weight:700;font-family:'DM Sans','Plus Jakarta Sans',sans-serif;color:#111;letter-spacing:-.02em}
.admin-tools-panel__sub{margin:8px 0 0;font-size:.84rem;color:rgba(17,17,17,.52);line-height:1.55}
.admin-tools-panel__sub code{font-size:.74rem;background:#f3f0ea;padding:2px 6px;border-radius:4px;color:#222}
.admin-tools-actions{display:flex;flex-wrap:wrap;align-items:center;gap:12px;margin-top:18px}
.admin-tools-actions .btn{margin:0}
.admin-tools-filename-form{display:flex;flex-direction:column;gap:8px;margin-top:18px;max-width:min(520px,100%)}
.admin-tools-filename-form__label{font-size:.82rem;font-weight:600;color:rgba(17,17,17,.78);letter-spacing:.01em}
.admin-tools-filename-form__hint{font-size:.78rem;color:rgba(17,17,17,.48);margin:0;line-height:1.45}
.admin-tools-filename-form__hint code{font-size:.72rem;background:#f3f0ea;padding:1px 5px;border-radius:4px;color:#222}
.admin-tools-filename-form__row{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.admin-tools-filename-form__input{
  flex:1;min-width:min(200px,100%);padding:10px 12px;border:1.5px solid #e8e4dc;border-radius:8px;font-size:.88rem;
  font-family:'DM Sans','Plus Jakarta Sans',sans-serif;background:#fff;box-sizing:border-box;transition:border-color .2s,box-shadow .2s;
}
.admin-tools-filename-form__input:focus{outline:none;border-color:#c6973f;box-shadow:0 0 0 3px rgba(198,151,63,.12)}
.admin-tools-filename-form__input::placeholder{color:rgba(17,17,17,.38)}
.admin-tools-filename-form .btn{margin:0;flex-shrink:0}
.admin-tools-csv-map th,.admin-tools-csv-map td{padding:10px 14px;border-bottom:1px solid #efece6;vertical-align:middle}
.admin-tools-csv-map select{min-width:220px;max-width:100%;padding:8px 10px;border:1.5px solid #e8e4dc;border-radius:8px;font-size:.82rem;font-family:'DM Sans','Plus Jakarta Sans',sans-serif;background:#fff}
.admin-tools-csv-map select:focus{outline:none;border-color:#c6973f;box-shadow:0 0 0 3px rgba(198,151,63,.12)}
.admin-tools-file{width:100%;max-width:100%}
.admin-tools-file input[type=file]{
  width:100%;max-width:100%;box-sizing:border-box;
  padding:16px 18px;border:2px dashed #ddd8cf;border-radius:12px;background:#fdfcf9;font-size:.82rem;cursor:pointer;
  transition:border-color .2s,background .2s,box-shadow .2s;font-family:'DM Sans','Plus Jakarta Sans',sans-serif;
}
.admin-tools-file input[type=file]:hover{border-color:#C6973F;background:#fffefb;box-shadow:0 0 0 3px rgba(198,151,63,.1)}
.admin-tools-callout{
  margin:0 0 18px;padding:14px 16px;border-radius:12px;background:rgba(198,151,63,.09);border:1px solid rgba(198,151,63,.24);
  font-size:.84rem;line-height:1.55;color:rgba(17,17,17,.7);
}
.admin-tools-callout__row{display:flex;flex-wrap:wrap;align-items:flex-start;gap:14px}
.admin-tools-callout__text{flex:1;min-width:0}
.admin-tools-details{margin-top:18px;border-top:1px solid #efece6;padding-top:16px}
.admin-tools-details summary{cursor:pointer;font-weight:700;font-size:.86rem;color:#111;padding:6px 0}
.admin-tools-details pre{
  margin:12px 0 0;padding:16px 18px;background:#1a1a1e;color:#eceae6;border-radius:10px;font-size:.76rem;line-height:1.5;overflow:auto;max-height:280px;
  border:1px solid #2a2a30;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;
}
.admin-tools-meta{font-size:.84rem;color:rgba(17,17,17,.55);line-height:1.5;margin:0 0 14px}
.admin-tools-meta strong{color:#111;font-weight:600}
.admin-tools-mono-link{font-size:.8rem;word-break:break-all;line-height:1.55;margin:0 0 16px}
.admin-tools-mono-link a{color:#9a7b2d;font-weight:600;text-decoration:none;border-bottom:1px solid rgba(154,123,45,.35)}
.admin-tools-mono-link a:hover{color:#E91E7B;border-bottom-color:rgba(233,30,123,.4)}
.admin-tools-single{max-width:780px}
.admin-tools-muted{color:var(--g4);font-size:.82rem;line-height:1.5;margin:0}

.admin-tools-history-heading{
  font-family:'DM Sans','Plus Jakarta Sans',sans-serif;font-size:1.02rem;font-weight:700;color:#111;
  margin:28px 0 14px;padding-bottom:8px;border-bottom:1px solid #efece6;letter-spacing:-.02em
}

.admin-tools-import-history{margin-top:8px}
.admin-tools-import-history .table-card{overflow-x:auto;-webkit-overflow-scrolling:touch}
.admin-tools-import-table td,.admin-tools-import-table th{vertical-align:middle}
.admin-tools-import-table code{font-size:.76rem;background:#f3f0ea;padding:2px 6px;border-radius:4px}
.admin-tools-status{
  display:inline-flex;align-items:center;font-size:.62rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;
  padding:4px 10px;border-radius:999px
}
.admin-tools-status--completed{background:rgba(46,173,106,.14);color:#0d5c36;border:1px solid rgba(46,173,106,.35)}
.admin-tools-status--validation_error{background:rgba(198,151,63,.15);color:#5c4a1f;border:1px solid rgba(198,151,63,.35)}
.admin-tools-status--failed{background:rgba(220,53,69,.12);color:#991b1b;border:1px solid rgba(220,53,69,.28)}

/* Admin Tools: DataTables wrapper (sitemap / feeds / CSV history) */
.admin-dt-lite-wrap .dataTables_wrapper{padding:0}
.admin-dt-lite-wrap table.dataTable{width:100%!important;margin:0!important;border-collapse:separate!important}
.admin-dt-lite-wrap .dt-top{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:12px 16px;border-bottom:1px solid #efece6;background:linear-gradient(180deg,#ffffff 0%,#fbfaf8 100%)}
.admin-dt-lite-wrap .dt-top .dataTables_length,.admin-dt-lite-wrap .dt-top .dataTables_filter{margin:0}
.admin-dt-lite-wrap .dataTables_filter label,.admin-dt-lite-wrap .dataTables_length label{font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:rgba(17,17,17,.55);font-weight:700;display:flex;align-items:center;gap:10px}
.admin-dt-lite-wrap .dataTables_filter input{border:1.5px solid #efece6;border-radius:10px;padding:8px 12px;font-size:.84rem;outline:none;min-width:200px;background:#fff}
.admin-dt-lite-wrap .dataTables_filter input:focus{border-color:#C6973F;box-shadow:0 0 0 3px rgba(198,151,63,.14)}
.admin-dt-lite-wrap .dataTables_length select{border:1.5px solid #efece6;border-radius:10px;padding:7px 11px;font-size:.84rem;background:#fff}
.admin-dt-lite-wrap .dt-bottom{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:10px 16px;border-top:1px solid #efece6;background:linear-gradient(0deg,#ffffff 0%,#fbfaf8 100%)}
.admin-dt-lite-wrap .dataTables_info{color:rgba(17,17,17,.55);font-size:.8rem}
.admin-dt-lite-wrap .dataTables_paginate .paginate_button{border:1.5px solid #efece6!important;border-radius:10px!important;padding:6px 10px!important;margin:0 0 0 6px!important;color:#111!important;background:#fff!important;font-size:.78rem!important}
.admin-dt-lite-wrap .dataTables_paginate .paginate_button.current{border-color:#C6973F!important;background:rgba(198,151,63,.12)!important}

.stat-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-bottom:32px}
.stat-card{background:rgba(255,255,255,.9);border-radius:10px;padding:24px;border:1px solid #efece6;box-shadow:0 10px 30px rgba(17,17,17,.04)}
.stat-value{font-size:1.8rem;font-weight:700;margin-bottom:4px}
.stat-label{font-size:.8rem;color:rgba(17,17,17,.55);text-transform:uppercase;letter-spacing:.08em}
.admin-table{width:100%;border-collapse:separate;border-spacing:0;background:rgba(255,255,255,.92);border:1px solid #efece6;overflow:hidden;border-radius:10px;max-width:100%}
.admin-table th{text-align:left;padding:12px 16px;font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;font-weight:700;background:linear-gradient(180deg,#ffffff 0%,#fbfaf8 100%);color:rgba(17,17,17,.55);border-bottom:1px solid #efece6}
.admin-table td{padding:14px 16px;font-size:.82rem;border-bottom:1px solid #f1eee8}
.admin-table tr:hover td{background:rgba(198,151,63,.05)}
.admin-form{background:rgba(255,255,255,.92);border:1px solid #efece6;border-radius:10px;padding:28px;box-shadow:0 10px 30px rgba(17,17,17,.04)}
.admin-form label{display:block;font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:#111;margin-bottom:6px}
.admin-form input[type=text],.admin-form input[type=url],.admin-form input[type=number],.admin-form input[type=email],.admin-form input[type=password],.admin-form input[type=tel],.admin-form input[type=datetime-local],.admin-form input[type=date],.admin-form textarea,.admin-form select{width:100%;padding:10px 14px;border:1.5px solid #efece6;border-radius:10px;font-size:.82rem;outline:none;transition:border-color .22s ease,box-shadow .22s ease;font-family:'DM Sans','Plus Jakarta Sans',sans-serif;background:#fff}
.admin-form input:focus,.admin-form textarea:focus,.admin-form select:focus{border-color:#C6973F;box-shadow:0 0 0 3px rgba(198,151,63,.14)}
.admin-form textarea{min-height:80px;resize:vertical}
.admin-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}
.admin-form .form-group{margin-bottom:20px}
.form-actions{display:flex;gap:12px;margin-top:24px;padding-top:24px;border-top:1px solid #efece6}
.status-active{background:rgba(26,122,58,.1);color:#1a7a3a;font-size:.6rem;font-weight:700;padding:4px 10px;border-radius:20px;display:inline-block}
.status-inactive{background:rgba(192,57,43,.1);color:#c0392b;font-size:.6rem;font-weight:700;padding:4px 10px;border-radius:20px;display:inline-block}

/* ═══════════════════════════════════════════════════════════════
   ADMIN COMPONENT LIBRARY
   Buttons, form controls, alerts, badges, cards
   ═══════════════════════════════════════════════════════════════ */

/* ── Form Controls ────────────────────────────────────────── */
.form-control{width:100%;padding:10px 14px;border:1.5px solid #e8e6e0;border-radius:4px;font-size:.88rem;font-family:'DM Sans','Plus Jakarta Sans',sans-serif;outline:none;transition:border-color .2s;background:#fff;color:#111}
.form-control:focus{border-color:#C6973F;box-shadow:0 0 0 3px rgba(233,30,123,.1)}
select.form-control{appearance:auto;cursor:pointer}
textarea.form-control{resize:vertical;min-height:60px}
.form-check{display:flex;align-items:center;gap:6px;font-size:.82rem;cursor:pointer;font-weight:400;text-transform:none;letter-spacing:0}
.form-check input[type=checkbox]{accent-color:#C6973F;width:16px;height:16px;cursor:pointer}

/* ── Settings: wide form + method cards (payment / shipping) ─ */
.admin-settings-form{max-width:720px}
.admin-settings-form--wide{max-width:960px}
.admin-method-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;margin-bottom:20px;align-items:stretch}
@media(max-width:820px){.admin-method-grid{grid-template-columns:1fr}}
.admin-method-card.admin-form{margin-bottom:0;height:100%;display:flex;flex-direction:column}
.admin-method-card.admin-form .admin-form-section{flex:1}

/* ── Toggle Switch (admin settings) ───────────────────────── */
label.admin-switch{display:flex;flex-direction:row;align-items:center;gap:10px;cursor:pointer;user-select:none}
.admin-form label.admin-switch{align-items:flex-start;gap:12px;text-transform:none;letter-spacing:normal;font-size:inherit;font-weight:600;color:#111;margin-bottom:0}
.admin-switch-ui{position:relative;display:inline-block;width:44px;height:24px;flex-shrink:0;margin-top:1px}
.admin-switch-input{position:absolute;inset:0;width:44px;height:24px;margin:0;opacity:0;cursor:pointer;z-index:2}
.admin-switch-track{position:absolute;inset:0;border-radius:999px;background:#e9e5de;border:1px solid #ddd8cf;pointer-events:none;z-index:0;display:flex;align-items:center;padding:2px;transition:background .18s,border-color .18s,box-shadow .18s}
.admin-switch-thumb{width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 2px 8px rgba(17,17,17,.12);transform:translateX(0);transition:transform .18s}
.admin-switch-input:checked + .admin-switch-track{background:linear-gradient(180deg,#d4a84b 0%,#C6973F 100%);border-color:#a67f2e}
.admin-switch-input:checked + .admin-switch-track .admin-switch-thumb{transform:translateX(20px)}
.admin-switch-input:focus + .admin-switch-track{box-shadow:0 0 0 3px rgba(198,151,63,.2)}
.admin-switch-text{font-size:.84rem;line-height:1.4;font-weight:600;color:#111;padding-top:2px}
.admin-switch-hint{display:block;font-size:.72rem;font-weight:400;color:rgba(17,17,17,.5);margin-top:4px;line-height:1.35}

/* ── Form Sections ────────────────────────────────────────── */
.admin-form-section{margin-bottom:0}
.admin-form-section+.admin-form-section{margin-top:28px;padding-top:28px;border-top:1px solid #e8e6e0}
.admin-form-section h4{font-family:'DM Sans','Plus Jakarta Sans',sans-serif;font-size:.95rem;font-weight:700;margin-bottom:20px;color:#111}

/* ── Table Card Wrapper ───────────────────────────────────── */
.table-card{
  background:#fff;
  border:1px solid #e8e6e0;
  border-radius:6px;
  max-width:100%;
  box-sizing:border-box;
  overflow-x:auto;
  overflow-y:hidden;
  -webkit-overflow-scrolling:touch;
}
.table-card .dataTables_wrapper{max-width:100%;min-width:0}
.table-card-header{
  padding:14px 18px;
  border-bottom:1px solid rgba(17,17,17,.06);
  background:linear-gradient(180deg,#fff 0%,#faf9f7 100%);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.table-card-header h3{
  margin:0;
  font-family:'Plus Jakarta Sans','DM Sans',sans-serif;
  font-size:.92rem;
  font-weight:900;
  color:#111;
  letter-spacing:-.01em;
}

/* DataTables (admin) */
.dataTables_wrapper{width:100%}
.dt-responsive{width:100%}

/* ── Buttons ──────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px;border-radius:4px;font-size:.82rem;font-weight:600;font-family:'DM Sans','Plus Jakarta Sans',sans-serif;cursor:pointer;transition:all .2s;text-decoration:none;border:1.5px solid transparent;line-height:1.4}
.btn--primary{background:#C6973F;color:#111;border-color:#C6973F}
.btn--primary:hover{background:#b8892e;border-color:#b8892e}
.btn--dark{background:#111;color:#fff;border-color:#111}
.btn--dark:hover{background:#C6973F;color:#111;border-color:#C6973F}
.btn--ghost{background:none;color:#7a7670;border-color:#e8e6e0}
.btn--ghost:hover{border-color:#C6973F;color:#C6973F}
.btn--outline{background:none;color:#111;border-color:#e8e6e0}
.btn--outline:hover{border-color:#C6973F;color:#C6973F}
.btn--sm{padding:6px 14px;font-size:.78rem}
.btn--lg{padding:14px 28px;font-size:.88rem}
.btn--full{width:100%}
.btn-admin-action{padding:6px 10px;font-size:.78rem}

/* ── Alerts ───────────────────────────────────────────────── */
/* Block layout: mixed text + <strong> must not become separate flex items (narrow sidebars broke into vertical columns). */
.alert{padding:14px 20px;border-radius:6px;font-size:.85rem;display:block;line-height:1.55;margin-bottom:20px;font-family:'DM Sans','Plus Jakarta Sans',sans-serif}
.alert .fas,.alert .far,.alert .fab{margin-right:8px;vertical-align:-.06em}
.alert--success{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}
.alert--error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}

/* ── Status Badges ────────────────────────────────────────── */
.status-badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:.68rem;font-weight:700;letter-spacing:.03em;white-space:nowrap}
.status-confirmed{background:#ecfdf5;color:#065f46}
.status-processing{background:#eff6ff;color:#1e40af}
.status-pending{background:#fff7ed;color:#9a3412}
.status-dispatched{background:#f0fdf4;color:#166534}
.status-delivered{background:#ecfdf5;color:#065f46}
.status-completed{background:#ecfdf5;color:#047857}
.status-cancelled{background:#fef2f2;color:#991b1b}
.status-refunded{background:#faf5ff;color:#6b21a8}
.status-payment_failed{background:#fef2f2;color:#991b1b}

/* ── Order success (/order-success.php) ───────────────────── */
.section--order-success{background:linear-gradient(180deg,#f8f7f4 0%,#fff 42%);padding-top:28px;padding-bottom:56px}
.order-success{max-width:820px;margin:0 auto}
.order-success__hero{text-align:center;margin-bottom:32px}
.order-success__badge{width:92px;height:92px;margin:0 auto 22px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,rgba(78,205,196,.28),rgba(46,173,106,.12));box-shadow:0 10px 32px rgba(46,125,50,.14)}
.order-success__title{font-family:'Playfair Display',serif;font-size:clamp(1.65rem,3.5vw,2.1rem);font-weight:700;color:var(--black);margin:0 0 12px;line-height:1.2}
.order-success__lead{max-width:520px;margin:0 auto;font-size:1.02rem;color:var(--text-light);line-height:1.55}
.order-success__grid{display:grid;gap:18px;margin-bottom:22px}
@media (min-width:880px){
  .order-success__grid--2{grid-template-columns:1fr 1fr;align-items:start}
}
.order-success__card{background:#fff;border:1px solid var(--grey-200);border-radius:14px;padding:22px 24px 24px;box-shadow:0 6px 28px rgba(26,26,26,.05)}
.order-success__card--lines{margin-bottom:22px}
.order-success__card--notes{margin-bottom:22px}
.order-success__card-title{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:.95rem;font-weight:800;color:var(--black);margin:0 0 16px;letter-spacing:.02em}
.order-success__subhead{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin:18px 0 8px}
.order-success__dl{display:grid;gap:14px}
.order-success__dl dt{font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);font-weight:700;margin-bottom:4px}
.order-success__dl dd{margin:0;font-size:.95rem;color:var(--black);line-height:1.55}
.order-success__dl dd a{color:var(--pink);text-decoration:underline;text-underline-offset:2px}
.order-success__dl--compact{gap:12px}
.order-success__address{font-size:.92rem;line-height:1.55;color:#333}
.order-success__mono{font-family:ui-monospace,'Cascadia Code','Segoe UI Mono',monospace;font-size:1rem}
.order-success__totals{margin-top:18px;padding-top:16px;border-top:1px dashed var(--grey-300)}
.order-success__totals-row{display:flex;justify-content:space-between;align-items:center;font-size:.88rem;padding:5px 0;color:#444}
.order-success__totals-row--muted{color:var(--text-light);font-size:.84rem}
.order-success__totals-row--total{margin-top:8px;padding-top:10px;border-top:1px dashed var(--grey-300);font-weight:800;font-size:1rem;color:var(--black)}
.order-success__lines{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:0}
.order-success__line{display:grid;grid-template-columns:72px 1fr auto;gap:16px;align-items:start;padding:18px 0;border-bottom:1px solid #f0eeec}
.order-success__line:last-child{border-bottom:none;padding-bottom:4px}
.order-success__line-img{display:block;width:72px;height:72px;border-radius:10px;overflow:hidden;border:1px solid #eee;background:var(--grey-100);flex-shrink:0}
.order-success__line-img img{width:100%;height:100%;object-fit:cover;display:block}
.order-success__line-img--static{cursor:default}
.order-success__line-title{font-weight:700;font-size:.95rem;line-height:1.3}
.order-success__line-title a{color:var(--black);text-decoration:none}
.order-success__line-title a:hover{color:var(--pink)}
.order-success__line-meta{font-size:.8rem;color:var(--text-muted);margin-top:4px}
.order-success__line-bd{margin-top:8px;font-size:.78rem}
.order-success__line-foot{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px;font-size:.8rem;color:var(--text-light)}
.order-success__line-total{font-weight:800;font-size:1rem;color:var(--black);text-align:right;padding-top:2px}
.order-success__notes{font-size:.9rem;color:#444;line-height:1.55;margin:0}
.order-success__actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:8px;padding-top:8px}
@media (max-width:640px){
  .order-success__line{gap:12px;grid-template-columns:56px minmax(0,1fr) auto}
  .order-success__line-img,.order-success__line-img img{width:56px;height:56px}
  .order-success__line-total{font-size:.92rem}
}

/* ── Inventory Badges ─────────────────────────────────────── */
.inventory-badge{display:inline-flex;align-items:center;justify-content:center;min-width:32px;padding:3px 8px;border-radius:4px;font-size:.78rem;font-weight:700}
.inv-ok{background:#ecfdf5;color:#065f46}
.inv-low{background:#fff7ed;color:#9a3412}
.inv-out{background:#fef2f2;color:#991b1b}

/* ── Search Input ─────────────────────────────────────────── */
.table-search{padding:8px 14px;border:1.5px solid #e8e6e0;border-radius:4px;font-size:.85rem;font-family:'DM Sans','Plus Jakarta Sans',sans-serif;outline:none;min-width:200px;transition:border-color .2s}
.table-search:focus{border-color:#C6973F}

/* ── Sort Select ──────────────────────────────────────────── */
.sort-select{padding:8px 12px;border:1.5px solid #e8e6e0;border-radius:4px;font-size:.85rem;font-family:'DM Sans','Plus Jakarta Sans',sans-serif;outline:none;cursor:pointer;background:#fff}
.sort-select:focus{border-color:#C6973F}

/* ── Image Upload ─────────────────────────────────────────── */
.image-upload-area{border:2px dashed #e8e6e0;border-radius:6px;padding:24px;text-align:center;cursor:pointer;transition:border-color .2s}
.image-upload-area:hover{border-color:#C6973F}

/* ── Admin Nav Section ────────────────────────────────────── */
.admin-nav-section{margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.06)}
.admin-nav-section:last-child{border-bottom:none}

/* ── Responsive Grid Helpers ──────────────────────────────── */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.mt-lg{margin-top:20px}

/* ── Admin Dashboard (index) ──────────────────────────────── */
.dash-kpis{
  display:grid;
  grid-template-columns:repeat(6,minmax(0,1fr));
  gap:18px;
  margin-bottom:24px;
}
.dash-kpi{
  background:linear-gradient(180deg,#fff 0%,#faf9f7 100%);
  border:1px solid #e8e6e0;
  border-radius:12px;
  padding:18px 18px 14px;
  box-shadow:0 2px 18px rgba(17,17,17,.03);
  min-width:0;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.dash-kpi:hover{transform:translateY(-1px);box-shadow:0 10px 34px rgba(17,17,17,.06);border-color:rgba(198,151,63,.35)}
.dash-kpi--warn{border-color:rgba(154,52,18,.25);background:linear-gradient(180deg,#fff 0%,#fff7ed 100%)}
.dash-kpi__top{display:flex;gap:12px;align-items:center}
.dash-kpi__icon{
  width:42px;height:42px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
  color:#111;
  border:1px solid rgba(17,17,17,.06);
}
.dash-kpi__icon--gold{background:rgba(198,151,63,.18)}
.dash-kpi__icon--blue{background:rgba(30,64,175,.12)}
.dash-kpi__icon--green{background:rgba(22,101,52,.12)}
.dash-kpi__icon--purple{background:rgba(107,33,168,.12)}
.dash-kpi__icon--pink{background:rgba(233,30,123,.12)}
.dash-kpi__icon--orange{background:rgba(154,52,18,.12)}
.dash-kpi__label{font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;font-weight:800;color:rgba(17,17,17,.6)}
.dash-kpi__value{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-weight:900;letter-spacing:-.02em;font-size:1.35rem;color:#111;line-height:1.05;margin-top:6px}
.dash-kpi__sub{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  margin-top:12px;padding-top:12px;border-top:1px solid rgba(17,17,17,.06);
  font-size:.78rem;color:rgba(17,17,17,.55);
  min-width:0;
}
.dash-kpi__sub span{min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dash-kpi__link{font-size:.78rem;font-weight:800;color:#C6973F;text-decoration:none;white-space:nowrap}
.dash-kpi__link:hover{text-decoration:underline}
.dash-delta{font-weight:900;font-size:.72rem;letter-spacing:.02em;white-space:nowrap}
.dash-delta--up{color:#166534}
.dash-delta--down{color:#b91c1c}
.dash-delta--flat{color:rgba(17,17,17,.35)}

.dash-grid{display:grid;gap:24px}
.dash-grid--2{grid-template-columns:repeat(2,minmax(0,1fr))}
.dash-card .table-card-header{align-items:baseline}
.dash-card__hint{font-size:.78rem;color:rgba(17,17,17,.45)}
.dash-chart{padding:18px 20px;height:260px}
.dash-links{padding:18px 20px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.dash-link{
  display:flex;align-items:center;gap:10px;
  border:1px solid #e8e6e0;background:#fff;border-radius:10px;
  padding:12px 12px;
  text-decoration:none;color:#111;
  font-weight:800;font-size:.86rem;
  transition:border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}
.dash-link:hover{border-color:rgba(233,30,123,.28);box-shadow:0 10px 26px rgba(17,17,17,.06);transform:translateY(-1px)}
.dash-link span:first-child{width:26px;height:26px;border-radius:8px;background:rgba(17,17,17,.05);display:flex;align-items:center;justify-content:center}

@media(max-width:900px){
  .grid-2,.grid-3{grid-template-columns:1fr}
  .admin-form .form-row{grid-template-columns:1fr}
}

@media(max-width:1200px){
  .dash-kpis{grid-template-columns:repeat(3,minmax(0,1fr))}
}
@media(max-width:900px){
  .dash-kpis{grid-template-columns:repeat(2,minmax(0,1fr))}
  .dash-grid--2{grid-template-columns:1fr}
  .dash-chart{height:240px}
}
@media(max-width:520px){
  .dash-kpis{grid-template-columns:1fr}
  .dash-links{grid-template-columns:1fr}
}

/* Cart drawer */
.cart-drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:2000;opacity:0;pointer-events:none;transition:opacity .25s}
.cart-drawer-overlay.open{opacity:1;pointer-events:all}
.cart-drawer{position:fixed;right:0;top:0;bottom:0;width:420px;background:#fff;z-index:2001;transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);overflow-y:auto;display:flex;flex-direction:column}
.cart-drawer.open{transform:translateX(0)}
.cart-drawer-header{padding:24px;border-bottom:1px solid #e8e6e0;display:flex;align-items:center;justify-content:space-between}
.cart-drawer-header h4{font-family:'Playfair Display',serif;font-size:1.3rem;font-weight:700}
.cart-drawer-items{flex:1;min-height:0;display:flex;flex-direction:column;padding:0;overflow:hidden}
.cart-drawer-lines{flex:1;min-height:0;overflow-y:auto;padding:16px 24px 8px}
.cart-drawer-promo{flex-shrink:0;padding:14px 24px 16px;border-top:1px solid #edebe7;background:#fafaf8}
.cart-drawer-promo[hidden]{display:none !important}
.cart-drawer-promo__title{font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#666;margin:0 0 10px;font-family:'Plus Jakarta Sans','DM Sans',sans-serif}
.coupon-form--drawer{margin:0}
.coupon-form--drawer input{padding:10px 12px;font-size:.82rem}
.cart-drawer-totals{flex-shrink:0;padding:12px 24px 16px;border-top:1px solid #e8e6e0;background:#f4f4f2}
.cart-drawer-totals[hidden]{display:none !important}
.cart-drawer-totals__row{display:flex;justify-content:space-between;align-items:center;gap:12px;font-size:.82rem;padding:5px 0;color:#444}
.cart-drawer-totals__row--discount{font-size:.78rem}
.cart-drawer-totals__row--discount[hidden]{display:none !important}
.cart-drawer-totals__row--total{margin-top:6px;padding-top:10px;border-top:1px dashed #ddd;font-weight:800;font-size:.92rem;color:#111}
.cart-drawer-footer{padding:24px;border-top:1px solid #e8e6e0;background:#f4f4f2}
.cart-drawer .cart-drawer-line__actions.cart-item__actions-btns .cart-item-edit,
.cart-drawer .cart-drawer-line__actions.cart-item__actions-btns .cart-item-remove{width:36px;height:36px}
.cart-drawer .cart-drawer-line__actions.cart-item__actions-btns .cart-item-edit svg,
.cart-drawer .cart-drawer-line__actions.cart-item__actions-btns .cart-item-remove svg{width:16px;height:16px}

/* ── Full basket page (/cart, cart.php) ───────────────────── */
.section--cart{background:var(--g1);min-height:50vh}
.section--cart .container{max-width:1600px}
.cart-page__title{font-family:'Playfair Display',serif;font-size:clamp(1.75rem,3vw,2.25rem);font-weight:700;color:var(--black);margin:0 0 8px;line-height:1.2}
.cart-page__title span{font-family:var(--font-body);font-size:1rem;font-weight:400;color:var(--text-light)}
.cart-layout{display:grid;grid-template-columns:1fr minmax(280px,380px);gap:40px;align-items:start}
/* Left column: line items + promo (summary stays on the right) */
.cart-layout__main{display:flex;flex-direction:column;gap:24px;min-width:0}
.cart-promo-section{background:var(--white);border:1px solid var(--grey-200);border-radius:12px;padding:22px 24px 24px;box-shadow:0 4px 24px rgba(26,26,26,.04)}
.cart-promo-section__title{font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:700;margin:0 0 8px;color:var(--black);line-height:1.25}
.cart-promo-section__hint{font-size:.82rem;color:var(--text-light);margin:0 0 14px;line-height:1.45}
.coupon-form--cart-main{margin:0}
/* Stretch summary column to full row height so position:sticky has room to work while scrolling long baskets */
.cart-layout__aside{align-self:stretch;display:flex;flex-direction:column;min-width:0}
.cart-items{background:var(--white);border:1px solid var(--grey-200);border-radius:12px;padding:8px 24px 24px;box-shadow:0 4px 24px rgba(26,26,26,.04)}
.cart-item{display:grid;grid-template-columns:108px 1fr auto;gap:20px;padding:24px 0;border-bottom:1px solid var(--grey-200);align-items:start}
.cart-item:last-child{border-bottom:none}
.cart-item-image{width:108px;height:108px;border-radius:10px;overflow:hidden;background:var(--grey-100);border:1px solid var(--grey-200);flex-shrink:0}
.cart-item-image img{width:100%;height:100%;object-fit:cover}
.cart-item-name{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:1.05rem;font-weight:700;margin:0 0 6px;line-height:1.3}
.cart-item-name a{color:var(--black);text-decoration:none}
.cart-item-name a:hover{color:var(--pink)}
.cart-item-variant{font-size:.85rem;color:var(--text-light);margin:0 0 8px;line-height:1.4}
.cart-price-breakdown{list-style:none;margin:8px 0 0;padding:8px 0 0;font-size:.78rem;color:var(--text-muted);border-top:1px dashed var(--grey-200);max-width:100%}
.cart-price-breakdown__row{display:flex;justify-content:space-between;gap:12px;align-items:baseline;line-height:1.45;margin:0 0 3px}
.cart-price-breakdown__lbl{flex:1;min-width:0}
.cart-price-breakdown__amt{font-variant-numeric:tabular-nums;white-space:nowrap;color:var(--text-light)}
.price-bd-wrap{margin-top:4px}
.price-bd-toggle{display:inline-flex;align-items:center;margin:0;padding:0;font:inherit;font-size:.78rem;font-weight:600;color:var(--text-muted);background:none;border:none;cursor:pointer;text-decoration:underline;text-underline-offset:2px;letter-spacing:.01em}
.price-bd-toggle:hover{color:var(--pink)}
.price-bd-toggle:focus-visible{outline:2px solid var(--gold);outline-offset:2px;border-radius:2px}
.price-bd-panel{margin-top:4px}
.price-bd-panel[hidden]{display:none!important}
.co__price-breakdown{margin-top:8px;padding-top:8px;border-top:1px dashed var(--grey-200);font-size:.76rem}
.acc-price-breakdown{margin-top:6px;padding-top:6px;border-top:1px dashed var(--grey-200);font-size:.78rem}
.cart-item-price{font-size:.88rem;color:var(--text-muted);margin:0 0 4px}
.cart-item-total{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:1.15rem;font-weight:800;color:var(--black)}
.cart-item__actions{display:flex;flex-direction:column;align-items:flex-end;gap:10px;text-align:right}
.cart-item-remove{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border:1.5px solid var(--grey-200);border-radius:8px;background:var(--white);color:var(--error);cursor:pointer;transition:background .15s,border-color .15s,color .15s,box-shadow .15s}
.cart-item-remove:hover{background:rgba(220,53,69,.08);border-color:var(--error);color:#b02a37;box-shadow:0 0 0 3px rgba(220,53,69,.12)}
.cart-item-remove:focus-visible{outline:2px solid var(--pink);outline-offset:2px}
.cart-item-remove svg{display:block;flex-shrink:0}

/* Cart page: loading overlay while qty/remove AJAX runs */
.cart-page-shell{position:relative}
.cart-page-shell.is-busy .cart-layout{pointer-events:none;user-select:none}
.cart-page-busy{position:absolute;inset:0;z-index:40;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.78);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);transition:opacity .2s}
.cart-page-busy[hidden]{display:none !important}
.cart-page-busy__inner{display:flex;flex-direction:column;align-items:center;gap:14px;padding:24px;text-align:center}
.cart-page-busy__spinner{width:42px;height:42px;border:3px solid var(--grey-200);border-top-color:var(--pink);border-radius:50%;animation:ghfo-cart-spin .65s linear infinite}
.cart-page-busy__text{margin:0;font-size:.88rem;font-weight:600;color:var(--black-s);font-family:'Plus Jakarta Sans','DM Sans',sans-serif}
@keyframes ghfo-cart-spin{to{transform:rotate(360deg)}}
@media (prefers-reduced-motion:reduce){
  .cart-page-busy__spinner{animation:none;border-color:var(--pink);opacity:.85}
}
.cart-summary-card{background:var(--white);border:1px solid var(--grey-200);border-radius:12px;padding:0;display:flex;flex-direction:column;position:sticky;top:76px;align-self:flex-start;width:100%;box-shadow:0 8px 32px rgba(26,26,26,.06);z-index:10;max-height:calc(100vh - 88px);overflow:hidden;-webkit-overflow-scrolling:touch}
.cart-summary-card__body{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding:28px;padding-bottom:20px;-webkit-overflow-scrolling:touch}
/* Sticks to top of the scroll area while delivery / spend-more content scrolls beneath */
.cart-summary-card__sticky-summary{position:sticky;top:0;z-index:3;margin:0 0 8px;padding-bottom:4px;background:var(--white);box-shadow:0 10px 20px -6px rgba(26,26,26,.1)}
.cart-summary-card__foot{flex-shrink:0;padding:16px 28px 24px;border-top:1px solid var(--grey-200);background:var(--white);box-shadow:0 -10px 28px rgba(26,26,26,.05)}
.cart-summary-card h3{font-family:'Playfair Display',serif;font-size:1.2rem;font-weight:700;margin:0 0 16px;padding-bottom:16px;border-bottom:1px solid var(--grey-200)}
.summary-row{display:flex;justify-content:space-between;align-items:center;gap:16px;font-size:.92rem;padding:10px 0;color:var(--black-s)}
.summary-row.total{margin-top:8px;padding-top:16px;border-top:2px solid var(--black);font-size:1.15rem;font-weight:800;color:var(--black)}
.coupon-form{display:flex;gap:10px;margin:20px 0 8px}
.coupon-form input{flex:1;min-width:0;padding:12px 14px;border:1.5px solid var(--grey-200);border-radius:8px;font-size:.9rem;font-family:var(--font-body);outline:none;transition:border-color .2s,box-shadow .2s}
.coupon-form input:focus{border-color:var(--pink);box-shadow:0 0 0 3px rgba(233,30,123,.1)}

/* Shipping methods (cart + checkout) */
.shipping-methods{margin:16px 0 0}
.shipping-methods__headline{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:.95rem;font-weight:700;color:var(--black);margin:0 0 8px;line-height:1.35}
.shipping-methods__subline{font-size:.82rem;color:var(--text-light);margin:0 0 14px;line-height:1.45}
.shipping-methods__list{display:flex;flex-direction:column;gap:10px}
.shipping-method{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;padding:14px 16px;border:1.5px solid var(--grey-200);border-radius:10px;background:var(--white);transition:border-color .2s,box-shadow .2s}
.shipping-method.is-selected{border-color:var(--pink);box-shadow:0 0 0 3px rgba(233,30,123,.08)}
.shipping-method__body{flex:1;min-width:0}
.shipping-method__badge{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--pink);margin-bottom:6px}
.shipping-method__title{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:.9rem;font-weight:700;color:var(--black);margin:0 0 4px;line-height:1.3}
.shipping-method__desc{font-size:.8rem;color:var(--text-light);line-height:1.4;margin:0}
.shipping-method__price{font-family:'Plus Jakarta Sans','DM Sans',sans-serif;font-size:1rem;font-weight:800;color:var(--black);flex-shrink:0;white-space:nowrap}

.cart-ship-calc{margin:20px 0 0;padding:18px;border:1px solid var(--grey-200);border-radius:10px;background:var(--g1)}
.cart-ship-calc__title{font-family:'Playfair Display',serif;font-size:1.05rem;font-weight:700;margin:0 0 8px;color:var(--black)}
.cart-ship-calc__hint{font-size:.8rem;color:var(--text-light);margin:0 0 14px;line-height:1.45}
.cart-ship-calc__hint a{color:var(--pink);font-weight:600;text-decoration:none}
.cart-ship-calc__hint a:hover{text-decoration:underline}
.cart-ship-calc__row{display:flex;gap:10px;align-items:stretch;margin-bottom:4px}
.cart-ship-calc__input{flex:1;min-width:0;padding:11px 14px;border:1.5px solid var(--grey-200);border-radius:8px;font-size:.9rem;font-family:var(--font-body);outline:none;background:var(--white)}
.cart-ship-calc__input:focus{border-color:var(--pink);box-shadow:0 0 0 3px rgba(233,30,123,.08)}
.cart-ship-calc__msg{font-size:.82rem;margin:10px 0 0;line-height:1.4}
.cart-ship-calc__msg--ok{color:var(--success)}
.cart-ship-calc__msg--err{color:var(--error)}
.shipping-methods--cart .shipping-methods__headline{margin-top:4px}
.qty-selector{display:inline-flex;align-items:stretch;border:1.5px solid var(--grey-200);border-radius:8px;overflow:hidden;background:var(--white)}
.qty-btn{width:44px;min-height:44px;border:none;background:var(--white);cursor:pointer;font-size:1.15rem;font-weight:600;color:var(--black);transition:background .15s;line-height:1}
.qty-btn:hover{background:var(--g1)}
.qty-input{font-family:var(--font-body);font-size:.95rem;font-weight:600;color:var(--black)}
.cart-empty{text-align:center;padding:64px 28px;background:var(--white);border:1px solid var(--grey-200);border-radius:12px;max-width:520px;margin:0 auto;box-shadow:0 8px 32px rgba(26,26,26,.05)}
.cart-empty .cart-empty__icon{font-size:3.5rem;color:var(--grey-200);margin-bottom:20px;line-height:1}
.cart-empty h3{font-family:'Playfair Display',serif;font-size:1.35rem;font-weight:700;margin:0 0 10px;color:var(--black)}
.cart-empty p{color:var(--text-light);margin:0 0 24px;font-size:1rem;line-height:1.5}
.mt-sm{margin-top:10px}
@media(max-width:900px){
  .cart-layout{grid-template-columns:1fr;gap:28px}
  .cart-layout__aside{align-self:stretch;order:-1}
  .cart-summary-card{position:static;top:auto;max-height:none;overflow:visible}
  .cart-summary-card__body{overflow:visible;min-height:0}
  .cart-summary-card__sticky-summary{position:relative;z-index:auto;box-shadow:none;margin-bottom:0}
  .cart-summary-card__foot{box-shadow:none}
}
@media(max-width:640px){
  .cart-item{grid-template-columns:88px 1fr;grid-template-rows:auto auto}
  .cart-item > div:last-child{grid-column:1/-1;display:flex;flex-direction:row;justify-content:space-between;align-items:center;padding-top:8px;border-top:1px dashed var(--grey-200);margin-top:8px}
  .cart-items{padding:8px 16px 20px}
}
.section--cart .btn--primary{background:var(--pink);border-color:var(--pink);color:#fff}
.section--cart .btn--primary:hover{background:var(--pink-dk);border-color:var(--pink-dk);color:#fff}
.section--cart .btn--dark{background:var(--black);border-color:var(--black);color:#fff}
.section--cart .btn--dark:hover{background:var(--black-s);border-color:var(--black-s);color:#fff}

/* Toast */
#toast-container{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:12px}
.toast{display:flex;align-items:center;gap:12px;background:#111;color:#fff;padding:14px 20px;border-radius:2px;box-shadow:0 12px 48px rgba(0,0,0,.18);min-width:280px;font-size:.82rem}
.toast--success{border-left:3px solid #1a7a3a}
.toast--error{border-left:3px solid #c0392b}

/* Modal (confirm/alert) */
.ghfo-modal-overlay{
  position:fixed;inset:0;
  background:rgba(0,0,0,.55);
  z-index:10050;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
}
/* [hidden] alone is overridden by display:flex above — must win when dialog is closed */
.ghfo-modal-overlay[hidden]{
  display:none !important;
}
.ghfo-modal{
  width:min(520px, 100%);
  background:#fff;
  border-radius:14px;
  border:1px solid rgba(17,17,17,.10);
  box-shadow:0 30px 90px rgba(0,0,0,.35);
  overflow:hidden;
}
.ghfo-modal__head{
  padding:14px 16px;
  border-bottom:1px solid rgba(17,17,17,.08);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  background:linear-gradient(180deg,#fff 0%,#faf9f7 100%);
}
.ghfo-modal__title{
  font-family:'Plus Jakarta Sans','DM Sans',sans-serif;
  font-weight:900;
  letter-spacing:-.01em;
  color:#111;
}
.ghfo-modal__x{
  width:36px;height:36px;border-radius:10px;
  border:1px solid rgba(17,17,17,.10);
  background:#fff;
  cursor:pointer;
  font-size:1.35rem;
  line-height:1;
  color:rgba(17,17,17,.7);
}
.ghfo-modal__x:hover{border-color:rgba(233,30,123,.35);color:#E91E7B}
.ghfo-modal__body{padding:16px 16px 10px;color:rgba(17,17,17,.72);font-size:.92rem;line-height:1.55}
.ghfo-modal__foot{
  padding:12px 16px 16px;
  display:flex;
  justify-content:flex-end;
  gap:10px;
}
.ghfo-modal-btn--danger{
  border-color:var(--error)!important;
  color:var(--error)!important;
  background:#fff!important;
}
.ghfo-modal-btn--danger:hover{
  background:rgba(192,57,43,.08)!important;
  border-color:var(--error)!important;
}

@media(max-width:1100px){
  .admin-content{padding:18px 14px}
}
@media(max-width:768px){
  .admin-sidebar{transform:translateX(-100%)}
  .admin-main{margin-left:0;max-width:100vw}
  .cart-drawer{width:100%}
  .stat-cards{grid-template-columns:1fr}

  /* Mobile: keep submenu inline (accordion) instead of flyout */
  .admin-nav-submenu{display:block;max-height:0;overflow:hidden;transition:max-height .25s ease}
  .admin-nav-section.open .admin-nav-submenu{max-height:900px}
  .admin-nav-section.open .admin-nav-submenu--channels,
  .admin-nav-section.open .admin-nav-submenu--suppliers{max-height:1400px}
  .admin-nav-flyout{display:none!important}
}

/* ═══════════════════════════════════════════════════════════════
   PRODUCT SPECIFICATIONS — Frontend
   ═══════════════════════════════════════════════════════════════ */

.spec-layout{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:28px;align-items:start}
@media(max-width:600px){.spec-layout{grid-template-columns:1fr;gap:20px}}

.spec-group{background:var(--white);border:1px solid var(--g2);border-radius:10px;overflow:hidden}
.spec-group__header{display:flex;align-items:center;gap:10px;padding:16px 22px;border-bottom:1px solid var(--g2);background:linear-gradient(135deg,#fdfcfa 0%,#f7f5f1 100%)}
.spec-group__icon{font-size:1.15rem;width:32px;height:32px;background:rgba(233,30,123,.1);border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.spec-group__title{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;color:var(--black);font-family:'DM Sans','Plus Jakarta Sans',sans-serif}

.spec-table{width:100%;border-collapse:collapse}
.spec-table tr{border-bottom:1px solid var(--g1)}
.spec-table tr:last-child{border-bottom:none}
.spec-table__label{padding:11px 22px;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--g4);font-weight:600;width:40%;vertical-align:top;white-space:nowrap}
.spec-table__value{padding:11px 22px;font-size:.84rem;font-weight:500;color:var(--black);line-height:1.5}

.spec-unit{font-size:.72rem;color:var(--g3);font-weight:400}
.spec-yes{color:#0d6832;font-weight:600}
.spec-no{color:#b91c1c;font-weight:500}

.spec-colours{display:flex;flex-wrap:wrap;gap:6px}
.spec-colour-chip{display:inline-block;padding:3px 10px;border-radius:20px;font-size:.75rem;font-weight:500;background:var(--g1);color:var(--black);border:1px solid var(--g2)}

/* Spec quick-view strip on product info (above tabs) */
.spec-highlights{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px;padding-top:14px;border-top:1px solid var(--g2)}
.spec-highlight{font-size:.75rem;color:var(--g4);display:flex;align-items:center;gap:4px;background:var(--g1);padding:4px 10px;border-radius:4px}
.spec-highlight strong{color:var(--black);font-weight:600}

/* ═══════════════════════════════════════════════════════════════
   MY ACCOUNT — storefront dashboard
   ═══════════════════════════════════════════════════════════════ */
.acc-page{background:linear-gradient(180deg,var(--g1) 0%,#f3f1ec 50%,var(--g1) 100%);padding:28px 0 72px;min-height:calc(100vh - 120px)}
.acc-page__inner{max-width:1320px;margin:0 auto}
.acc-bread{font-family:'DM Sans','Plus Jakarta Sans',sans-serif;font-size:13px;color:var(--g4);margin-bottom:22px;display:flex;align-items:center;flex-wrap:wrap;gap:6px}
.acc-bread a{color:var(--g4);text-decoration:none;transition:color .2s}
.acc-bread a:hover{color:var(--pink)}
.acc-bread span{color:var(--g3)}
.acc-layout{display:grid;grid-template-columns:minmax(0,268px) minmax(0,1fr);gap:28px;align-items:start}
.acc-sidebar{background:var(--white);border-radius:12px;border:1px solid var(--g2);box-shadow:0 4px 24px rgba(26,26,26,.04);overflow:hidden;position:sticky;top:76px}
.acc-profile{padding:26px 22px;text-align:center;border-bottom:1px solid var(--g2);background:linear-gradient(165deg,#fff 0%,#faf9f7 100%)}
.acc-avatar{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--pink) 0%,#c4176a 100%);display:flex;align-items:center;justify-content:center;font-size:1.35rem;font-weight:800;color:#fff;margin:0 auto 14px;font-family:'Plus Jakarta Sans',sans-serif;letter-spacing:-.02em;box-shadow:0 8px 24px rgba(233,30,123,.25)}
.acc-profile__name{font-family:'Plus Jakarta Sans',sans-serif;font-size:1rem;font-weight:700;color:var(--black);display:block;margin-bottom:4px}
.acc-profile__email{font-size:.78rem;color:var(--g4);line-height:1.4;word-break:break-all}
.acc-menu{padding:10px 0 12px}
.acc-menu__link{display:flex;align-items:center;gap:12px;padding:12px 20px;font-size:.86rem;font-weight:600;color:var(--black);text-decoration:none;transition:background .2s,color .2s;border-left:3px solid transparent;font-family:'DM Sans','Plus Jakarta Sans',sans-serif}
.acc-menu__link:hover{background:var(--g1);color:var(--pink)}
.acc-menu__link--active{background:rgba(233,30,123,.06);color:var(--pink);border-left-color:var(--pink)}
.acc-menu__ico{flex-shrink:0;color:var(--g3);transition:color .2s}
.acc-menu__link:hover .acc-menu__ico,.acc-menu__link--active .acc-menu__ico{color:var(--pink)}
.acc-menu__out{margin-top:6px;padding-top:10px;border-top:1px solid var(--g2)}
.acc-menu__link--out{color:var(--g4);font-weight:600}
.acc-menu__link--out:hover{color:#b91c1c;background:#fef2f2}
.acc-main{min-width:0}
.acc-alert{margin-bottom:22px}
.acc-head{margin-bottom:26px}
.acc-head__title{font-family:'Playfair Display',serif;font-size:clamp(1.65rem,3vw,2.1rem);font-weight:700;color:var(--black);line-height:1.15;margin-bottom:6px}
.acc-head__title em{font-style:italic;color:var(--pink)}
.acc-head__sub{font-size:.88rem;color:var(--g4);max-width:520px;line-height:1.55}
.acc-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:32px}
.acc-stat{background:var(--white);border:1px solid var(--g2);border-radius:12px;padding:22px 20px;text-align:center;transition:box-shadow .2s,border-color .2s}
.acc-stat:hover{box-shadow:0 8px 28px rgba(26,26,26,.06);border-color:rgba(233,30,123,.2)}
.acc-stat__val{font-family:'Plus Jakarta Sans',sans-serif;font-size:clamp(1.5rem,3vw,1.95rem);font-weight:800;color:var(--pink);letter-spacing:-.02em;line-height:1}
.acc-stat__lbl{font-size:.65rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--g4);margin-top:10px}
.acc-block-title{font-family:'Plus Jakarta Sans',sans-serif;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--g4);margin-bottom:14px}
.acc-panel{background:var(--white);border:1px solid var(--g2);border-radius:12px;padding:24px 26px;box-shadow:0 2px 16px rgba(26,26,26,.03)}
.acc-panel+.acc-panel{margin-top:16px}
.acc-order-card{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px;padding:18px 20px;border:1px solid var(--g2);border-radius:10px;background:var(--white);margin-bottom:12px;transition:border-color .2s,box-shadow .2s}
.acc-order-card:hover{border-color:rgba(233,30,123,.25);box-shadow:0 6px 20px rgba(26,26,26,.05)}
.acc-order-card__num{font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;font-size:.95rem;color:var(--black)}
.acc-order-card__meta{font-size:.8rem;color:var(--g4);margin-top:4px}
.acc-order-card__right{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.acc-order-card__price{font-family:'Plus Jakarta Sans',sans-serif;font-weight:800;font-size:1rem;color:var(--black)}
.acc-link{font-size:.82rem;font-weight:700;color:var(--pink);text-decoration:none;white-space:nowrap}
.acc-link:hover{text-decoration:underline}
.acc-toolbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-bottom:22px}
.acc-detail-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:24px;padding-bottom:22px;border-bottom:1px solid var(--g2)}
.acc-detail-grid dt{font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--g4);font-weight:700;margin-bottom:6px}
.acc-detail-grid dd{font-size:.92rem;font-weight:600;color:var(--black);margin:0}
.acc-line-item{display:flex;gap:16px;padding:14px 0;border-bottom:1px solid var(--g2);align-items:flex-start}
.acc-line-item:last-child{border-bottom:none}
.acc-line-item__main{flex:1;min-width:0}
.acc-line-item__title{font-weight:700;font-size:.9rem;color:var(--black)}
.acc-line-item__meta{font-size:.8rem;color:var(--g4);margin-top:4px;line-height:1.45}
.acc-line-item__price{font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;font-size:.95rem;color:var(--black);flex-shrink:0}
.acc-totals{text-align:right;padding-top:18px;font-size:.88rem;color:var(--g4)}
.acc-totals strong{display:block;font-size:1.1rem;color:var(--black);margin-top:8px;font-family:'Plus Jakarta Sans',sans-serif}
.acc-back{display:inline-flex;align-items:center;gap:8px;font-size:.86rem;font-weight:600;color:var(--pink);text-decoration:none;margin-bottom:18px}
.acc-back:hover{text-decoration:underline}
.acc-table-wrap{border:1px solid var(--g2);border-radius:12px;overflow:hidden;background:var(--white)}
.acc-table-wrap .admin-table{border:none;border-radius:0}
.acc-empty{text-align:center;padding:56px 24px;background:var(--white);border:1px dashed var(--g2);border-radius:12px}
.acc-empty__ico{width:56px;height:56px;margin:0 auto 16px;border-radius:50%;background:var(--g1);display:flex;align-items:center;justify-content:center;color:var(--g3)}
.acc-empty p{font-size:.9rem;color:var(--g4);line-height:1.6;max-width:320px;margin:0 auto}
.acc-form-panel{background:var(--white);border:1px solid var(--g2);border-radius:12px;padding:28px 30px}
.acc-form-panel h3,.acc-form-panel .acc-block-title{font-family:'Plus Jakarta Sans',sans-serif;font-size:1.05rem;letter-spacing:0;text-transform:none;font-weight:800;color:var(--black);margin-bottom:20px}
.acc-address-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.acc-address-card{background:var(--white);border:1px solid var(--g2);border-radius:12px;padding:22px 24px;position:relative;transition:border-color .2s,box-shadow .2s}
.acc-address-card:hover{box-shadow:0 6px 22px rgba(26,26,26,.05)}
.acc-address-card--default{border-color:rgba(233,30,123,.45);box-shadow:0 0 0 1px rgba(233,30,123,.08)}
.acc-address-card__badge{position:absolute;top:14px;right:14px;font-size:.62rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;background:rgba(233,30,123,.12);color:var(--pink);padding:4px 10px;border-radius:20px}
.acc-address-card__name{font-weight:700;font-size:.95rem;margin-bottom:10px;color:var(--black)}
.acc-address-card__lines{font-size:.86rem;color:var(--g4);line-height:1.65}
.acc-page .form-group label{font-family:'DM Sans','Plus Jakarta Sans',sans-serif;font-size:13px;font-weight:600;color:var(--black)}
.acc-page .form-control{border-radius:8px;border-color:var(--g2);padding:12px 14px}
.acc-page .form-control:focus{border-color:var(--pink);box-shadow:0 0 0 3px rgba(233,30,123,.08)}
.acc-page .btn--primary{background:var(--pink);border-color:var(--pink);color:#fff}
.acc-page .btn--primary:hover{background:var(--pink-dk);border-color:var(--pink-dk);color:#fff}
.acc-page .btn--dark{background:var(--black);border-color:var(--black);color:#fff}
.acc-page .btn--dark:hover{background:var(--pink);border-color:var(--pink);color:#fff}
.acc-page .btn--outline{border-color:var(--g2);color:var(--black)}
.acc-page .btn--outline:hover{border-color:var(--pink);color:var(--pink)}
@media(max-width:960px){
  .acc-layout{grid-template-columns:1fr}
  .acc-sidebar{position:static;padding:0;border-radius:12px}
  .acc-profile{padding:18px 20px;text-align:left;border-bottom:1px solid var(--g2);display:flex;align-items:center;gap:14px}
  .acc-avatar{width:52px;height:52px;margin:0;font-size:1.1rem;flex-shrink:0}
  .acc-profile__wrap{text-align:left;min-width:0}
  .acc-menu{display:flex;flex-wrap:wrap;gap:4px;padding:10px 12px 12px}
  .acc-menu__link{border-left:none;border-radius:8px;padding:10px 14px;font-size:.8rem}
  .acc-menu__link--active{border-left:none;background:rgba(233,30,123,.1)}
  .acc-menu__out{flex-basis:100%;border-top:1px solid var(--g2);margin-top:6px;padding-top:8px}
  .acc-stats{grid-template-columns:1fr}
  .acc-detail-grid{grid-template-columns:1fr}
  .acc-address-grid{grid-template-columns:1fr}
  .acc-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
}
@media(max-width:520px){
  .acc-order-card{flex-direction:column;align-items:flex-start}
  .acc-order-card__right{width:100%;justify-content:space-between}
}

/* Homepage trust strip: one slide at a time on mobile */
@media (max-width: 768px){
  .trust-cell{min-width:100% !important}
}

@media (max-width: 420px){
  .ghfo-backtotop{right:12px;bottom:78px}
}

