:root{
  --cream:#F2EFEA; --cream-dark:#E8E3DC; --taupe:#726658; --brown:#3D3028;
  --sage:#5C7A5E; --sage-dark:#3D5C3F; --rose:#C9968F; --gold:#C9A86A;
  --shadow:0 1px 4px rgba(0,0,0,0.06); --shadow-lg:0 8px 30px rgba(0,0,0,0.10);
  --maxw:1440px; --gutter:24px;
  --edge:max(var(--gutter), calc((100vw - var(--maxw)) / 2 + var(--gutter)));
  --font-head:'Cormorant Garamond', serif; --font-body:'Nunito', sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:var(--font-body);background:var(--cream);color:var(--brown);line-height:1.55;-webkit-font-smoothing:antialiased;}
a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;}
.serif{font-family:var(--font-head);}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px;}

/* ============================================================
   DESIGN SYSTEM — Studio Pear3  (use these canonical classes for new markup)
   ── Tokens (see :root): colours, --shadow/-lg, --maxw, --gutter, --edge
   ── Buttons:  .btn  +  .btn-primary | .btn-secondary | .btn-ghost
        modifiers: .btn-block (full width) · .is-loading (spinner) · .is-added (success morph)
        PRIMARY = sage filled (main CTA) · SECONDARY = white outline · GHOST = subtle outline
   ── Type scale (prefer over ad-hoc font-size):
        .t-eyebrow  uppercase kicker/label
        .t-display  hero headline      .t-h1 / .t-h2 / .t-h3  serif headings
        .t-lead     intro paragraph    .t-body  default        .t-meta  small muted
   ── Helpers: .u-center  .u-muted
   ============================================================ */
.t-eyebrow{font-size:0.72rem;font-weight:700;letter-spacing:0.13em;text-transform:uppercase;color:var(--sage);}
.t-display{font-family:var(--font-head);font-weight:600;font-size:3rem;line-height:1.08;color:var(--brown);}
.t-h1{font-family:var(--font-head);font-weight:600;font-size:2.2rem;line-height:1.12;color:var(--brown);}
.t-h2{font-family:var(--font-head);font-weight:600;font-size:1.5rem;line-height:1.15;color:var(--brown);}
.t-h3{font-family:var(--font-head);font-weight:600;font-size:1.18rem;line-height:1.2;color:var(--brown);}
.t-lead{font-size:1.05rem;color:#5a4f44;line-height:1.55;}
.t-body{font-size:0.95rem;color:var(--brown);}
.t-meta{font-size:0.78rem;color:var(--taupe);}
.u-center{text-align:center;}
.u-muted{color:var(--taupe);}

/* ── Announcement bar (hub-controlled) ── */
.announce{background:var(--sage-dark);color:#fff;text-align:center;font-size:0.8rem;font-weight:600;letter-spacing:0.02em;padding:8px 16px;}
.announce a{color:#fff;text-decoration:underline;}

/* ── Store closed overlay (hub-controlled) ── */
.store-closed{position:fixed;inset:0;z-index:2000;background:var(--cream);display:flex;align-items:center;justify-content:center;padding:24px;text-align:center;}
.store-closed .sc-box{max-width:460px;}
.store-closed .brand{font-family:var(--font-head);font-size:2rem;font-weight:700;color:var(--brown);margin-bottom:14px;}
.store-closed .brand span{color:var(--sage);}
.store-closed p{font-size:1.05rem;color:var(--taupe);line-height:1.5;}

/* ── Header ── */
header.site{position:sticky;top:0;z-index:50;background:rgba(242,239,234,0.85);backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--cream-dark);}
.hbar{max-width:var(--maxw);margin:0 auto;padding:15px 24px;display:flex;align-items:center;justify-content:space-between;gap:20px;}
.brand{font-family:var(--font-head);font-size:1.55rem;font-weight:700;letter-spacing:0.5px;color:var(--brown);white-space:nowrap;display:inline-flex;align-items:center;}
.brand span{color:var(--sage);}
.brand img{height:34px;width:auto;display:block;}
@media(max-width:560px){.brand img{height:28px;}}
.nav{display:flex;align-items:center;gap:26px;}
.nav a{font-size:0.86rem;font-weight:600;color:var(--taupe);transition:color .15s;}
.nav a:hover,.nav a.active{color:var(--brown);}
.hsearch{flex:1;max-width:620px;display:flex;align-items:center;background:#fff;border:1.5px solid var(--cream-dark);border-radius:24px;padding:3px 4px 3px 18px;color:var(--taupe);min-width:0;transition:border-color .15s, box-shadow .15s;}
.hsearch:focus-within{border-color:var(--sage);box-shadow:0 0 0 3px rgba(92,122,94,0.12);}
.hsearch input{border:none;outline:none;background:none;font-family:var(--font-body);font-size:0.95rem;color:var(--brown);width:100%;padding:8px 0;}
.hsearch-btn{flex-shrink:0;width:38px;height:38px;border-radius:50%;border:none;background:var(--sage-dark);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s;}
.hsearch-btn:hover{background:#345034;}
.hsearch-btn svg{width:18px;height:18px;}
@media(max-width:600px){.hsearch{display:none;}}

/* Categories mega-menu */
.cat-wrap{position:relative;}
.cat-btn{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-body);font-size:0.86rem;font-weight:600;color:var(--taupe);background:none;border:none;cursor:pointer;padding:6px 2px;}
.cat-btn:hover{color:var(--brown);}
.cat-menu{position:absolute;top:calc(100% + 14px);right:0;width:min(860px,94vw);background:#fff;border:1px solid var(--cream-dark);border-radius:16px;box-shadow:var(--shadow-lg);padding:20px 22px;display:none;z-index:60;max-height:76vh;overflow:auto;}
.cat-wrap.open .cat-menu{display:block;}
.cat-all{display:inline-block;font-size:0.84rem;font-weight:700;color:var(--sage-dark);margin-bottom:14px;}
.cat-all:hover{text-decoration:underline;}
.cat-cols{display:grid;grid-template-columns:repeat(5,1fr);gap:20px;}
.cat-col h4{font-family:var(--font-head);font-weight:600;font-size:1.02rem;color:var(--brown);margin-bottom:9px;padding-bottom:7px;border-bottom:1px solid var(--cream-dark);}
.cat-col a{display:block;font-size:0.8rem;color:var(--taupe);padding:3px 0;transition:color .12s;}
.cat-col a:hover{color:var(--sage-dark);}
@media(max-width:820px){.cat-cols{grid-template-columns:repeat(2,1fr);}}
.cart-btn{position:relative;display:inline-flex;align-items:center;color:var(--brown);}
.cart-count{position:absolute;top:-8px;right:-10px;background:var(--sage-dark);color:#fff;font-size:0.62rem;font-weight:700;min-width:17px;height:17px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px;}
.cart-count:empty{display:none;}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:12px;font-family:var(--font-body);font-size:0.96rem;font-weight:700;letter-spacing:0.02em;cursor:pointer;padding:14px 22px;transition:transform .08s, background .15s, box-shadow .15s;}
.btn-primary{background:var(--sage-dark);color:#fff;box-shadow:var(--shadow);}
.btn-primary:hover{background:#345034;box-shadow:var(--shadow-lg);}
.btn-primary:active{transform:translateY(1px);}
.btn-primary:disabled{background:var(--cream-dark);color:var(--taupe);cursor:not-allowed;box-shadow:none;}
.btn-ghost{background:#fff;color:var(--brown);border:1.5px solid var(--cream-dark);}
.btn-ghost:hover{border-color:var(--sage);}
.btn-block{width:100%;}

/* ── Hero (home) ── */
.hero-band{position:relative;overflow:hidden;}
.hero-band::before{content:"";position:absolute;inset:0;background-image:url(/pear-pattern.jpg);background-repeat:no-repeat;background-position:center;background-size:cover;opacity:0.65;z-index:0;}
.hero-band::after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 62% 74% at 50% 46%, var(--cream) 28%, rgba(242,239,234,0.15) 100%);z-index:1;}
.hero-band .wrap{position:relative;z-index:2;}
.hero{padding:64px 0 40px;text-align:center;}
.hero-eyebrow{font-size:0.76rem;font-weight:700;letter-spacing:0.13em;text-transform:uppercase;color:var(--sage);margin-bottom:16px;}
.about-strip{text-align:center;padding:26px 0 6px;}
.about-strip p{max-width:680px;margin:0 auto;color:var(--taupe);font-family:var(--font-head);font-size:1.32rem;line-height:1.45;}
.hero h1{font-family:var(--font-head);font-weight:600;font-size:3rem;line-height:1.1;color:var(--brown);margin-bottom:16px;}
.hero p{max-width:620px;margin:0 auto 26px;color:#5a4f44;font-size:1.05rem;}
.section-title{font-family:var(--font-head);font-weight:600;font-size:1.9rem;color:var(--brown);margin:8px 0 22px;text-align:center;}

/* category tiles */
.cat-tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin:18px 0 56px;}
.cat-tile{position:relative;border-radius:14px;overflow:hidden;aspect-ratio:4/3;background:var(--cream-dark);box-shadow:var(--shadow);cursor:pointer;}
.cat-tile img{width:100%;height:100%;object-fit:cover;transition:transform .4s;}
.cat-tile:hover img{transform:scale(1.05);}
.cat-tile span{position:absolute;left:0;right:0;bottom:0;padding:26px 16px 14px;background:linear-gradient(transparent,rgba(0,0,0,0.55));color:#fff;font-family:var(--font-head);font-weight:600;font-size:1.3rem;}

/* ── Product grid ── */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:26px 22px;margin:8px 0 64px;}
.card{display:flex;flex-direction:column;cursor:pointer;}
.card .ph{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:14px;background:var(--cream-dark);box-shadow:var(--shadow);transition:box-shadow .15s, transform .15s;}
.card:hover .ph{box-shadow:var(--shadow-lg);transform:translateY(-2px);}
.card .cat{font-size:0.62rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--sage);margin:12px 0 4px;}
.card .nm{font-family:var(--font-head);font-size:1.12rem;font-weight:600;color:var(--brown);line-height:1.25;margin-bottom:5px;}
.card .pr{font-size:0.92rem;font-weight:700;color:var(--brown);}

/* filter chips */
.filters{display:flex;flex-wrap:wrap;gap:9px;justify-content:center;margin:10px 0 30px;}
.chip{font-size:0.8rem;font-weight:600;color:var(--taupe);background:#fff;border:1.5px solid var(--cream-dark);border-radius:20px;padding:7px 15px;cursor:pointer;transition:all .15s;}
.chip:hover{border-color:var(--sage);}
.chip.active{background:var(--sage-dark);border-color:var(--sage-dark);color:#fff;}

/* ── PDP ── */
.product{display:grid;grid-template-columns:1.05fr 0.95fr;gap:48px;padding:32px 0 80px;}
@media(max-width:860px){.product{grid-template-columns:1fr;gap:28px;}.hero h1{font-size:2.2rem;}.nav{gap:16px;}}
/* swipeable main gallery */
.pdp-slides{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;border-radius:16px;background:var(--cream-dark);box-shadow:var(--shadow);scrollbar-width:none;-ms-overflow-style:none;}
.pdp-slides::-webkit-scrollbar{display:none;}
.pdp-slide{flex:0 0 100%;width:100%;aspect-ratio:1/1;object-fit:cover;scroll-snap-align:center;cursor:zoom-in;}
.thumbs{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap;}
.thumbs img{width:62px;height:62px;object-fit:cover;border-radius:9px;cursor:pointer;border:2px solid transparent;transition:border-color .15s;background:var(--cream-dark);}
.thumbs img.active{border-color:var(--sage);}

/* full-screen lightbox */
.lightbox{position:fixed;inset:0;z-index:1000;background:var(--cream);display:none;}
.lightbox.open{display:block;}
.lb-slides{position:absolute;inset:0;display:flex;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;-ms-overflow-style:none;}
.lb-slides::-webkit-scrollbar{display:none;}
.lb-slide{flex:0 0 100%;width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;scroll-snap-align:center;}
.lb-slide img{max-width:88vw;max-height:84vh;object-fit:contain;}
.lb-close,.lb-arrow{position:absolute;z-index:2;border:none;background:rgba(255,255,255,0.82);color:var(--brown);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow);transition:background .15s;}
.lb-close:hover,.lb-arrow:hover{background:#fff;}
.lb-close{top:20px;right:22px;width:42px;height:42px;font-size:1.1rem;}
.lb-arrow{top:50%;transform:translateY(-50%);width:48px;height:48px;font-size:1.7rem;line-height:1;}
.lb-prev{left:22px;} .lb-next{right:22px;}
.lb-dots{position:absolute;bottom:26px;left:0;right:0;display:flex;justify-content:center;gap:9px;z-index:2;}
.lb-dots button{width:8px;height:8px;border-radius:50%;border:none;background:var(--cream-dark);cursor:pointer;padding:0;transition:background .15s;}
.lb-dots button.active{background:var(--brown);}
@media(max-width:600px){.lb-arrow{display:none;}}
.cat-tag{display:inline-block;font-size:0.66rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--sage);background:rgba(92,122,94,0.10);padding:4px 11px;border-radius:20px;margin-bottom:14px;}
a.cat-tag{transition:background .14s;}
a.cat-tag:hover{background:rgba(92,122,94,0.2);}
.pdp-tags{display:flex;flex-wrap:wrap;gap:6px;margin:2px 0 20px;}
.pdp-tags:empty{display:none;}
.pdp-tag{font-size:0.7rem;font-weight:600;color:var(--taupe);background:var(--cream);border:1px solid var(--cream-dark);border-radius:999px;padding:3px 10px;transition:all .14s;}
.pdp-tag:hover{border-color:var(--sage);color:var(--brown);}
h1.title{font-family:var(--font-head);font-weight:600;font-size:2.15rem;line-height:1.15;color:var(--brown);margin-bottom:14px;}
.price{font-family:var(--font-head);font-size:2rem;font-weight:600;color:var(--brown);margin-bottom:4px;}
.price .price-from{font-family:var(--font-body);font-size:0.82rem;font-weight:600;letter-spacing:0.04em;text-transform:uppercase;color:var(--taupe);vertical-align:middle;margin-right:2px;}
.price small{font-size:0.85rem;font-family:var(--font-body);color:var(--taupe);font-weight:600;letter-spacing:0.04em;}
.desc{font-size:0.92rem;color:#5a4f44;margin:18px 0 24px;}
.desc p{margin-bottom:10px;}
.desc ul{list-style:none;margin:8px 0 14px;}
.desc li{position:relative;padding-left:16px;margin-bottom:5px;}
.desc li:before{content:"–";position:absolute;left:0;color:var(--sage);}
.opt{margin-bottom:20px;}
.opt label{display:block;font-size:0.74rem;font-weight:700;letter-spacing:0.05em;text-transform:uppercase;color:var(--taupe);margin-bottom:7px;}
.opt select,.opt input[type=text]{width:100%;padding:11px 13px;font-family:var(--font-body);font-size:0.95rem;color:var(--brown);background:#fff;border:1.5px solid var(--cream-dark);border-radius:11px;outline:none;transition:border-color .15s;}
.opt select:focus,.opt input[type=text]:focus{border-color:var(--sage);}
.opt .hint{font-size:0.76rem;color:var(--taupe);margin-top:6px;line-height:1.45;}
.opt .counter{float:right;font-size:0.72rem;color:var(--taupe);font-weight:600;}
.req{color:var(--rose);}

/* colour swatches — matte spheres, palette-grouped */
.swatch-group{border:1px solid var(--cream-dark);border-radius:13px;padding:15px 16px 6px;background:rgba(255,255,255,0.45);}
.swatch-group + .swatch-group{margin-top:14px;}
.swatch-group > label{display:block;padding-bottom:10px;margin-bottom:12px;border-bottom:1px solid var(--cream-dark);}
.swatch-group .swatch-readout{font-weight:600;color:var(--brown);text-transform:none;letter-spacing:0;font-size:0.82rem;margin-left:6px;}
.swatch-pal{margin-bottom:13px;}
.swatch-pal-label{display:block;font-size:0.6rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--taupe);margin-bottom:7px;}
.swatch-row{display:flex;flex-wrap:wrap;gap:9px;}
.swatch{width:30px;height:30px;border-radius:50%;border:1px solid rgba(0,0,0,0.10);padding:0;cursor:pointer;
  background:radial-gradient(circle at 34% 30%, color-mix(in srgb, var(--sw) 76%, #fff) 0%, var(--sw) 52%, color-mix(in srgb, var(--sw) 80%, #000) 100%);
  box-shadow:0 1px 2px rgba(0,0,0,0.14);transition:transform .12s, box-shadow .12s;}
.swatch:hover{transform:translateY(-2px) scale(1.06);}
.swatch:focus-visible{outline:2px solid var(--sage);outline-offset:3px;}
.swatch.selected{box-shadow:0 0 0 2px var(--cream), 0 0 0 4px var(--sage-dark);transform:scale(1.06);}
.swatch-help{font-size:0.74rem;color:var(--taupe);margin:2px 0 18px;}
.linklike{border:none;background:none;padding:0;color:var(--sage-dark);text-decoration:underline;cursor:pointer;font:inherit;}

/* live combination preview */
.combo{margin:4px 0 22px;padding:14px 16px;background:#fff;border:1px solid var(--cream-dark);border-radius:12px;}
.combo-title{font-size:0.64rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--taupe);margin-bottom:11px;}
.combo-cells{display:flex;gap:24px;flex-wrap:wrap;}
.combo-cell{display:flex;align-items:center;gap:11px;}
.combo-sphere{width:42px;height:42px;border-radius:50%;flex-shrink:0;border:1px solid rgba(0,0,0,0.10);box-shadow:0 1px 3px rgba(0,0,0,0.16);
  background:radial-gradient(circle at 34% 30%, color-mix(in srgb, var(--sw) 76%, #fff) 0%, var(--sw) 52%, color-mix(in srgb, var(--sw) 80%, #000) 100%);}
.combo-sphere.empty{background:var(--cream-dark);border:1px dashed var(--taupe);box-shadow:none;}
.combo-role{display:block;font-size:0.68rem;color:var(--taupe);}
.combo-name{display:block;font-family:var(--font-head);font-size:1.08rem;color:var(--brown);}
/* SVG live preview */
.combo-svg-wrap{display:flex;justify-content:center;padding:8px 0 14px;}
.combo-svg-wrap svg{max-height:210px;width:auto;height:auto;max-width:100%;}
.combo-svg-wrap svg path,.combo-svg-wrap svg polygon,.combo-svg-wrap svg circle,.combo-svg-wrap svg rect,.combo-svg-wrap svg ellipse{transition:fill .15s;}
.combo-legend{display:flex;flex-direction:column;gap:7px;}
.combo-leg{display:flex;align-items:center;gap:9px;font-size:0.85rem;color:var(--taupe);}
.combo-leg b{color:var(--brown);font-weight:600;}
.combo-dot{width:16px;height:16px;border-radius:50%;flex-shrink:0;border:1px solid rgba(0,0,0,0.12);box-shadow:0 1px 2px rgba(0,0,0,0.14);background:radial-gradient(circle at 35% 30%, color-mix(in srgb, var(--sw) 75%, #fff), var(--sw) 58%, color-mix(in srgb, var(--sw) 82%, #000));}
.combo-dot.empty{background:var(--cream-dark);border:1px dashed var(--taupe);box-shadow:none;}
.qtybox{display:inline-flex;align-items:center;border:1.5px solid var(--cream-dark);border-radius:11px;overflow:hidden;background:#fff;}
.qtybox button{width:40px;height:42px;border:none;background:#fff;font-size:1.2rem;color:var(--brown);cursor:pointer;transition:background .12s;}
.qtybox button:hover{background:var(--cream);}
.qtybox input{width:46px;text-align:center;border:none;outline:none;font-family:var(--font-body);font-size:1rem;font-weight:600;color:var(--brown);}
.pdp-actions{display:flex;gap:10px;margin-top:8px;}
.pdp-actions .btn{flex:1;}
.ship-note{font-size:0.78rem;color:var(--taupe);margin-top:14px;display:flex;align-items:flex-start;gap:7px;line-height:1.5;}
.err{color:var(--rose);font-size:0.82rem;font-weight:600;margin-top:10px;min-height:1em;}

/* ── Cart ── */
.cart-wrap{padding:32px 0 80px;max-width:780px;margin:0 auto;}
.cart-row{display:grid;grid-template-columns:84px 1fr auto;gap:16px;align-items:center;padding:16px 0;border-bottom:1px solid var(--cream-dark);}
.cart-row img{width:84px;height:84px;object-fit:cover;border-radius:11px;background:var(--cream-dark);display:block;}
.cart-row .bk-title{font-family:var(--font-head);font-size:1.12rem;font-weight:600;color:var(--brown);display:inline-block;transition:color .12s;}
.cart-row .bk-title:hover{color:var(--sage-dark);}
.cart-row a img{transition:opacity .12s;}
.cart-row a:hover img{opacity:0.85;}
.cart-row .meta{font-size:0.78rem;color:var(--taupe);margin-top:3px;}
.bk-sw{display:inline-block;width:11px;height:11px;border-radius:50%;border:1px solid rgba(0,0,0,0.14);vertical-align:-1px;margin-right:3px;box-shadow:0 1px 1px rgba(0,0,0,0.12);background:radial-gradient(circle at 35% 30%, color-mix(in srgb, var(--sw) 75%, #fff), var(--sw) 58%, color-mix(in srgb, var(--sw) 82%, #000));}
.cart-row .rm{font-size:0.74rem;color:var(--rose);cursor:pointer;font-weight:600;margin-top:6px;display:inline-block;}
.bk-pills{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px;}
.bk-pill{display:inline-flex;align-items:center;gap:5px;font-size:0.74rem;color:var(--brown);background:var(--cream);border:1px solid var(--cream-dark);border-radius:999px;padding:3px 10px;line-height:1.3;white-space:nowrap;}
.bk-pill-k{font-size:0.62rem;font-weight:700;letter-spacing:0.04em;text-transform:uppercase;color:var(--taupe);}
.bk-pill .bk-sw{margin-right:0;}
.clear-basket{display:inline-flex;align-items:center;gap:6px;font-family:inherit;font-size:0.78rem;font-weight:600;color:var(--taupe);background:none;border:none;cursor:pointer;padding:5px 4px;border-radius:7px;transition:color .14s;}
.clear-basket svg{opacity:0.7;transition:opacity .14s;}
.clear-basket:hover{color:var(--rose);}
.clear-basket:hover svg{opacity:1;}
.clear-confirm{display:flex;align-items:center;gap:8px;font-size:0.78rem;color:var(--brown);}
.clear-confirm button{font-family:inherit;font-size:0.74rem;font-weight:600;cursor:pointer;border-radius:999px;padding:4px 12px;border:1px solid var(--cream-dark);transition:all .14s;}
.clear-confirm .cc-yes{background:var(--rose);border-color:var(--rose);color:#fff;}
.clear-confirm .cc-yes:hover{filter:brightness(0.94);}
.clear-confirm .cc-no{background:#fff;color:var(--taupe);}
.clear-confirm .cc-no:hover{background:var(--cream);}
.cart-summary{margin-top:24px;display:flex;flex-direction:column;gap:10px;}
.cart-total{display:flex;justify-content:space-between;font-family:var(--font-head);font-size:1.5rem;font-weight:600;}
.bk-price{font-family:var(--font-head);font-size:1.3rem;font-weight:600;color:var(--brown);margin-bottom:8px;}

/* ── Generic ── */
.loading,.empty-state{text-align:center;padding:80px 20px;color:var(--taupe);font-size:0.95rem;}
.hsecure{font-size:0.72rem;color:var(--taupe);display:flex;align-items:center;gap:6px;}
.footer{text-align:center;padding:46px 20px;color:var(--taupe);font-size:0.76rem;border-top:1px solid var(--cream-dark);margin-top:30px;}
.footer a{color:var(--taupe);margin:0 8px;text-decoration:underline;}
svg.ico{width:14px;height:14px;flex-shrink:0;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}
.prose{max-width:720px;margin:0 auto;padding:36px 0 70px;}
.prose h1{font-family:var(--font-head);font-weight:600;font-size:2.2rem;margin-bottom:18px;}
.prose h2{font-family:var(--font-head);font-weight:600;font-size:1.4rem;margin:26px 0 8px;}
.prose p{margin-bottom:12px;color:#5a4f44;}
.about-signoff{margin-top:30px;padding-top:22px;border-top:1px solid var(--cream-dark);font-family:var(--font-head);font-size:1.5rem;color:var(--brown);line-height:1.3;}
.about-signoff span{display:block;font-size:1rem;color:var(--taupe);margin-top:2px;}
.about-figure{margin:0 0 26px;}
.about-figure img{width:100%;border-radius:16px;background:var(--cream-dark);box-shadow:var(--shadow);display:block;}
.about-figure figcaption{font-size:0.8rem;color:var(--taupe);text-align:center;margin-top:9px;font-style:italic;}

/* ── Full-bleed overflow carousels (Apple / ui.com style) ── */
.row-head{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin:40px 0 14px;}
.row-head h2{font-family:var(--font-head);font-weight:600;font-size:1.85rem;color:var(--brown);}
.row-head h2 .muted{color:var(--taupe);}
.row-head .viewall{font-size:0.82rem;font-weight:700;color:var(--sage-dark);white-space:nowrap;}
.row-head .viewall:hover{text-decoration:underline;}

.carousel-shell{position:relative;}
/* first card aligns to the content gutter; cards bleed off the right edge */
.carousel{display:flex;gap:18px;overflow-x:auto;scroll-snap-type:x mandatory;
  padding:6px var(--edge) 20px;scroll-padding-left:var(--edge);
  scrollbar-width:none;-ms-overflow-style:none;scroll-behavior:smooth;}
.carousel::-webkit-scrollbar{display:none;}
.carousel > *{scroll-snap-align:start;flex:0 0 auto;}

/* arrow buttons (desktop) */
.carousel-shell .arrow{position:absolute;top:38%;transform:translateY(-50%);z-index:5;width:40px;height:40px;border-radius:50%;border:none;background:rgba(255,255,255,0.92);box-shadow:var(--shadow-lg);color:var(--brown);cursor:pointer;display:none;align-items:center;justify-content:center;transition:background .15s;}
.carousel-shell .arrow:hover{background:#fff;}
.carousel-shell .arrow.left{left:calc(var(--edge) - 20px);}
.carousel-shell .arrow.right{right:calc(var(--edge) - 20px);}
@media(min-width:861px){.carousel-shell:hover .arrow{display:inline-flex;}}

/* big feature card ("new arrivals") */
.feature{width:300px;border-radius:18px;overflow:hidden;background:#fff;box-shadow:var(--shadow);display:flex;flex-direction:column;transition:box-shadow .15s, transform .15s;}
.feature:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px);}
.feature .ftxt{padding:22px 22px 6px;}
.feature .tag{font-size:0.64rem;font-weight:700;letter-spacing:0.09em;text-transform:uppercase;color:var(--gold);}
.feature h3{font-family:var(--font-head);font-weight:600;font-size:1.42rem;line-height:1.12;margin:6px 0 8px;color:var(--brown);}
.feature p{font-size:0.85rem;color:#5a4f44;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.feature .fimg{margin-top:16px;aspect-ratio:1/1;background:var(--cream-dark);}
.feature .fimg img{width:100%;height:100%;object-fit:cover;}
.feature .fprice{padding:10px 22px 18px;font-weight:700;font-size:0.92rem;color:var(--brown);}

/* product card sized for carousel */
.carousel .card{width:230px;}

/* ── Hero dual CTA ── */
.hero-cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;}
.btn-secondary{background:#fff;color:var(--brown);border:1.5px solid var(--cream-dark);box-shadow:var(--shadow);}
.btn-secondary:hover{border-color:var(--sage);background:#fff;box-shadow:var(--shadow-lg);}
.btn-secondary:active{transform:translateY(1px);}

/* ── Category paths (home) ── */
.paths{padding:30px 0 6px;}
.paths-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
@media(max-width:760px){.paths-grid{grid-template-columns:1fr;}}
.path-card{display:flex;flex-direction:column;align-items:flex-start;gap:6px;padding:26px 24px;background:#fff;border:1px solid var(--cream-dark);border-radius:16px;box-shadow:var(--shadow);transition:transform .16s, box-shadow .16s;}
.path-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);}
.path-kicker{font-size:0.64rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--sage);}
.path-card h2{font-family:var(--font-head);font-weight:600;font-size:1.5rem;color:var(--brown);line-height:1.1;}
.path-card p{font-size:0.9rem;color:#5a4f44;flex:1;}
.path-link{font-size:0.84rem;font-weight:700;color:var(--sage-dark);margin-top:4px;transition:gap .15s;}
.path-card:hover .path-link{text-decoration:underline;}

/* ── Trust strip ── */
.trust-strip{padding:30px 0 8px;}
.trust-strip ul{list-style:none;display:flex;flex-wrap:wrap;justify-content:center;gap:10px 30px;border-top:1px solid var(--cream-dark);border-bottom:1px solid var(--cream-dark);padding:18px 0;}
.trust-strip li{display:flex;align-items:center;gap:8px;font-size:0.84rem;font-weight:600;color:var(--taupe);}
.trust-strip .tico{font-size:1rem;line-height:1;}

/* ── Personalise badge on cards ── */
.ph-wrap{position:relative;}
.card-badge{position:absolute;top:10px;left:10px;font-size:0.6rem;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;color:var(--brown);background:rgba(255,255,255,0.92);border-radius:20px;padding:4px 9px;box-shadow:var(--shadow);backdrop-filter:blur(4px);}

/* ── Skeleton loaders (shimmer) ── */
@keyframes shimmer{0%{background-position:-468px 0;}100%{background-position:468px 0;}}
/* single shared shimmer surface — every skeleton element inherits from here */
.sk,.sk-head,.sk-card,.sk-grid-card .ph,.sk-grid-card .b1,.sk-grid-card .b2{
  background:var(--cream-dark);
  background-image:linear-gradient(90deg,var(--cream-dark) 0px,#efe9e1 40px,var(--cream-dark) 80px);
  background-size:600px 100%;animation:shimmer 1.4s infinite linear;border-radius:12px;}
.skeleton-row{padding:18px 0;}
.sk-head{height:30px;width:240px;margin:24px 24px 18px;border-radius:8px;}
.sk-cards{display:flex;gap:18px;padding:0 24px;overflow:hidden;}
.sk-card{flex:0 0 230px;height:300px;border-radius:14px;}
.sk-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:26px 22px;margin:8px 0 64px;}
.sk-grid-card .ph{aspect-ratio:1/1;border-radius:14px;}
.sk-grid-card .b1{height:13px;width:55%;margin:13px 0 7px;border-radius:6px;}
.sk-grid-card .b2{height:13px;width:32%;border-radius:6px;}

/* ── Add-to-basket button feedback ── */
.btn.is-loading{pointer-events:none;color:transparent !important;position:relative;}
.btn.is-loading::after{content:"";position:absolute;width:18px;height:18px;border:2.5px solid rgba(255,255,255,0.45);border-top-color:#fff;border-radius:50%;animation:btnspin .6s linear infinite;}
.btn-ghost.is-loading::after,.btn-secondary.is-loading::after{border-color:rgba(61,48,40,0.25);border-top-color:var(--brown);}
@keyframes btnspin{to{transform:rotate(360deg);}}
.btn.is-added{background:var(--sage) !important;color:#fff !important;pointer-events:none;}
.btn.is-added .btn-label{display:inline-flex;align-items:center;gap:8px;}
@keyframes badgePop{0%{transform:scale(1);}40%{transform:scale(1.5);}100%{transform:scale(1);}}
.cart-count.pop{animation:badgePop .42s cubic-bezier(.34,1.56,.64,1);}
@keyframes shake{10%,90%{transform:translateX(-1px);}20%,80%{transform:translateX(2px);}30%,50%,70%{transform:translateX(-4px);}40%,60%{transform:translateX(4px);}}
.shake{animation:shake .5s cubic-bezier(.36,.07,.19,.97);}

/* ── A11y & motion ── */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,.card:focus-visible,.path-card:focus-visible,.feature:focus-visible{outline:2.5px solid var(--sage);outline-offset:3px;border-radius:8px;}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important;}
}

/* header gains a shadow once scrolled */
header.site{transition:box-shadow .2s, background .2s;}
header.site.scrolled{box-shadow:0 2px 16px rgba(0,0,0,0.07);}

/* ── Toast ── */
.toast-wrap{position:fixed;left:0;right:0;bottom:26px;display:flex;flex-direction:column;align-items:center;gap:8px;z-index:1200;pointer-events:none;}
.toast{background:var(--brown);color:#fff;font-size:0.86rem;font-weight:600;padding:11px 18px;border-radius:12px;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:9px;opacity:0;transform:translateY(12px);transition:opacity .22s, transform .22s;max-width:90vw;}
.toast.show{opacity:1;transform:translateY(0);}
.toast.success{background:var(--sage-dark);}
.toast.error{background:#9d5b54;}
.toast a{color:#fff;text-decoration:underline;pointer-events:auto;}

/* ── Secondary category nav (occasion-based) ── */
.subnav{border-bottom:1px solid var(--cream-dark);background:rgba(242,239,234,0.6);}
.subnav-inner{max-width:var(--maxw);margin:0 auto;padding:0 24px;display:flex;justify-content:center;gap:30px;overflow-x:auto;scrollbar-width:none;}
.subnav-inner::-webkit-scrollbar{display:none;}
.subnav a{display:inline-flex;align-items:center;gap:7px;font-size:0.82rem;font-weight:600;color:var(--taupe);white-space:nowrap;padding:11px 0;border-bottom:2px solid transparent;transition:color .15s, border-color .15s;}
.subnav a .nav-ico{width:16px;height:16px;flex-shrink:0;}
.subnav a:hover{color:var(--brown);}
.subnav a.active{color:var(--sage-dark);border-bottom-color:var(--sage-dark);}

/* ── Faceted filter bar (shop) ── */
.facetbar{display:flex;flex-direction:column;gap:9px;margin:0 0 26px;padding:16px 18px;background:rgba(255,255,255,0.55);border:1px solid var(--cream-dark);border-radius:14px;}
.facetbar:empty{display:none;}
.facet-group{display:flex;flex-wrap:wrap;align-items:center;gap:7px;}
.facet-label{font-size:0.62rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--taupe);width:74px;flex-shrink:0;}
.facet-chip{font-size:0.76rem;font-weight:600;color:var(--taupe);background:#fff;border:1.5px solid var(--cream-dark);border-radius:18px;padding:5px 12px;cursor:pointer;transition:all .14s;}
.facet-chip:hover{border-color:var(--sage);color:var(--brown);}
.facet-chip.active{background:var(--sage-dark);border-color:var(--sage-dark);color:#fff;}
.facet-more{font-size:0.73rem;font-weight:600;color:var(--sage-dark);background:none;border:none;cursor:pointer;padding:5px 6px;text-decoration:underline;}
.facet-clear{align-self:flex-start;margin-top:2px;font-size:0.74rem;font-weight:600;color:var(--rose);background:none;border:none;cursor:pointer;padding:2px 0;}
.facet-clear:hover{text-decoration:underline;}

/* ── Collection landing pages ── */
.collection-hero{padding:40px 0 22px;text-align:center;max-width:760px;margin:0 auto;}
.collection-hero .eyebrow{font-size:0.72rem;font-weight:700;letter-spacing:0.13em;text-transform:uppercase;color:var(--sage);margin-bottom:12px;}
.collection-hero h1{font-family:var(--font-head);font-weight:600;font-size:2.5rem;line-height:1.08;color:var(--brown);margin-bottom:14px;}
.collection-hero p{color:#5a4f44;font-size:1.02rem;}
.collection-links{display:flex;flex-wrap:wrap;gap:9px;justify-content:center;margin:8px 0 26px;}
.breadcrumbs{font-size:0.76rem;color:var(--taupe);padding:18px 0 0;}
.breadcrumbs a{color:var(--sage-dark);}
.breadcrumbs a:hover{text-decoration:underline;}
