/* ===================================================================
   Benbi Studio - מערכת עיצוב
   פלטה: לבן מוחלט + שחור. ללא זהב, חום, או אוף-וויט.
   =================================================================== */
:root{
  --cream:#fff; --cream-2:#f6f6f6; --tan:#f0f0f0; --sand:#e8e8e8;
  --gold:#111; --gold-soft:#bbb; --gold-line:#e0e0e0; --gold-deep:#111; --brown:#333; --espresso:#111;
  --ink:#111; --body:#444; --muted:#888; --line:#e0e0e0;
  --white:#fff; --error:#c0392b; --error-bg:#fdf0ef; --success:#276749;
  --display:"Suez One",Georgia,serif; --serif:"Suez One",Georgia,serif; --editorial:"Frank Ruhl Libre",Georgia,serif; --sans:"Assistant",system-ui,Arial,sans-serif;
  --maxw:1240px; --gutter:clamp(1rem,4vw,2.5rem);
  --shadow:0 26px 60px -30px rgba(0,0,0,.10); --shadow-sm:0 12px 30px -18px rgba(0,0,0,.07);
  --shadow-gold:0 18px 44px -24px rgba(0,0,0,.10);
  --r:16px; --r-sm:10px;
  --fs-root:1.0625rem;
  --ease:cubic-bezier(.22,1,.36,1);
}
*,*::before,*::after{box-sizing:border-box}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media(min-width:760px){html{font-size:var(--fs-root)}}
/* a11y font scaling (persisted via data-font on <html>) */
html[data-font="lg"]{font-size:118%}
html[data-font="xl"]{font-size:132%}
html[data-font="sm"]{font-size:92%}
body{margin:0;font-family:var(--sans);font-weight:400;line-height:1.62;color:var(--body);
  background:var(--cream);-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block;height:auto}
a{color:var(--gold-deep);text-decoration:none}
a:hover{color:var(--brown)}
.prose a,.acc__panel a,.cookie a,.pdp__desc a,.trustlist a,.breadcrumbs a,.drawer__note a,.heritage__grid a{text-decoration:underline}
h1,h2{font-family:var(--display);color:var(--ink);line-height:1.14;margin:0;font-weight:400;letter-spacing:0}
h3,h4{font-family:var(--sans);color:var(--ink);line-height:1.2;margin:0;font-weight:700;letter-spacing:-.01em}
p{margin:0 0 1rem}
.container{width:min(100% - 2*var(--gutter),var(--maxw));margin-inline:auto}
.flow>*+*{margin-block-start:1rem}

/* ---------- focus + skip link (a11y) ---------- */
:focus{outline:none}
:focus-visible{outline:3px solid var(--gold-deep);outline-offset:3px;border-radius:4px}
.skip-link{position:fixed;inset-block-start:-100px;inset-inline-start:1rem;z-index:200;
  background:var(--espresso);color:var(--cream);padding:.7rem 1.2rem;border-radius:0 0 10px 10px;font-weight:700;transition:inset-block-start .2s}
.skip-link:focus{inset-block-start:0;color:var(--cream)}
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  font-family:var(--sans);font-weight:700;font-size:1rem;line-height:1;cursor:pointer;
  padding:.95rem 1.9rem;border-radius:8px;border:1.5px solid transparent;transition:.25s var(--ease);text-align:center}
.btn--primary{background:var(--gold);color:#fff;border-color:var(--gold);box-shadow:var(--shadow-gold)}
.btn--primary:hover{background:#333;border-color:#333;color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.btn--dark{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.btn--dark:hover{background:#000;color:#fff;transform:translateY(-2px)}
.btn--ghost{background:#fff;color:var(--ink);border-color:var(--ink)}
.btn--ghost:hover{background:var(--ink);color:#fff;border-color:var(--ink);transform:translateY(-2px)}
.btn--lt{background:transparent;color:#fff;border-color:rgba(255,255,255,.6)}
.btn--lt:hover{background:rgba(255,255,255,.16);color:#fff;border-color:#fff}
.btn--block{width:100%}
.btn[disabled]{background:var(--sand);color:var(--body);border-color:var(--sand);cursor:not-allowed;transform:none!important;box-shadow:none!important}
.kicker{font-size:.78rem;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-deep);margin:0 0 .9rem}

/* ---------- announcement marquee ---------- */
.announce{background:var(--espresso);color:rgba(255,255,255,.85);overflow:hidden;font-size:.82rem;letter-spacing:.04em;border-block-end:1px solid rgba(255,255,255,.12)}
.announce__track{display:flex;gap:3.5rem;white-space:nowrap;width:max-content;padding-block:.55rem;animation:marquee 40s linear infinite}
.announce__track span{flex:0 0 auto;color:var(--cream-2)}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- header ---------- */
.site-header{position:sticky;inset-block-start:0;z-index:90;border-block-end:1px solid var(--line);transition:box-shadow .3s}
.site-header::before{content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;background:rgba(255,255,255,.92);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}
.site-header.is-scrolled{box-shadow:var(--shadow-sm)}
.site-header__row{display:flex;flex-wrap:wrap;align-items:center;gap:.8rem 1rem;min-height:72px;padding-block:.5rem}
.brand{display:inline-flex;align-items:center}
.brand img{height:52px;width:auto;flex:0 0 auto;object-fit:contain}
/* ---- header search ---- */
.hsearch{position:relative;flex:1 1 auto;max-width:540px;display:flex;align-items:center;gap:.5rem;margin-inline:auto;background:#fff;border:1.5px solid var(--line);border-radius:30px;padding-inline:1rem .4rem}
.hsearch:focus-within{border-color:var(--ink);box-shadow:0 0 0 3px rgba(0,0,0,.08)}
.hsearch__ico{display:grid;place-items:center;color:var(--muted);flex:0 0 auto}
.hsearch__input{flex:1;min-width:0;border:none;background:none;font-family:var(--sans);font-size:.96rem;color:var(--ink);padding:.72rem 0;outline:none}
.hsearch__input::placeholder{color:var(--muted)}
.hsearch__clear{flex:0 0 auto;width:30px;height:30px;border:none;background:var(--cream-2);color:var(--muted);border-radius:50%;cursor:pointer;font-size:.8rem}
.hsearch__panel{position:absolute;inset-inline:0;inset-block-start:calc(100% + .5rem);background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);overflow:hidden auto;z-index:95;max-height:72vh}
.sresult{display:flex;align-items:center;gap:.8rem;padding:.6rem .9rem;color:var(--ink);border-block-end:1px solid var(--line)}
.sresult:last-child{border-block-end:none}
.sresult.is-active,.sresult:hover{background:var(--cream-2)}
.sresult img{width:46px;height:57px;object-fit:cover;border-radius:8px;flex:0 0 auto;background:var(--cream-2)}
.sresult__name{font-weight:700;font-size:.95rem;line-height:1.2}
.sresult__meta{font-size:.8rem;color:var(--muted)}
.sresult__price{margin-inline-start:auto;font-weight:800;color:var(--brown);white-space:nowrap}
.sresult--all{justify-content:center;font-weight:700;color:var(--gold-deep);background:var(--cream)}
.sresult--empty{padding:1.2rem;text-align:center;color:var(--muted)}
/* ---- desktop nav bar + mega ---- */
.navbar{position:relative;background:var(--cream);border-block-end:1px solid var(--line)}
.navbar__row{display:flex;align-items:center;gap:1.7rem;min-height:50px;font-weight:600;font-size:.95rem}
.navbar__row>a{color:var(--ink);position:relative;padding-block:.3rem}
.navbar__row>a::after{content:"";position:absolute;inset-inline:0;inset-block-end:-2px;height:2px;background:var(--gold);transform:scaleX(0);transform-origin:inline-end;transition:transform .25s var(--ease)}
.navbar__row>a:hover::after,.navbar__row>a:focus-visible::after,.navbar__row>a[aria-current="page"]::after{transform:scaleX(1)}
.navbar__ship{margin-inline-start:auto;color:var(--gold-deep);font-weight:700}
.navbar__ship::after{display:none}
.megatrigger{display:inline-flex;align-items:center;gap:.5rem;background:var(--gold);color:#fff;border:none;border-radius:9px;padding:.55rem 1.15rem;font-family:var(--sans);font-weight:700;font-size:.95rem;cursor:pointer;transition:.2s}
.megatrigger:hover,.megatrigger[aria-expanded="true"]{background:#333;color:#fff}
.mega{position:absolute;inset-inline:0;inset-block-start:100%;background:#fff;border-block-end:1px solid var(--line);box-shadow:var(--shadow);z-index:94;animation:megaIn .22s var(--ease)}
@keyframes megaIn{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:none}}
.mega__grid{display:grid;grid-template-columns:1fr 1fr 1.1fr;gap:2rem;padding-block:1.8rem}
.mega__col h3{font-family:var(--sans);font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-deep);margin-block-end:.9rem}
.mega__links{display:grid;grid-template-columns:1fr 1fr;gap:.15rem}
.mega__links a{color:var(--ink);padding:.5rem .6rem;border-radius:8px;font-weight:600;font-size:.95rem}
.mega__links a:hover{background:var(--cream-2);color:var(--gold-deep)}
.mega__feature{display:flex;flex-direction:column;justify-content:center;gap:.35rem;background:linear-gradient(135deg,var(--cream-2),#fff);border:1px solid var(--gold-line);border-radius:14px;padding:1.5rem}
.mega__feature strong{font-family:var(--display);font-size:1.6rem;color:var(--ink)}
.mega__go{color:var(--gold-deep);font-weight:700}
/* ---- mobile drawer (mainnav) ---- */
.mainnav{display:none}
.mnav__group h3{font-family:var(--sans);font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-deep);margin-block:1.3rem .4rem}
.mnav__links{display:grid;grid-template-columns:1fr 1fr;gap:.1rem}
.header-actions{display:flex;align-items:center;gap:.3rem}
.iconbtn{position:relative;display:grid;place-items:center;width:42px;height:42px;border:none;background:none;color:var(--ink);border-radius:10px;cursor:pointer;transition:.2s}
.iconbtn:hover{background:var(--cream-2);color:var(--gold-deep)}
.cart-count{position:absolute;inset-block-start:2px;inset-inline-start:2px;min-width:18px;height:18px;padding:0 5px;background:var(--gold-deep);color:#fff;font-size:.68rem;font-weight:700;border-radius:9px;display:grid;place-items:center}
.cart-count[hidden]{display:none}
.burger{display:none;flex-direction:column;gap:4px;width:42px;height:42px;border:none;background:none;cursor:pointer;align-items:center;justify-content:center}
.burger span{width:22px;height:2px;background:var(--ink);border-radius:2px;transition:.3s}

/* ---------- hero (editorial, asymmetric) ---------- */
.hero{position:relative;color:var(--ink);overflow:hidden;isolation:isolate;border-block-end:1px solid var(--gold-line);
  background:#fff}
.hero__veil{display:none}
.hero__inner{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;min-height:min(72vh,620px);padding-block:clamp(3.5rem,8vw,6rem);max-width:48rem}
.hero__eyebrow{display:flex;align-items:center;justify-content:center;gap:.7rem;font-size:.8rem;font-weight:700;letter-spacing:.14em;color:var(--gold-deep);margin-block-end:1.2rem}
.hero__rule{display:inline-block;width:2.4rem;height:1px;background:var(--gold)}
.hero__title{font-family:var(--display);font-weight:400;color:var(--ink);font-size:clamp(2.6rem,6.2vw,4.6rem);line-height:1.08;letter-spacing:-.01em}
.hero__title em{font-family:var(--editorial);font-style:normal;font-weight:700;color:var(--gold-deep)}
.hero__sub{font-size:clamp(1.06rem,1.7vw,1.26rem);line-height:1.7;color:var(--body);max-width:40rem;margin:1.3rem auto 0}
.hero__cta{display:flex;flex-wrap:wrap;justify-content:center;gap:.8rem;margin-block-start:1.8rem}
.hero__meta{list-style:none;display:flex;flex-wrap:wrap;justify-content:center;gap:.4rem 1.3rem;margin-block-start:2rem;padding:0;font-size:.85rem;color:var(--muted)}
.hero__meta li{position:relative;padding-inline-start:1.1rem}
.hero__meta li::before{content:"✦";position:absolute;inset-inline-start:0;color:var(--gold)}
.hero__art{position:relative;display:grid;place-items:center}
.exhibit{position:relative;background:#fff;border:1px solid var(--line);border-radius:6px;padding:1rem 1rem 0;box-shadow:0 42px 80px -42px rgba(0,0,0,.12),0 10px 26px -18px rgba(0,0,0,.08);max-width:380px;transform:rotate(-1.4deg)}
.exhibit img{width:100%;height:auto;aspect-ratio:4/5;object-fit:cover;border-radius:3px;display:block}
.exhibit__tag{position:absolute;inset-block-start:-.8rem;inset-inline-end:1.2rem;background:var(--ink);color:var(--gold-soft);font-size:.7rem;font-weight:700;letter-spacing:.08em;padding:.32rem .8rem;border-radius:20px}
.exhibit figcaption{text-align:center;padding:.9rem .5rem 1.1rem}
.exhibit figcaption b{font-family:var(--editorial);font-size:1.15rem;color:var(--ink);display:block}
.exhibit figcaption span{font-size:.8rem;color:var(--muted)}
.exhibit__orn{position:absolute;inset-block-start:-2.2rem;inset-inline-start:-1.4rem;font-size:2.4rem;color:var(--gold);opacity:.55;z-index:-1}
/* ---------- trust strip ---------- */
.trust{background:#fff;color:var(--ink);border-block-end:1px solid var(--line)}
.trust__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.6rem;padding-block:2.1rem}
.trust__item{display:flex;gap:.9rem;align-items:flex-start}
.trust__ico{flex:0 0 auto;width:46px;height:46px;display:grid;place-items:center;border:1px solid var(--gold-line);background:var(--cream);border-radius:50%;color:var(--gold-deep)}
.trust__ico svg{width:24px;height:24px}
.trust__item b{display:block;font-size:1rem;font-weight:700;color:var(--ink);margin-block-end:.12rem}
.trust__item span{font-size:.85rem;line-height:1.5;color:var(--muted)}
/* ---------- quote band (editorial) ---------- */
.quoteband{background:var(--cream-2);position:relative;overflow:hidden;border-block:1px solid var(--gold-line)}
.quoteband::before{display:none}
.quoteband__in{position:relative;max-width:52rem;text-align:center;padding-block:clamp(3rem,6vw,5rem);margin-inline:auto}
.quoteband__mark{font-family:var(--editorial);font-size:4.5rem;line-height:.2;color:var(--gold);display:inline-block;height:1.8rem}
.quoteband__q{font-family:var(--editorial);font-weight:500;font-size:clamp(1.45rem,3vw,2.1rem);line-height:1.55;color:var(--ink);margin:0 0 1.4rem}
.quoteband__by b{display:block;font-weight:700;color:var(--gold-deep)}
.quoteband__by span{font-size:.88rem;color:var(--muted)}
@media(max-width:860px){
  .hero__inner{grid-template-columns:1fr;gap:2.2rem;min-height:0;padding-block:2.4rem 3rem;text-align:center}
  .hero__eyebrow,.hero__meta,.hero__cta{justify-content:center}
  .hero__sub{margin-inline:auto}
  .exhibit{max-width:290px;transform:none}
  .exhibit__orn{display:none}
}

/* ---------- section scaffolding ---------- */
.section{padding-block:clamp(3.2rem,7vw,6rem)}
.section--tint{background:linear-gradient(180deg,var(--cream),var(--cream-2))}
.section__head{max-width:42rem;margin-block-end:2.6rem}
.section__head--center{margin-inline:auto;text-align:center}
.section__cta{text-align:center;margin-block-start:clamp(2rem,4vw,3rem)}
/* ===== editorial system (numbered, asymmetric) ===== */
.hero__grid{display:grid;grid-template-columns:1.25fr .9fr;gap:clamp(2rem,5vw,4rem);align-items:end;min-height:min(74vh,640px);padding-block:clamp(3.5rem,7vw,6rem)}
.hero__eyebrow{font-size:.78rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-deep);margin:0 0 1.4rem}
.hero__main .hero__title{font-family:var(--display);font-weight:400;color:var(--ink);font-size:clamp(3rem,8vw,6rem);line-height:1.02;letter-spacing:-.02em;margin:0}
.hero__main .hero__title em{font-family:var(--editorial);font-style:normal;font-weight:700;color:var(--gold-deep)}
.hero__side{border-inline-start:1px solid var(--gold-line);padding-inline-start:clamp(1.2rem,2.5vw,2.4rem);padding-block-end:.5rem}
.hero__side .hero__sub{font-size:1.1rem;line-height:1.75;color:var(--body);max-width:30rem;margin:0}
.hero__side .hero__cta{display:flex;flex-wrap:wrap;gap:.7rem;margin-block-start:1.5rem}
.hero__side .hero__meta{list-style:none;padding:0;margin-block-start:1.6rem;display:flex;flex-direction:column;gap:.4rem;font-size:.85rem;color:var(--muted)}
.hero__side .hero__meta li{position:relative;padding-inline-start:1.1rem}
.hero__side .hero__meta li::before{content:"✦";position:absolute;inset-inline-start:0;color:var(--gold)}
.promise{background:var(--ink);color:var(--cream)}
.promise__row{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.4rem,3vw,3rem);padding-block:2.4rem}
.promise__item{display:flex;gap:.9rem;align-items:flex-start}
.promise__n{font-family:var(--editorial);font-size:1.5rem;color:rgba(255,255,255,.5);line-height:1;flex:0 0 auto}
.promise__item p{margin:0;font-size:.92rem;line-height:1.6;color:rgba(255,255,255,.82)}
.promise__item b{color:var(--cream);font-weight:700}
.ehead{display:flex;align-items:flex-end;gap:1rem 1.4rem;flex-wrap:wrap;margin-block-end:clamp(1.8rem,4vw,3rem);padding-block-start:1.3rem;border-block-start:1px solid var(--gold-line)}
.ehead__num{font-family:var(--editorial);font-size:1.6rem;color:var(--gold-deep);line-height:1}
.ehead__txt{flex:1 1 auto}
.ehead__kicker{font-size:.74rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-deep);margin:0 0 .35rem}
.ehead__title{font-family:var(--display);font-size:clamp(1.9rem,4.5vw,3.2rem);line-height:1.05;margin:0}
.ehead__lead{flex:0 1 22rem;font-size:.95rem;line-height:1.6;color:var(--muted);margin:0 0 .4rem}
.cidx-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 clamp(2rem,5vw,4rem)}
.cidx{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:1.1rem;padding-block:1.2rem;border-block-end:1px solid var(--line);color:var(--ink);transition:.2s var(--ease)}
.cidx:hover{padding-inline-start:.5rem;border-color:var(--gold)}
.cidx__n{font-family:var(--editorial);font-size:1rem;color:var(--gold-deep);opacity:.65}
.cidx__name{font-family:var(--display);font-size:1.45rem;line-height:1.1;display:block;transition:color .2s}
.cidx__blurb{font-size:.85rem;color:var(--muted);line-height:1.4;display:block;margin-block-start:.15rem}
.cidx__go{color:var(--gold-deep);font-size:1.2rem;opacity:0;transform:translateX(6px);transition:.2s}
.cidx:hover .cidx__go{opacity:1;transform:none}
.cidx:hover .cidx__name{color:var(--gold-deep)}
/* ===== imagery-first (photographic hero + image cards) ===== */
.hero{position:relative;min-height:min(82vh,720px);display:flex;align-items:center;overflow:hidden;background:var(--cream);isolation:isolate;border-block-end:1px solid var(--gold-line)}
.hero__bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:30% center;z-index:-2}
.hero__scrim{position:absolute;inset:0;z-index:-1;background:linear-gradient(270deg,rgba(255,255,255,.9),rgba(255,255,255,.62) 38%,rgba(255,255,255,.12) 72%,transparent)}
.hero__inner{width:min(100% - 2*var(--gutter),var(--maxw));margin-inline:auto;display:block}
.hero__copy{max-width:35rem}
.hero .hero__eyebrow{font-size:.8rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-deep);margin:0 0 1.1rem}
.hero .hero__title{font-family:var(--display);font-weight:400;color:var(--ink);font-size:clamp(2.6rem,6vw,4.6rem);line-height:1.06;letter-spacing:-.01em;margin:0}
.hero .hero__title em{font-family:var(--editorial);font-style:normal;font-weight:700;color:var(--gold-deep)}
.hero .hero__sub{font-size:clamp(1.05rem,1.6vw,1.25rem);line-height:1.7;color:var(--body);max-width:30rem;margin:1.2rem 0 0;text-align:start}
.hero .hero__cta{display:flex;flex-wrap:wrap;justify-content:flex-start;gap:.7rem;margin-block-start:1.6rem}
.hero .hero__meta{list-style:none;padding:0;margin-block-start:1.6rem;display:flex;flex-wrap:wrap;justify-content:flex-start;gap:.4rem 1.3rem;font-size:.84rem;color:var(--muted)}
.hero .hero__meta li{position:relative;padding-inline-start:1.1rem}
.hero .hero__meta li::before{content:"✦";position:absolute;inset-inline-start:0;color:var(--gold)}
/* image category cards */
.ccard-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(.9rem,1.6vw,1.4rem)}
.ccard{position:relative;display:block;border-radius:var(--r);overflow:hidden;background:var(--cream-2);box-shadow:var(--shadow-sm);aspect-ratio:1}
.ccard--occ{aspect-ratio:4/5}
.ccard__img{position:absolute;inset:0;display:block}
.ccard__img img{width:100%;height:100%;object-fit:cover;transition:transform .65s var(--ease)}
.ccard:hover .ccard__img img{transform:scale(1.06)}
.ccard__cap{position:absolute;inset-inline:0;inset-block-end:0;padding:1.4rem 1.2rem 1.1rem;display:flex;flex-direction:column;gap:.2rem;background:linear-gradient(to top,rgba(0,0,0,.82),rgba(0,0,0,.06) 70%,transparent);color:var(--cream)}
.ccard__cap b{font-family:var(--display);font-weight:400;font-size:1.4rem;line-height:1.1}
.ccard__go{font-size:.82rem;font-weight:700;color:var(--gold-soft);opacity:0;transform:translateX(6px);transition:.25s var(--ease)}
.ccard:hover .ccard__go{opacity:1;transform:none}
.ccard::after{content:"";position:absolute;inset:0;border-radius:var(--r);box-shadow:inset 0 0 0 0 var(--gold);transition:box-shadow .3s}
.ccard:hover::after{box-shadow:inset 0 0 0 2px var(--gold)}
/* heritage photo + shop round image icons */
.heritage__media--photo{padding:0;background:none;box-shadow:var(--shadow);border:1px solid var(--gold-line);border-radius:var(--r);overflow:hidden;aspect-ratio:3/2}
.heritage__media--photo img{max-width:100%;width:100%;height:100%;object-fit:cover}
.catnav__row{display:grid;grid-template-columns:repeat(auto-fill,minmax(88px,1fr));gap:1.2rem .5rem}
.catnav__item{display:flex;flex-direction:column;align-items:center;gap:.5rem;text-align:center;color:var(--ink)}
.catnav__ico{width:76px;height:76px;border-radius:50%;overflow:hidden;background:var(--cream-2);border:1px solid var(--gold-line);transition:.2s var(--ease)}
.catnav__ico img{width:100%;height:100%;object-fit:cover}
.catnav__item:hover .catnav__ico{box-shadow:var(--shadow-gold);transform:translateY(-3px);border-color:var(--gold)}
.catnav__lbl{font-size:.8rem;font-weight:600;line-height:1.2}
@media(max-width:900px){.ccard-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){
  /* hero: image as a banner on top, copy below on cream (no overlay clipping) */
  .hero{display:block;min-height:auto}
  .hero__bg{position:relative;inset:auto;width:100%;height:auto;aspect-ratio:16/10;object-position:center;z-index:0}
  .hero__scrim{display:none}
  .hero__inner{padding-block:1.7rem 2.2rem}
  .hero__copy{max-width:none}
  .hero .hero__title{font-size:2.3rem;line-height:1.1}
  .hero .hero__sub{max-width:none}
  /* product card: full-width add button under price */
  .pcard__foot{flex-direction:column;align-items:stretch;gap:.55rem}
  .pcard__add{width:100%;justify-content:center;height:44px}
  .ccard-grid{gap:.7rem}
}
@media(max-width:820px){
  .hero__grid{grid-template-columns:1fr;align-items:start;gap:1.5rem;min-height:0;padding-block:2.4rem 2.8rem}
  .hero__side{border-inline-start:none;border-block-start:1px solid var(--gold-line);padding-inline-start:0;padding-block-start:1.4rem}
  .promise__row{grid-template-columns:1fr;gap:1rem}
  .ehead__lead{display:none}
  .cidx-grid{grid-template-columns:1fr}
}
.section__title{font-size:clamp(2rem,4.6vw,3rem);line-height:1.08}
.section__lead{margin-block-start:.8rem;color:var(--muted);font-size:1.08rem}
.section__top{display:flex;justify-content:space-between;align-items:flex-end;gap:1rem;flex-wrap:wrap}
.link-arrow{font-weight:700;color:var(--gold-deep);white-space:nowrap}
.link-arrow:hover{color:var(--brown)}

/* ---------- category mosaic (real variation, not uniform) ---------- */
.cat-mosaic{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem}
.cat-card{position:relative;overflow:hidden;border-radius:var(--r);aspect-ratio:1;border:1px solid var(--line);background:var(--cream-2);box-shadow:var(--shadow-sm)}
.cat-card--feature{grid-column:span 2;grid-row:span 2;aspect-ratio:auto}
.cat-card img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.cat-card:hover img{transform:scale(1.06)}
.cat-card__cap{position:absolute;inset-inline:0;inset-block-end:0;padding:1.5rem 1.1rem 1.1rem;
  background:linear-gradient(to top,rgba(0,0,0,.82),transparent);color:var(--cream)}
.cat-card__cap b{font-family:var(--serif);font-weight:700;font-size:1.2rem;display:block}
.cat-card--feature .cat-card__cap b{font-size:1.7rem}
.cat-card__cap span{font-size:.85rem;color:rgba(255,255,255,.85)}
.cat-card::after{content:"";position:absolute;inset:0;box-shadow:inset 0 0 0 0 var(--gold);transition:box-shadow .3s}
.cat-card:hover::after{box-shadow:inset 0 0 0 3px var(--gold)}

/* ---------- catalog toolbar ---------- */
.toolbar{display:flex;flex-wrap:wrap;gap:1rem;align-items:center;justify-content:space-between;margin-block-end:1.8rem}
.chips{display:flex;flex-wrap:wrap;gap:.5rem}
.chip{padding:.5rem 1.1rem;border-radius:30px;border:1.5px solid var(--line);background:var(--white);color:var(--brown);font-family:var(--sans);font-weight:600;font-size:.9rem;cursor:pointer;transition:.2s}
.chip:hover{border-color:var(--gold-deep);color:var(--gold-deep)}
.chip[aria-pressed="true"]{background:var(--gold-deep);color:var(--cream);border-color:var(--gold-deep)}
.sortwrap{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--muted)}
.sortwrap select{font-family:var(--sans);font-size:.92rem;padding:.5rem 2rem .5rem .8rem;border:1.5px solid var(--line);border-radius:8px;background:var(--white);color:var(--ink);cursor:pointer}

/* ---------- product grid + card ---------- */
.product-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(1rem,2vw,1.7rem)}
.pcard{position:relative;display:flex;flex-direction:column;background:var(--white);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.pcard:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.pcard__media{position:relative;display:block;aspect-ratio:4/5;overflow:hidden;background:var(--cream-2)}
.pcard__media img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.pcard:hover .pcard__media img{transform:scale(1.05)}
.pcard__badge{position:absolute;inset-block-start:.7rem;inset-inline-start:.7rem;z-index:2;background:var(--ink);color:#fff;font-size:.68rem;font-weight:700;letter-spacing:.04em;padding:.26rem .66rem;border-radius:20px}
.pcard__acts{position:absolute;inset-block-start:.6rem;inset-inline-end:.6rem;z-index:3;display:flex;flex-direction:column;gap:.4rem;opacity:0;transform:translateX(-6px);transition:.22s var(--ease)}
.pcard:hover .pcard__acts,.pcard:focus-within .pcard__acts{opacity:1;transform:none}
.pcard__icon{width:38px;height:38px;border-radius:50%;border:1px solid var(--line);background:rgba(255,255,255,.95);color:var(--muted);display:grid;place-items:center;cursor:pointer;box-shadow:var(--shadow-sm);transition:.18s}
.pcard__icon:hover{color:var(--gold-deep);border-color:var(--gold)}
.pcard__fav svg path{fill:none;stroke:currentColor;stroke-width:1.7}
.pcard__fav.is-fav{opacity:1;transform:none;color:var(--gold)}
.pcard__fav.is-fav svg path{fill:var(--gold);stroke:var(--gold)}
.pcard__oos{position:absolute;inset:0;z-index:2;background:rgba(255,255,255,.62);display:grid;place-items:center}
.pcard__oos span{background:var(--ink);color:var(--cream);font-weight:700;font-size:.9rem;padding:.4rem 1rem;border-radius:30px}
.pcard__body{display:flex;flex-direction:column;gap:.22rem;padding:.9rem 1rem 1.05rem;flex:1}
.pcard__vendor{font-size:.72rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--gold-deep)}
.pcard__name{font-family:var(--sans);font-weight:700;font-size:1rem;line-height:1.3;color:var(--ink);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.6em}
.pcard__name a{color:inherit}
.pcard__name a::after{content:"";position:absolute;inset:0;z-index:1}
.pcard__sku{font-size:.73rem;color:var(--muted)}
.pcard__foot{margin-block-start:auto;display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding-block-start:.7rem}
.pcard__price{font-family:var(--sans);font-weight:800;font-size:1.28rem;color:var(--brown)}
.pcard__add{position:relative;z-index:2;display:inline-flex;align-items:center;gap:.35rem;height:40px;padding-inline:.85rem;border-radius:9px;border:1.5px solid var(--ink);background:var(--ink);color:#fff;font-family:var(--sans);font-weight:700;font-size:.85rem;line-height:1;cursor:pointer;transition:.2s}
.pcard__add:hover{background:#333;color:#fff;border-color:#333}
.pcard__low{font-size:.74rem;color:var(--error);font-weight:600}
.pcard__soldout{font-size:.82rem;color:var(--muted);font-weight:700}
/* ---------- category icon strip ---------- */
.catnav{padding-block:clamp(1.4rem,4vw,2.4rem) .6rem}
.catnav__title{font-size:clamp(1.8rem,4vw,2.6rem)}
.catnav__sub{color:var(--muted);margin-block:.4rem 1.5rem;max-width:46rem}
.catnav__row{display:flex;flex-wrap:wrap;gap:.6rem}
.catpill{display:inline-flex;align-items:center;padding:.55rem 1.15rem;border:1px solid var(--gold-line);border-radius:30px;background:#fff;color:var(--ink);font-weight:600;font-size:.92rem;transition:.18s}
.catpill:hover{border-color:var(--gold);background:var(--cream);color:var(--gold-deep);transform:translateY(-2px)}
.catpill--occ{background:var(--cream-2)}
/* editorial category index (text-led, no AI illustrations) */
.catx-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(232px,1fr));gap:1rem}
.catx{position:relative;display:flex;flex-direction:column;gap:.4rem;padding:1.7rem 1.5rem 1.4rem;background:#fff;border:1px solid var(--line);border-radius:var(--r);transition:.22s var(--ease);overflow:hidden}
.catx::before{content:"";position:absolute;inset-block-start:0;inset-inline:0;height:3px;background:linear-gradient(90deg,var(--gold),var(--gold-soft));transform:scaleX(0);transform-origin:inline-end;transition:transform .3s var(--ease)}
.catx:hover{border-color:var(--gold-line);box-shadow:var(--shadow);transform:translateY(-4px)}
.catx:hover::before{transform:scaleX(1)}
.catx__name{font-family:var(--display);font-size:1.45rem;color:var(--ink);line-height:1.15}
.catx__blurb{font-size:.9rem;color:var(--muted);line-height:1.55;flex:1}
.catx__go{font-weight:700;font-size:.85rem;color:var(--gold-deep);margin-block-start:.5rem}
.catx--occ{background:var(--cream-2)}
/* ---------- shop layout ---------- */
.shop{display:grid;grid-template-columns:250px 1fr;gap:1.8rem;align-items:start;padding-block:.6rem 4rem}
.filters-toggle{display:none}
.filters{position:sticky;inset-block-start:140px;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1rem 1.2rem;max-height:calc(100vh - 160px);overflow:auto}
.filters__head{display:flex;justify-content:space-between;align-items:center;gap:.5rem;margin-block-end:.3rem}
.filters__head h2{font-size:1.15rem}
.filters__close{display:none}
.facet{border-block-start:1px solid var(--line);padding-block:.6rem}
.facet:first-of-type{border-block-start:none}
.facet>summary{font-weight:700;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;padding-block:.3rem;color:var(--ink)}
.facet>summary::-webkit-details-marker{display:none}
.facet>summary::after{content:"⌄";color:var(--muted);font-size:1.1rem;transition:.2s}
.facet[open]>summary::after{transform:rotate(180deg)}
.facet__list{display:flex;flex-direction:column;gap:.05rem;margin-block-start:.35rem}
.facet__check{display:flex;align-items:center;gap:.55rem;padding:.34rem .25rem;cursor:pointer;font-size:.92rem;border-radius:6px}
.facet__check:hover{background:var(--cream-2)}
.facet__check input{accent-color:var(--gold);width:16px;height:16px;flex:0 0 auto;cursor:pointer}
.facet__lbl{flex:1}
.facet__count{color:var(--muted);font-size:.8rem;font-variant-numeric:tabular-nums}
.facet__check.is-dim{opacity:.45}
.facet--toggles{border-block-start:1px solid var(--line)}
.shop__bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-block-end:1rem;flex-wrap:wrap}
.shop__count{font-weight:600;color:var(--body)}
.shop__count strong{color:var(--ink);font-weight:800}
.shop__tools{display:flex;align-items:center;gap:.6rem}
.shop__tools select{font-family:var(--sans);font-size:.9rem;padding:.55rem 2rem .55rem .9rem;border:1.5px solid var(--line);border-radius:8px;background:#fff;color:var(--ink);cursor:pointer}
.viewtoggle{display:flex;border:1.5px solid var(--line);border-radius:8px;overflow:hidden}
.viewtoggle button{width:38px;height:38px;border:none;background:#fff;color:var(--muted);cursor:pointer;display:grid;place-items:center}
.viewtoggle button.is-active{background:var(--ink);color:#fff}
.shop__active{display:flex;flex-wrap:wrap;gap:.5rem;margin-block-end:1.1rem}
.achip{display:inline-flex;align-items:center;gap:.4rem;background:var(--cream-2);border:1px solid var(--line);color:var(--ink);border-radius:30px;padding:.38rem .9rem;font-size:.85rem;font-weight:600;cursor:pointer}
.achip:hover{border-color:var(--gold)}
.achip--reset{background:none;border-color:transparent;color:var(--gold-deep);text-decoration:underline}
.shop__empty{text-align:center;color:var(--muted);padding-block:3rem}
.product-grid[data-view="list"]{grid-template-columns:1fr;gap:.9rem}
.product-grid[data-view="list"] .pcard{flex-direction:row;align-items:stretch}
.product-grid[data-view="list"] .pcard__media{width:150px;flex:0 0 150px;aspect-ratio:auto}
.product-grid[data-view="list"] .pcard__body{justify-content:center}
.product-grid[data-view="list"] .pcard__name{-webkit-line-clamp:3;min-height:0}
/* ---------- quick view ---------- */
.qvmodal{position:fixed;inset:0;z-index:120;display:none;place-items:center;padding:1.1rem;overflow:auto;pointer-events:none}
.qvmodal.is-open{display:grid}
.qvmodal__box{position:relative;pointer-events:auto;background:#fff;border-radius:var(--r);width:100%;max-width:760px;max-height:92vh;overflow:auto;box-shadow:var(--shadow)}
.qvmodal__close{position:absolute;inset-block-start:.7rem;inset-inline-end:.7rem;z-index:2;width:40px;height:40px;border:none;background:rgba(255,255,255,.92);border-radius:50%;font-size:1.1rem;cursor:pointer;color:var(--ink);box-shadow:var(--shadow-sm)}
#quickViewBody{display:grid;grid-template-columns:1fr 1fr;gap:0}
.qv__media{background:var(--cream-2)}
.qv__media img{width:100%;height:100%;max-height:92vh;object-fit:cover;display:block}
.qv__info{padding:1.9rem;display:flex;flex-direction:column;gap:.4rem}
.qv__vendor{font-size:.74rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--gold-deep)}
.qv__info h2{font-size:1.5rem;line-height:1.15}
.qv__sku{font-size:.8rem;color:var(--muted)}
.qv__price{font-family:var(--sans);font-weight:800;font-size:1.7rem;color:var(--brown);margin-block:.2rem}
.qv__stock{font-size:.85rem;font-weight:700}
.qv__stock--in{color:var(--success)}.qv__stock--low{color:var(--error)}.qv__stock--out{color:var(--muted)}
.qv__desc{color:var(--body);font-size:.95rem;line-height:1.6}
.qv__actions{display:flex;gap:.6rem;flex-wrap:wrap;margin-block-start:.5rem}
.qv__full{color:var(--gold-deep);font-weight:700;margin-block-start:.5rem}
@media(max-width:900px){
  .shop{grid-template-columns:1fr}
  .filters-toggle{display:inline-flex;margin-block-end:1rem}
  .filters{position:fixed;inset-block:0;right:0;left:auto;width:88%;max-width:360px;max-height:none;border:none;border-radius:0;z-index:116;transform:translateX(100%);transition:transform .32s var(--ease);display:flex;flex-direction:column;overflow:hidden;padding:0;box-shadow:var(--shadow)}
  .filters.is-open{transform:translateX(0)}
  .filters__head{position:sticky;inset-block-start:0;background:#fff;border-block-end:1px solid var(--line);padding:1.05rem 1.2rem;margin:0;z-index:1}
  .filters>#facets{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:.2rem 1.2rem calc(1.6rem + env(safe-area-inset-bottom))}
  .filters__close{display:grid;place-items:center;width:40px;height:40px;border:none;background:var(--cream-2);border-radius:50%;cursor:pointer;font-size:1.05rem;flex:none}
  #quickViewBody{grid-template-columns:1fr}
  .qv__media{aspect-ratio:4/3}
}

/* ---------- occasions band ---------- */
.occ-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem}
.occ-card{position:relative;overflow:hidden;border-radius:var(--r);aspect-ratio:3/4;box-shadow:var(--shadow-sm)}
.occ-card img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.occ-card:hover img{transform:scale(1.06)}
.occ-card__in{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:1.4rem;color:var(--cream);background:linear-gradient(to top,rgba(0,0,0,.82),transparent 62%)}
.occ-card__in b{font-family:var(--serif);font-size:1.35rem}
.occ-card__in span{font-size:.85rem;color:rgba(255,255,255,.85);margin-block:.3rem .6rem}
.occ-card__in .go{font-weight:700;color:var(--gold)}

/* ---------- heritage ---------- */
.heritage{background:#fff;color:var(--body);position:relative;overflow:hidden;border-block:1px solid var(--line)}
.heritage__grid{position:relative;display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.heritage__media{background:#fff;border:1px solid var(--gold-line);border-radius:var(--r);padding:2.4rem;display:grid;place-items:center;box-shadow:var(--shadow)}
.heritage__media img{max-width:78%}
.heritage h2{color:var(--ink)}
.heritage p{color:var(--body)}
.heritage__stats{display:flex;gap:2.6rem;margin-block-start:1.8rem;flex-wrap:wrap}
.heritage__stats b{font-family:var(--display);font-size:2rem;color:var(--gold-deep);display:block;line-height:1}
.heritage__stats span{font-size:.85rem;color:var(--muted)}

/* ---------- newsletter ---------- */
.news{background:linear-gradient(135deg,var(--cream-2),var(--tan));text-align:center}
.news form{display:flex;gap:.6rem;max-width:30rem;margin:1.4rem auto 0}
.field{display:flex;flex-direction:column;gap:.35rem;text-align:start}
.field label{font-weight:600;font-size:.9rem;color:var(--ink)}
.field input,.field select,.field textarea{font-family:var(--sans);font-size:1rem;padding:.85rem 1rem;border:1.5px solid var(--line);border-radius:8px;background:var(--white);color:var(--ink);width:100%}
.field input:focus-visible,.field select:focus-visible,.field textarea:focus-visible{outline:3px solid var(--gold-deep);outline-offset:1px;border-color:var(--gold-deep)}
.field--error input,.field--error select{border-color:var(--error);background:var(--error-bg)}
.field__err{color:var(--error);font-size:.82rem;font-weight:600;min-height:1em}
.news .field{flex:1}
.news__note{margin-block-start:.9rem;color:var(--gold-deep);font-weight:700;min-height:1.2em}

/* ---------- footer (explicit link contrast, not inherited) ---------- */
.site-footer{background:var(--espresso);color:rgba(255,255,255,.82)}
.site-footer__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:2rem;padding-block:3.4rem}
.footer-logo{display:inline-block;background:var(--cream);padding:.55rem .8rem;border-radius:14px;line-height:0;margin-block-end:1rem;box-shadow:0 6px 18px -10px rgba(0,0,0,.5)}
.footer-logo img{height:46px;width:auto;margin:0;display:block}
.site-footer h2{color:#fff;font-family:var(--sans);font-weight:700;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;margin-block-end:1rem}
.site-footer a{display:block;color:rgba(255,255,255,.82);padding-block:.32rem;font-size:.93rem}
.site-footer a:hover,.site-footer a:focus-visible{color:#fff}
.site-footer p{color:rgba(255,255,255,.65);font-size:.92rem;max-width:26rem}
.site-footer__bottom{border-block-start:1px solid rgba(255,255,255,.15);padding-block:1.2rem;font-size:.82rem;color:rgba(255,255,255,.5);text-align:center}
.payicons{display:flex;gap:.5rem;margin-block-start:1rem;opacity:.8}
.payicons span{font-size:.7rem;border:1px solid rgba(255,255,255,.25);border-radius:5px;padding:.2rem .45rem}

/* ---------- overlay + cart drawer ---------- */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);backdrop-filter:blur(2px);opacity:0;visibility:hidden;transition:.3s;z-index:100}
.overlay.is-open{opacity:1;visibility:visible}
.drawer{position:fixed;inset-block:0;left:0;right:auto;width:min(420px,92vw);background:var(--cream);z-index:110;display:flex;flex-direction:column;transform:translateX(-100%);transition:transform .35s var(--ease);box-shadow:var(--shadow)}
.drawer.is-open{transform:translateX(0)}
.drawer__head{display:flex;align-items:center;justify-content:space-between;padding:1.2rem 1.4rem;border-block-end:1px solid var(--line)}
.drawer__head h2{font-size:1.3rem}
.shipbar{padding:.9rem 1.4rem;background:var(--cream-2);font-size:.85rem;color:var(--brown)}
.shipbar__track{height:6px;border-radius:4px;background:var(--sand);margin-block-start:.5rem;overflow:hidden}
.shipbar__fill{height:100%;background:var(--gold-deep);width:0;transition:width .4s var(--ease)}
.drawer__body{flex:1;overflow-y:auto;padding:1rem 1.4rem;display:flex;flex-direction:column;gap:1rem}
.drawer__empty{text-align:center;color:var(--muted);margin-block-start:2.5rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.5rem 1rem}
.drawer__empty .empty__ico{width:60px;height:60px;display:grid;place-items:center;border-radius:50%;background:var(--cream-2);color:var(--gold-deep);margin-block-end:.4rem}
.drawer__empty b{color:var(--ink);font-size:1.05rem}
.drawer__empty .btn{margin-block-start:.6rem}
/* cart page: when empty, collapse to a centered state */
.cart-layout:has(.drawer__empty){grid-template-columns:1fr!important;max-width:560px;margin-inline:auto}
.cart-layout:has(.drawer__empty) .osum{display:none}
.cart-layout:has(.drawer__empty) [data-cart-list]{border:none!important;background:none!important}
/* 404 */
.e404{text-align:center;max-width:640px;margin-inline:auto;padding-block:clamp(1rem,4vw,3rem)}
.e404__num{font-family:var(--display);font-size:clamp(5rem,18vw,9rem);line-height:.9;color:var(--gold-soft);letter-spacing:.04em}
.e404__title{font-size:clamp(1.7rem,4.5vw,2.4rem);margin-block:.2rem .6rem}
.e404__lead{color:var(--muted);font-size:1.05rem;line-height:1.7;max-width:30rem;margin-inline:auto}
.e404__cta{display:flex;gap:.7rem;justify-content:center;flex-wrap:wrap;margin-block:1.6rem}
.e404__links{display:flex;gap:.4rem .9rem;justify-content:center;flex-wrap:wrap;align-items:center;font-size:.92rem;color:var(--muted);border-block-start:1px solid var(--line);padding-block-start:1.4rem}
.e404__links a{color:var(--gold-deep);font-weight:700}
.e404__links a:hover{color:var(--ink)}
.citem{display:flex;gap:.9rem}
.citem img{width:66px;height:82px;object-fit:cover;border-radius:8px;flex:0 0 auto}
.citem__info{flex:1;min-width:0}
.citem__name{font-weight:700;font-size:.92rem;line-height:1.3;color:var(--ink)}
.citem__vendor{font-size:.74rem;color:var(--gold-deep);text-transform:uppercase;letter-spacing:.06em}
.citem__price{font-weight:700;color:var(--brown);margin-block-start:.25rem}
.qty{display:inline-flex;align-items:center;gap:.4rem;margin-block-start:.4rem;border:1px solid var(--line);border-radius:8px;padding:.1rem}
.qty button{width:28px;height:28px;border:none;background:none;font-size:1.1rem;line-height:1;color:var(--brown);cursor:pointer;border-radius:6px}
.qty button:hover{background:var(--cream-2)}
.citem__rm{align-self:flex-start;background:none;border:none;color:var(--muted);cursor:pointer;font-size:1.1rem;padding:.2rem}
.citem__rm:hover{color:var(--error)}
.drawer__foot{padding:1.2rem 1.4rem;border-block-start:1px solid var(--line);background:var(--cream-2)}
.summ-row{display:flex;justify-content:space-between;font-size:.95rem;margin-block-end:.4rem;color:var(--body)}
.summ-row--total{font-family:var(--serif);font-weight:700;font-size:1.25rem;color:var(--espresso);margin-block:.6rem 1rem}
.drawer__note{text-align:center;font-size:.78rem;color:var(--muted);margin-block-start:.7rem}

/* ---------- product page ---------- */
.pdp{display:grid;grid-template-columns:1.08fr .92fr;gap:clamp(1.6rem,4vw,3.5rem);align-items:start;padding-block:2.4rem}
.pdp__media{position:sticky;inset-block-start:90px}
.gallery__main{position:relative;border-radius:20px;overflow:hidden;background:#fff;border:1px solid var(--line);padding:clamp(1.1rem,3.2vw,2.6rem);box-shadow:var(--shadow-sm)}
.gallery__main img{width:100%;height:auto;display:block;cursor:zoom-in;border-radius:10px;transition:transform .7s var(--ease)}
.gallery__main:hover img{transform:scale(1.04)}
.gallery__zoom{position:absolute;inset-block-start:1.2rem;inset-inline-end:1.2rem;z-index:2;background:rgba(255,255,255,.94);border:1px solid var(--line);border-radius:50%;width:42px;height:42px;display:grid;place-items:center;cursor:pointer;font-size:1.1rem;box-shadow:var(--shadow-sm);transition:.2s var(--ease)}
.gallery__zoom:hover{background:var(--ink);color:#fff}
.pdp__info{position:static}
.pdp__vendor{font-size:.82rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-deep)}
.pdp__title{font-size:clamp(1.8rem,3.6vw,2.6rem);margin-block:.5rem .2rem;line-height:1.12}
.pdp__price{font-family:var(--serif);font-weight:700;font-size:1.8rem;color:var(--brown);margin-block:.8rem}
.pdp__stock{display:inline-flex;align-items:center;gap:.45rem;font-size:.9rem;font-weight:600;margin-block-end:1rem}
.pdp__stock--in{color:var(--success)}.pdp__stock--low{color:var(--error)}.pdp__stock--out{color:var(--muted)}
.pdp__stock::before{content:"";width:9px;height:9px;border-radius:50%;background:currentColor}
.pdp__desc{font-size:1.05rem;line-height:1.7;color:var(--body)}
.pdp__buy{display:flex;gap:.7rem;align-items:stretch;margin-block:1.4rem;flex-wrap:wrap}
.pdp__buy .qty{padding:.25rem;border-color:var(--line)}
.pdp__buy .qty button{width:38px;height:38px;font-size:1.3rem}
.pdp__addbtn{flex:1 1 auto;min-width:58%}
.pdp__buy>.btn[disabled]{flex:1}
.pdp__fav{flex:0 0 auto;gap:.4rem}
.pdp__fav svg path{fill:none;stroke:currentColor;stroke-width:1.7}
.pdp__fav.is-fav{color:var(--gold-deep);border-color:var(--gold)}
.pdp__fav.is-fav svg path{fill:var(--gold);stroke:var(--gold)}
.pdp__spec-h{font-size:1.15rem;margin-block:1.7rem .4rem}
.pdp__spec{width:100%;border-collapse:collapse;font-size:.95rem}
.pdp__spec th,.pdp__spec td{text-align:start;padding:.6rem .2rem;border-block-end:1px solid var(--line);vertical-align:top}
.pdp__spec th{color:var(--muted);font-weight:600;width:34%}
.trustlist{list-style:none;padding:1rem 1.2rem;margin:1.2rem 0;background:var(--cream-2);border-radius:var(--r-sm);display:grid;gap:.5rem;font-size:.9rem}
.trustlist li{display:flex;gap:.55rem;align-items:center}
.trustlist b{color:var(--gold-deep)}
.acc{border-block-start:1px solid var(--line)}
.acc__item{border-block-end:1px solid var(--line)}
.acc__btn{width:100%;display:flex;justify-content:space-between;align-items:center;gap:1rem;background:none;border:none;padding:1.05rem 0;font-family:var(--sans);font-weight:700;font-size:1rem;color:var(--ink);cursor:pointer;text-align:start}
.acc__btn::after{content:"+";font-size:1.4rem;color:var(--gold-deep);transition:transform .2s}
.acc__btn[aria-expanded="true"]::after{content:"-"}
.acc__panel{padding-block-end:1.1rem;color:var(--body);font-size:.95rem;line-height:1.65}
.acc__panel[hidden]{display:none}

/* lightbox dialog */
dialog.lightbox{border:none;padding:0;background:transparent;max-width:96vw;max-height:96vh}
dialog.lightbox::backdrop{background:rgba(0,0,0,.8);backdrop-filter:blur(4px)}
dialog.lightbox img{max-width:96vw;max-height:90vh;border-radius:var(--r);box-shadow:var(--shadow)}
dialog.lightbox .lb-close{position:absolute;inset-block-start:-3.2rem;inset-inline-start:0;background:none;border:none;color:#fff;font-size:1.6rem;cursor:pointer}

/* ---------- page wrapper for content/legal ---------- */
.page{padding-block:clamp(2.4rem,6vw,4.5rem)}
.prose{max-width:46rem;margin-inline:auto}
.prose h1{font-size:clamp(2rem,5vw,3rem);margin-block-end:1.2rem}
.prose h2{font-size:1.5rem;margin-block:2rem .7rem;color:var(--brown)}
.prose p,.prose li{font-size:1.05rem;line-height:1.75;color:var(--body)}
.prose ul,.prose ol{padding-inline-start:1.3rem;margin-block-end:1rem}
.prose li{margin-block-end:.4rem}
.prose .updated{color:var(--muted);font-size:.9rem;margin-block-end:2rem}
.breadcrumbs{font-size:.85rem;color:var(--muted);margin-block-end:1.5rem}
.breadcrumbs a{color:var(--gold-deep)}
.heritage__cta{margin-block-start:1.6rem}
/* ---------- about / story ---------- */
.about__hero{max-width:48rem;margin-block-end:clamp(1.8rem,4vw,2.8rem)}
.about__hero h1{font-size:clamp(2rem,5vw,3rem);margin-block:.4rem 1rem}
.about__lead{font-size:1.15rem;line-height:1.7;color:var(--body)}
.about__grid{display:grid;grid-template-columns:1.7fr .9fr;gap:clamp(1.8rem,4vw,3.2rem);align-items:start}
.about__grid .prose{max-width:none;margin-inline:0}
.about__card{position:sticky;top:90px;background:var(--cream-2);border:1px solid var(--line);border-radius:var(--r);padding:1.8rem;text-align:center;box-shadow:var(--shadow-sm)}
.about__card img{height:78px;width:auto;margin-block-end:.6rem}
.about__card h2{font-size:1.4rem;margin-block-end:.7rem}
.about__card p{margin-block-end:.6rem;color:var(--body)}
.about__card .btn{margin-block-start:.5rem}
.about__addr strong{color:var(--espresso)}
@media(max-width:820px){.about__grid{grid-template-columns:1fr}.about__card{position:static;order:-1}}
/* ---------- account button (header) ---------- */
.iconbtn--account{width:auto;min-width:42px;gap:.35rem;padding-inline:.5rem}
.account-name{font-size:.86rem;font-weight:700;color:var(--ink);max-width:8rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
@media(max-width:540px){.account-name{display:none}}
/* ---------- linklike button ---------- */
.linklike{background:none;border:none;color:var(--gold-deep);font:inherit;font-weight:700;cursor:pointer;text-decoration:underline;padding:0}
.linklike:hover{color:var(--espresso)}
/* ---------- auth modal ---------- */
.authmodal{position:fixed;inset:0;z-index:120;display:none;place-items:center;padding:1.1rem;overflow:auto;pointer-events:none}
.authmodal.is-open{display:grid}
.authmodal__box{position:relative;pointer-events:auto;background:var(--cream);border-radius:var(--r);width:100%;max-width:430px;max-height:94vh;overflow:auto;padding:clamp(1.5rem,4vw,2.3rem);box-shadow:var(--shadow);text-align:center}
.authmodal__close{position:absolute;inset-block-start:.7rem;inset-inline-end:.7rem;width:38px;height:38px;border:none;background:none;font-size:1.2rem;border-radius:10px;cursor:pointer;color:var(--ink)}
.authmodal__close:hover{background:var(--cream-2);color:var(--gold-deep)}
.authmodal__brand img{height:60px;width:auto;margin-block-end:.5rem}
.authtabs{display:flex;gap:.3rem;background:var(--cream-2);border:1px solid var(--line);border-radius:999px;padding:.25rem;margin:.4rem auto 1.2rem;max-width:260px}
.authtab{flex:1;border:none;background:none;padding:.5rem .8rem;border-radius:999px;font:inherit;font-weight:700;color:var(--muted);cursor:pointer;transition:.2s}
.authtab.is-active{background:var(--white);color:var(--espresso);box-shadow:var(--shadow-sm)}
.authmodal__title{font-size:1.5rem;margin-block-end:.2rem}
.authmodal__sub{color:var(--muted);margin-block-end:1.2rem}
.authform{text-align:start}
.authform .field{margin-block-end:.9rem}
.field--pass{position:relative}
.authshow{position:absolute;inset-block-start:2.1rem;inset-inline-end:.6rem;background:none;border:none;color:var(--gold-deep);font:inherit;font-weight:700;font-size:.85rem;cursor:pointer;padding:.2rem}
.authforgot{display:inline-block;font-size:.86rem;margin-block-end:.6rem}
.authform__msg{background:var(--error-bg);border:1px solid var(--error);color:var(--error);border-radius:10px;padding:.6rem .8rem;font-size:.9rem;font-weight:600;margin-block:.2rem .9rem}
.authform__msg[data-kind="ok"]{background:#eaf6ec;border-color:var(--success);color:var(--success)}
.authmodal__guest{font-size:.92rem;color:var(--body);margin-block-start:1.1rem}
.authmodal__legal{font-size:.8rem;color:var(--muted);margin-block-start:.7rem}
.authmodal__legal a{color:var(--gold-deep);text-decoration:underline}
/* ---------- checkout login bar / user note ---------- */
.loginbar{display:flex;align-items:center;gap:.6rem;justify-content:space-between;background:var(--cream-2);border:1px solid var(--line);border-radius:12px;padding:.6rem .9rem;margin-block-end:1.1rem;font-size:.92rem}
.loginbar__x{background:none;border:none;color:var(--muted);cursor:pointer;font-size:1rem;line-height:1;flex:0 0 auto}
.usernote{background:var(--cream-2);border:1px solid var(--line);border-radius:12px;padding:.55rem .9rem;margin-block-end:1.1rem;font-size:.92rem}
.confirm__cta{margin-block:.4rem 1rem;color:var(--body)}
/* ---------- account page ---------- */
.account-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.2rem;margin-block-start:1.5rem}
.account-card{background:var(--cream-2);border:1px solid var(--line);border-radius:var(--r);padding:1.4rem}
.account-card h2{font-size:1.25rem;margin-block-end:.7rem}
.account-empty{color:var(--muted)}
.account-empty a{color:var(--gold-deep);text-decoration:underline}
.order-card{background:var(--white);border:1px solid var(--line);border-radius:12px;padding:.9rem 1rem;margin-block-end:.7rem}
.order-card__top{display:flex;justify-content:space-between;font-size:.9rem;color:var(--muted);margin-block-end:.3rem}
.order-card__top strong{color:var(--espresso)}
.order-card__items{font-size:.92rem;color:var(--body)}
.order-card__total{font-weight:700;color:var(--brown);margin-block-start:.3rem}

/* ---------- checkout ---------- */
.checkout{display:grid;grid-template-columns:1.3fr .9fr;gap:clamp(1.6rem,4vw,3rem);align-items:start;padding-block:2.4rem}
.steps{display:flex;gap:.5rem;margin-block-end:2rem;flex-wrap:wrap}
.steps li{list-style:none;display:flex;align-items:center;gap:.5rem;font-size:.88rem;color:var(--muted);font-weight:600}
.steps li[aria-current="step"]{color:var(--espresso)}
.steps li b{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;background:var(--sand);color:var(--brown);font-size:.85rem}
.steps li[aria-current="step"] b{background:var(--gold-deep);color:var(--cream)}
.formgrid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.formgrid .field--full{grid-column:1/-1}
.osum{background:var(--white);border:1px solid var(--line);border-radius:var(--r);padding:1.4rem;position:sticky;inset-block-start:90px}
.osum__item{display:flex;gap:.8rem;padding-block:.7rem;border-block-end:1px solid var(--line)}
.osum__item img{width:54px;height:67px;object-fit:cover;border-radius:6px}
.confirm{max-width:38rem;margin-inline:auto;text-align:center;padding-block:4rem}
.confirm__check{width:74px;height:74px;border-radius:50%;background:var(--success);color:#fff;display:grid;place-items:center;font-size:2.2rem;margin-inline:auto;margin-block-end:1.4rem}

/* ---------- cookie banner ---------- */
.cookie{position:fixed;inset-block-end:1rem;inset-inline:1rem;max-width:34rem;margin-inline:auto;z-index:130;background:var(--espresso);color:var(--cream);border-radius:var(--r);padding:1.2rem 1.4rem;box-shadow:var(--shadow);display:flex;gap:1rem;align-items:center;flex-wrap:wrap;transform:translateY(170%);transition:transform .45s var(--ease)}
.cookie.is-shown{transform:translateY(0)}
.cookie p{margin:0;font-size:.9rem;color:rgba(255,255,255,.9);flex:1;min-width:14rem}
.cookie a{color:rgba(255,255,255,.75);text-decoration:underline}

/* ---------- accessibility widget ---------- */
.a11y-fab{position:fixed;inset-block-end:1rem;inset-inline-end:1rem;z-index:120;width:54px;height:54px;border-radius:50%;background:var(--espresso);color:#fff;border:2px solid rgba(255,255,255,.25);cursor:pointer;display:grid;place-items:center;font-size:1.5rem;box-shadow:var(--shadow-sm)}
.a11y-panel{position:fixed;inset-block-end:5rem;inset-inline-end:1rem;z-index:121;width:min(310px,92vw);background:var(--white);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);padding:1.1rem;display:none}
.a11y-panel.is-open{display:block}
.a11y-panel h2{font-size:1.05rem;margin-block-end:.8rem;color:var(--espresso)}
.a11y-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}
.a11y-grid button{font-family:var(--sans);font-size:.82rem;font-weight:600;padding:.6rem .4rem;border:1.5px solid var(--line);border-radius:8px;background:var(--cream);color:var(--brown);cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:.25rem}
.a11y-grid button[aria-pressed="true"]{background:var(--gold-deep);color:var(--cream);border-color:var(--gold-deep)}
.a11y-reset{margin-block-start:.7rem;width:100%}
.a11y-statement{display:block;text-align:center;margin-block-start:.7rem;font-size:.85rem}

/* a11y modes applied on <html> */
html.a11y-contrast{--cream:#fff;--cream-2:#fff;--body:#000;--ink:#000;--muted:#222;--line:#000;--gold-deep:#6b3f12}
html.a11y-contrast body{background:#fff}
html.a11y-contrast .hero,html.a11y-contrast .trust,html.a11y-contrast .heritage,html.a11y-contrast .site-footer{background:#000;color:#fff}
html.a11y-grayscale{filter:grayscale(1)}
html.a11y-links a{text-decoration:underline!important;font-weight:700!important}
html.a11y-readable,html.a11y-readable *{font-family:Arial,"Assistant",sans-serif!important}

/* ---------- toast ---------- */
.toast{position:fixed;inset-block-end:1.3rem;inset-inline-start:50%;transform:translate(50%,150%);background:var(--espresso);color:var(--cream);padding:.85rem 1.4rem;border-radius:30px;font-weight:700;z-index:140;box-shadow:var(--shadow);display:flex;gap:.5rem;align-items:center;max-width:90vw}
.toast.is-open{transform:translate(50%,0)}
.toast b{color:rgba(255,255,255,.75)}

/* ---------- reveal (varied, reduced-motion safe) ---------- */
[data-reveal]{opacity:0;transition:opacity .7s var(--ease),transform .7s var(--ease)}
[data-reveal="up"]{transform:translateY(28px)}
[data-reveal="left"]{transform:translateX(28px)}
[data-reveal="scale"]{transform:scale(.94)}
[data-reveal].is-in{opacity:1;transform:none}

/* ---------- responsive ---------- */
@media(max-width:1000px){
  .pdp{grid-template-columns:1fr}.pdp__info,.pdp__media{position:static}
  .checkout{grid-template-columns:1fr}.osum{position:static}
  .heritage__grid{grid-template-columns:1fr}.heritage__media{order:-1;max-width:330px;margin-inline:auto}
  .site-footer__grid{grid-template-columns:1fr 1fr}
  .cat-mosaic,.product-grid,.occ-grid,.trust__grid{grid-template-columns:repeat(3,1fr)}
  .cat-card--feature{grid-column:span 2;grid-row:span 1;aspect-ratio:1}
}
@media(max-width:760px){
  .navbar{display:none}
  .burger{display:flex;order:-1}
  .brand{margin-inline-end:auto}
  .hsearch{order:5;flex-basis:100%;max-width:none;margin-inline:0}
  .mainnav{display:block;position:fixed;inset-block:0;right:0;left:auto;width:86%;max-width:340px;background:#fff;padding:3.4rem 1.3rem 2rem;transform:translateX(100%);transition:transform .35s var(--ease);z-index:115;box-shadow:var(--shadow);overflow-y:auto}
  .mainnav.is-open{transform:translateX(0)}
  .mnav__close{position:absolute;inset-block-start:.7rem;inset-inline-end:.8rem;width:40px;height:40px;border:none;background:var(--cream-2);color:var(--ink);border-radius:50%;font-size:1.1rem;cursor:pointer}
  .mnav__link{display:block;padding-block:.9rem;border-block-end:1px solid var(--line);font-size:1.08rem;font-weight:700;color:var(--ink)}
  .mnav__links a{padding:.55rem .4rem;color:var(--ink);font-weight:600}
  .cat-mosaic,.product-grid,.occ-grid{grid-template-columns:repeat(2,1fr)}
  .trust__grid{grid-template-columns:1fr 1fr;gap:1rem}
  .trust__item{flex-direction:column;text-align:center;gap:.4rem}
  .formgrid{grid-template-columns:1fr}
  .news form{flex-direction:column}
  .cat-card--feature{grid-column:span 2;grid-row:span 1}
}
@media(max-width:430px){
  .product-grid,.cat-mosaic,.occ-grid{grid-template-columns:1fr 1fr;gap:.8rem}
  .site-footer__grid{grid-template-columns:1fr}
  .trust__grid{grid-template-columns:1fr}
}
/* ---------- mobile-first: sticky buy bar + larger tap targets ---------- */
.pdp-buybar{position:fixed;inset-inline:0;inset-block-end:0;z-index:85;display:flex;align-items:center;gap:.8rem;justify-content:space-between;background:var(--cream);border-block-start:1px solid var(--line);box-shadow:0 -10px 26px -18px rgba(0,0,0,.07);padding:.6rem .9rem;padding-block-end:calc(.6rem + env(safe-area-inset-bottom))}
.pdp-buybar__info{display:flex;flex-direction:column;line-height:1.15;min-width:0}
.pdp-buybar__price{font-family:var(--serif);font-weight:700;font-size:1.25rem;color:var(--brown)}
.pdp-buybar__name{font-size:.8rem;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:46vw}
.pdp-buybar .btn{flex:0 0 auto;padding-block:.8rem;min-height:48px}
body:has(.pdp-buybar){padding-block-end:76px}
@media(min-width:761px){.pdp-buybar{display:none}body:has(.pdp-buybar){padding-block-end:0}}
@media(max-width:760px){
  body:has(.pdp-buybar) .a11y-fab{inset-block-end:calc(76px + .7rem)}
  .iconbtn{width:44px;height:44px}
  .chip{padding-block:.62rem}
  .pcard__foot{display:grid;grid-template-columns:1fr;gap:.5rem}
  .pcard__add{display:flex;width:100%;height:44px;justify-content:center}
}

/* ---------- reduced motion (rule 7 + 9) ---------- */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  [data-reveal]{opacity:1!important;transform:none!important}
}
html.a11y-stop *,html.a11y-stop *::before,html.a11y-stop *::after{animation:none!important;transition:none!important}
html.a11y-stop [data-reveal]{opacity:1!important;transform:none!important}

/* ---- single-collection mode: remove block when adding more collections ---- */
.hsearch,#megaBtn,#megaPanel,#occasions,
.navbar a[href*="occasions"],.catnav__row,
.filters,#filtersToggle,.viewtoggle{display:none!important}
