/* ========== TOTHERNO.COM BETA — SHARED STYLE ========== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%;text-size-adjust:100%;text-rendering:optimizeLegibility;scroll-behavior:smooth}
img,svg{display:block;max-width:100%;height:auto}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
a{color:inherit;text-decoration:none}
input,textarea,select{font:inherit;color:inherit}

:root{
  /* Manawa-inspired warm sand palette */
  --cream:        #f5ede0;
  --cream-2:      #fbf6ec;
  --cream-soft:   #ece1cb;
  --cream-tile:   #efe5d2;
  --ink:          #3a2f24;
  --ink-soft:     #574838;
  --ink-mute:     #8b7a64;

  --rust:         #a47148;
  --rust-deep:    #7e5732;
  --rust-light:   #c39669;
  --gold:         #b88a3e;
  --teal:         #3f575e;
  --teal-deep:    #2a221a;
  --olive:        #7a6e4e;
  --wine:         #7a2840;

  --line:         #3a2f24;
  --line-soft:    #d8c8a8;
  --line-softer:  #ead9bd;

  --f-display:    'DM Serif Display', 'Georgia', serif;
  --f-body:       'DM Sans', system-ui, -apple-system, sans-serif;

  --grid-w:       1380px;
  --gutter:       clamp(1.25rem, 3.5vw, 3.25rem);
  --ease:         cubic-bezier(.2,.7,.2,1);
}

html, body{ background: var(--cream); color: var(--ink); }
body{
  font-family: var(--f-body);
  font-size: clamp(1rem, .92rem + .25vw, 1.1rem);
  line-height: 1.6;
  overflow-x: hidden;
  font-feature-settings: "ss01";
}
::selection{ background: var(--rust); color: var(--cream); }
h1,h2,h3,h4{ font-family: var(--f-display); font-weight: 400; line-height: 1.05; letter-spacing: -.005em; color: var(--ink); }
em, i{ font-style: italic; }

.wrap{ max-width: var(--grid-w); margin-inline: auto; padding-inline: var(--gutter); }

/* ── BUTTONS ── */
.btn{ display:inline-flex; align-items:center; justify-content:center; gap:.55rem; padding:.95rem 1.55rem;
  font-family: var(--f-body); font-size: .9rem; font-weight: 500; letter-spacing: .005em;
  border: 1px solid; cursor: pointer;
  transition: background .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease); }
.btn .arrow{ transition: transform .35s var(--ease); }
.btn:hover .arrow{ transform: translateX(4px); }
.btn-primary{ background: var(--rust); color: var(--cream); border-color: var(--rust); }
.btn-primary:hover{ background: var(--rust-deep); border-color: var(--rust-deep); }
.btn-ghost{ background: var(--cream); color: var(--ink); border-color: var(--cream); }
.btn-ghost:hover{ background: transparent; color: var(--cream); border-color: var(--cream); }
.btn-dark{ background: var(--ink); color: var(--cream); border-color: var(--ink); }
.btn-dark:hover{ background: var(--rust); border-color: var(--rust); }
.btn-outline{ background: transparent; color: var(--ink); border-color: var(--ink); }
.btn-outline:hover{ background: var(--ink); color: var(--cream); }
.btn-sm{ padding: .65rem 1.1rem; font-size: .8rem; }

.eyebrow{ font-family: var(--f-body); font-size: .72rem; letter-spacing: .25em; text-transform: uppercase;
  color: var(--rust); font-weight: 600; display: inline-flex; align-items: center; gap: .55rem; }
.eyebrow::before{ content:''; display:inline-block; width: 20px; height: 1px; background: var(--rust); }
.eyebrow.center::before, .eyebrow.center::after{ content:''; display:inline-block; width: 30px; height: 1px; background: var(--rust); }
.eyebrow.no-line::before{ display: none; }

/* ── NAV ── */
nav.top{ position: sticky; top: 0; left: 0; right: 0; z-index: 80;
  padding: 1rem var(--gutter);
  display: flex; align-items: center; justify-content: space-between;
  transition: background .35s var(--ease), box-shadow .35s var(--ease);
  background: rgba(252, 249, 243, .97);
  -webkit-backdrop-filter: blur(14px) saturate(1.05);
  backdrop-filter: blur(14px) saturate(1.05);
  box-shadow: 0 1px 0 var(--line-soft); }
nav.top .brand{ color: var(--ink); }
nav.top ul a{ color: var(--ink); }
nav.top .lang{ color: var(--ink); }
nav.top .mobile-menu-btn span{ background: var(--ink); }
nav.top.scrolled, nav.top.solid{
  background: color-mix(in srgb, var(--cream) 92%, transparent);
  -webkit-backdrop-filter: blur(14px) saturate(1.05);
  backdrop-filter: blur(14px) saturate(1.05);
  box-shadow: 0 1px 0 var(--line-soft); }
nav.top .brand{ display: flex; align-items: baseline; gap: .55rem;
  font-family: var(--f-display); font-size: 1.45rem; color: var(--cream);
  transition: color .35s var(--ease); letter-spacing: -.01em; }
nav.top.scrolled .brand, nav.top.solid .brand{ color: var(--ink); }
nav.top .brand .est{ font-family: var(--f-body); font-size: .65rem; letter-spacing: .2em;
  text-transform: uppercase; font-weight: 500; opacity: .7; }
nav.top ul{ display: flex; gap: clamp(1rem, 2vw, 2rem); list-style: none; }
nav.top ul a{ font-family: var(--f-body); font-size: .82rem; letter-spacing: .04em;
  color: var(--cream); opacity: .85; padding: .35rem 0; position: relative;
  transition: opacity .25s, color .35s var(--ease); }
nav.top ul a.active{ color: var(--rust-light); opacity: 1; }
nav.top.scrolled ul a, nav.top.solid ul a{ color: var(--ink); }
nav.top.scrolled ul a.active, nav.top.solid ul a.active{ color: var(--rust); }
nav.top ul a:hover{ opacity: 1; }
nav.top ul a::after{ content:''; position: absolute; left: 0; right: 0; bottom: -3px;
  height: 1px; background: var(--rust); transform: scaleX(0); transform-origin: left;
  transition: transform .3s var(--ease); }
nav.top ul a:hover::after, nav.top ul a.active::after{ transform: scaleX(1); }
nav.top .right{ display: flex; align-items: center; gap: .85rem; }
nav.top .lang{ font-family: var(--f-body); font-size: .75rem; letter-spacing: .08em;
  color: var(--cream); opacity: .85; padding: .35rem .6rem;
  transition: color .35s var(--ease), background .2s, border-color .2s; border: 1px solid transparent; }
nav.top.scrolled .lang, nav.top.solid .lang{ color: var(--ink); }
nav.top .lang:hover{ opacity: 1; background: rgba(244,232,195,.08); border-color: var(--rust); }
nav.top.scrolled .lang:hover, nav.top.solid .lang:hover{ background: rgba(31,45,53,.05); }
@media (max-width: 920px){
  nav.top ul{ display: none; }
}

/* ── MOBILE HAMBURGER (left side) ── */
.mobile-menu-btn{
  display: none;
  width: 38px; height: 38px;
  background: transparent; border: 0; cursor: pointer;
  align-items: center; justify-content: center;
  flex-direction: column; gap: 4px;
  padding: 8px;
  order: 99;  /* push to far right on mobile (last in flex row) */
  margin-left: .5rem;
}
.mobile-menu-btn span{
  display: block; width: 22px; height: 2px;
  background: var(--cream);
  transition: background .35s var(--ease), transform .25s var(--ease), opacity .2s var(--ease);
  border-radius: 1px;
}
nav.top.scrolled .mobile-menu-btn span, nav.top.solid .mobile-menu-btn span{ background: var(--ink); }
.mobile-menu-btn.open span:nth-child(1){ transform: translateY(6px) rotate(45deg); }
.mobile-menu-btn.open span:nth-child(2){ opacity: 0; }
.mobile-menu-btn.open span:nth-child(3){ transform: translateY(-6px) rotate(-45deg); }
@media (max-width: 920px){ .mobile-menu-btn{ display: inline-flex; } nav.top{ padding-left: .75rem; } }

.mobile-menu{
  position: fixed; top: 0; left: 0; bottom: 0;
  width: min(320px, 80vw);
  background: var(--cream); color: var(--ink);
  z-index: 200;
  transform: translateX(-100%);
  transition: transform .35s var(--ease);
  display: flex; flex-direction: column;
  box-shadow: 10px 0 30px rgba(11,9,8,.2);
  padding-top: 5rem;
}
.mobile-menu.open{ transform: translateX(0); }
.mobile-menu-backdrop{
  position: fixed; inset: 0; z-index: 195;
  background: rgba(11,9,8,.55);
  display: none;
}
.mobile-menu-backdrop.open{ display: block; }
.mobile-menu nav{ display: flex; flex-direction: column; padding: 0 1.5rem; }
.mobile-menu nav a{
  font-family: var(--f-display); font-size: 1.5rem; color: var(--ink);
  padding: .85rem 0; border-bottom: 1px solid var(--line-soft);
  transition: color .2s var(--ease), padding-left .2s var(--ease);
}
.mobile-menu nav a:hover, .mobile-menu nav a.active{ color: var(--rust); }
.mobile-menu nav a:hover{ padding-left: .35rem; }
.mobile-menu .lang-row{
  padding: 1.25rem 1.5rem 0; display: flex; gap: .55rem;
}
.mobile-menu .lang-row a{
  font-family: var(--f-body); font-size: .75rem; letter-spacing: .12em; text-transform: uppercase;
  padding: .35rem .65rem; border: 1px solid var(--line-soft); color: var(--ink-soft);
}
.mobile-menu .lang-row a:hover{ color: var(--rust); border-color: var(--rust); }

/* ── DEFENSIVE MOBILE PADDING — stop edge-bleed ── */
@media (max-width: 760px){
  .studio-band > div, .sj-home > .wrap, .sj-feature .sj-grid, .inquire-stripe > .wrap, .inquire > .wrap, .press > .wrap, .page-hero > .wrap{
    padding-left: var(--gutter); padding-right: var(--gutter);
  }
  /* Section head paragraphs/headers in centered text contexts */
  .sec-head{ padding-inline: var(--gutter); }
  /* Long titles wrap rather than overflow */
  h1, h2, h3{ overflow-wrap: break-word; word-break: break-word; }
}

/* ── SECTION HEAD ── */
.sec-head{ text-align: center; padding: clamp(4rem,9vh,7rem) 0 clamp(2rem,4vh,3.25rem);
  display: flex; flex-direction: column; gap: .85rem; align-items: center; }
.sec-head h2{ font-size: clamp(2.25rem, 4.5vw, 4rem); line-height: 1.05; }
.sec-head h2 em{ font-style: italic; color: var(--rust); }
.sec-head p{ max-width: 56ch; font-size: 1.05rem; color: var(--ink-soft); }

/* ── SHOP CARD GRID — image-forward, paintings fill the tile ── */
.shop-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(1.25rem, 2vw, 2rem);
}
@media (min-width: 1280px){ .shop-grid{ grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 980px){ .shop-grid{ grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px){ .shop-grid{ grid-template-columns: 1fr; gap: 1rem; } }

.card{
  position: relative;
  background: var(--cream-tile);
  border: 1px solid var(--line-softer);
  display: flex; flex-direction: column;
  cursor: pointer;
  transition: transform .25s var(--ease), box-shadow .25s var(--ease), border-color .25s var(--ease);
}
.card:hover{
  transform: translateY(-3px);
  box-shadow: 0 12px 30px rgba(31,45,53,.12);
  border-color: var(--rust-light);
}
.card-img{
  aspect-ratio: 5/4;
  display: block;
  padding: 0;
  background: var(--cream-tile);
  overflow: hidden;
  position: relative;
}
.card-img img{
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  transition: transform .6s var(--ease);
}
.card:hover .card-img img{ transform: scale(1.03); }
.card-body{
  padding: .85rem 1rem 1.1rem;
  display: flex; flex-direction: column; gap: .25rem;
  border-top: 1px solid var(--line-softer);
}
.card-num{ font-family: var(--f-body); font-size: .65rem; letter-spacing: .18em;
  text-transform: uppercase; color: var(--rust); font-weight: 600; }
.card-ttl{ font-family: var(--f-display); font-size: 1.1rem; line-height: 1.2; color: var(--ink); }
.card-spec{ font-family: var(--f-body); font-size: .78rem; color: var(--ink-mute); margin-top: .15rem; }
.card-cta{
  margin-top: .5rem;
  display: inline-flex; align-items: center; gap: .35rem;
  font-family: var(--f-body); font-size: .78rem; font-weight: 500;
  color: var(--rust);
  transition: color .2s var(--ease);
}
.card:hover .card-cta{ color: var(--rust-deep); }
.card-cta::after{ content: '→'; transition: transform .25s var(--ease); }
.card:hover .card-cta::after{ transform: translateX(3px); }

/* Status pill */
.card-status{
  position: absolute; top: .65rem; right: .65rem; z-index: 2;
  padding: .25rem .55rem;
  font-family: var(--f-body); font-size: .62rem; letter-spacing: .15em; text-transform: uppercase;
  font-weight: 600;
  background: var(--cream); color: var(--ink);
  border: 1px solid var(--line-soft);
}
.card-status.available{ color: var(--olive); border-color: var(--olive); }

/* ── SAVE (heart) button on card + modal ── */
.save-btn{
  position: absolute; top: .55rem; left: .55rem; z-index: 3;
  width: 34px; height: 34px;
  display: flex; align-items: center; justify-content: center;
  background: rgba(244,232,195,.92);
  -webkit-backdrop-filter: blur(6px);
  backdrop-filter: blur(6px);
  border: 1px solid var(--line-soft);
  color: var(--ink-soft);
  font-size: 1rem; line-height: 1;
  cursor: pointer;
  transition: background .2s var(--ease), color .2s var(--ease), border-color .2s var(--ease), transform .2s var(--ease);
}
.save-btn svg{ width: 18px; height: 18px; stroke: currentColor; stroke-width: 1.8; fill: none; }
.save-btn:hover{ background: var(--cream); color: var(--rust); border-color: var(--rust); transform: scale(1.05); }
.save-btn.is-saved{ background: var(--rust); color: var(--cream); border-color: var(--rust); }
.save-btn.is-saved svg{ fill: var(--cream); }

.modal .save-btn{
  position: static;
  width: auto; height: auto;
  padding: .55rem 1rem;
  gap: .55rem;
  background: transparent; border: 1px solid var(--line-soft); color: var(--ink-soft);
  font-family: var(--f-body); font-size: .8rem; font-weight: 500;
}
.modal .save-btn:hover{ background: var(--cream-2); color: var(--rust); border-color: var(--rust); transform: none; }
.modal .save-btn.is-saved{ background: var(--rust); color: var(--cream); border-color: var(--rust); }

/* ── SAVED PILL (floating, below nav) ── */
.saved-pill{
  position: fixed; top: 5rem; right: 1rem; z-index: 75;
  display: none; align-items: center; gap: .5rem;
  padding: .65rem 1rem;
  background: var(--ink); color: var(--cream);
  font-family: var(--f-body); font-size: .82rem; font-weight: 500;
  border: 1px solid var(--rust);
  box-shadow: 0 8px 24px rgba(11,9,8,.18);
  cursor: pointer;
  transition: background .25s var(--ease), transform .2s var(--ease);
}
.saved-pill:hover{ background: var(--rust); transform: translateY(-2px); }
.saved-pill.visible{ display: inline-flex; }
.saved-pill .badge{
  background: var(--rust); color: var(--cream);
  border-radius: 999px; padding: 0 .45rem; min-width: 22px;
  font-size: .72rem; font-weight: 600;
  display: inline-flex; align-items: center; justify-content: center;
  line-height: 1.5;
}
.saved-pill:hover .badge{ background: var(--cream); color: var(--rust); }

/* ── SAVED DRAWER (right slide-in) ── */
.saved-drawer{
  position: fixed; top: 0; right: 0; bottom: 0;
  width: min(420px, 100vw);
  background: var(--cream); color: var(--ink);
  z-index: 210;
  transform: translateX(100%);
  transition: transform .35s var(--ease);
  display: flex; flex-direction: column;
  box-shadow: -10px 0 30px rgba(11,9,8,.18);
}
.saved-drawer.open{ transform: translateX(0); }
.saved-backdrop{
  position: fixed; inset: 0; z-index: 205;
  background: rgba(11,9,8,.55);
  display: none;
}
.saved-backdrop.open{ display: block; }
.saved-drawer header{
  padding: 1.25rem 1.5rem;
  border-bottom: 1px solid var(--line-soft);
  display: flex; align-items: center; justify-content: space-between;
}
.saved-drawer h3{
  font-family: var(--f-display); font-size: 1.4rem; color: var(--ink);
}
.saved-drawer h3 .count{ color: var(--rust); }
.saved-drawer .close{
  width: 36px; height: 36px; border: 1px solid var(--line-soft);
  background: transparent; color: var(--ink); font-size: 1.4rem; line-height: 1;
  display: flex; align-items: center; justify-content: center; cursor: pointer;
}
.saved-drawer .close:hover{ background: var(--ink); color: var(--cream); border-color: var(--ink); }
.saved-list{ flex: 1; overflow-y: auto; padding: 1rem 1.5rem; }
.saved-list .empty{
  text-align: center; padding: 3rem 1rem; color: var(--ink-mute);
  font-family: var(--f-display); font-style: italic; font-size: 1.05rem;
}
.saved-row{
  display: grid; grid-template-columns: 90px 1fr auto; gap: 1rem; align-items: center;
  padding: .75rem 0; border-bottom: 1px solid var(--line-softer);
}
.saved-row .thumb{
  width: 90px; aspect-ratio: 1/1;
  background: var(--cream-2); overflow: hidden;
  display: flex; align-items: center; justify-content: center;
}
.saved-row .thumb img{ max-width: 100%; max-height: 100%; object-fit: contain; }
.saved-row .meta{ min-width: 0; }
.saved-row .meta .num{ font-family: var(--f-body); font-size: .62rem; letter-spacing: .15em;
  text-transform: uppercase; color: var(--rust); font-weight: 600; }
.saved-row .meta .ttl{ font-family: var(--f-display); font-size: 1rem; color: var(--ink); line-height: 1.2; margin-top: .15rem; }
.saved-row .meta .sp{ font-family: var(--f-body); font-size: .78rem; color: var(--ink-mute); margin-top: .15rem; }
.saved-row .rm{
  width: 28px; height: 28px; border: 1px solid var(--line-soft); background: transparent; color: var(--ink-mute);
  font-size: 1.1rem; line-height: 1; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .2s, color .2s, border-color .2s;
}
.saved-row .rm:hover{ background: var(--wine); color: var(--cream); border-color: var(--wine); }
.saved-drawer footer{
  padding: 1.25rem 1.5rem;
  border-top: 1px solid var(--line-soft);
  background: var(--cream-2);
  display: flex; flex-direction: column; gap: .75rem;
}
.saved-drawer footer .btn{ width: 100%; }
.saved-drawer footer .clear-all{
  font-family: var(--f-body); font-size: .75rem; color: var(--ink-mute);
  background: transparent; border: 0; cursor: pointer; padding: .25rem;
  text-decoration: underline;
}
.saved-drawer footer .clear-all:hover{ color: var(--wine); }

/* ── FILTERS ── */
.filters{
  display: flex; justify-content: space-between; gap: 1rem;
  align-items: center; flex-wrap: wrap;
  padding: 1.5rem 0;
  border-top: 1px solid var(--line-soft);
  border-bottom: 1px solid var(--line-soft);
  margin-bottom: clamp(2rem, 4vh, 3rem);
}
.filter-group{ display: flex; gap: .35rem; align-items: center; flex-wrap: wrap; }
.filter-label{ font-family: var(--f-body); font-size: .7rem; letter-spacing: .15em; text-transform: uppercase;
  color: var(--ink-mute); margin-right: .35rem; }
.chip{
  display: inline-flex; align-items: center; gap: .35rem;
  padding: .45rem .85rem;
  font-family: var(--f-body); font-size: .8rem; font-weight: 500;
  background: transparent; color: var(--ink-soft);
  border: 1px solid var(--line-soft);
  cursor: pointer;
  transition: background .2s var(--ease), color .2s var(--ease), border-color .2s var(--ease);
}
.chip:hover{ border-color: var(--rust); color: var(--rust); }
.chip.active{ background: var(--ink); color: var(--cream); border-color: var(--ink); }
.chip .n{ opacity: .6; font-size: .72rem; }
.results-count{ font-family: var(--f-body); font-size: .85rem; color: var(--ink-mute); }
.results-count strong{ color: var(--ink); font-weight: 600; }

/* ── PAGE HERO (catalogue pages) ── */
.page-hero{
  background: var(--cream-2);
  padding: clamp(7rem, 14vh, 11rem) var(--gutter) clamp(2rem, 4vh, 3rem);
  border-bottom: 1px solid var(--line-soft);
}
.page-hero .wrap{ display: grid; grid-template-columns: minmax(0,1fr) auto; gap: 2rem; align-items: end; }
.page-hero h1{ font-size: clamp(2.5rem, 6vw, 5rem); line-height: 1; letter-spacing: -.02em; }
.page-hero h1 em{ font-style: italic; color: var(--rust); }
.page-hero p{ margin-top: 1rem; color: var(--ink-soft); max-width: 60ch; }
.page-hero .breadcrumbs{ font-family: var(--f-body); font-size: .75rem; letter-spacing: .12em;
  text-transform: uppercase; color: var(--ink-mute); margin-bottom: 1rem; }
.page-hero .breadcrumbs a{ color: var(--rust); }
.page-hero .meta-right{ text-align: right; font-family: var(--f-body); font-size: .9rem; color: var(--ink-soft); }
.page-hero .meta-right .n{ font-family: var(--f-display); font-size: 2.5rem; color: var(--ink); display: block; line-height: 1; }
.page-hero .meta-right .l{ letter-spacing: .15em; text-transform: uppercase; font-size: .7rem; color: var(--rust); }
@media (max-width: 720px){ .page-hero .wrap{ grid-template-columns: 1fr; } .page-hero .meta-right{ text-align: left; } }

/* ── MODAL ── */
.modal{
  position: fixed; inset: 0; z-index: 200;
  background: rgba(15, 22, 28, .85);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  display: none;
  align-items: center; justify-content: center;
  padding: clamp(1rem, 4vh, 3rem);
}
.modal.open{ display: flex; }
.modal-card{
  background: var(--cream);
  width: 100%; max-width: 1100px;
  max-height: 90vh;
  overflow: auto;
  display: grid;
  grid-template-columns: minmax(0, 6fr) minmax(0, 5fr);
  position: relative;
  animation: modalIn .35s var(--ease);
}
@keyframes modalIn { from { opacity: 0; transform: scale(.97); } to { opacity: 1; transform: scale(1); } }
.modal-img-wrap{
  background: linear-gradient(135deg, var(--cream-tile) 0%, var(--cream-2) 100%);
  display: flex; align-items: center; justify-content: center;
  padding: 2rem;
  min-height: 400px;
}
.modal-img-wrap img{
  max-width: 100%; max-height: 70vh;
  width: auto; height: auto;
  object-fit: contain;
  filter: drop-shadow(0 10px 30px rgba(31,45,53,.25));
}
.modal-info{
  padding: 2rem 2rem 2rem;
  display: flex; flex-direction: column; gap: 1rem;
}
.modal-info .num{ font-family: var(--f-body); font-size: .68rem; letter-spacing: .2em; text-transform: uppercase;
  color: var(--rust); font-weight: 600; }
.modal-info h3{ font-family: var(--f-display); font-size: clamp(1.7rem, 2.5vw, 2.4rem); line-height: 1.05; }
.modal-info h3 em{ font-style: italic; }
.modal-info .desc{ font-size: .96rem; color: var(--ink-soft); line-height: 1.65; }
.modal-specs{
  margin: .5rem 0;
  display: grid; grid-template-columns: 1fr 1fr; gap: .65rem 1rem;
  padding: 1rem 1.2rem; border: 1px solid var(--line-soft); background: var(--cream-2);
}
.modal-specs .s .l{ font-family: var(--f-body); font-size: .64rem; letter-spacing: .15em;
  text-transform: uppercase; color: var(--rust); font-weight: 500; }
.modal-specs .s .v{ font-family: var(--f-display); font-size: 1rem; color: var(--ink); margin-top: .15rem; }
.modal-ctas{ display: flex; gap: .65rem; flex-wrap: wrap; margin-top: .5rem; }
.modal-promise{
  display: flex; align-items: center; gap: .55rem;
  font-family: var(--f-body); font-size: .82rem; color: var(--ink-soft);
  padding: .8rem 1rem; background: color-mix(in srgb, var(--gold) 12%, transparent);
  border-left: 2px solid var(--gold);
}
.modal-close{
  position: absolute; top: .65rem; right: .65rem; z-index: 5;
  width: 38px; height: 38px;
  display: flex; align-items: center; justify-content: center;
  background: var(--cream); color: var(--ink); border: 1px solid var(--line-soft);
  font-size: 1.4rem; line-height: 1;
}
.modal-close:hover{ background: var(--rust); color: var(--cream); border-color: var(--rust); }
.modal-nav{
  position: absolute; top: 50%; transform: translateY(-50%); z-index: 5;
  width: 44px; height: 44px;
  display: flex; align-items: center; justify-content: center;
  background: var(--cream); color: var(--ink); border: 1px solid var(--line-soft);
  font-family: var(--f-display); font-size: 1.4rem;
}
.modal-nav:hover{ background: var(--rust); color: var(--cream); border-color: var(--rust); }
.modal-prev{ left: .65rem; }
.modal-next{ right: .65rem; }
@media (max-width: 880px){
  .modal-card{ grid-template-columns: 1fr; max-height: 95vh; }
  .modal-img-wrap{ min-height: 280px; }
  .modal-nav{ top: 35%; }
}

/* ── INQUIRE STRIPE (catalogue page footer) ── */
.inquire-stripe{
  background: var(--ink); color: var(--cream);
  padding: clamp(3rem, 6vh, 5rem) var(--gutter);
  position: relative; overflow: hidden;
}
.inquire-stripe::before{
  content:''; position:absolute; inset:0; z-index: 0;
  background: radial-gradient(ellipse 50% 80% at 80% 100%, rgba(200,114,31,.22), transparent 70%);
}
.inquire-stripe > .wrap{ position: relative; z-index: 1;
  display: grid; grid-template-columns: minmax(0,1fr) auto; gap: 2rem; align-items: center; }
.inquire-stripe h2{ color: var(--cream); font-size: clamp(1.85rem, 3vw, 2.75rem); line-height: 1.1; }
.inquire-stripe h2 em{ color: var(--rust-light); font-style: italic; }
.inquire-stripe p{ color: rgba(244,232,195,.85); margin-top: .5rem; max-width: 50ch; }
@media (max-width: 720px){ .inquire-stripe > .wrap{ grid-template-columns: 1fr; } }

/* ── FOOTER ── */
footer{
  background: var(--cream-2); color: var(--ink-soft);
  padding: clamp(3rem,6vh,4.5rem) var(--gutter) 1.5rem;
  border-top: 1px solid var(--line-soft);
}
.foot-grid{
  max-width: var(--grid-w); margin-inline: auto;
  display: grid; grid-template-columns: 1.5fr 1fr 1fr 1.5fr; gap: 2.5rem;
  padding-bottom: 2rem; border-bottom: 1px solid var(--line-soft);
}
.foot-brand .b{ font-family: var(--f-display); font-size: 1.55rem; color: var(--ink); }
.foot-brand .est{ font-family: var(--f-body); font-size: .7rem; letter-spacing: .2em; text-transform: uppercase;
  color: var(--rust); margin-top: .4rem; font-weight: 500; }
.foot-brand p{ margin-top: .85rem; font-size: .9rem; color: var(--ink-soft); max-width: 32ch; }
.foot-col h5{ font-family: var(--f-body); font-size: .72rem; letter-spacing: .2em; text-transform: uppercase;
  color: var(--rust); font-weight: 600; margin-bottom: .9rem; }
.foot-col ul{ list-style: none; display: flex; flex-direction: column; gap: .55rem; }
.foot-col a{ font-size: .92rem; color: var(--ink-soft); transition: color .2s var(--ease); }
.foot-col a:hover{ color: var(--rust); }
.foot-bottom{
  max-width: var(--grid-w); margin-inline: auto;
  padding-top: 1.5rem;
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: 1rem;
  font-family: var(--f-body); font-size: .75rem; color: var(--ink-mute); letter-spacing: .04em;
}
@media (max-width: 880px){ .foot-grid{ grid-template-columns: 1fr 1fr; gap: 2rem; } }
@media (max-width: 540px){ .foot-grid{ grid-template-columns: 1fr; } }

/* ── STICKY MOBILE CTA ── */
.sticky-cta{
  position: fixed; bottom: 1rem; right: 1rem; z-index: 70;
  display: none;
  padding: .9rem 1.35rem;
  background: var(--rust); color: var(--cream);
  border-radius: 999px;
  font-family: var(--f-body); font-size: .82rem; font-weight: 500;
  box-shadow: 0 8px 24px rgba(200,114,31,.45);
}
@media (max-width: 820px){ .sticky-cta{ display:inline-flex; align-items:center; gap:.5rem; } }

/* ── REVEAL ── */
.reveal{ opacity: 0; transform: translateY(20px); transition: opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in{ opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{ transition: none !important; animation: none !important; }
  .reveal{ opacity: 1; transform: none; }
  html{ scroll-behavior: auto; }
  .modal-card{ animation: none; }
}

/* ── INQUIRE/CONTACT SECTION (home page) ── */
.inquire{ background: var(--ink); color: var(--cream);
  padding: clamp(4rem,8vh,6rem) 0; position: relative; overflow: hidden; }
.inquire::before{ content:''; position:absolute; inset:0; z-index:0;
  background:
    radial-gradient(ellipse 600px 400px at 80% 100%, rgba(200,114,31,.22), transparent 70%),
    radial-gradient(ellipse 700px 500px at 0% 0%, rgba(197,162,52,.14), transparent 70%); }
.inquire > .wrap{ position: relative; z-index: 1; }
.inq-head{ display: grid; grid-template-columns: 1fr auto; gap: 2rem; align-items: end;
  padding-bottom: clamp(2rem,4vh,3rem);
  border-bottom: 1px solid rgba(244,232,195,.18);
  margin-bottom: clamp(2rem,4vh,3rem); }
.inq-head .eyebrow{ color: var(--rust-light); }
.inq-head .eyebrow::before{ background: var(--rust-light); }
.inq-head h2{ font-size: clamp(2.4rem,5vw,4.5rem); color: var(--cream); margin-top: .65rem; }
.inq-head h2 em{ color: var(--rust-light); font-style: italic; }
.inq-head .right .l{ font-family: var(--f-body); font-size: .7rem; letter-spacing: .18em; text-transform: uppercase; color: var(--rust-light); }
.inq-head .right .v{ font-family: var(--f-display); font-size: 1.2rem; color: var(--cream); margin-top: .35rem; }
@media (max-width: 720px){ .inq-head{ grid-template-columns: 1fr; } }
.inq-grid{ display: grid; grid-template-columns: minmax(0,5fr) minmax(0,7fr); gap: clamp(2rem,5vw,4rem); align-items: start; }
.inq-info{ display: flex; flex-direction: column; gap: 1.5rem; }
.inq-info .lead{ font-family: var(--f-display); font-style: italic;
  font-size: clamp(1.45rem,1.4vw + 1rem,1.95rem); color: var(--cream); line-height: 1.3; }
.inq-info .lead em{ color: var(--rust-light); }
.inq-info .ch{ padding-top: 1rem; border-top: 1px solid rgba(244,232,195,.18); display: flex; flex-direction: column; gap: .3rem; }
.inq-info .ch .l{ font-family: var(--f-body); font-size: .68rem; letter-spacing: .18em; text-transform: uppercase; color: var(--rust-light); }
.inq-info .ch a{ font-family: var(--f-display); font-size: 1.25rem; color: var(--cream); transition: color .2s var(--ease); }
.inq-info .ch a:hover{ color: var(--rust-light); }
form#inq-form{ display: grid; gap: 1.15rem; }
form#inq-form .row{ display:grid; grid-template-columns: 1fr 1fr; gap: 1.15rem; }
@media (max-width: 540px){ form#inq-form .row{ grid-template-columns: 1fr; } }
form#inq-form .field{ display:flex; flex-direction:column; gap:.35rem; }
form#inq-form label{ font-family: var(--f-body); font-size: .67rem; letter-spacing: .18em; text-transform: uppercase;
  color: rgba(244,232,195,.7); font-weight: 500; }
form#inq-form input, form#inq-form textarea{
  background: transparent; border: 0; border-bottom: 1px solid rgba(244,232,195,.25);
  padding: .8rem 0 .85rem;
  font-family: var(--f-display); font-size: 1.2rem; color: var(--cream);
  outline: none; transition: border-color .25s var(--ease); }
form#inq-form input:focus, form#inq-form textarea:focus{ border-color: var(--rust-light); }
form#inq-form input::placeholder, form#inq-form textarea::placeholder{ color: rgba(244,232,195,.4); font-style: italic; }
form#inq-form textarea{ min-height: 8rem; resize: vertical; }
form#inq-form .actions{ display:flex; align-items:center; gap: 1.25rem; padding-top: .5rem; flex-wrap: wrap; }
form#inq-form button[type="submit"]{
  background: var(--rust); color: var(--cream); border: 1px solid var(--rust);
  padding: 1.05rem 1.85rem; font-family: var(--f-body); font-size: .9rem; font-weight: 500;
  letter-spacing: .04em; cursor: pointer; display:inline-flex; align-items:center; gap:.55rem;
  transition: background .2s var(--ease), border-color .2s var(--ease); }
form#inq-form button[type="submit"]:hover:not(:disabled){ background: var(--rust-deep); border-color: var(--rust-deep); }
form#inq-form button[type="submit"]:disabled{ opacity: .55; cursor: wait; }
form#inq-form .note{ font-family: var(--f-body); font-size: .78rem; color: rgba(244,232,195,.6); }
.form-msg{ margin-top: 1rem; padding: 1rem 1.25rem; font-family: var(--f-display); font-style: italic;
  font-size: 1.05rem; border-left: 2px solid; display: none; }
.form-msg.success{ display:block; border-left-color: var(--rust-light); color: var(--rust-light); background: rgba(224,154,74,.08); }
.form-msg.error{ display:block; border-left-color: var(--wine); color: var(--cream); background: rgba(122,40,64,.18); }
@media (max-width: 880px){ .inq-grid{ grid-template-columns: 1fr; } }

/* ── STUDIO/WORKSHOP MASONRY ── */
.studio-band{ background: var(--cream-2); padding: clamp(4rem,8vh,6rem) var(--gutter); border-top: 1px solid var(--line-soft); border-bottom: 1px solid var(--line-soft); }
.studio-grid{ max-width: var(--grid-w); margin-inline: auto; columns: 3 320px; column-gap: clamp(.75rem, 1.5vw, 1.25rem); margin-top: 2rem; }
.studio-grid .sg-item{ break-inside: avoid; margin-bottom: clamp(.75rem, 1.5vw, 1.25rem); background: var(--cream-tile); overflow: hidden; cursor: zoom-in; position: relative; display: block; transition: transform .25s var(--ease); border: 0; padding: 0; width: 100%; }
.studio-grid .sg-item:hover{ transform: translateY(-3px); }
.studio-grid .sg-item img{ width: 100%; height: auto; display: block; transition: filter .3s var(--ease); }
.studio-grid .sg-item:hover img{ filter: brightness(1.04); }
.studio-grid .sg-item .badge{ position: absolute; top: .55rem; right: .55rem; font-family: var(--f-body); font-size: .58rem; letter-spacing: .15em; text-transform: uppercase; font-weight: 600; background: rgba(11,9,8,.75); color: var(--cream); padding: .25rem .55rem; -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px); }

/* ── IMAGE LIGHTBOX ── */
.img-lb{ position: fixed; inset: 0; z-index: 220; background: rgba(11,9,8,.92); -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px); display: none; align-items: center; justify-content: center; padding: clamp(1rem, 3vh, 2.5rem); cursor: zoom-out; }
.img-lb.open{ display: flex; }
.img-lb img{ max-width: 100%; max-height: 100%; object-fit: contain; filter: drop-shadow(0 20px 50px rgba(0,0,0,.6)); cursor: default; }
.img-lb .close-x{ position: absolute; top: 1rem; right: 1rem; z-index: 5; width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; background: rgba(244,232,195,.12); color: var(--cream); font-size: 1.5rem; line-height: 1; border: 1px solid rgba(244,232,195,.25); cursor: pointer; transition: background .2s var(--ease); }
.img-lb .close-x:hover{ background: var(--rust); border-color: var(--rust); }
.img-lb .cap{ position: absolute; bottom: 1rem; left: 50%; transform: translateX(-50%); font-family: var(--f-body); font-size: .78rem; letter-spacing: .12em; text-transform: uppercase; color: rgba(244,232,195,.55); }

/* ── FOLLOW DROPDOWN ── */
.follow-wrap{ position: relative; display: inline-block; }
.follow-panel{ position: absolute; top: calc(100% + .6rem); right: 0; width: min(320px, calc(100vw - 2rem)); background: var(--cream); color: var(--ink); border: 1px solid var(--line-soft); box-shadow: 0 20px 40px rgba(11,9,8,.18); padding: 1.1rem 1.1rem 1rem; z-index: 90; display: none; }
.follow-panel.open{ display: block; animation: followIn .25s var(--ease); }
@keyframes followIn { from { opacity: 0; transform: translateY(-6px); } to { opacity: 1; transform: translateY(0); } }
.follow-panel h4{ font-family: var(--f-display); font-size: 1.2rem; line-height: 1.15; color: var(--ink); margin-bottom: .35rem; }
.follow-panel h4 em{ color: var(--rust); font-style: italic; }
.follow-panel p{ font-size: .82rem; color: var(--ink-soft); margin-bottom: .85rem; line-height: 1.45; }
.follow-panel form{ display: flex; flex-direction: column; gap: .55rem; }
.follow-panel input[type="email"]{ background: var(--cream-2); border: 1px solid var(--line-soft); padding: .65rem .85rem; font-family: var(--f-body); font-size: .9rem; color: var(--ink); outline: none; transition: border-color .25s var(--ease); }
.follow-panel input[type="email"]:focus{ border-color: var(--rust); }
.follow-panel button[type="submit"]{ background: var(--rust); color: var(--cream); border: 1px solid var(--rust); padding: .7rem 1rem; font-family: var(--f-body); font-size: .85rem; font-weight: 500; cursor: pointer; transition: background .2s var(--ease); }
.follow-panel button[type="submit"]:hover:not(:disabled){ background: var(--rust-deep); border-color: var(--rust-deep); }
.follow-panel button[type="submit"]:disabled{ opacity: .6; cursor: wait; }
.follow-panel .small{ font-size: .68rem; color: var(--ink-mute); margin-top: .35rem; line-height: 1.4; }
.follow-panel .msg{ font-size: .82rem; margin-top: .55rem; }
.follow-panel .msg.ok{ color: var(--olive); }
.follow-panel .msg.err{ color: var(--wine); }

/* ── PRICE PILL ── */
.card-price{ color: var(--ink); font-weight: 600; letter-spacing: 0; text-transform: none; font-family: var(--f-body); }
