/* --- Service hub + service-page extras --- */
.svc-icon{font-size:1.9rem;display:block;margin-bottom:.4rem}
.soon-badge{display:inline-block;font-size:.58em;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  background:#eef0e6;color:#7c7c5a;border-radius:20px;padding:.18em .65em;vertical-align:middle;margin-left:.35em}
a.service-card{text-decoration:none;color:inherit;display:block;transition:transform .12s ease,box-shadow .18s ease}
a.service-card:hover{transform:translateY(-3px);box-shadow:0 10px 28px rgba(51,60,69,.12)}

/* --- Team (understated, uniform) --- */
.team-teaser{text-align:center}
.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,220px));gap:1.6rem 1.2rem;margin-top:1.4rem;justify-content:center}
.team-card{display:flex;flex-direction:column;align-items:center;text-align:center;text-decoration:none;color:inherit}
.tm-photo{width:140px;height:140px;border-radius:50%;overflow:hidden;background:#f0eee6;box-shadow:0 5px 18px rgba(51,60,69,.1);transition:box-shadow .18s ease}
.tm-photo img{width:100%;height:100%;object-fit:cover;display:block}
.team-card:hover .tm-photo{box-shadow:0 10px 26px rgba(51,60,69,.18)}
.tm-name{font-family:"Cormorant Garamond",serif;font-size:1.35rem;font-weight:600;margin-top:.7rem;color:#333c45}
.tm-role{font-size:.74rem;text-transform:uppercase;letter-spacing:.1em;color:#8a8a5a;margin-top:.15rem}
.tm-cred{font-size:.86rem;color:#7c7c74;margin-top:.25rem;line-height:1.4}
@media(max-width:560px){.team-grid{grid-template-columns:1fr 1fr;gap:1.2rem .8rem}.tm-photo{width:120px;height:120px}}

/* --- Misc page components --- */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;margin-top:1.2rem}
.gallery-ph{aspect-ratio:4/3;background:linear-gradient(135deg,#f3f1ea,#e9e6da);border-radius:12px;display:flex;align-items:center;justify-content:center;color:#b3ae9c;font-size:.85rem;letter-spacing:.08em;text-transform:uppercase}
.visit-map{width:100%;height:360px;border:0;border-radius:14px;display:block}
.careers-form{display:flex;flex-direction:column;gap:.7rem;max-width:520px;margin-top:1rem}
.careers-form input,.careers-form textarea{padding:.7rem .8rem;border:1px solid #d9d5c8;border-radius:10px;background:#fff;font:inherit;color:var(--slate,#333c45)}
.careers-form .button{align-self:flex-start}

/* --- Site notice bar (sales / closures / alerts) --- */
.site-notice{padding:.6rem 1.2rem;text-align:center;font-size:.92rem;font-weight:600;display:flex;
  gap:.6rem;align-items:center;justify-content:center;flex-wrap:wrap}
.site-notice--info{background:#fbf0c4;color:#7a5d12;border-bottom:1px solid #f0e0a0}
.site-notice--urgent{background:#f6d6d2;color:#9a2820;border-bottom:1px solid #eebab3}
.site-notice a{color:inherit;text-decoration:underline;font-weight:700;white-space:nowrap}

/* --- Lightbox gallery --- */
.lb-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:.8rem;margin-top:1.2rem}
.lb-item{display:block;aspect-ratio:1;overflow:hidden;border-radius:10px;background:#f0eee6}
.lb-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .25s ease}
.lb-item:hover img{transform:scale(1.05)}
.lb-overlay{position:fixed;inset:0;background:rgba(28,31,36,.93);display:flex;align-items:center;justify-content:center;z-index:200}
.lb-overlay[hidden]{display:none}
.lb-img{max-width:90vw;max-height:88vh;border-radius:6px;box-shadow:0 12px 44px rgba(0,0,0,.5)}
.lb-close,.lb-prev,.lb-next{position:absolute;background:none;border:0;color:#fff;font-size:2.6rem;line-height:1;cursor:pointer;opacity:.8;padding:.4rem .8rem}
.lb-close{top:.6rem;right:1rem}.lb-prev{left:.6rem;top:50%;transform:translateY(-50%)}.lb-next{right:.6rem;top:50%;transform:translateY(-50%)}
.lb-close:hover,.lb-prev:hover,.lb-next:hover{opacity:1}

/* ===== FAQ — category filter + accordion (rebuilt) ===== */
.faq-filter{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem;margin:0 auto 1.6rem;max-width:820px}
.faq-chip{background:#fff;border:1px solid #e2ddd0;border-radius:24px;padding:.4rem .9rem;font:inherit;
  font-size:.86rem;font-weight:600;color:var(--slate,#333c45);cursor:pointer;transition:.15s}
.faq-chip:hover{border-color:var(--sage,#c2bf8b)}
.faq-chip.active{background:var(--sage,#c2bf8b);border-color:var(--sage,#c2bf8b);color:#333c45}
.faq-accordion{max-width:820px;margin:0 auto}
.faq-accordion .faq-item{background:#fff;border:1px solid #eee7d8;border-radius:12px;padding:14px 20px;margin-bottom:11px;
  box-shadow:0 6px 18px rgba(51,60,69,.04)}
.faq-accordion summary{font-weight:600;color:#333c45;cursor:pointer;list-style:none;font-size:1.02rem;padding-right:1.4rem;position:relative}
.faq-accordion summary::-webkit-details-marker{display:none}
.faq-accordion summary::after{content:"+";position:absolute;right:0;top:0;color:var(--sage-dk,#9a965f);font-weight:700}
.faq-accordion .faq-item[open] summary::after{content:"–"}
.faq-accordion .faq-a{margin-top:.7em;color:#4a4a4a;line-height:1.6}

/* ===== Book page — Bookeo embed gated behind the agree modal ===== */
.book-wrap{position:relative;min-height:520px;max-width:860px;margin:0 auto}
.bookeo-embed{min-height:520px}
.book-gate{position:absolute;inset:0;background:rgba(247,245,239,.97);display:flex;align-items:center;justify-content:center;padding:1rem;border-radius:14px}
.book-gate-box{background:#fff;border:1px solid #e8e2d4;border-radius:16px;max-width:560px;width:100%;padding:1.6rem 1.8rem;box-shadow:0 18px 50px rgba(51,60,69,.14)}
.book-rules{margin:.6rem 0 1rem;padding-left:1.1rem;color:#4a4a4a;line-height:1.6}
.book-rules li{margin-bottom:.5rem}
.book-agree{display:flex;align-items:flex-start;gap:.5rem;margin:0 0 1rem;font-size:.92rem;color:#333c45;cursor:pointer}
.book-agree input{margin-top:.25rem}

/* ===== Marquee gallery wall + click-to-zoom (sitewide, Brad's pick) ===== */
.marquee{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent)}
.mq-track{display:flex;gap:.7rem;width:max-content;animation:mq-scroll var(--mq-dur,40s) linear infinite}
/* No hover-pause — the strip keeps gliding; a deliberate click opens the photo full-size. */
.mq-item{flex:0 0 auto;display:block;height:340px;border-radius:12px;overflow:hidden;cursor:zoom-in;background:#f0eee6}
.mq-item img{height:100%;width:auto;max-width:none;object-fit:cover;display:block}
@keyframes mq-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.mq-track{animation:none;overflow-x:auto}}
@media(max-width:560px){.mq-item{height:240px}}

/* The geometric "wallpaper" (sage diamond lattice) moved to the global body rule in base.css
   (site-wide + shop, Brad 2026-06-10). body.staff-bg remains only for the team pages' tighter
   vertical-rhythm rules below. */

.zoom-modal{position:fixed;inset:0;background:rgba(18,20,24,.93);display:none;align-items:center;justify-content:center;z-index:120;padding:2rem;cursor:zoom-out}
.zoom-modal.on{display:flex}
.zoom-modal img{max-width:92vw;max-height:92vh;border-radius:12px;object-fit:contain;animation:zpop .3s ease}
.zoom-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.14);color:#fff;border:none;font-size:1.8rem;width:3rem;height:3rem;border-radius:50%;cursor:pointer;line-height:1}
.zoom-nav:hover{background:rgba(255,255,255,.28)}
.zoom-prev{left:1.4rem}.zoom-next{right:1.4rem}
.zoom-close{position:absolute;top:1rem;right:1.5rem;background:none;border:none;color:#fff;font-size:2.4rem;cursor:pointer;line-height:1}
@keyframes zpop{from{transform:scale(.92);opacity:0}to{transform:scale(1);opacity:1}}

/* public staff member page */
.tm-hero-photo{width:100%;max-width:340px;border-radius:18px;object-fit:cover;box-shadow:0 14px 40px rgba(51,60,69,.16)}

/* per-artist work blocks on service pages */
.artist-work{margin:0 auto 2.2rem;max-width:1000px}
.artist-work-head{display:flex;align-items:center;gap:.8rem;text-decoration:none;color:#333c45;margin-bottom:.7rem}
.artist-work-head img{width:56px;height:56px;border-radius:50%;object-fit:cover;background:#f0eee6;border:1px solid #e7e4d8}
.aw-meta{display:flex;flex-direction:column;line-height:1.3}
.aw-meta b{font-size:1.15rem}
.artist-work-head:hover .aw-meta b{text-decoration:underline}

/* Tighter vertical rhythm on the customer-facing staff pages (hero → work → bio). */
body.staff-bg .section{padding:46px 0}
body.staff-bg .hero-inner{padding-bottom:40px}
@media(max-width:860px){
  body.staff-bg .section{padding:30px 0}
  body.staff-bg .hero-inner{padding-bottom:22px}
}
