/* ============================================================
   Rabbit Hole — Antiques & Art  ·  warm, artisanal showcase
   ============================================================ */
:root{
  --cream:#FBF7EF; --cream-2:#F4EBDC; --paper:#FFFDF8;
  --brown:#6B4A2E; --brown-deep:#4A3221;
  --purple:#8A6FB0; --purple-deep:#6E5896;
  --sage:#586A41; --sage-deep:#41502F;
  --peach:#E2A579; --coral:#C9774F; --gold:#CFA23B;
  --ink:#3B342B; --muted:#8B8070; --line:rgba(77,53,91,.18);
  --shadow:0 18px 40px -22px rgba(60,45,75,.42);
  --r:14px;
  --display:'Cormorant Garamond',Georgia,'Times New Roman',serif;
  --script:'Pinyon Script','Cormorant Garamond',cursive;
  --body:'EB Garamond',Georgia,'Times New Roman',serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--cream);color:var(--ink);
  font-family:var(--body);font-size:18px;line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%}
a{color:inherit}
h1,h2,h3{font-family:var(--display);font-weight:600;color:var(--brown-deep);line-height:1.12;margin:0}
.wrap{max-width:1200px;margin:0 auto;padding:0 28px}
.eyebrow{font-family:var(--body);font-size:.74rem;letter-spacing:.32em;text-transform:uppercase;color:var(--coral);font-weight:600}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5em;cursor:pointer;border:none;
  font-family:var(--body);font-size:1rem;letter-spacing:.04em;
  padding:.72em 1.5em;border-radius:999px;text-decoration:none;transition:.25s;
}
.btn-primary{background:var(--purple);color:#FFF8EC;box-shadow:0 10px 22px -12px rgba(110,88,150,.5)}
.btn-primary:hover{background:var(--purple-deep);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--purple);border:1.5px solid var(--purple)}
.btn-ghost:hover{border-color:var(--purple-deep);background:rgba(138,111,176,.08)}
.btn-etsy{background:var(--coral);color:#fff;box-shadow:0 10px 22px -12px rgba(201,119,79,.8)}
.btn-etsy:hover{background:#b9663f;transform:translateY(-2px)}

/* ---------- header / nav with dropdowns ---------- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(251,247,239,.92);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.site-header .wrap{display:flex;align-items:center;gap:18px;height:74px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;margin-right:auto}
.brand .mark{font-family:var(--script);font-size:2rem;color:#584166;line-height:1;margin-top:6px}
.brand .sub{font-size:.66rem;letter-spacing:.34em;text-transform:uppercase;color:var(--muted);font-weight:600}
.brand-logo{height:56px;width:auto;display:block;mix-blend-mode:multiply}
@media(max-width:820px){.brand-logo{height:48px}}
.nav-links{display:flex;align-items:center;gap:24px}
.nav-links>a,.navlink{text-decoration:none;color:var(--ink);font-size:1rem;letter-spacing:.02em;transition:.2s}
.nav-links>a:hover,.navlink:hover{color:var(--coral)}
.navitem{position:relative}
.navlink{display:inline-flex;align-items:center;gap:6px;cursor:pointer}
.caret{width:6px;height:6px;border-right:1.6px solid currentColor;border-bottom:1.6px solid currentColor;
  transform:rotate(45deg);margin-top:-3px;transition:.2s}
.dropdown{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(10px);min-width:215px;
  background:var(--paper);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);
  padding:8px;opacity:0;visibility:hidden;transition:.18s;display:flex;flex-direction:column;gap:2px;z-index:60}
.navitem:hover .dropdown,.navitem:focus-within .dropdown{opacity:1;visibility:visible;transform:translateX(-50%) translateY(5px)}
.dropdown a{padding:9px 14px;border-radius:8px;font-size:.95rem;white-space:nowrap;color:var(--ink);text-decoration:none}
.dropdown a:hover{background:var(--cream-2);color:var(--brown-deep)}
.nav-toggle,.nav-toggle-cb{display:none}
@media(max-width:820px){
  .brand .sub{display:none}
  .nav-toggle{display:flex;flex-direction:column;justify-content:center;gap:5px;width:32px;height:32px;cursor:pointer}
  .nav-toggle span{display:block;height:2px;width:22px;background:var(--brown);border-radius:2px}
  .nav-links{position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;
    background:var(--cream);border-bottom:1px solid var(--line);box-shadow:var(--shadow);padding:6px 0 14px;display:none}
  .nav-toggle-cb:checked~.nav-links{display:flex}
  .nav-links>a,.navlink{padding:13px 24px}
  .navitem{position:static}
  .caret{display:none}
  .dropdown{position:static;transform:none;opacity:1;visibility:visible;box-shadow:none;border:none;
    background:transparent;padding:0 0 6px;border-radius:0;min-width:0}
  .dropdown a{padding:9px 44px;color:var(--muted)}
  .nav-links .btn-etsy{margin:12px 24px 4px;text-align:center;justify-content:center}
}

/* ---------- home: intro + featured ---------- */
.intro-section .wrap{max-width:720px;margin:0 auto;text-align:center}
.intro-section h2{font-size:clamp(1.9rem,4vw,2.6rem);margin:.2em 0 .5em}
.intro-section p{font-size:1.12rem;color:var(--ink);margin:0 0 1.4em}
.featured-section{background:var(--cream-2)}
.featured-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:26px}
@media(max-width:640px){.featured-grid{grid-template-columns:repeat(2,1fr);gap:16px 12px}}

/* ---------- hero ---------- */
.hero{position:relative;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:var(--cream) url('../brand/banner.jpg') center/contain no-repeat}
.hero-bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(251,247,239,.12),rgba(251,247,239,.08) 50%,rgba(251,247,239,.45) 100%)}
.hero-inner{position:relative;text-align:center;padding:96px 28px 92px;max-width:820px;margin:0 auto}
.hero .mark{font-family:var(--script);font-size:clamp(3.4rem,9vw,6rem);color:#000;line-height:.9}
.hero .caps{font-family:var(--display);letter-spacing:.42em;text-transform:uppercase;
  font-size:clamp(.9rem,2.4vw,1.2rem);color:var(--brown);margin:.4em 0 0;font-weight:600}
.hero .tagline{font-size:clamp(1.5rem,3.6vw,2.3rem);font-family:var(--display);
  font-style:italic;color:var(--brown-deep);margin:.7em 0 .35em;font-weight:500}
.hero p.lede{font-size:1.12rem;color:var(--ink);max-width:600px;margin:0 auto 1.8em}
.hero .cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* hero entrance animation (disabled for reduced-motion users) */
@media (prefers-reduced-motion: no-preference){
  @keyframes heroUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
  @keyframes heroFade{from{opacity:0}to{opacity:1}}
  .hero-bg{opacity:0;animation:heroFade 1.6s ease .05s forwards}
  .hero .mark,.hero .caps,.hero .tagline,.hero p.lede,.hero .cta{opacity:0;animation:heroUp .9s cubic-bezier(.2,.7,.2,1) forwards}
  .hero .mark{animation-delay:.15s}
  .hero .caps{animation-delay:.34s}
  .hero .tagline{animation-delay:.52s}
  .hero p.lede{animation-delay:.68s}
  .hero .cta{animation-delay:.84s}
}

/* ---------- marquee strip ---------- */
.strip{background:#ECE6D7;color:var(--ink)}
.strip .wrap{display:flex;flex-wrap:wrap;justify-content:center;gap:14px 46px;padding:18px 28px;
  font-size:.94rem;letter-spacing:.06em}
.strip b{font-family:var(--display);font-size:1.18rem;color:#2C2620;font-weight:600;margin-right:.4em}

/* ---------- section heading ---------- */
.section{padding:74px 0}
.section-head{text-align:center;max-width:680px;margin:0 auto 36px}
.section-head h2{font-size:clamp(2rem,4.4vw,2.9rem);margin:.18em 0 .25em}
.section-head p{color:var(--muted);margin:0;font-size:1.08rem}

/* ---------- collection toolbar ---------- */
.toolbar{display:flex;align-items:center;gap:14px;flex-wrap:wrap;justify-content:space-between;margin-bottom:22px}
.search{position:relative;flex:1 1 280px;max-width:380px}
.search input{width:100%;padding:.7em 1em .7em 2.5em;border:1.5px solid var(--line);border-radius:999px;
  background:var(--paper);font-family:var(--body);font-size:1rem;color:var(--ink)}
.search input:focus{outline:none;border-color:var(--peach)}
.search svg{position:absolute;left:.95em;top:50%;transform:translateY(-50%);width:18px;height:18px;stroke:var(--muted)}
.sort select{padding:.62em 2.2em .62em 1em;border:1.5px solid var(--line);border-radius:999px;background:var(--paper);
  font-family:var(--body);font-size:1rem;color:var(--ink);cursor:pointer;
  -webkit-appearance:none;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238B8070' stroke-width='3'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right .9em center}

/* ---------- category pills ---------- */
.pills{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-bottom:34px}
.pill{cursor:pointer;border:1.5px solid var(--line);background:var(--paper);color:var(--ink);
  padding:.42em 1.1em;border-radius:999px;font-family:var(--body);font-size:.96rem;transition:.2s;white-space:nowrap}
.pill .ct{color:var(--muted);font-size:.82em;margin-left:.4em}
.pill:hover{border-color:var(--peach)}
.pill.active{background:var(--purple);color:#FFF8EC;border-color:var(--purple)}
.pill.active .ct{color:#EDE3F4}

/* ---------- product grid ---------- */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(248px,1fr));gap:30px 26px}
.card{background:var(--paper);border-radius:var(--r);overflow:hidden;cursor:pointer;text-decoration:none;
  border:1px solid var(--line);transition:.28s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.card .ph{position:relative;aspect-ratio:4/5;overflow:hidden;background:var(--cream-2)}
.card .sold-tag{position:absolute;top:10px;left:10px;z-index:2;background:rgba(58,52,43,.8);color:#FBF7EF;
  font-size:.64rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;padding:4px 10px;border-radius:6px}
.card.is-sold .ph img{opacity:.88}
.card .ph img{width:100%;height:100%;object-fit:cover;transition:.5s}
.card:hover .ph img{transform:scale(1.06)}
.card .noimg{width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  font-family:var(--script);font-size:3rem;color:var(--peach);background:
  repeating-linear-gradient(45deg,#F4EBDC,#F4EBDC 12px,#F0E4D0 12px,#F0E4D0 24px)}
.card .body{padding:16px 18px 20px;display:flex;flex-direction:column;gap:6px;flex:1}
.card .cat{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--coral);font-weight:600}
.card h3{font-size:1.22rem;font-weight:600;line-height:1.2;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card .meta{margin-top:auto;display:flex;align-items:baseline;justify-content:space-between;padding-top:10px}
.card .price{font-family:var(--display);font-size:1.18rem;color:var(--brown-deep);font-weight:600}
.card .price.none{color:var(--muted);font-style:italic;font-size:.98rem}
.card .view{font-size:.82rem;color:var(--muted);letter-spacing:.04em}
.empty{text-align:center;color:var(--muted);padding:70px 0;font-style:italic;font-size:1.15rem;grid-column:1/-1}

/* ---------- about ---------- */
.about{background:var(--cream-2)}
.about .wrap{display:grid;grid-template-columns:1.1fr 1fr;gap:54px;align-items:center}
.about h2{font-size:clamp(2rem,4vw,2.7rem);margin-bottom:.4em}
.about p{margin:0 0 1.1em}
.about .quote{font-family:var(--display);font-style:italic;font-size:1.5rem;color:var(--sage-deep);
  border-left:3px solid var(--peach);padding-left:20px;margin:1.4em 0}
.about-art{border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:1/1}
.about-art img{width:100%;height:100%;object-fit:cover}
@media(max-width:820px){.about .wrap{grid-template-columns:1fr;gap:30px}.about-art{order:-1;aspect-ratio:16/10}}

/* ---------- owner intro ---------- */
.owner-wrap{max-width:680px;margin:0 auto;text-align:center}
.owner-wrap h2{font-size:clamp(1.9rem,4vw,2.6rem);margin:.18em 0 .5em}
.owner-wrap p{font-size:1.12rem;color:var(--ink);margin:0 0 1.1em}
.owner-wrap .signature{font-family:var(--script);font-size:2.4rem;color:#584166;margin-top:.2em;line-height:1}
.owner-photo{display:block;width:100%;height:auto;border-radius:170px 170px var(--r) var(--r);box-shadow:var(--shadow);margin:0 auto 2.2em}
@media(max-width:560px){.owner-photo{border-radius:110px 110px var(--r) var(--r)}}

/* ---------- footer ---------- */
.site-footer{background:var(--purple-deep);color:#EDE6F2;padding:54px 0 30px;text-align:center}
.site-footer .mark{font-family:var(--script);font-size:2.6rem;color:#F4E9D2;line-height:1}
.site-footer .sub{letter-spacing:.34em;text-transform:uppercase;font-size:.7rem;color:#C9B79A;margin:.4em 0 1.4em}
.site-footer .fnav{display:flex;gap:26px;justify-content:center;flex-wrap:wrap;margin-bottom:22px}
.site-footer a{color:#E9DCC8;text-decoration:none}
.site-footer a:hover{color:#fff}
.site-footer .fcontact{font-size:.95rem;color:#D9C7A8;margin-bottom:8px}
.site-footer .fcontact a{color:#F4E9D2;text-decoration:none;font-weight:500}
.site-footer .fcontact a:hover{color:#fff}
.site-footer .fine{font-size:.84rem;color:#A8987C;margin-top:18px}

/* ---------- services ---------- */
.services-section{background:var(--cream-2)}
.services{display:grid;grid-template-columns:repeat(auto-fit,minmax(238px,1fr));gap:24px}
.svc-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);
  padding:34px 30px;display:flex;flex-direction:column;align-items:flex-start;gap:12px;transition:.28s}
.svc-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.svc-ic{width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:var(--cream);border:1px solid var(--line)}
.svc-ic svg{width:26px;height:26px;stroke:var(--brown)}
.svc-card h3{font-size:1.5rem}
.svc-card p{margin:0;color:var(--ink);flex:1}
.svc-card .btn{margin-top:8px}
@media(max-width:860px){.services{grid-template-columns:1fr;max-width:460px;margin:0 auto}}

/* ---------- sub-pages ---------- */
.subhero{position:relative;overflow:hidden;border-bottom:1px solid var(--line)}
.subhero .bg{position:absolute;inset:0;background:var(--cream) url('../brand/banner.jpg') center/contain no-repeat}
.subhero .bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(251,247,239,.18),rgba(251,247,239,.4))}
.subhero .inner{position:relative;text-align:center;padding:70px 28px 60px;max-width:760px;margin:0 auto}
.subhero h1{font-size:clamp(2.2rem,5vw,3.3rem);margin:.15em 0 .3em}
.subhero p{font-size:1.12rem;color:var(--ink);margin:0 auto;max-width:600px}
.page{max-width:920px;margin:0 auto;padding:60px 28px}
.page .lead{font-size:1.2rem;color:var(--brown-deep);font-family:var(--display);font-style:italic;margin:0 0 2em}
.svc-block{display:grid;grid-template-columns:auto 1fr;gap:22px;align-items:start;
  padding:26px 0;border-top:1px solid var(--line)}
.svc-block:first-of-type{border-top:none}
.svc-block .num{font-family:var(--display);font-size:2.4rem;color:var(--peach);line-height:1;font-weight:600}
.svc-block h3{font-size:1.5rem;margin:0 0 .35em}
.svc-block p{margin:0 0 .7em}
.svc-block ul{margin:.2em 0 0;padding-left:1.1em;color:var(--ink)}
.svc-block li{margin:.3em 0}
.pricing-note{background:var(--cream-2);border-left:3px solid var(--peach);border-radius:0 10px 10px 0;
  padding:16px 20px;margin:1em 0 0;font-size:.98rem}
.steps{counter-reset:s;list-style:none;padding:0;margin:1.4em 0 0;display:grid;gap:14px}
.steps li{position:relative;padding:14px 18px 14px 56px;background:var(--paper);border:1px solid var(--line);border-radius:12px}
.steps li::before{counter-increment:s;content:counter(s);position:absolute;left:16px;top:50%;transform:translateY(-50%);
  width:28px;height:28px;border-radius:50%;background:var(--brown);color:#FFF8EC;display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-weight:600}
.contact-card{margin:48px auto 0;max-width:640px;text-align:center;background:var(--paper);
  border:1px solid var(--line);border-radius:var(--r);padding:34px 30px;box-shadow:var(--shadow)}
.contact-card h3{font-size:1.7rem;margin:0 0 .3em}
.contact-card p{margin:0 0 1.2em;color:var(--muted)}
.contact-card .links{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.backlink{display:inline-flex;align-items:center;gap:.4em;margin-top:36px;color:var(--coral);text-decoration:none;font-size:1rem}
.backlink:hover{color:var(--brown)}
.note-edit{font-size:.8rem;color:var(--muted);font-style:italic}
@media(max-width:620px){.svc-block{grid-template-columns:1fr;gap:6px}.svc-block .num{font-size:1.8rem}}

/* ---------- journal / article ---------- */
.article{max-width:760px;margin:0 auto;padding:52px 28px 64px}
.article .kicker{display:block;text-align:center;font-size:.74rem;letter-spacing:.3em;text-transform:uppercase;color:var(--coral);font-weight:600}
.article h1{font-size:clamp(2rem,5vw,2.9rem);text-align:center;margin:.25em 0 .3em;line-height:1.14}
.article .byline{text-align:center;color:var(--muted);font-size:.95rem;margin-bottom:2em}
.article .author{text-align:center;color:var(--brown-deep);font-family:var(--display);font-style:italic;font-size:1.05rem;margin:0 0 2em}
.article p{font-size:1.12rem;line-height:1.75;margin:0 0 1.2em;color:var(--ink)}
.article .lead-p{font-size:1.26rem;font-family:var(--display);font-style:italic;color:var(--brown-deep);line-height:1.5}
.article h2{font-size:1.65rem;margin:1.7em 0 .5em}
.article ul{margin:0 0 1.2em;padding-left:1.2em}
.article li{margin:.45em 0;font-size:1.08rem;line-height:1.6}
.article blockquote{margin:1.5em 0;padding-left:22px;border-left:3px solid var(--peach);
  font-family:var(--display);font-style:italic;font-size:1.4rem;line-height:1.4;color:var(--sage-deep)}
.article .fig{margin:1.8em 0}
.article .fig img{width:100%;border-radius:var(--r);display:block}
.article .fig figcaption{font-size:.88rem;color:var(--muted);text-align:center;margin-top:9px;font-style:italic}
.article .fig a{display:block;text-decoration:none}
.article .fig a img{transition:.28s}
.article .fig a:hover img{box-shadow:var(--shadow);transform:translateY(-3px)}
.article .figlink{color:var(--coral);font-style:normal;font-weight:600;font-size:.84rem;white-space:nowrap}
.fig-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:1.7em 0}
.fig-row figure{margin:0}
.fig-row a{display:block;text-decoration:none}
.fig-row img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:var(--r);display:block;transition:.28s}
.fig-row a:hover img{transform:translateY(-4px);box-shadow:var(--shadow)}
.fig-row figcaption{font-size:.84rem;color:var(--muted);text-align:center;margin-top:9px;line-height:1.35}
.fig-row figcaption .figlink{display:block;margin-top:2px}
@media(max-width:560px){.fig-row{grid-template-columns:1fr 1fr}}
.article-cta{background:var(--cream-2);border-radius:var(--r);padding:26px 28px;text-align:center;margin-top:2.6em}
.article-cta p{font-size:1.06rem;margin:0 0 1em}
.article .src{font-size:.84rem;color:var(--muted);border-top:1px solid var(--line);margin-top:2.4em;padding-top:1.2em}
.article .src a{color:var(--muted)}

/* ---------- blog index ---------- */
.blog-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:26px}
.post-card{display:flex;flex-direction:column;background:var(--paper);border:1px solid var(--line);
  border-radius:var(--r);overflow:hidden;text-decoration:none;transition:.28s}
.post-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.post-card .ph{aspect-ratio:16/10;overflow:hidden;background:var(--cream-2)}
.post-card .ph img{width:100%;height:100%;object-fit:cover;transition:.5s}
.post-card:hover .ph img{transform:scale(1.05)}
.post-card .body{padding:18px 20px 22px;flex:1;display:flex;flex-direction:column;gap:6px}
.post-card .cat{font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--coral);font-weight:600}
.post-card h3{font-size:1.3rem;margin:0;line-height:1.22}
.post-card p{margin:0;color:var(--muted);font-size:.98rem}
.post-card.soon{opacity:.65}
.post-card.soon .ph{display:flex;align-items:center;justify-content:center;font-family:var(--script);font-size:2.4rem;color:var(--peach)}

/* ---------- testimonials ---------- */
.reviews-section{background:var(--cream-2)}
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.review{margin:0;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);
  padding:26px 26px 22px;display:flex;flex-direction:column;gap:12px}
.stars{display:flex;gap:3px}
.star{width:15px;height:15px;background:var(--gold);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 2l2.9 6.3 6.9.6-5.2 4.5 1.6 6.7L12 17.8 5.8 20.7 7.4 14 2.2 9.5l6.9-.6z'/%3E%3C/svg%3E") center/contain no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 2l2.9 6.3 6.9.6-5.2 4.5 1.6 6.7L12 17.8 5.8 20.7 7.4 14 2.2 9.5l6.9-.6z'/%3E%3C/svg%3E") center/contain no-repeat}
.review blockquote{margin:0;font-family:var(--display);font-style:italic;font-size:1.18rem;
  line-height:1.4;color:var(--brown-deep);flex:1}
.review figcaption{font-size:.92rem;color:var(--muted);letter-spacing:.04em}
@media(max-width:860px){.reviews{grid-template-columns:1fr 1fr}}

/* ---------- footer social ---------- */
.site-footer .social{display:flex;gap:14px;justify-content:center;margin-bottom:18px}
.site-footer .social a{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(233,220,200,.35);color:#E9DCC8;transition:.2s}
.site-footer .social a:hover{background:rgba(233,220,200,.12);color:#fff;border-color:rgba(233,220,200,.6)}
.site-footer .social svg{width:20px;height:20px}

/* ---------- modal ---------- */
.modal{position:fixed;inset:0;z-index:80;display:none;align-items:flex-start;justify-content:center;
  padding:40px 18px;overflow:auto;background:rgba(48,33,21,.55);backdrop-filter:blur(4px)}
.modal.open{display:flex}
.modal-panel{background:var(--paper);max-width:1020px;width:100%;border-radius:18px;overflow:hidden;
  display:grid;grid-template-columns:1fr 1fr;box-shadow:0 40px 90px -30px rgba(0,0,0,.6);animation:rise .3s ease}
@keyframes rise{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
.gallery{background:var(--cream-2);padding:22px;display:flex;flex-direction:column;gap:12px}
.gallery .main{position:relative;aspect-ratio:1/1;border-radius:12px;overflow:hidden;background:var(--cream)}
.gallery .main img{width:100%;height:100%;object-fit:cover}
.gallery .navbtn{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;border-radius:50%;
  border:none;background:rgba(255,253,248,.9);cursor:pointer;font-size:1.2rem;color:var(--brown);box-shadow:var(--shadow)}
.gallery .navbtn:hover{background:#fff}
.gallery .prev{left:12px}.gallery .next{right:12px}
.gallery .thumbs{display:flex;gap:9px;flex-wrap:wrap}
.gallery .thumbs img{width:62px;height:62px;object-fit:cover;border-radius:8px;cursor:pointer;
  border:2px solid transparent;opacity:.7;transition:.2s}
.gallery .thumbs img.active{border-color:var(--coral);opacity:1}
.info{padding:34px 36px 38px;overflow:auto;max-height:84vh}
.info .cat{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--coral);font-weight:600}
.info h2{font-size:1.7rem;margin:.3em 0 .4em;line-height:1.15;color:var(--purple-deep)}
.info .price{font-family:var(--display);font-size:1.55rem;color:var(--brown-deep);font-weight:600;margin-bottom:1em}
.info .price.none{font-style:italic;font-size:1.1rem;color:var(--muted)}
.info .desc p{margin:0 0 .9em;font-size:1.04rem}
.info h4{font-family:var(--body);font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--sage-deep);font-weight:700;margin:1.6em 0 .6em;border-bottom:1px solid var(--line);padding-bottom:.4em}
.specs{display:grid;grid-template-columns:auto 1fr;gap:6px 18px;font-size:.98rem}
.specs dt{color:var(--muted);font-variant:small-caps;letter-spacing:.02em}
.specs dd{margin:0;color:var(--ink)}
.cond{background:var(--cream-2);border-radius:10px;padding:14px 16px;font-size:.96rem;color:var(--ink)}
.info .buy{margin-top:24px;display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.info .disclaimer{font-size:.82rem;color:var(--muted);margin-top:14px}
.modal-close{position:absolute;top:18px;right:20px;z-index:5;width:42px;height:42px;border-radius:50%;border:none;
  background:rgba(255,253,248,.92);font-size:1.3rem;color:var(--brown);cursor:pointer;box-shadow:var(--shadow)}
.modal-close:hover{background:#fff;color:var(--coral)}
@media(max-width:760px){
  .modal-panel{grid-template-columns:1fr}
  .info{max-height:none}
  .gallery .main{aspect-ratio:4/3}
}

/* ---------- mobile refinements ---------- */
@media(max-width:640px){
  body{font-size:16px}
  .wrap{padding:0 16px}
  .section{padding:46px 0}

  /* header: tighten */
  .site-header .wrap{height:62px;gap:10px}
  .brand .mark{font-size:1.6rem}

  /* hero: less towering, smaller copy */
  .hero-inner{padding:50px 18px 46px}
  .hero .lede{font-size:1rem}
  .hero .cta{gap:10px}
  .hero .cta .btn{padding:.62em 1.2em;font-size:.95rem}

  /* stat strip: even 2x2 grid instead of ragged wrap */
  .strip .wrap{display:grid;grid-template-columns:1fr 1fr;gap:10px 14px;padding:16px 18px;font-size:.8rem;text-align:center}
  .strip span{display:flex;flex-direction:column;align-items:center;gap:1px}
  .strip b{font-size:1.05rem;margin:0}

  /* section heads */
  .section-head{margin-bottom:24px}
  .section-head h2{font-size:2rem}
  .section-head p{font-size:1rem}

  /* toolbar: stack full width */
  .toolbar{flex-direction:column;align-items:stretch;gap:10px}
  .search{max-width:none;flex:none}
  .sort,.sort select{width:100%}

  /* category pills: one neat swipeable row, no messy multi-row wrap */
  .pills{flex-wrap:nowrap;justify-content:flex-start;overflow-x:auto;gap:8px;
    padding:2px 16px 8px;margin:0 -16px 22px;scrollbar-width:none}
  .pills::-webkit-scrollbar{display:none}
  .pill{flex:0 0 auto}

  /* gallery: 2 columns, compact text */
  .grid{grid-template-columns:repeat(2,1fr);gap:18px 12px}
  .card .body{padding:11px 12px 14px;gap:4px}
  .card h3{font-size:1rem;-webkit-line-clamp:3}
  .card .cat{font-size:.58rem;letter-spacing:.14em}
  .card .view{font-size:.72rem}
  .card .meta{padding-top:8px}

  /* reviews single column */
  .reviews{grid-template-columns:1fr;gap:16px}
  .review blockquote{font-size:1.08rem}

  /* services + about + modal spacing */
  .svc-card{padding:26px 22px}
  .about .wrap{gap:24px}
  .info{padding:24px 20px 28px}
  .info h2{font-size:1.45rem}
  .modal{padding:0}
  .modal-panel{border-radius:0;min-height:100vh}
}

/* ---------- newsletter / interest form ---------- */
.newsletter-section{background:#F2ECF7}
.nl-wrap{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.nl-intro h2{margin:.1em 0 .4em}
.nl-intro p{color:var(--muted);max-width:46ch;margin:0}
.nl-form{background:#fff;border:1px solid var(--line);border-radius:18px;padding:26px 24px;box-shadow:0 12px 34px rgba(110,88,150,.12)}
.nl-form label{display:block;font-size:.74rem;letter-spacing:.06em;text-transform:uppercase;color:var(--brown-deep);font-weight:600;margin-bottom:15px}
.nl-form .opt{text-transform:none;letter-spacing:0;color:var(--muted);font-weight:400}
.nl-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.nl-form input,.nl-form select,.nl-form textarea{display:block;width:100%;margin-top:6px;padding:.64em .8em;border:1.5px solid var(--line);border-radius:10px;font-family:inherit;font-size:1rem;color:var(--ink);background:#fff;box-sizing:border-box}
.nl-form input:focus,.nl-form select:focus,.nl-form textarea:focus{outline:none;border-color:var(--purple)}
.nl-form textarea{resize:vertical}
.nl-submit{width:100%;margin-top:4px}
.nl-note{margin:.7em 0 0;font-size:.9rem;color:var(--purple-deep);min-height:1em;text-transform:none;letter-spacing:0;font-weight:400}
@media(max-width:760px){.nl-wrap{grid-template-columns:1fr;gap:26px}.nl-row{grid-template-columns:1fr}}

/* ---------- "what we buy" category grid (pickup page) ---------- */
.buy-grid{list-style:none;padding:0;margin:1em 0 0;display:grid;grid-template-columns:1fr 1fr;gap:.5em 1.6em}
.buy-grid li{position:relative;padding-left:1.15em;color:var(--ink)}
.buy-grid li::before{content:"";position:absolute;left:0;top:.6em;width:.44em;height:.44em;border-radius:50%;background:var(--purple)}
@media(max-width:560px){.buy-grid{grid-template-columns:1fr}}

/* footer service-area line (local SEO) */
.fareas{max-width:720px;margin:16px auto 0;font-size:.78rem;line-height:1.55;color:rgba(255,248,236,.6);text-align:center}

/* ============ product detail page (PDP) ============ */
.pdp{padding:30px 28px 70px;max-width:1200px;margin:0 auto}
.crumbs{font-size:.85rem;color:var(--muted);margin:0 0 22px}
.crumbs a{color:var(--muted);text-decoration:none}
.crumbs a:hover{color:var(--coral)}
.crumbs span{color:var(--brown-deep)}
.pdp-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:46px;align-items:start}
.pdp-main{border-radius:14px;overflow:hidden;background:var(--cream-2);box-shadow:var(--shadow)}
.pdp-main img{width:100%;height:auto;display:block;cursor:zoom-in}
.pdp-thumbs{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}
.pdp-thumbs img{width:72px;height:72px;object-fit:cover;border-radius:8px;cursor:pointer;border:2px solid transparent;opacity:.78;transition:.15s}
.pdp-thumbs img:hover{opacity:1}
.pdp-thumbs img.active{border-color:var(--purple);opacity:1}
.pdp-info .eyebrow{display:block;margin-bottom:.4em}
.pdp-info h1{font-size:clamp(1.6rem,3vw,2.3rem);line-height:1.15;margin:0 0 .5em;color:var(--brown-deep)}
.pdp-sold{display:inline-block;background:rgba(58,52,43,.85);color:#FBF7EF;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;padding:5px 12px;border-radius:6px;margin:0 0 1em}
.pdp-desc p{margin:0 0 1em;color:var(--ink)}
.pdp-info .btn{margin-top:.5em}
.pdp-block{margin:52px 0 0;border-top:1px solid var(--line);padding-top:32px}
.pdp-block>h2{font-size:1.6rem;color:var(--brown-deep);margin:0 0 .7em}
.pdp-block>h3{font-size:1.15rem;color:var(--brown-deep);margin:1.2em 0 .3em}
dl.spec{display:grid;grid-template-columns:auto 1fr;gap:.45em 1.4em;margin:0}
dl.spec dt{font-weight:600;color:var(--brown-deep);white-space:nowrap}
dl.spec dd{margin:0;color:var(--ink)}
@media(max-width:520px){dl.spec{grid-template-columns:1fr;gap:.05em 0}dl.spec dt{margin-top:.5em}dl.spec dd{margin:0 0 .3em}}
.backstamp-block .bs-grid{display:grid;grid-template-columns:300px 1fr;gap:34px;align-items:start}
.bs-img{border-radius:12px;overflow:hidden;background:var(--cream-2);border:1px solid var(--line)}
.bs-img img{width:100%;display:block}
.bs-note{margin:0 0 1.1em;color:var(--ink);font-style:italic}
@media(max-width:680px){.backstamp-block .bs-grid{grid-template-columns:1fr;gap:18px}.bs-img{max-width:320px}}
@media(max-width:860px){.pdp-grid{grid-template-columns:1fr;gap:26px}}

/* ============ backstamp & pattern guide ============ */
.guide-wrap{max-width:920px;margin:0 auto;padding:0 28px 70px}
.guide-intro{max-width:730px}
.guide-toc{display:flex;flex-wrap:wrap;gap:8px;margin:24px 0 8px}
.guide-toc a{font-size:.85rem;padding:6px 12px;border:1px solid var(--line);border-radius:999px;text-decoration:none;color:var(--brown-deep);background:var(--paper)}
.guide-toc a:hover{background:var(--cream-2);border-color:var(--purple)}
.guide-maker{border-top:1px solid var(--line);padding-top:26px;margin-top:30px;scroll-margin-top:90px}
.guide-maker h2{font-size:1.5rem;color:var(--brown-deep);margin:0 0 .15em}
.guide-maker .gm-mark{font-size:.85rem;letter-spacing:.03em;color:var(--purple-deep);font-weight:600;margin:0 0 .8em}
.guide-maker p{margin:0 0 .8em;color:var(--ink)}
.guide-maker ul{margin:.2em 0 .8em;padding-left:1.2em}
.guide-maker li{margin:.25em 0;color:var(--ink)}

.bs-grid.bs-noimg{grid-template-columns:1fr}

/* ============================================================
   MUSEUM-EDITORIAL REFINEMENT — typography-led, ink + hairlines
   brand purple kept as the interactive accent; one gilt edge
   ============================================================ */
:root{
  --cream:#FAF6EC; --cream-2:#F1EBDC; --paper:#FFFDF9;
  --ink:#2C2823;
  --brown:#5A4A38; --brown-deep:#1E1B16;     /* headlines become ink */
  --line:rgba(31,28,22,.15);
  --rule:rgba(31,28,22,.8);
  --label:#6E6456;
  --footer:#221E27;
  --shadow:0 22px 50px -30px rgba(31,28,22,.34);
  --r:4px;
}
body{font-size:19px;line-height:1.74}
h1,h2,h3{letter-spacing:.004em}

/* tracked small-caps labels */
.eyebrow,.card .cat,.post-card .cat,.info .cat,.article .kicker{
  color:var(--label);font-weight:600;letter-spacing:.32em;font-size:.7rem}
/* centred labels flanked by fine rules (section heads, heroes, articles) */
.section-head .eyebrow,.subhero .inner .eyebrow,.article .kicker,.owner-wrap .eyebrow{
  display:inline-flex;align-items:center;gap:1em}
.section-head .eyebrow::before,.section-head .eyebrow::after,
.subhero .inner .eyebrow::before,.subhero .inner .eyebrow::after,
.article .kicker::before,.article .kicker::after,
.owner-wrap .eyebrow::before,.owner-wrap .eyebrow::after{
  content:"";width:36px;height:1px;background:var(--line)}

/* headings + rhythm */
.section{padding:92px 0}
.section-head{max-width:720px;margin-bottom:46px}
.section-head h2{font-size:clamp(2.1rem,4.6vw,3.2rem)}
.section-head p{font-size:1.05rem}

/* refined, tracked nav */
.nav-links>a,.navlink{text-transform:uppercase;letter-spacing:.13em;font-size:.78rem}

/* drop cap — magazine opening on journal articles */
.article .lead-p{font-style:normal;font-family:var(--display);color:var(--brown-deep)}
.article .lead-p::first-letter{
  float:left;font-family:var(--display);font-weight:600;color:var(--brown-deep);
  font-size:3.7em;line-height:.7;margin:.04em .12em 0 0}

/* buttons: uppercase, tracked, sharp */
.btn{border-radius:3px;text-transform:uppercase;letter-spacing:.15em;font-size:.74rem;font-weight:600;padding:1.02em 1.7em}
.btn-ghost{border-width:1px}

/* hero: airy */
.hero-inner{padding:118px 28px 108px}
.hero .caps{color:var(--label);letter-spacing:.5em}
.hero p.lede{font-size:1.08rem}

/* stat strip → ruled editorial band */
.strip{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.strip .wrap{padding:24px 28px;gap:16px 52px}
.strip span{color:var(--label);font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;display:flex;align-items:baseline;gap:.5em}
.strip b{color:var(--brown-deep);font-size:1.7rem;margin:0}

/* cards: framed, restrained */
.card{border-radius:0}
.card:hover{transform:translateY(-4px);border-color:var(--line)}
.card:hover .ph img{transform:scale(1.04)}
.card .ph{border-bottom:1px solid var(--line);border-radius:0}
.card h3{font-weight:500;font-size:1.15rem}
.post-card,.svc-card,.review{border-radius:0}
.contact-card,.modal-panel,.about-art{border-radius:2px}

/* pull-quotes — centred, hairline-framed */
.article blockquote{border-left:none;padding:0;text-align:center;color:var(--brown-deep);font-size:1.5rem;margin:1.9em auto}
.article blockquote::before,.article blockquote::after{content:"";display:block;width:52px;height:1px;background:var(--rule);margin:0 auto}
.article blockquote::before{margin-bottom:.9em}
.article blockquote::after{margin-top:.9em}

/* footer → deep ink with a single gilt hairline */
.site-footer{background:var(--footer);border-top:2px solid var(--gold)}
.info h2{color:var(--brown-deep)}

/* mobile: keep tight */
@media(max-width:640px){
  body{font-size:16.5px}
  .section{padding:54px 0}
  .hero-inner{padding:74px 18px 66px}
  .article .lead-p::first-letter{font-size:3em}
  .strip b{font-size:1.4rem}
}
