/* ============================================================
   GALERION — Design System
   Muzeum / editorial · kość słoniowa · grafit · mosiądz
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300..700;1,9..144,300..600&family=Playfair+Display:ital,wght@0,400..700;1,400..600&family=Inter:wght@300;400;500;600&display=swap');

/* ----------  TOKENS  ---------- */
:root{
  --ivory:#F7F4EF;
  --ivory-deep:#EFEAE1;
  --graphite:#1C1B19;
  --graphite-soft:#3A3733;
  --muted:#6E6A63;
  --brass:#B08D57;
  --brass-deep:#9A784A;
  --white:#FFFFFF;
  --line:rgba(28,27,25,.12);
  --line-soft:rgba(28,27,25,.07);

  --serif:'Fraunces',Georgia,serif;
  --sans:'Inter',system-ui,sans-serif;

  --shadow-sm:0 1px 2px rgba(28,27,25,.04), 0 4px 14px rgba(28,27,25,.05);
  --shadow-md:0 6px 18px rgba(28,27,25,.07), 0 22px 50px rgba(28,27,25,.09);
  --shadow-frame:0 2px 4px rgba(28,27,25,.10), 0 18px 40px rgba(28,27,25,.16);

  --maxw:1240px;
  --pad:clamp(20px,5vw,64px);
  --r:3px;

  --ease:cubic-bezier(.22,.61,.36,1);
}

/* theme: heading font + accent (tweakable, persisted) */
:root[data-head="playfair"]{ --serif:'Playfair Display',Georgia,serif; }
:root[data-accent="ink"]{ --brass:#2F4858; --brass-deep:#223742; }
:root[data-accent="terracotta"]{ --brass:#B5613F; --brass-deep:#974A2D; }

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  background:var(--ivory);
  color:var(--graphite);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
::selection{background:var(--brass);color:var(--white)}

/* ----------  TYPE  ---------- */
h1,h2,h3,h4{font-family:var(--serif);font-weight:400;margin:0;line-height:1.06;letter-spacing:-.01em}
h1{font-size:clamp(2.6rem,6vw,5rem);font-optical-sizing:auto}
h2{font-size:clamp(1.9rem,3.4vw,3rem)}
h3{font-size:clamp(1.3rem,2vw,1.7rem)}
p{margin:0 0 1em}
.lead{font-size:clamp(1.05rem,1.5vw,1.3rem);color:var(--graphite-soft);line-height:1.65}

.eyebrow{
  font-family:var(--sans);
  font-size:.72rem;
  font-weight:500;
  text-transform:uppercase;
  letter-spacing:.22em;
  color:var(--brass-deep);
}
.eyebrow--muted{color:var(--muted)}

.serif{font-family:var(--serif)}
.ital{font-style:italic}

/* ----------  LAYOUT  ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad)}
.section{padding-block:clamp(56px,8vw,112px)}
.section--tight{padding-block:clamp(40px,5vw,64px)}
.hairline{height:1px;background:var(--line);border:0;margin:0}
.center{text-align:center}

.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:clamp(28px,4vw,52px)}
.section-head h2{max-width:18ch}
.section-head .eyebrow{display:block;margin-bottom:14px}
.link-more{
  font-size:.8rem;text-transform:uppercase;letter-spacing:.14em;color:var(--graphite);
  white-space:nowrap;border-bottom:1px solid var(--brass);padding-bottom:3px;transition:color .25s
}
.link-more:hover{color:var(--brass-deep)}

/* ----------  BUTTONS  ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--sans);font-size:.86rem;font-weight:500;
  letter-spacing:.08em;text-transform:uppercase;
  padding:15px 26px;border:1px solid transparent;border-radius:var(--r);
  transition:all .3s var(--ease);
}
.btn svg{width:16px;height:16px}
.btn--primary{background:var(--graphite);color:var(--ivory)}
.btn--primary:hover{background:var(--brass-deep)}
.btn--brass{background:var(--brass);color:var(--white)}
.btn--brass:hover{background:var(--brass-deep)}
.btn--ghost{background:transparent;color:var(--graphite);border-color:var(--line)}
.btn--ghost:hover{border-color:var(--graphite);background:var(--white)}
.btn--block{width:100%;justify-content:center}
.btn--lg{padding:18px 34px;font-size:.92rem}

/* ----------  NAV  ---------- */
.nav{
  position:sticky;top:0;z-index:50;
  background:color-mix(in srgb, var(--ivory) 82%, transparent);
  backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid var(--line);
}
.nav__in{display:flex;align-items:center;justify-content:space-between;height:68px;gap:20px}
.brand{font-family:var(--serif);font-size:1.5rem;letter-spacing:.04em;font-weight:500}
.brand sup{font-size:.5em;color:var(--brass);letter-spacing:.2em;margin-left:.25em;vertical-align:super}
.nav__links{display:flex;gap:34px;align-items:center}
.nav__links a{
  font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:var(--graphite-soft);
  position:relative;padding:6px 0;transition:color .25s
}
.nav__links a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--brass);transition:width .3s var(--ease)}
.nav__links a:hover{color:var(--graphite)}
.nav__links a:hover::after,.nav__links a[aria-current="page"]::after{width:100%}
.nav__right{display:flex;align-items:center;gap:18px}
.cart-btn{display:flex;align-items:center;gap:8px;background:none;border:0;color:var(--graphite);padding:6px}
.cart-btn svg{width:22px;height:22px}
.cart-count{
  font-size:.7rem;min-width:18px;height:18px;padding:0 5px;border-radius:9px;
  background:var(--brass);color:#fff;display:grid;place-items:center;font-weight:600;letter-spacing:0
}
.nav__menu-btn{display:none;background:none;border:0;padding:6px}
.nav__menu-btn svg{width:24px;height:24px}

@media(max-width:860px){
  .nav__links{
    position:fixed;inset:68px 0 auto 0;flex-direction:column;gap:0;
    background:var(--ivory);border-bottom:1px solid var(--line);
    transform:translateY(-120%);transition:transform .4s var(--ease);padding:8px 0;align-items:stretch
  }
  .nav__links.open{transform:translateY(0)}
  .nav__links a{padding:16px var(--pad);border-bottom:1px solid var(--line-soft);font-size:.9rem}
  .nav__links a::after{display:none}
  .nav__menu-btn{display:block}
}

/* ----------  POSTER (placeholder art system)  ---------- */
/* A poster = passe-partout mat + framed art field. Art fields are
   palette-accurate abstractions standing in for real reproductions. */
.poster{
  position:relative;background:var(--white);
  padding:8.5%;
  box-shadow:var(--shadow-frame);
  border:1px solid rgba(28,27,25,.06);
}
.poster--framed{
  padding:5.5%;
  background:linear-gradient(135deg,#2b2622,#171411 60%,#241f1b);
  border:1px solid #0e0c0a;
}
.poster--framed .poster__mat{background:#faf8f3}
.poster__mat{
  background:var(--white);padding:11% 11% 13%;
  box-shadow:inset 0 0 0 1px rgba(28,27,25,.05), inset 0 1px 8px rgba(28,27,25,.04);
}
.poster__art{
  position:relative;aspect-ratio:3/4;overflow:hidden;
  box-shadow:0 1px 2px rgba(0,0,0,.18);
  background:#ccc;
}
.poster__art::after{ /* subtle paper sheen */
  content:"";position:absolute;inset:0;
  background:linear-gradient(115deg,rgba(255,255,255,.10),transparent 40%);
  pointer-events:none;mix-blend-mode:overlay
}
.poster__sig{ /* tiny faux-signature/title in mat */
  position:absolute;left:0;right:0;bottom:3.5%;text-align:center;
  font-family:var(--serif);font-style:italic;font-size:.62rem;color:var(--muted);letter-spacing:.02em
}

/* --- Art treatments (abstract, palette-accurate) --- */
.art-wave{background:
  radial-gradient(120% 90% at 80% 18%,#f3ede0 0 22%,transparent 23%),
  radial-gradient(60% 50% at 18% 78%,#e9dfca 0 40%,transparent 41%),
  repeating-linear-gradient(115deg,#1f3d63 0 14px,#2b568a 14px 22px,#dfe7ee 22px 26px,#1f3d63 26px 40px),
  linear-gradient(180deg,#cdd9e4,#284b78)}
.art-starry{background:
  radial-gradient(8px 8px at 22% 30%,#f4d784 0 35%,transparent 40%),
  radial-gradient(6px 6px at 64% 22%,#f0cf78 0 35%,transparent 40%),
  radial-gradient(10px 10px at 80% 60%,#e9c66a 0 35%,transparent 40%),
  conic-gradient(from 200deg at 38% 46%,#1b2c5a,#2d4a86,#1b2c5a),
  linear-gradient(160deg,#16244c,#28407a 55%,#101a38)}
.art-klimt{background:
  radial-gradient(50% 40% at 50% 58%,#b07a3e 0 30%,transparent 60%),
  repeating-linear-gradient(45deg,#caa14e 0 8px,#a07c33 8px 16px),
  linear-gradient(160deg,#d9b25a,#8a6a2c)}
.art-mucha{background:
  radial-gradient(60% 45% at 50% 28%,#efe7d2 0 40%,transparent 60%),
  conic-gradient(from 90deg at 50% 38%,#9aa978,#c4cba0,#9aa978),
  linear-gradient(180deg,#cdd0ac,#7e8a5e)}
.art-vermeer{background:
  radial-gradient(45% 38% at 52% 44%,#e9d9b8 0 30%,transparent 55%),
  linear-gradient(150deg,#2a2620 0 55%,#0f0d0b),
  #14110d}
.art-botanika{background:
  radial-gradient(40% 60% at 50% 55%,#7d8a5c 0 22%,transparent 55%),
  linear-gradient(180deg,#f3efe4,#e7e2d2)}
.art-travel{background:
  linear-gradient(180deg,#e3b15a 0 38%,#cf8e3e 38% 41%,#8aa6a0 41% 64%,#6f8c86 64% 67%,#dfd6c2 67%)}
.art-line{background:
  radial-gradient(closest-side at 50% 48%,transparent 0 46%,#d9d2c4 47% 48%,transparent 49%),
  linear-gradient(120deg,#f4f1e9,#efe9dd)}
.art-typo{background:linear-gradient(135deg,#1c1b19 0 50%,#d6452e 50%)}
.art-abstrakcja{background:
  linear-gradient(115deg,#2f4858 0 40%,#dfb35a 40% 55%,#b5613f 55% 70%,#e9e3d6 70%)}
.art-pejzaz{background:
  linear-gradient(180deg,#cfd6d4 0 34%,#aeb9b3 34% 50%,#7d8b80 50% 70%,#4f5d52 70%)}
.art-mapa{background:
  repeating-linear-gradient(0deg,transparent 0 22px,rgba(120,95,55,.18) 22px 23px),
  repeating-linear-gradient(90deg,transparent 0 22px,rgba(120,95,55,.18) 22px 23px),
  linear-gradient(160deg,#efe6d2,#ddccab)}
.art-ukiyoe{background:
  radial-gradient(50% 40% at 30% 30%,#e7d4a8 0 30%,transparent 55%),
  linear-gradient(180deg,#cf6a4a 0 30%,#e0e6ea 30% 60%,#2f5d7a 60%)}
.art-nouveau{background:
  conic-gradient(from 30deg at 50% 50%,#b08d57,#d8c79a,#8a6a2c,#b08d57)}

/* ----------  PRODUCT CARD  ---------- */
.card{display:flex;flex-direction:column;gap:14px;text-align:left;background:none}
.card__media{position:relative;padding:6% 9% 9%;background:var(--ivory-deep);overflow:hidden}
.card__media .poster{transition:transform .6s var(--ease)}
.card:hover .poster{transform:scale(1.035)}
.card__badge{
  position:absolute;top:14px;left:14px;z-index:2;
  font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;
  background:var(--white);color:var(--graphite);padding:5px 9px;border:1px solid var(--line);border-radius:2px
}
.card__badge--orig{background:var(--graphite);color:var(--ivory);border-color:var(--graphite)}
.card__cat{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.card__title{font-family:var(--serif);font-size:1.18rem;line-height:1.2}
.card__title .ital{display:block;font-size:.86em}
.card__artist{font-size:.86rem;color:var(--graphite-soft);margin-top:-6px}
.card__foot{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-top:4px}
.card__price{font-family:var(--serif);font-size:1.05rem}
.card__price b{font-weight:600}
.card__price small{font-size:.72rem;color:var(--muted);font-family:var(--sans);margin-right:4px;text-transform:uppercase;letter-spacing:.1em}
.card__buy{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--brass-deep);border-bottom:1px solid transparent;transition:border-color .25s}
.card:hover .card__buy{border-color:var(--brass)}

/* grids */
.grid{display:grid;gap:clamp(20px,3vw,40px)}
.grid--4{grid-template-columns:repeat(4,1fr)}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--2{grid-template-columns:repeat(2,1fr)}
@media(max-width:1024px){.grid--4{grid-template-columns:repeat(3,1fr)}}
@media(max-width:760px){.grid--4,.grid--3{grid-template-columns:repeat(2,1fr)}.grid--2{grid-template-columns:1fr}}
@media(max-width:440px){.grid--4,.grid--3{grid-template-columns:1fr}}

/* ----------  CATEGORY TILE  ---------- */
.cat-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
@media(max-width:980px){.cat-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.cat-grid{grid-template-columns:repeat(2,1fr)}}
.tile{
  position:relative;aspect-ratio:4/5;overflow:hidden;display:flex;align-items:flex-end;
  background:var(--graphite);border-radius:var(--r)
}
.tile__art{position:absolute;inset:0;transition:transform .7s var(--ease)}
.tile:hover .tile__art{transform:scale(1.06)}
.tile::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(15,13,11,.62),rgba(15,13,11,.05) 55%)}
.tile__label{position:relative;z-index:2;color:#fff;padding:16px 16px 18px;width:100%}
.tile__label .n{font-family:var(--serif);font-size:1.12rem;display:block}
.tile__label .c{font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;opacity:.8}
.tile__arrow{position:absolute;top:14px;right:14px;z-index:2;width:30px;height:30px;border-radius:50%;
  background:rgba(255,255,255,.14);display:grid;place-items:center;opacity:0;transform:translateY(-4px);transition:.3s var(--ease)}
.tile__arrow svg{width:14px;height:14px;stroke:#fff}
.tile:hover .tile__arrow{opacity:1;transform:translateY(0)}

/* ----------  H SCROLLER (bestsellery)  ---------- */
.scroller{display:flex;gap:clamp(16px,2.4vw,30px);overflow-x:auto;scroll-snap-type:x mandatory;
  padding-bottom:10px;margin-inline:calc(var(--pad)*-1);padding-inline:var(--pad);scrollbar-width:none}
.scroller::-webkit-scrollbar{display:none}
.scroller>.card{scroll-snap-align:start;flex:0 0 clamp(230px,26vw,300px)}
.scroll-ctrl{display:flex;gap:10px}
.scroll-ctrl button{width:42px;height:42px;border-radius:50%;border:1px solid var(--line);background:var(--white);
  display:grid;place-items:center;transition:.25s}
.scroll-ctrl button:hover{border-color:var(--graphite)}
.scroll-ctrl svg{width:16px;height:16px;stroke:var(--graphite)}

/* ----------  TRUST BAR  ---------- */
.trust{border-block:1px solid var(--line);background:var(--white)}
.trust__in{display:flex;flex-wrap:wrap;justify-content:center;gap:10px 38px;padding-block:18px}
.trust span{display:inline-flex;align-items:center;gap:10px;font-size:.74rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--graphite-soft)}
.trust span::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--brass)}

/* ----------  HERO  ---------- */
.hero{position:relative;overflow:hidden}
.hero__in{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,5vw,72px);align-items:center;
  padding-block:clamp(40px,6vw,86px)}
.hero__copy .eyebrow{margin-bottom:22px;display:block}
.hero__copy h1{margin-bottom:36px;line-height:1.12}
.hero__copy .lead{max-width:40ch;margin-bottom:34px}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap}
.hero__art{position:relative}
.hero__art .poster{max-width:430px;margin-inline:auto}
.hero__tag{position:absolute;bottom:6%;left:-6%;background:var(--white);box-shadow:var(--shadow-md);
  padding:14px 18px;border-radius:var(--r);max-width:200px}
.hero__tag .eyebrow{font-size:.62rem}
.hero__tag p{margin:6px 0 0;font-family:var(--serif);font-size:.96rem;line-height:1.3}
@media(max-width:860px){
  .hero__in{grid-template-columns:1fr;text-align:center}
  .hero__copy .lead{margin-inline:auto}
  .hero__cta{justify-content:center}
  .hero__art{order:-1}
  .hero__art .poster{max-width:300px}
  .hero__tag{display:none}
}

/* ----------  EDITORIAL (historia dzieła)  ---------- */
.editorial{background:var(--graphite);color:var(--ivory)}
.editorial .wrap{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(34px,5vw,80px);align-items:center}
.editorial h2{color:var(--ivory)}
.editorial .eyebrow{color:var(--brass);display:block;margin-bottom:18px}
.editorial p{color:rgba(247,244,239,.74)}
.editorial .poster{max-width:360px}
.editorial .drop::first-letter{font-family:var(--serif);font-size:3.4em;float:left;line-height:.8;
  padding:6px 12px 0 0;color:var(--brass)}
.editorial__meta{display:flex;gap:34px;margin-top:26px;flex-wrap:wrap}
.editorial__meta div span{display:block}
.editorial__meta .k{font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--brass);margin-bottom:5px}
.editorial__meta .v{font-family:var(--serif);font-size:1.05rem}
@media(max-width:820px){.editorial .wrap{grid-template-columns:1fr}.editorial .poster{max-width:260px;margin-inline:auto}}

/* ----------  NEWSLETTER  ---------- */
.news{text-align:center}
.news .wrap{max-width:680px}
.news h2{margin-bottom:16px}
.news form{display:flex;gap:10px;margin-top:28px;max-width:480px;margin-inline:auto}
.news input{flex:1;padding:15px 18px;border:1px solid var(--line);border-radius:var(--r);background:var(--white);
  font-family:inherit;font-size:.95rem;color:var(--graphite)}
.news input:focus{outline:none;border-color:var(--brass)}
.news__ok{color:var(--brass-deep);font-size:.9rem;margin-top:14px;min-height:1.2em}
.news small{display:block;margin-top:14px;color:var(--muted);font-size:.76rem}
@media(max-width:520px){.news form{flex-direction:column}}

/* ----------  FOOTER  ---------- */
.footer{background:var(--ivory-deep);border-top:1px solid var(--line)}
.footer__top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:34px;padding-block:clamp(48px,6vw,72px)}
.footer .brand{font-size:1.7rem;margin-bottom:16px;display:inline-block}
.footer__top p{color:var(--muted);font-size:.9rem;max-width:30ch}
.footer h4{font-family:var(--sans);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--graphite);margin-bottom:16px;font-weight:600}
.footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px}
.footer ul a{font-size:.9rem;color:var(--graphite-soft);transition:color .2s}
.footer ul a:hover{color:var(--brass-deep)}
.footer__socials{display:flex;gap:12px;margin-top:20px}
.footer__socials a{width:38px;height:38px;border:1px solid var(--line);border-radius:50%;display:grid;place-items:center;transition:.25s}
.footer__socials a:hover{background:var(--graphite);border-color:var(--graphite)}
.footer__socials a:hover svg{fill:var(--ivory)}
.footer__socials svg{width:17px;height:17px;fill:var(--graphite)}
.footer__bar{border-top:1px solid var(--line);padding-block:22px;display:flex;justify-content:space-between;
  flex-wrap:wrap;gap:10px;font-size:.78rem;color:var(--muted)}
@media(max-width:820px){.footer__top{grid-template-columns:1fr 1fr;gap:30px}}
@media(max-width:480px){.footer__top{grid-template-columns:1fr}}

/* ----------  REVEAL  ---------- */
/* No entrance animation — content is always visible & static for reliability. */
.reveal{opacity:1}

/* ----------  TWEAKS panel  ---------- */
.tweaks{position:fixed;right:18px;bottom:18px;z-index:100;font-family:var(--sans)}
.tweaks__toggle{width:48px;height:48px;border-radius:50%;background:var(--graphite);color:var(--ivory);
  border:0;display:grid;place-items:center;box-shadow:var(--shadow-md)}
.tweaks__toggle svg{width:20px;height:20px;stroke:var(--ivory)}
.tweaks__panel{position:absolute;right:0;bottom:60px;width:248px;background:var(--white);border:1px solid var(--line);
  border-radius:8px;box-shadow:var(--shadow-md);padding:18px;display:none}
.tweaks.open .tweaks__panel{display:block}
.tweaks__panel h5{margin:0 0 14px;font-family:var(--serif);font-weight:500;font-size:1.05rem}
.tw-row{margin-bottom:16px}
.tw-row label{font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:8px}
.tw-seg{display:flex;gap:6px}
.tw-seg button{flex:1;padding:8px 6px;border:1px solid var(--line);background:var(--ivory);border-radius:4px;font-size:.74rem;color:var(--graphite-soft);transition:.2s}
.tw-seg button[aria-pressed="true"]{background:var(--graphite);color:var(--ivory);border-color:var(--graphite)}
.tw-sw{display:flex;gap:8px}
.tw-sw button{width:30px;height:30px;border-radius:50%;border:2px solid transparent}
.tw-sw button[aria-pressed="true"]{border-color:var(--graphite)}

/* utility */
.muted{color:var(--muted)}
.mb0{margin-bottom:0}
.maxw-prose{max-width:64ch}

/* ----------  PAGE HEADER / BREADCRUMB  ---------- */
.crumb{display:flex;gap:8px;align-items:center;font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:22px}
.crumb a:hover{color:var(--brass-deep)}
.crumb span{opacity:.5}
.page-head{padding-block:clamp(38px,5vw,66px) clamp(24px,3vw,38px)}
.page-head .eyebrow{display:block;margin-bottom:14px}
.page-head h1{font-size:clamp(2.2rem,4.5vw,3.6rem)}
.page-head p{max-width:54ch;margin-top:18px}

/* ----------  FILTER BAR  ---------- */
.filterbar{position:sticky;top:68px;z-index:30;background:color-mix(in srgb,var(--ivory) 86%,transparent);
  backdrop-filter:blur(10px);border-block:1px solid var(--line)}
.filterbar__in{display:flex;align-items:center;justify-content:space-between;gap:18px;padding-block:14px;flex-wrap:wrap}
.fgroup{display:flex;align-items:center;gap:10px}
.fgroup>span{font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.chips{display:flex;gap:7px;flex-wrap:wrap}
.chip{font-size:.78rem;letter-spacing:.04em;padding:8px 15px;border:1px solid var(--line);border-radius:100px;
  background:var(--white);color:var(--graphite-soft);transition:.22s}
.chip:hover{border-color:var(--graphite)}
.chip[aria-pressed="true"]{background:var(--graphite);color:var(--ivory);border-color:var(--graphite)}
.filter-count{font-size:.82rem;color:var(--muted)}
.filter-count b{font-family:var(--serif);color:var(--graphite);font-weight:500}
@media(max-width:640px){.filterbar__in{gap:12px}.fgroup{width:100%;justify-content:space-between}}

.cat-empty{text-align:center;padding:60px 0;color:var(--muted)}

/* category nav rail */
.cat-rail{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;padding-bottom:4px}
.cat-rail::-webkit-scrollbar{display:none}
.cat-rail a{white-space:nowrap;font-size:.8rem;letter-spacing:.04em;padding:8px 16px;border:1px solid var(--line);
  border-radius:100px;color:var(--graphite-soft);transition:.2s}
.cat-rail a:hover,.cat-rail a[aria-current="true"]{background:var(--graphite);color:var(--ivory);border-color:var(--graphite)}

/* ----------  PRODUCT PAGE  ---------- */
.pdp{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(34px,5vw,72px);align-items:start}
.pdp__gallery{position:sticky;top:96px}
/* wall mockup */
.wall{position:relative;background:
   linear-gradient(180deg,#efe9df,#e7e0d3);
   padding:clamp(34px,6vw,72px) clamp(30px,8vw,90px);
   border-radius:var(--r);overflow:hidden;box-shadow:inset 0 0 60px rgba(28,27,25,.05)}
.wall::before{content:"";position:absolute;left:0;right:0;bottom:0;height:34%;
   background:linear-gradient(180deg,transparent,rgba(28,27,25,.05));border-top:1px solid rgba(28,27,25,.06)}
.wall .poster{max-width:340px;margin-inline:auto;position:relative;z-index:2}
.wall__floor-shadow{position:absolute;left:50%;bottom:8%;width:42%;height:18px;transform:translateX(-50%);
   background:radial-gradient(ellipse,rgba(28,27,25,.18),transparent 70%);z-index:1}
.thumbs{display:flex;gap:12px;margin-top:18px;justify-content:center}
.thumb{width:64px;aspect-ratio:3/4;padding:5px;background:var(--white);border:1px solid var(--line);cursor:pointer;
   border-radius:2px;transition:.2s}
.thumb[aria-pressed="true"]{border-color:var(--graphite)}
.thumb .t-art{width:100%;height:100%}

/* info column */
.pdp__info{padding-top:6px}
.pdp__cat{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--brass-deep);margin-bottom:14px}
.pdp__info h1{font-size:clamp(2rem,3.6vw,3.1rem);line-height:1.05;margin-bottom:6px}
.pdp__artist{font-family:var(--serif);font-style:italic;font-size:1.2rem;color:var(--graphite-soft);margin-bottom:20px}
.pdp__badges{display:flex;gap:8px;margin-bottom:26px}
.tagbadge{font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;padding:5px 10px;
   border:1px solid var(--line);border-radius:2px;color:var(--graphite-soft)}
.tagbadge--pd{background:var(--graphite);color:var(--ivory);border-color:var(--graphite)}

.opt{margin-bottom:24px}
.opt__label{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:11px}
.opt__label .k{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.opt__label .hint{font-size:.8rem;color:var(--muted)}
.opt__row{display:flex;gap:10px;flex-wrap:wrap}
.opt-btn{flex:1;min-width:120px;text-align:left;padding:14px 16px;border:1px solid var(--line);border-radius:var(--r);
   background:var(--white);transition:.2s;cursor:pointer}
.opt-btn:hover{border-color:var(--graphite-soft)}
.opt-btn[aria-pressed="true"]{border-color:var(--graphite);box-shadow:inset 0 0 0 1px var(--graphite)}
.opt-btn .n{display:block;font-family:var(--serif);font-size:1.05rem;margin-bottom:2px}
.opt-btn .d{display:block;font-size:.76rem;color:var(--muted)}
.opt-btn .p{float:right;font-size:.78rem;color:var(--brass-deep);font-weight:500}

.price-block{display:flex;align-items:baseline;gap:12px;margin:26px 0 6px;padding-top:24px;border-top:1px solid var(--line)}
.price-now{font-family:var(--serif);font-size:2.2rem}
.price-meta{font-size:.82rem;color:var(--muted)}
.pdp__cta{margin-top:22px}
.pdp__cta .btn{font-size:.95rem;padding:18px 28px}
.tiktok-note{font-size:.8rem;color:var(--muted);margin-top:14px;display:flex;align-items:center;gap:8px}
.tiktok-note svg{width:15px;height:15px;flex:none;stroke:var(--brass-deep)}

/* spec accordion-ish list */
.specs{margin-top:30px;border-top:1px solid var(--line)}
.specs__row{display:flex;justify-content:space-between;gap:20px;padding:14px 0;border-bottom:1px solid var(--line-soft);font-size:.9rem}
.specs__row .k{color:var(--muted)}
.specs__row .v{text-align:right}

/* PDP story + related */
.pdp-story{background:var(--white);border-block:1px solid var(--line)}
.pdp-story .wrap{display:grid;grid-template-columns:1fr 1.2fr;gap:clamp(30px,5vw,70px);align-items:center}
.pdp-story .eyebrow{display:block;margin-bottom:16px}
.pdp-story .drop::first-letter{font-family:var(--serif);font-size:3.2em;float:left;line-height:.8;padding:6px 12px 0 0;color:var(--brass)}
@media(max-width:900px){
  .pdp{grid-template-columns:1fr}
  .pdp__gallery{position:static}
  .pdp-story .wrap{grid-template-columns:1fr}
}

/* ----------  ABOUT  ---------- */
.about-hero{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(34px,5vw,72px);align-items:center}
.about-hero .poster{max-width:330px;margin-inline:auto}
.about-hero h1{font-size:clamp(2.4rem,5vw,4rem);line-height:1.05;margin-bottom:22px}
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,40px)}
.value{background:var(--white);border:1px solid var(--line);border-radius:var(--r);padding:30px;box-shadow:var(--shadow-sm)}
.value__n{font-family:var(--serif);font-size:1.5rem;color:var(--brass);margin-bottom:14px}
.value h3{font-size:1.25rem;margin-bottom:10px}
.value p{color:var(--graphite-soft);font-size:.92rem;margin:0}
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.stat .v{font-family:var(--serif);font-size:clamp(2rem,3.5vw,2.8rem);display:block;line-height:1}
.stat .k{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:8px;display:block}
@media(max-width:820px){.about-hero{grid-template-columns:1fr}.about-hero .poster{max-width:240px}.values{grid-template-columns:1fr}.stat-row{grid-template-columns:repeat(2,1fr);gap:34px}}

/* ----------  LEGAL / PROSE  ---------- */
.legal{display:grid;grid-template-columns:230px 1fr;gap:clamp(30px,5vw,64px);align-items:start}
.legal__nav{position:sticky;top:96px;display:flex;flex-direction:column;gap:4px}
.legal__nav a{font-size:.88rem;color:var(--graphite-soft);padding:9px 14px;border-radius:var(--r);transition:.2s}
.legal__nav a:hover{background:var(--white);color:var(--graphite)}
.legal__nav a[aria-current="page"]{background:var(--graphite);color:var(--ivory)}
.prose{max-width:68ch}
.prose h2{font-size:1.5rem;margin:38px 0 14px}
.prose h2:first-child{margin-top:0}
.prose h3{font-size:1.12rem;font-family:var(--sans);font-weight:600;margin:24px 0 8px}
.prose p,.prose li{color:var(--graphite-soft);font-size:.96rem;line-height:1.7}
.prose ul,.prose ol{padding-left:20px;margin:0 0 1em}
.prose li{margin-bottom:7px}
.prose strong{color:var(--graphite);font-weight:600}
.prose .upd{font-size:.82rem;color:var(--muted);margin-bottom:30px}
.callout{background:var(--white);border:1px solid var(--line);border-left:3px solid var(--brass);
  padding:18px 22px;border-radius:var(--r);margin:22px 0}
.callout p{margin:0;color:var(--graphite)}
@media(max-width:820px){.legal{grid-template-columns:1fr}.legal__nav{position:static;flex-direction:row;flex-wrap:wrap;margin-bottom:20px}}
