:root {
  --bg-main: #050606;
  --bg-hero: #040505;
  --bg-panel-1: #0b110e;
  --bg-panel-2: #101714;
  --bg-panel-3: #151d19;
  --text: #f3eee7;
  --muted: #aab2ac;
  --line: rgba(255, 255, 255, 0.08);
  --accent: #1f5d47;
  --accent-strong: #2f8b69;
  --danger: #7a2d2d;
  --heading: "Cinzel", serif;
  --body: "Inter", sans-serif;
  --container: 1400px;
  --content: 1240px;
  --radius: 18px;
  --shadow: 0 24px 80px rgba(0, 0, 0, 0.36);
  --header-height: 106px;
  --admin-bar-height: 58px;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { background: var(--bg-main); color: var(--text); font-family: var(--body); line-height: 1.6; }
img { display: block; width: 100%; height: 100%; object-fit: cover; }
a { color: inherit; text-decoration: none; }
button, input, textarea, select { font: inherit; }
button { border: none; background: none; }
.hidden { display: none !important; }

.container { width: min(100% - 72px, var(--container)); margin-inline: auto; }
.section { padding: 110px 0; }
.section-shell { max-width: var(--content); }

.section-kicker, .hero-kicker, .contact-panel-kicker, .contact-clean-mini, .contact-side-card-label, .hair-promo-kicker {
  display: inline-block;
  color: var(--accent-strong);
  font-size: 0.84rem;
  letter-spacing: 0.24em;
  text-transform: uppercase;
}

.section-kicker, .hero-kicker { margin-bottom: 18px; }
h1, h2, h3, h4 { font-family: var(--heading); font-weight: 600; line-height: 1.03; }
h1 { font-size: clamp(3.6rem, 7vw, 6.7rem); letter-spacing: 0.02em; text-transform: uppercase; }
h2 { font-size: clamp(2.3rem, 4vw, 3.6rem); letter-spacing: 0.02em; text-transform: uppercase; margin-bottom: 14px; }
h3 { font-size: 1.1rem; letter-spacing: 0.04em; text-transform: uppercase; }
h4 { font-size: 1rem; letter-spacing: 0.03em; }
p { color: var(--muted); font-size: 1rem; }

.btn {
  display: inline-flex; align-items: center; justify-content: center;
  min-height: 56px; padding: 0 26px; border-radius: 12px;
  font-size: 0.98rem; font-weight: 600; transition: 0.25s ease;
  border: 1px solid transparent; cursor: pointer;
}
.btn:hover { transform: translateY(-2px); }
.btn-primary {
  background: linear-gradient(180deg, var(--accent-strong), var(--accent));
  color: #f5f8f6; box-shadow: 0 12px 28px rgba(31, 93, 71, 0.26);
}
.btn-secondary {
  border-color: rgba(255, 255, 255, 0.14); background: rgba(255, 255, 255, 0.03); color: var(--text);
}
.btn-clean-highlight {
  border-color: rgba(255, 255, 255, 0.16); background: rgba(255, 255, 255, 0.04);
  color: #f3eee7; box-shadow: 0 12px 28px rgba(0, 0, 0, 0.18); backdrop-filter: blur(12px);
}
.wide-btn { width: 100%; }

/* ADMIN */
.admin-bar {
  position: sticky; top: 0; z-index: 300;
  background: linear-gradient(180deg, rgba(8, 12, 10, 0.96), rgba(8, 12, 10, 0.9));
  border-bottom: 1px solid rgba(255, 255, 255, 0.06); backdrop-filter: blur(14px);
}
.admin-bar-inner {
  min-height: var(--admin-bar-height); display: flex; align-items: center;
  justify-content: space-between; gap: 16px; padding-block: 8px;
}
.admin-pill {
  display: inline-flex; align-items: center; min-height: 36px; padding: 0 15px; border-radius: 999px;
  background: linear-gradient(90deg, rgba(31, 93, 71, 0.24), rgba(31, 93, 71, 0.08));
  border: 1px solid rgba(47,139,105,0.14); color: #e6efea; font-size: 0.92rem; font-weight: 800;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.02);
}
.admin-bar-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.admin-mini-btn {
  min-height: 42px; min-width: 120px; padding: 0 14px; border-radius: 10px;
  background: var(--accent); color: #fff; font-weight: 700; cursor: pointer; transition: 0.2s ease;
  display: inline-flex; align-items: center; justify-content: center;
}
.admin-mini-btn:hover { transform: translateY(-1px); }
.admin-mini-btn.ghost { background: rgba(255, 255, 255, 0.04); border: 1px solid rgba(255,255,255,0.1); }
.admin-mini-btn.danger {
  background: linear-gradient(180deg, #8b3434, #732828);
  box-shadow: 0 12px 24px rgba(122,45,45,0.22);
}

/* HAIR PROMO */
.hair-promo-wrap {
  position: fixed; top: 0; right: 24px; z-index: 350;
  display: flex; flex-direction: column; align-items: center;
}
body.admin-active .hair-promo-wrap { top: calc(var(--admin-bar-height) + 2px); }
.hair-promo-thread {
  width: 1px; height: 22px; background: linear-gradient(180deg, rgba(255,255,255,0.12), rgba(255,255,255,0.03));
}
.hair-spider-trigger {
  width: 46px; height: 46px; border-radius: 50%;
  display: grid; place-items: center;
  background: radial-gradient(circle at center, rgba(31,93,71,0.22), rgba(6, 16, 12, 0.98));
  border: 1px solid rgba(47,139,105,0.28); color: var(--accent-strong);
  box-shadow: 0 14px 26px rgba(0,0,0,0.24); transition: 0.25s ease;
}
.hair-spider-trigger:hover { transform: translateY(2px) scale(1.03); }

.hair-promo-flyout {
  position: absolute; top: 56px; right: 0;
  width: min(760px, calc(100vw - 48px));
  max-height: min(860px, calc(100vh - 84px));
  overflow-y: auto; overscroll-behavior: contain; -webkit-overflow-scrolling: touch;
  padding: 26px;
  border-radius: 28px;
  background: linear-gradient(180deg, rgba(7,10,9,0.985), rgba(6,8,8,0.98));
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow: 0 28px 84px rgba(0,0,0,0.42);
}
.hair-promo-flyout::before {
  content: ""; position: absolute; top: -16px; right: 22px; width: 1px; height: 16px;
  background: linear-gradient(180deg, rgba(255,255,255,0.12), rgba(255,255,255,0.02));
}
.hair-promo-close {
  position: absolute; top: 14px; right: 14px; width: 38px; height: 38px;
  border-radius: 50%; background: rgba(255,255,255,0.04); color: #fff; cursor: pointer; font-size: 1.5rem;
  border: 1px solid rgba(255,255,255,0.08);
}
.hair-promo-display { display: block; }
.hair-promo-content {
  display: grid; grid-template-columns: minmax(250px, 290px) minmax(0, 1fr); gap: 26px; align-items: start;
}
.hair-promo-edit-btn { position: absolute; top: 16px; right: 62px; min-height: 38px; z-index: 2; }
.hair-promo-media {
  width: 100%; min-height: 496px; aspect-ratio: 9 / 16; border-radius: 22px; overflow: hidden;
  border: 1px solid rgba(255,255,255,0.08); background: rgba(255,255,255,0.03);
}
.hair-promo-media img { width: 100%; height: 100%; object-fit: cover; }
.hair-promo-copy { display: flex; flex-direction: column; justify-content: center; gap: 16px; padding: 12px 42px 8px 0; min-width: 0; }
.hair-promo-copy-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding-right: 120px; }
.hair-promo-kicker { margin-bottom: 0; }
.hair-promo-copy h3 { font-size: clamp(2.2rem, 2.8vw, 3rem); line-height: 0.96; }
.hair-promo-copy p { color: #ced6d0; max-width: 32ch; }
.hair-promo-actions { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 8px; }
.hair-promo-secondary { min-height: 48px; }
.hair-promo-editor { margin-top: 0; }
.hair-promo-upload-row { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.hair-promo-upload-preview {
  width: 112px; aspect-ratio: 9 / 16; border-radius: 14px; overflow: hidden;
  border: 1px solid rgba(255,255,255,0.08); background: rgba(255,255,255,0.03);
}
.hair-promo-toggle { margin-bottom: 2px; }

/* HEADER */
.site-header {
  position: sticky; top: 0; z-index: 200;
  padding: 18px 0 0;
  background:
    linear-gradient(180deg, rgba(4, 5, 5, 0.86), rgba(4, 5, 5, 0.14)),
    linear-gradient(90deg, rgba(31, 93, 71, 0.05), transparent 34%);
  backdrop-filter: blur(14px);
}
body.admin-active .site-header { top: var(--admin-bar-height); }
.header-inner {
  position: relative;
  min-height: 74px;
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 28px;
  padding: 0 0 16px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}
.brand-mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}
.brand-logo {
  width: 84px;
  height: 56px;
  object-fit: contain;
  filter: invert(1) brightness(0.95) drop-shadow(0 0 12px rgba(255,255,255,0.06));
}
.brand-copy {
  display: grid;
  gap: 2px;
}
.brand-kicker {
  color: rgba(219, 224, 220, 0.72);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.brand-location {
  color: #f3eee7;
  font-family: var(--heading);
  font-size: 1.02rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.header-actions {
  position: relative;
  justify-self: end;
  display: flex;
  align-items: center;
  gap: 18px;
}
.site-nav {
  display: flex;
  align-items: center;
  gap: 30px;
  padding: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
}
.site-nav a {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0;
  border-radius: 0;
  color: rgba(221, 225, 222, 0.78);
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  transition: color 0.22s ease, opacity 0.22s ease;
}
.site-nav a:hover,
.footer-links a:hover,
#accountLink.admin-active-link {
  color: #fff;
}
.site-nav a:hover {
  background: transparent;
  transform: none;
}
.site-nav a::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 4px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(47,139,105,0.9), transparent);
  transform: scaleX(0.18);
  transform-origin: center;
  opacity: 0;
  transition: transform 0.22s ease, opacity 0.22s ease;
}
.site-nav a:hover::after {
  transform: scaleX(1);
  opacity: 1;
}
.site-nav a.site-nav-cta {
  min-height: 42px;
  padding: 0 18px;
  border-radius: 999px;
  color: #f3eee7;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(47,139,105,0.32);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}
.site-nav a.site-nav-cta:hover {
  background: rgba(31,93,71,0.18);
  border-color: rgba(47,139,105,0.5);
}
.site-nav a.site-nav-cta::after {
  display: none;
}
#accountLink.admin-active-link { font-weight: 700; }
.header-socials {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 0;
  background: transparent;
  border: 0;
  border-radius: 0;
}
.header-social-link {
  width: 40px;
  height: 40px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(255,255,255,0.09);
  color: var(--accent-strong);
  background: rgba(255,255,255,0.02);
  box-shadow: none;
  transition: 0.22s ease;
}
.header-social-link:hover {
  transform: translateY(-1px);
  border-color: rgba(47,139,105,0.3);
  background: rgba(255,255,255,0.04);
}
.menu-toggle {
  display: none;
  width: 46px;
  height: 46px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.08);
  cursor: pointer;
  background: rgba(255,255,255,0.02);
  box-shadow: none;
  transition: 0.22s ease;
}
.menu-toggle:hover {
  transform: none;
  border-color: rgba(47,139,105,0.26);
}
.menu-toggle span {
  display: block;
  width: 18px;
  height: 2px;
  margin: 5px auto;
  border-radius: 999px;
  background: #fff;
}

/* HERO */
.hero {
  position: relative; min-height: calc(100vh - var(--header-height)); display: flex; align-items: center;
  overflow: hidden; background: var(--bg-hero);
}
.hero-bg, .hero-overlay { position: absolute; inset: 0; }
.hero-bg img { filter: brightness(0.28) contrast(1.03); }
.hero-overlay {
  background:
    radial-gradient(circle at center, rgba(31, 93, 71, 0.14), transparent 30%),
    linear-gradient(180deg, rgba(4,5,5,0.35), rgba(4,5,5,0.56)),
    linear-gradient(90deg, rgba(4,5,5,0.72), rgba(4,5,5,0.50), rgba(4,5,5,0.72));
}
.hero-inner { position: relative; z-index: 2; width: 100%; padding: 90px 0; }
.hero-content { max-width: 980px; margin: 0 auto; text-align: center; }
.hero-content h1 span { color: #b9aea1; }
.hero-content p { max-width: 860px; margin: 24px auto 0; font-size: 1.16rem; color: #d4dad6; }
.hero-actions { display: flex; justify-content: center; gap: 16px; flex-wrap: wrap; margin-top: 38px; }

/* SECTION COLORS */
.section-artist { background: var(--bg-panel-1); }
.section-work { background: var(--bg-panel-2); }
.section-aftercare { background: var(--bg-panel-3); }
.section-contact { background: var(--bg-panel-1); }

/* SHARED SECTION */
.section-head { margin-bottom: 44px; }
.work-head {
  display: flex; align-items: flex-end; justify-content: space-between; gap: 20px; flex-wrap: wrap;
}
.work-head-copy, .contact-head-copy { max-width: 760px; }
.edit-trigger {
  min-height: 42px; padding: 0 14px; border-radius: 10px; background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.1); color: #fff; font-weight: 700; cursor: pointer;
}

/* ARTIST */
.artist-grid {
  display: grid; grid-template-columns: minmax(280px, 420px) minmax(0, 1fr); gap: 60px; align-items: start;
}
.artist-image-wrap {
  position: relative; width: 100%; aspect-ratio: 3 / 4; border-radius: var(--radius); overflow: hidden;
  border: 1px solid var(--line); box-shadow: var(--shadow); background: #0c0f0d;
}
.artist-image-stage { position: absolute; inset: 0; overflow: hidden; background: #0c0f0d; }
.artist-image {
  position: absolute; top: 50%; left: 50%; width: 110%; height: 110%; object-fit: cover;
  transform: translate(-50%, -50%) scale(1); user-select: none; -webkit-user-drag: none; transition: filter 0.35s ease;
}
.artist-image-overlay {
  position: absolute; inset: 0; display: flex; align-items: flex-end; justify-content: flex-start; padding: 18px;
  background: linear-gradient(180deg, rgba(0,0,0,0) 34%, rgba(0,0,0,0.68) 100%); opacity: 0; transition: 0.25s ease;
}
body.admin-active .artist-image-wrap:hover .artist-image-overlay,
body.admin-active .artist-image-wrap:focus-within .artist-image-overlay { opacity: 1; }
body.admin-active .artist-image-wrap:hover .artist-image { filter: brightness(0.78); }
.artist-image-overlay-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.artist-image-btn {
  min-height: 46px; padding: 0 16px; border-radius: 12px; background: rgba(12, 18, 16, 0.92);
  border: 1px solid rgba(255,255,255,0.12); color: #fff; font-weight: 700; cursor: pointer; display: inline-flex; align-items: center; justify-content: center;
}
.artist-image-btn.secondary { background: rgba(255,255,255,0.06); }
.artist-image-btn.small { min-height: 42px; padding: 0 14px; }
.artist-header {
  display: flex; align-items: flex-start; justify-content: space-between; gap: 24px; margin-bottom: 22px;
}
.artist-header .section-title-block { display: grid; }
.artist-header .section-title-block h2 { margin-bottom: 0; }
.artist-header-actions { display: flex; gap: 10px; flex-wrap: wrap; flex-shrink: 0; }
.artist-copy-card.editing-artist-text #artistHeading { display: none; }
.artist-copy p + p { margin-top: 18px; }
.tag-row { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 24px; }
.tag {
  display: inline-flex; align-items: center; min-height: 38px; padding: 0 14px; border-radius: 999px;
  background: rgba(255,255,255,0.03); border: 1px solid var(--line); color: #dbe0dc; font-size: 0.84rem;
}

/* INLINE EDITOR */
.inline-editor {
  display: grid; gap: 14px; margin-top: 12px; padding: 20px; border-radius: 18px;
  background: rgba(255,255,255,0.03); border: 1px solid var(--line);
}
.inline-editor label { display: grid; gap: 8px; color: #dde2de; }
.inline-editor input, .inline-editor textarea, .portfolio-modal-controls select, .artist-modal-controls input {
  width: 100%; padding: 14px 15px; border-radius: 12px; border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.03); color: var(--text); outline: none;
}
.inline-editor-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.editor-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.editor-span-2 { grid-column: 1 / -1; }

/* MODALS */
.artist-modal { position: fixed; inset: 0; z-index: 610; display: grid; place-items: center; }
.portfolio-modal { position: fixed; inset: 0; z-index: 690; display: grid; place-items: center; }
.artist-modal-backdrop, .portfolio-modal-backdrop { position: absolute; inset: 0; background: rgba(0,0,0,0.78); }
.artist-modal-card, .portfolio-modal-card {
  position: relative; width: min(100% - 24px, 980px); max-height: 92vh; overflow: auto; padding: 24px;
  border-radius: 24px; background: linear-gradient(180deg, rgba(12,18,16,0.97), rgba(9,13,12,0.98));
  border: 1px solid rgba(255,255,255,0.08); box-shadow: 0 24px 80px rgba(0,0,0,0.42);
}
.artist-modal-head, .portfolio-modal-head {
  display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-bottom: 20px;
}
.artist-modal-close, .portfolio-modal-close { font-size: 2rem; color: #fff; cursor: pointer; }
.artist-modal-body { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 20px; }
.portfolio-modal-body { display: grid; grid-template-columns: 1.2fr 0.8fr; gap: 20px; }
.artist-crop-preview, .portfolio-crop-preview {
  display: grid; place-items: center; min-height: 420px; padding: 16px; border-radius: 20px; background: #0c0f0d;
  border: 1px solid rgba(255,255,255,0.08);
}
.artist-crop-frame, .portfolio-crop-frame {
  position: relative; width: 100%; max-width: 420px; border-radius: 18px; overflow: hidden; background: #111; touch-action: none; cursor: grab;
}
.artist-crop-frame { aspect-ratio: 3 / 4; }
.portfolio-crop-frame { max-width: 520px; aspect-ratio: 1 / 1; }
.portfolio-crop-frame.shape-horizontal { aspect-ratio: 2 / 1; }
.portfolio-crop-frame.shape-vertical { aspect-ratio: 1 / 2; }
.portfolio-modal-card.is-collection-crop-mode .portfolio-crop-frame.shape-horizontal { aspect-ratio: 16 / 10; }
.portfolio-modal-card.is-collection-crop-mode .portfolio-crop-frame.shape-vertical { aspect-ratio: 4 / 5; }
.collection-image-crop-frame {
  position: relative;
  width: 100%;
  max-width: 420px;
  aspect-ratio: 4 / 5;
  border-radius: 22px;
  overflow: hidden;
  background: #111;
  touch-action: none;
  cursor: grab;
}
.artist-crop-frame:active, .portfolio-crop-frame:active, .collection-image-crop-frame:active { cursor: grabbing; }
.artist-crop-frame img, .portfolio-crop-frame img, .collection-image-crop-frame img {
  position: absolute; top: 50%; left: 50%; width: 110%; height: 110%; object-fit: cover;
  transform: translate(-50%, -50%) scale(1); user-select: none; -webkit-user-drag: none; pointer-events: none;
}
.artist-modal-controls, .portfolio-modal-controls { display: grid; gap: 16px; align-content: start; }
.artist-modal-controls label, .portfolio-modal-controls label { display: grid; gap: 10px; color: #dde2de; }
.artist-modal-info {
  display: grid; gap: 8px; padding: 16px; border-radius: 16px; background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
}
.artist-modal-label {
  color: #f3eee7; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; font-size: 0.82rem;
}
.artist-modal-actions, .portfolio-modal-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.toggle-control {
  display: flex !important; align-items: center; justify-content: space-between; gap: 14px; min-height: 58px; padding: 14px 15px;
  border-radius: 12px; border: 1px solid rgba(255,255,255,0.08); background: rgba(255,255,255,0.03); color: #dde2de;
}
.toggle-control span { font-weight: 600; }
.toggle-control input[type="checkbox"] {
  appearance: none; -webkit-appearance: none; width: 58px; height: 30px; border-radius: 999px;
  background: rgba(255,255,255,0.12); border: 1px solid rgba(255,255,255,0.12); position: relative; cursor: pointer; transition: 0.2s ease; flex-shrink: 0;
}
.toggle-control input[type="checkbox"]::after {
  content: ""; position: absolute; top: 3px; left: 3px; width: 22px; height: 22px; border-radius: 50%; background: #fff; transition: 0.2s ease;
}
.toggle-control input[type="checkbox"]:checked { background: linear-gradient(180deg, var(--accent-strong), var(--accent)); border-color: transparent; }
.toggle-control input[type="checkbox"]:checked::after { transform: translateX(28px); }
.crop-help { font-size: 0.95rem; }

/* WORK */
.portfolio-head-actions { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.upload-cta {
  display: inline-flex; align-items: center; justify-content: center; min-height: 50px; padding: 0 20px; border-radius: 14px;
  background: linear-gradient(180deg, var(--accent-strong), var(--accent)); color: #fff; font-weight: 800; cursor: pointer; box-shadow: 0 12px 28px rgba(31, 93, 71, 0.24);
}
.portfolio-display-shell {
  position: relative;
  --portfolio-collapse-height: 980px;
  isolation: isolate;
}
.portfolio-display-shell.is-collapsed {
  max-height: var(--portfolio-collapse-height);
  overflow: hidden;
}
.portfolio-display-shell.is-expanded {
  padding-bottom: 0;
}
.portfolio-expand-zone {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  min-height: clamp(78px, 8vw, 96px);
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: 0 18px 10px;
  z-index: 6;
  pointer-events: none;
}
.portfolio-expand-zone::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    rgba(16, 23, 20, 0) 0%,
    rgba(16, 23, 20, 0.06) 28%,
    rgba(16, 23, 20, 0.22) 54%,
    rgba(16, 23, 20, 0.74) 82%,
    rgba(16, 23, 20, 0.98) 100%
  );
}
.portfolio-display-shell.is-expanded .portfolio-expand-zone {
  position: relative;
  left: auto;
  right: auto;
  bottom: auto;
  min-height: 0;
  padding: 14px 0 0;
  align-items: flex-start;
  pointer-events: auto;
}
.portfolio-display-shell.is-expanded .portfolio-expand-zone::before {
  display: none;
}
.portfolio-expand-btn {
  position: relative;
  z-index: 1;
  pointer-events: auto;
  min-height: 38px;
  padding: 0 14px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(5, 8, 7, 0.94);
  border: 1px solid rgba(255,255,255,0.06);
  color: #f4efe8;
  font-weight: 700;
  font-size: 0.84rem;
  cursor: pointer;
  box-shadow: 0 8px 18px rgba(0,0,0,0.14);
  transition: transform 0.18s ease, border-color 0.18s ease, background 0.18s ease, box-shadow 0.18s ease;
}
.portfolio-expand-btn:hover {
  transform: translateY(-1px);
  border-color: rgba(47,139,105,0.2);
  background: rgba(8, 11, 10, 0.98);
  box-shadow: 0 10px 20px rgba(0,0,0,0.18);
}
.portfolio-expand-icon {
  font-size: 0.76rem;
  line-height: 1;
  opacity: 0.76;
}
.portfolio-grid {
  --portfolio-row-unit: 8px;
  display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); grid-auto-rows: var(--portfolio-row-unit);
  grid-auto-flow: dense; gap: 14px;
}
.portfolio-grid[data-columns="4"] { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.portfolio-grid.portfolio-grid--single { grid-template-columns: 1fr !important; }
.portfolio-grid.portfolio-grid--single .portfolio-item { grid-column: 1 / -1 !important; }
.portfolio-item {
  position: relative; min-width: 0; border-radius: 18px; overflow: hidden; border: 1px solid rgba(255,255,255,0.06);
  background: #0d100f; box-shadow: var(--shadow);
}
.portfolio-item.shape-square { grid-column: span 1; }
.portfolio-item.shape-horizontal { grid-column: span 2; }
.portfolio-item.shape-vertical { grid-column: span 1; }
.portfolio-media { position: absolute; inset: 0; overflow: hidden; transition: transform 0.28s ease; }
.portfolio-image {
  position: absolute; top: 50%; left: 50%; width: auto; height: auto; max-width: none; max-height: none; object-fit: fill; user-select: none;
  -webkit-user-drag: none; pointer-events: none; transition: filter 0.25s ease;
}
.portfolio-image.fit-width {
  width: 100%;
  height: auto;
}
.portfolio-image.fit-height {
  width: auto;
  height: 100%;
}
@media (hover: hover) and (pointer: fine) {
  .portfolio-item:not(.edit-mode):not(.dragging) { transition: border-color 0.28s ease, box-shadow 0.28s ease, transform 0.28s ease; }
  .portfolio-item:not(.edit-mode):not(.dragging):hover {
    border-color: rgba(47,139,105,0.34);
    box-shadow: 0 28px 80px rgba(0,0,0,0.34);
  }
  .portfolio-item:not(.edit-mode):not(.dragging):hover .portfolio-media { transform: scale(1.022); }
}
.portfolio-lightbox-trigger { position: absolute; inset: 0; z-index: 2; cursor: pointer; }
.portfolio-item.edit-mode { cursor: grab; }
.portfolio-item.dragging { opacity: 0.55; }
.portfolio-item.edit-mode .portfolio-admin-overlay {
  position: absolute; inset: auto 10px 10px 10px; z-index: 4; display: flex; justify-content: space-between; gap: 10px;
  padding: 10px; border-radius: 14px; background: rgba(7, 12, 10, 0.90); border: 1px solid rgba(255,255,255,0.1); backdrop-filter: blur(8px);
}
.portfolio-admin-left, .portfolio-admin-right { display: flex; gap: 8px; flex-wrap: wrap; }
.portfolio-chip {
  min-height: 38px; padding: 0 12px; border-radius: 10px; background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.1); color: #fff; font-weight: 700; cursor: pointer; display: inline-flex; align-items: center; justify-content: center;
}
.portfolio-chip.danger { background: var(--danger); border-color: transparent; }

/* AFTERCARE */
.care-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.care-card {
  background: rgba(255,255,255,0.03); border: 1px solid var(--line); border-radius: 16px; padding: 24px 22px;
}
.care-card h3 { margin-bottom: 10px; color: #f2eee6; }

/* CONTACT */
.contact-clean-layout { display: grid; grid-template-columns: 0.43fr 0.57fr; gap: 24px; align-items: stretch; }
.contact-clean-sidebar, .contact-panel-shell {
  background: rgba(255,255,255,0.03); border: 1px solid var(--line); border-radius: 28px; padding: 24px; min-height: 760px;
}
.contact-clean-sidebar { display: flex; flex-direction: column; gap: 16px; }
.contact-clean-sidebar-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 18px; margin-bottom: 6px; }
.contact-clean-sidebar-head h3 { margin-top: 4px; font-size: 1.35rem; }

.contact-side-card {
  width: 100%; display: grid; grid-template-columns: 56px 1fr; gap: 16px; align-items: start; text-align: left;
  padding: 20px; border-radius: 22px; background: linear-gradient(90deg, rgba(255,255,255,0.03), rgba(255,255,255,0.02));
  border: 1px solid rgba(255,255,255,0.08); cursor: pointer; transition: 0.22s ease;
}
.contact-side-card:hover { transform: translateY(-1px); border-color: rgba(47,139,105,0.22); }
.contact-side-card.active {
  background: linear-gradient(90deg, rgba(17,53,42,0.65), rgba(255,255,255,0.03)); border-color: rgba(47,139,105,0.26);
  box-shadow: inset 0 0 0 1px rgba(47,139,105,0.12);
}
.contact-side-card-icon {
  width: 56px; height: 56px; border-radius: 18px; display: grid; place-items: center;
  background: rgba(31, 93, 71, 0.14); border: 1px solid rgba(47,139,105,0.18); color: var(--accent-strong);
}
.contact-side-card-copy { display: grid; gap: 8px; padding-top: 4px; }
.contact-side-card-label { margin-bottom: 0; }
.contact-side-card-value { color: #f2efe8; font-size: 1rem; font-weight: 700; line-height: 1.38; }
.contact-side-card-value.multiline { font-weight: 700; }
.contact-side-hours { margin-top: auto; display: block; }
.contact-side-hours-head { display: grid; grid-template-columns: 56px 1fr; gap: 16px; align-items: start; margin-bottom: 16px; }
.contact-hours-list { display: grid; gap: 8px; }
.contact-hours-row {
  display: grid; grid-template-columns: 1fr auto; gap: 10px; align-items: center;
  min-height: 34px; color: #dde3de;
}
.contact-hours-row strong { color: #f2efe8; }

.contact-panel-shell { position: relative; display: flex; flex-direction: column; }
.contact-panel-shell.is-editing { justify-content: flex-start; }
.integrated-contact-editor { margin-top: 0; min-height: 100%; overflow: auto; }
.contact-editor-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; margin-bottom: 8px; }
.hours-editor-block {
  margin-top: 4px; padding: 18px; border-radius: 16px; background: rgba(255,255,255,0.025); border: 1px solid rgba(255,255,255,0.08);
}
.hours-editor-head { margin-bottom: 14px; }
.hours-editor-head .section-kicker { margin-bottom: 10px; }
.hours-editor-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.hours-editor-full { grid-column: 1 / -1; }

.contact-panel-view { display: none; flex-direction: column; gap: 22px; min-height: 100%; }
.contact-panel-view.active { display: flex; }
.contact-panel-intro { display: grid; gap: 10px; }
.contact-panel-intro h3 { font-size: 1.4rem; }

.contact-stage-card {
  flex: 1; border-radius: 26px; padding: 26px;
  background: linear-gradient(180deg, rgba(7,10,9,0.82), rgba(8,10,9,0.55));
  border: 1px solid rgba(255,255,255,0.06);
}
.contact-form-panel {
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px; flex: 1; align-content: start;
}
.field { display: grid; gap: 8px; }
.field.full { grid-column: 1 / -1; }
.field label { color: #dde0dc; font-size: 0.88rem; }
.field input, .field textarea {
  width: 100%; padding: 14px 15px; border-radius: 12px; border: 1px solid rgba(255,255,255,0.07);
  background: rgba(255,255,255,0.02); color: var(--text); outline: none;
}
.field-grow textarea { min-height: 280px; height: 100%; }

.contact-map-card { display: flex; flex-direction: column; gap: 18px; }
.map-frame-wrap {
  position: relative; flex: 1; min-height: 0; border-radius: 18px; overflow: hidden;
  border: 1px solid rgba(255,255,255,0.08); background: rgba(255,255,255,0.02);
}
.map-frame-wrap iframe { width: 100%; height: 100%; min-height: 520px; border: 0; }
.map-empty {
  position: absolute; inset: 0; display: grid; place-items: center; text-align: center; padding: 24px;
  color: var(--muted); background: rgba(8, 11, 10, 0.92);
}
.panel-action-btn { width: fit-content; }

.contact-direct-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; }
.contact-direct-card {
  min-height: 260px; padding: 22px; border-radius: 22px;
  border: 1px solid rgba(255,255,255,0.08); background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.015));
  display: flex; flex-direction: column; align-items: flex-start; gap: 14px;
}
.contact-direct-card.accent {
  background: linear-gradient(180deg, rgba(17,53,42,0.72), rgba(8,14,11,0.85));
  border-color: rgba(47,139,105,0.22);
}
.contact-direct-card.full {
  grid-column: 1 / -1; min-height: auto;
  display: grid; grid-template-columns: 64px 1fr auto; align-items: center;
}
.contact-direct-icon {
  width: 56px; height: 56px; border-radius: 18px; display: grid; place-items: center; color: var(--accent-strong);
  background: rgba(31,93,71,0.14); border: 1px solid rgba(47,139,105,0.18);
}
.contact-direct-label { color: var(--accent-strong); font-size: 0.85rem; letter-spacing: 0.22em; text-transform: uppercase; }
.contact-direct-card strong { font-size: 1.05rem; line-height: 1.05; }
.contact-direct-card p { color: #d0d8d2; }
.contact-direct-btn { min-height: 48px; padding-inline: 18px; }
.contact-direct-copy { display: grid; gap: 6px; }

.hours-stage-card { display: grid; grid-template-columns: 1fr; gap: 20px; }
.hours-table-card, .hours-vacation-card {
  padding: 22px; border-radius: 22px; background: rgba(255,255,255,0.025); border: 1px solid rgba(255,255,255,0.08);
}
.hours-table-card { display: grid; align-content: start; }
.hours-table-row {
  display: grid; grid-template-columns: 1fr auto; gap: 16px; align-items: center; min-height: 62px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.hours-table-row:last-child { border-bottom: none; }
.hours-table-row span { color: #d9dfdb; font-weight: 500; }
.hours-table-row strong { color: #f3eee7; text-align: right; font-weight: 700; }
.hours-vacation-card { display: grid; gap: 12px; }
.hours-vacation-card p { color: #d0d8d2; font-size: 1.02rem; line-height: 1.7; white-space: pre-wrap; }

/* FOOTER */
.site-footer { background: #040505; border-top: 1px solid rgba(255,255,255,0.05); padding: 26px 0 34px; }
.footer-inner { display: flex; align-items: center; justify-content: space-between; gap: 18px; flex-wrap: wrap; }
.footer-logo { width: 120px; height: 56px; object-fit: contain; filter: invert(1) brightness(0.95); opacity: 0.9; }
.footer-links { display: flex; gap: 20px; flex-wrap: wrap; }
.footer-links a { color: #d6dbd7; font-size: 0.95rem; }

/* LIGHTBOX */
.lightbox {
  position: fixed; inset: 0; z-index: 500; display: none; place-items: center; background: rgba(0, 0, 0, 0.82); padding: 32px;
}
.lightbox.active { display: grid; }
.lightbox img {
  max-width: min(92vw, 1100px); max-height: 86vh; width: auto; height: auto; object-fit: contain; border-radius: 16px;
}
.lightbox-close { position: absolute; top: 20px; right: 24px; font-size: 2rem; color: white; cursor: pointer; }

/* RESPONSIVE */
@media (max-width: 1200px) {
  .contact-clean-layout, .hours-stage-card, .artist-modal-body, .portfolio-modal-body { grid-template-columns: 1fr; }
  .contact-clean-sidebar, .contact-panel-shell { min-height: auto; }
  .contact-direct-grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 1100px) {
  .artist-grid, .care-grid { grid-template-columns: 1fr; }
  .contact-form-panel, .editor-grid, .hours-editor-grid { grid-template-columns: 1fr; }
  .editor-span-2, .hours-editor-full { grid-column: auto; }
  .artist-image-wrap { max-width: 420px; margin-inline: auto; }
  .map-frame-wrap iframe { min-height: 420px; }
}

@media (max-width: 1180px) {
  .header-inner { gap: 20px; }
  .site-nav { gap: 22px; }
  .site-nav a { font-size: 0.7rem; letter-spacing: 0.14em; }
}

@media (max-width: 860px) {
  .portfolio-grid, .portfolio-grid[data-columns="4"], .portfolio-grid[data-columns="3"], .portfolio-grid[data-columns="1"] { grid-template-columns: 1fr; }
  .brand-copy { display: none; }
  .brand-logo { width: 60px; height: 46px; }
  .site-nav {
    position: absolute;
    top: calc(100% + 10px);
    right: 0;
    width: min(300px, calc(100vw - 48px));
    padding: 16px;
    display: none;
    flex-direction: column;
    align-items: stretch;
    gap: 2px;
    background: linear-gradient(180deg, rgba(8,10,9,0.97), rgba(10,14,12,0.94));
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 20px;
    box-shadow: 0 24px 48px rgba(0,0,0,0.3);
    backdrop-filter: blur(20px);
  }
  .site-nav.active { display: flex; }
  .menu-toggle { display: inline-block; }
  .site-nav a {
    width: 100%;
    justify-content: flex-start;
    min-height: 46px;
    padding: 0 12px;
    font-size: 0.76rem;
    letter-spacing: 0.12em;
  }
  .site-nav a::after {
    left: 12px;
    right: 12px;
    bottom: 6px;
  }
  .site-nav a.site-nav-cta {
    justify-content: center;
    margin-top: 8px;
  }
  .header-inner {
    grid-template-columns: auto auto;
    justify-content: space-between;
    gap: 14px;
    padding: 0 0 14px;
  }
  .header-actions { gap: 12px; }
  :root { --header-height: 92px; --admin-bar-height: 56px; }
  .admin-bar-inner {
    min-height: var(--admin-bar-height);
    padding-block: 8px;
    justify-content: space-between;
  }
  .admin-pill { min-height: 34px; padding-inline: 14px; font-size: 0.86rem; }
  .admin-bar-actions { width: auto; }
  .admin-bar-actions .admin-mini-btn {
    flex: 0 0 auto;
    min-height: 36px;
    min-width: auto;
    padding-inline: 16px;
    border-radius: 12px;
  }
  body.admin-active .site-header { top: var(--admin-bar-height); }
  .portfolio-grid { grid-template-columns: 1fr; }
  .artist-header, .work-head, .contact-clean-sidebar-head { flex-direction: column; align-items: stretch; }
  .artist-header-actions { justify-content: flex-start; }
  .hair-promo-wrap { left: clamp(136px, 30vw, 182px); right: auto; top: 2px; }
  body.admin-active .hair-promo-wrap { top: calc(var(--admin-bar-height) + 4px); }
  .hair-promo-thread { height: 18px; }
  .hair-spider-trigger { width: 38px; height: 38px; }
  .hair-spider-trigger svg { width: 20px; height: 20px; }
  .hair-promo-flyout { position: fixed; left: 50%; right: auto; transform: translateX(-50%); width: min(420px, calc(100vw - 24px)); top: calc(var(--header-height) + 8px); max-height: calc(100vh - var(--header-height) - 16px); }
  body.admin-active .hair-promo-flyout { top: calc(var(--admin-bar-height) + var(--header-height) + 8px); max-height: calc(100vh - var(--admin-bar-height) - var(--header-height) - 16px); }
  .hair-promo-flyout::before { display: none; }
  .hair-promo-content { grid-template-columns: 1fr; }
  .hair-promo-media { min-height: min(48vh, 420px); aspect-ratio: 9 / 16; }
  .hair-promo-copy { padding-right: 0; }
  .hair-promo-copy-head { align-items: flex-start; padding-right: 76px; }
  .contact-direct-grid { grid-template-columns: 1fr; }
  .contact-direct-card.full { grid-template-columns: 56px 1fr; }
  .contact-direct-card.full .contact-direct-btn { grid-column: 1 / -1; width: 100%; }
  .header-socials { order: 2; }
  .menu-toggle { order: 3; }
  .portfolio-display-shell.is-collapsed { max-height: var(--portfolio-collapse-height); }
  .portfolio-expand-zone { min-height: 144px; padding-top: 24px; }
  .portfolio-display-shell.is-expanded .portfolio-expand-zone { padding-top: 14px; }
}

@media (max-width: 640px) {
  .portfolio-grid, .portfolio-grid[data-columns="4"], .portfolio-grid[data-columns="3"], .portfolio-grid[data-columns="1"] { grid-template-columns: 1fr; }
  .container { width: min(100% - 28px, var(--container)); }
  .section { padding: 84px 0; }
  h1 { font-size: clamp(2.7rem, 12vw, 4.4rem); }
  h2 { font-size: clamp(1.9rem, 8vw, 2.8rem); }
  .hero-actions, .inline-editor-actions, .portfolio-head-actions, .portfolio-modal-actions, .artist-modal-actions, .hair-promo-actions {
    flex-direction: column; align-items: stretch;
  }
  .portfolio-expand-zone { min-height: 92px; padding: 0 12px 8px; }
  .portfolio-display-shell.is-expanded .portfolio-expand-zone { padding-top: 10px; }
  .portfolio-item.edit-mode .portfolio-admin-overlay { inset: auto 10px 10px 10px; flex-direction: column; align-items: stretch; }
  .portfolio-admin-left, .portfolio-admin-right { width: 100%; }
  .portfolio-chip { flex: 1 1 0; }
  .portfolio-crop-preview, .artist-crop-preview { min-height: 300px; }
  .artist-image-overlay-actions { flex-direction: column; align-items: stretch; }
  .artist-image-btn, .panel-action-btn, .contact-direct-btn { width: 100%; }
  .map-frame-wrap iframe { min-height: 320px; }
  .hours-table-row { grid-template-columns: 1fr; gap: 6px; padding: 10px 0; }
  .hours-table-row strong { text-align: left; }
  .contact-stage-card { padding: 18px; }
  .contact-side-card, .contact-side-hours-head { grid-template-columns: 50px 1fr; gap: 14px; }
  .contact-side-card-icon, .contact-direct-icon { width: 50px; height: 50px; border-radius: 16px; }
  .contact-hours-row { grid-template-columns: 1fr; gap: 2px; }
  .brand-logo { width: 56px; height: 42px; }
  .header-social-link { width: 40px; height: 40px; border-radius: 999px; }
  .header-actions { gap: 8px; }
  .header-inner { padding: 0 0 12px; }
  .site-nav { right: 0; width: min(260px, calc(100vw - 28px)); }
  .hair-promo-wrap { left: clamp(118px, 34vw, 154px); right: auto; top: 2px; }
  body.admin-active .hair-promo-wrap { top: calc(var(--admin-bar-height) + 4px); }
  .hair-promo-thread { height: 16px; }
  .hair-promo-flyout { width: min(360px, calc(100vw - 18px)); top: calc(var(--header-height) + 6px); max-height: calc(100vh - var(--header-height) - 12px); }
  body.admin-active .hair-promo-flyout { top: calc(var(--admin-bar-height) + var(--header-height) + 6px); max-height: calc(100vh - var(--admin-bar-height) - var(--header-height) - 12px); }
  .hair-promo-flyout::before { display: none; }
  .hair-spider-trigger { width: 32px; height: 32px; }
  .hair-spider-trigger svg { width: 16px; height: 16px; }
  .hair-promo-close { top: 10px; right: 10px; }
  .hair-promo-copy-head { flex-direction: column; align-items: flex-start; padding-right: 42px; }
  .hair-promo-edit-btn { position: static; }
}

/* HERO ADMIN */
.hero-admin-controls { position: absolute; top: 24px; right: 0; z-index: 4; display: flex; gap: 10px; flex-wrap: wrap; justify-content: flex-end; }
.hero-admin-image-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.hero-inline-editor { max-width: 920px; margin: 26px auto 0; }
.hero-bg img { position: absolute; top: 50%; left: 50%; width: 110%; height: 110%; object-fit: cover; transform: translate(-50%, -50%) scale(1); user-select: none; -webkit-user-drag: none; }
.hero-modal { position: fixed; inset: 0; z-index: 610; display: grid; place-items: center; }
.hero-modal-backdrop { position: absolute; inset: 0; background: rgba(0,0,0,0.78); }
.hero-modal-card { position: relative; width: min(100% - 24px, 1100px); max-height: 92vh; overflow: auto; padding: 24px; border-radius: 24px; background: linear-gradient(180deg, rgba(12,18,16,0.97), rgba(9,13,12,0.98)); border: 1px solid rgba(255,255,255,0.08); box-shadow: 0 24px 80px rgba(0,0,0,0.42); }
.hero-modal-head { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-bottom: 20px; }
.hero-modal-close { font-size: 2rem; color: #fff; cursor: pointer; }
.hero-modal-body { display: grid; grid-template-columns: 1.25fr 0.75fr; gap: 20px; }
.hero-crop-preview { display: grid; place-items: center; min-height: 420px; padding: 16px; border-radius: 20px; background: #0c0f0d; border: 1px solid rgba(255,255,255,0.08); }
.hero-crop-frame { position: relative; width: 100%; max-width: 680px; aspect-ratio: 16 / 7; border-radius: 18px; overflow: hidden; background: #111; touch-action: none; cursor: grab; }
.hero-crop-frame:active { cursor: grabbing; }
.hero-crop-frame img { position: absolute; top: 50%; left: 50%; width: 110%; height: 110%; object-fit: cover; transform: translate(-50%, -50%) scale(1); user-select: none; -webkit-user-drag: none; pointer-events: none; }
.hero-modal-controls { display: grid; gap: 16px; align-content: start; }
.hero-modal-controls label { display: grid; gap: 10px; color: #dde2de; }
.aftercare-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 18px; flex-wrap: wrap; }
.footer-link-btn { color: #d6dbd7; font-size: 0.95rem; background: none; border: none; cursor: pointer; padding: 0; }
.footer-link-btn:hover { color: #fff; }
.legal-modal { position: fixed; inset: 0; z-index: 620; display: grid; place-items: center; }
.legal-modal-backdrop { position: absolute; inset: 0; background: rgba(0,0,0,0.82); }
.legal-modal-card { position: relative; width: min(100% - 24px, 980px); max-height: 92vh; overflow: auto; padding: 28px; border-radius: 24px; background: linear-gradient(180deg, rgba(12,18,16,0.97), rgba(9,13,12,0.98)); border: 1px solid rgba(255,255,255,0.08); box-shadow: 0 24px 80px rgba(0,0,0,0.42); }
.legal-modal-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; margin-bottom: 20px; }
.legal-modal-head-actions { display: flex; gap: 10px; align-items: center; }
.legal-modal-close { font-size: 2rem; color: #fff; cursor: pointer; }
.legal-richtext { display: grid; gap: 14px; color: #d8ded9; }
.legal-richtext h2 { font-family: var(--heading); color: var(--text); font-size: 1.2rem; margin-top: 14px; }
.legal-richtext p, .legal-richtext li { color: #cfd6d1; font-size: 0.98rem; }
.legal-richtext ul { padding-left: 22px; display: grid; gap: 8px; }
.legal-richtext a { color: #8fd7b7; }
@media (max-width: 1100px) { .hero-modal-body { grid-template-columns: 1fr; } }
@media (max-width: 860px) { .hero-admin-controls { position: static; margin: 0 auto 24px; justify-content: center; } }
@media (max-width: 640px) {
  .hero-admin-controls, .hero-admin-image-actions { flex-direction: column; align-items: stretch; }
  .hero-modal-card, .legal-modal-card { padding: 20px; }
  .legal-modal-head { flex-direction: column; align-items: stretch; }
  .legal-modal-head-actions { justify-content: space-between; }
}


/* ===== COLLECTIONS + FLIPCARD EXTENSIONS ===== */
.artist-flip-shell {
  position: relative;
  perspective: 1800px;
  min-height: 620px;
}
.artist-flip-card {
  display: grid;
  transform-style: preserve-3d;
  transition: transform 0.82s cubic-bezier(0.2, 0.75, 0.2, 1);
}
.artist-flip-shell.is-flipped .artist-flip-card {
  transform: rotateY(180deg);
}
.artist-flip-face {
  grid-area: 1 / 1;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}
.artist-flip-back {
  transform: rotateY(180deg);
}
.artist-copy-card,
.artist-studio-card {
  min-height: 100%;
  display: flex;
  flex-direction: column;
}
.artist-panel-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 28px;
}
.artist-panel-actions .btn {
  min-height: 50px;
}
.studio-showcase {
  display: grid;
  grid-template-columns: minmax(180px, 250px) minmax(0, 1fr);
  gap: 22px;
  align-items: stretch;
}
.studio-showcase-media {
  position: relative;
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.03);
  min-height: 420px;
  box-shadow: var(--shadow);
}
.studio-showcase-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.gallery-dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: rgba(255,255,255,0.38);
  border: 0;
  padding: 0;
  cursor: pointer;
  transition: transform 0.22s ease, background 0.22s ease;
}
.gallery-dot.active {
  background: var(--accent-strong);
  transform: scale(1.18);
}
.studio-gallery-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
  width: 40px;
  height: 40px;
  border-radius: 999px;
  background: rgba(6,10,8,0.62);
  border: 1px solid rgba(255,255,255,0.1);
  color: #fff;
  font-size: 1.4rem;
  display: grid;
  place-items: center;
  cursor: pointer;
  backdrop-filter: blur(10px);
}
.studio-gallery-nav.prev { left: 12px; }
.studio-gallery-nav.next { right: 12px; }
.studio-gallery-dots {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 14px;
  z-index: 2;
  display: flex;
  justify-content: center;
  gap: 8px;
  pointer-events: none;
}
.studio-gallery-dots .gallery-dot {
  pointer-events: auto;
}
.studio-showcase-copy {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.studio-showcase-copy p + p {
  margin-top: 16px;
}
.studio-upload-row {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}
.studio-upload-preview {
  width: 112px;
  height: 140px;
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.03);
  flex-shrink: 0;
}

/* Portfolio project cards */
.portfolio-item {
  isolation: isolate;
}
.portfolio-project-meta {
  position: absolute;
  left: 12px;
  right: 12px;
  bottom: 12px;
  z-index: 3;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  pointer-events: none;
}
.portfolio-project-dots {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  min-height: 28px;
  padding: 0 12px;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(7,11,10,0.74), rgba(7,11,10,0.56));
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,0.06);
}
.portfolio-project-extra {
  color: #d8dfda;
  font-size: 0.72rem;
  font-weight: 700;
}
.portfolio-project-video-indicator {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(7,11,10,0.68);
  border: 1px solid rgba(255,255,255,0.06);
  color: #eef4ef;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.04em;
}
.portfolio-item.edit-mode .portfolio-project-meta {
  bottom: 62px;
}

/* Public project viewer */
.project-viewer {
  position: fixed;
  inset: 0;
  z-index: 560;
  display: none;
  place-items: center;
}
.project-viewer.hidden {
  display: none !important;
}
.project-viewer:not(.hidden) {
  display: grid;
}
.project-viewer-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.84);
  backdrop-filter: blur(8px);
}
.project-viewer-card {
  position: relative;
  width: min(100% - 24px, 1180px);
  max-height: min(92vh, 1080px);
  overflow: auto;
  padding: 56px 22px 22px;
  border-radius: 28px;
  background: linear-gradient(180deg, rgba(10,14,13,0.985), rgba(6,9,8,0.98));
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow: 0 28px 90px rgba(0,0,0,0.44);
}
.project-viewer-shell {
  display: grid;
  grid-template-columns: minmax(0, 1.38fr) minmax(240px, 0.62fr);
  gap: 22px;
  align-items: start;
}
.project-viewer-shell.is-textless {
  grid-template-columns: 1fr;
}
.project-viewer-stage {
  position: relative;
  min-width: 0;
}
.project-viewer-frame {
  min-height: min(72vh, 820px);
  border-radius: 24px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.06);
  background: rgba(255,255,255,0.03);
  display: grid;
  place-items: center;
}
.project-viewer-frame img,
.project-viewer-frame video {
  width: 100%;
  height: 100%;
  object-fit: contain;
  background: #060807;
}
.project-viewer-copy {
  display: grid;
  gap: 12px;
  align-content: start;
  padding: 4px 4px 4px 0;
}
.project-viewer-meta {
  color: var(--accent-strong);
  font-size: 0.76rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
.project-viewer-copy h3 {
  font-size: clamp(1.55rem, 2vw, 2.25rem);
  margin: 0;
}
.project-viewer-copy p {
  color: #d1d8d3;
  white-space: pre-wrap;
}
.project-viewer-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
  width: 48px;
  height: 48px;
  border-radius: 999px;
  background: rgba(6, 10, 8, 0.82);
  border: 1px solid rgba(255,255,255,0.08);
  color: #fff;
  font-size: 1.9rem;
  line-height: 1;
  display: grid;
  place-items: center;
  cursor: pointer;
  box-shadow: 0 16px 32px rgba(0,0,0,0.22);
}
.project-viewer-nav.prev { left: 18px; }
.project-viewer-nav.next { right: 18px; }
.project-viewer-nav.hidden {
  display: none !important;
}
.project-viewer-dots {
  margin-top: 16px;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 10px;
}
.project-viewer-dot {
  width: 9px;
  height: 9px;
  border-radius: 999px;
  border: 0;
  padding: 0;
  background: rgba(255,255,255,0.3);
  cursor: pointer;
  transition: transform 0.2s ease, background 0.2s ease;
}
.project-viewer-dot.active {
  background: var(--accent-strong);
  transform: scale(1.18);
}
.project-viewer-dot.video {
  width: 11px;
  height: 11px;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.3);
}
.project-viewer-close {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  color: #fff;
  font-size: 1.55rem;
  cursor: pointer;
  z-index: 3;
}

/* Portfolio project admin */
.portfolio-modal-body--project {
  grid-template-columns: minmax(0, 1fr) minmax(360px, 0.94fr);
}
.portfolio-media-admin-head {
  display: grid;
  gap: 6px;
  padding: 14px 16px;
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.02));
  border: 1px solid rgba(255,255,255,0.08);
}
.portfolio-media-upload-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.portfolio-media-admin-list {
  display: grid;
  gap: 12px;
}
.portfolio-media-admin-item {
  display: grid;
  grid-template-columns: 84px minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  padding: 14px;
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.025));
  border: 1px solid rgba(255,255,255,0.08);
}
.portfolio-media-admin-thumb {
  width: 84px;
  height: 84px;
  border-radius: 14px;
  overflow: hidden;
  background: rgba(255,255,255,0.04);
  display: grid;
  place-items: center;
  color: #dfe6e1;
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.portfolio-media-admin-thumb img,
.portfolio-media-admin-thumb video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.portfolio-media-admin-meta {
  min-width: 0;
}
.portfolio-media-admin-meta strong {
  display: block;
  color: #f3eee7;
  font-size: 0.95rem;
  margin-bottom: 4px;
}
.portfolio-media-admin-meta p {
  font-size: 0.88rem;
  line-height: 1.45;
  white-space: pre-wrap;
}
.portfolio-media-admin-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.portfolio-media-admin-chip {
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.1);
  color: #fff;
  font-size: 0.82rem;
  font-weight: 700;
  cursor: pointer;
}
.portfolio-media-admin-chip.active {
  background: rgba(31,93,71,0.18);
  border-color: rgba(47,139,105,0.3);
}
.portfolio-media-admin-chip.danger {
  background: rgba(122,45,45,0.92);
  border-color: transparent;
}
.portfolio-media-admin-empty {
  padding: 18px;
  border-radius: 16px;
  background: rgba(255,255,255,0.025);
  border: 1px dashed rgba(255,255,255,0.08);
  color: var(--muted);
}

@media (max-width: 1200px) {
  .studio-showcase,
  .project-viewer-shell,
  .portfolio-modal-body--project {
    grid-template-columns: 1fr;
  }
  .project-viewer-copy {
    padding-right: 0;
  }
}

@media (max-width: 860px) {
  .artist-flip-shell {
    min-height: auto;
  }
  .artist-flip-face {
    position: relative;
  }
  .studio-showcase-media {
    min-height: 320px;
  }
  .studio-gallery-nav {
    width: 36px;
    height: 36px;
  }
  .project-viewer-card {
    padding: 54px 16px 16px;
    width: min(100% - 14px, 1000px);
  }
  .project-viewer-frame {
    min-height: min(54vh, 520px);
  }
  .project-viewer-nav {
    width: 42px;
    height: 42px;
    font-size: 1.55rem;
  }
  .project-viewer-nav.prev { left: 10px; }
  .project-viewer-nav.next { right: 10px; }
  .portfolio-media-admin-item {
    grid-template-columns: 64px minmax(0, 1fr);
  }
  .portfolio-media-admin-actions {
    grid-column: 1 / -1;
    justify-content: flex-start;
  }
}

@media (max-width: 640px) {
  .artist-panel-actions {
    flex-direction: column;
    align-items: stretch;
  }
  .studio-showcase-media {
    min-height: 240px;
  }
  .project-viewer-card {
    padding: calc(env(safe-area-inset-top, 0px) + 54px) 14px 14px;
    border-radius: 22px;
  }
  .project-viewer-frame {
    min-height: min(44vh, 420px);
    border-radius: 20px;
  }
  .project-viewer-close {
    top: calc(env(safe-area-inset-top, 0px) + 8px);
    right: 8px;
  }
  .portfolio-project-meta {
    left: 10px;
    right: 10px;
    bottom: 10px;
    gap: 8px;
  }
  .portfolio-project-dots,
  .portfolio-project-video-indicator {
    min-height: 26px;
    padding-inline: 10px;
  }
}

body.viewer-open { overflow: hidden; }
.studio-media-admin-item .portfolio-media-admin-meta strong { color: #f4efe8; }

/* === v8.2 polish overrides === */
.edit-trigger {
  min-height: 40px;
  padding: 0 14px;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(255,255,255,0.08), rgba(255,255,255,0.04));
  border: 1px solid rgba(255,255,255,0.12);
  color: #f6f1ea;
  font-weight: 700;
  letter-spacing: 0.01em;
  box-shadow: 0 12px 30px rgba(0,0,0,0.14);
}

.edit-trigger:hover,
.admin-mini-btn:hover,
.artist-image-btn:hover,
.portfolio-chip:hover {
  transform: translateY(-1px);
  filter: brightness(1.03);
}

.hero-admin-controls {
  position: absolute;
  top: 28px;
  left: 50%;
  right: auto;
  transform: translateX(-50%);
  z-index: 4;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: center;
  padding: 10px 12px;
  border-radius: 999px;
  background: rgba(6,10,8,0.68);
  border: 1px solid rgba(255,255,255,0.08);
  backdrop-filter: blur(14px);
}

.hero-admin-image-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.artist-header-actions,
.work-head .portfolio-head-actions,
.aftercare-head,
.contact-clean-sidebar-head {
  gap: 12px;
}

.inline-editor,
.hero-inline-editor,
.contact-editor.integrated-contact-editor {
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.03));
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow: 0 22px 60px rgba(0,0,0,0.18);
}

.studio-showcase {
  grid-template-columns: minmax(220px, 320px) minmax(0, 1fr);
  gap: 26px;
}

.studio-gallery-trigger {
  position: relative;
  appearance: none;
  -webkit-appearance: none;
  cursor: pointer;
  padding: 0;
  text-align: left;
  transition: transform 0.26s ease, border-color 0.26s ease, box-shadow 0.26s ease;
}

.studio-gallery-trigger:hover {
  transform: translateY(-2px);
  border-color: rgba(255,255,255,0.14);
  box-shadow: 0 22px 60px rgba(0,0,0,0.22);
}

.studio-gallery-trigger::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0.02), rgba(0,0,0,0.34));
  pointer-events: none;
}

.studio-gallery-count,
.portfolio-project-count,
.portfolio-project-video-indicator {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(7,11,10,0.68);
  border: 1px solid rgba(255,255,255,0.08);
  color: #eef3ef;
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  backdrop-filter: blur(10px);
}

.studio-gallery-count {
  position: absolute;
  top: 14px;
  left: 14px;
  z-index: 2;
}

.studio-gallery-open {
  position: absolute;
  left: 14px;
  right: 14px;
  bottom: 14px;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 14px;
  border-radius: 16px;
  background: rgba(7,11,10,0.66);
  border: 1px solid rgba(255,255,255,0.08);
  color: #f5efe8;
  backdrop-filter: blur(12px);
}

.studio-gallery-open-label {
  font-weight: 700;
}

.studio-gallery-open-icon {
  display: inline-flex;
  width: 30px;
  height: 30px;
  border-radius: 999px;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,0.06);
}

.portfolio-project-meta {
  left: 14px;
  right: 14px;
  bottom: 14px;
  gap: 8px;
  justify-content: flex-start;
}

.portfolio-project-count {
  min-height: 28px;
}

.portfolio-project-video-indicator {
  gap: 7px;
}

.portfolio-project-video-dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--accent-strong);
  box-shadow: 0 0 0 4px rgba(47,139,105,0.16);
}

.project-viewer-card {
  width: min(100% - 24px, 1100px);
  padding: 58px 22px 22px;
}

.project-viewer-shell {
  grid-template-columns: minmax(0, 1.45fr) minmax(240px, 0.55fr);
  gap: 26px;
}

.project-viewer-frame {
  border-radius: 28px;
  min-height: min(72vh, 800px);
  background: radial-gradient(circle at top, rgba(255,255,255,0.03), rgba(255,255,255,0.015));
}

.project-viewer-close {
  top: 14px;
  right: 14px;
  width: 44px;
  height: 44px;
  background: rgba(7,11,10,0.88);
}

.project-viewer-copy {
  gap: 10px;
  align-content: center;
  padding: 8px 0;
}

.project-viewer-meta {
  color: var(--accent-strong);
  font-size: 0.72rem;
  letter-spacing: 0.18em;
}

.project-viewer-copy h3 {
  font-size: clamp(1.35rem, 2vw, 2rem);
}

.project-viewer-description,
.project-viewer-copy p {
  font-size: 0.98rem;
  line-height: 1.7;
}

.project-viewer-dots {
  margin-top: 18px;
  gap: 8px;
}

.project-viewer-dot {
  width: 28px;
  height: 4px;
  border-radius: 999px;
  background: rgba(255,255,255,0.18);
  border: 0;
  padding: 0;
}

.project-viewer-dot.active {
  background: linear-gradient(90deg, var(--accent), var(--accent-strong));
  transform: none;
}

.project-viewer-dot.video {
  width: 38px;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.16);
}

.portfolio-modal-card {
  width: min(100% - 24px, 1180px);
  padding: 24px;
  border-radius: 30px;
}

.portfolio-modal-head {
  margin-bottom: 18px;
}

.portfolio-modal-body--project {
  grid-template-columns: minmax(340px, 0.88fr) minmax(0, 1.12fr);
  gap: 22px;
  align-items: start;
}

.portfolio-crop-preview {
  min-height: 560px;
  border-radius: 26px;
  background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.02));
}

.portfolio-crop-frame {
  max-width: 100%;
  box-shadow: 0 18px 40px rgba(0,0,0,0.24);
}

.portfolio-crop-frame img,
#cropPreviewImage {
  width: auto;
  height: auto;
  max-width: none;
  max-height: none;
  object-fit: fill;
}

.portfolio-crop-frame img.fit-width,
#cropPreviewImage.fit-width {
  width: 100%;
  height: auto;
}

.portfolio-crop-frame img.fit-height,
#cropPreviewImage.fit-height {
  width: auto;
  height: 100%;
}

.portfolio-modal-controls {
  gap: 18px;
}

.portfolio-modal-controls > label,
.portfolio-media-admin-head {
  padding: 14px 16px;
  border-radius: 18px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.07);
}

.portfolio-modal-controls > label input,
.portfolio-modal-controls > label textarea,
.portfolio-modal-controls > label select {
  margin-top: 10px;
}

.portfolio-media-admin-head {
  display: grid;
  gap: 6px;
}

.portfolio-media-upload-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.portfolio-media-admin-list {
  display: grid;
  gap: 12px;
}

.portfolio-media-admin-item {
  grid-template-columns: 78px minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  padding: 12px 14px;
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.025));
  border: 1px solid rgba(255,255,255,0.08);
}

.portfolio-media-admin-thumb {
  width: 78px;
  height: 78px;
  border-radius: 16px;
  background: rgba(255,255,255,0.04);
}

.portfolio-media-admin-thumb-label {
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #f1ede6;
}

.portfolio-media-admin-meta strong {
  margin-bottom: 2px;
  font-size: 0.92rem;
}

.portfolio-media-admin-meta p {
  color: #b8c1bb;
  font-size: 0.84rem;
}

.portfolio-media-admin-actions {
  justify-content: flex-end;
  gap: 6px;
}

.portfolio-media-admin-chip {
  min-height: 34px;
  min-width: 34px;
  padding: 0 11px;
  border-radius: 999px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.09);
  color: #f5efe8;
  font-size: 0.76rem;
}

.portfolio-media-admin-chip.active {
  background: rgba(31,93,71,0.18);
}

.portfolio-media-admin-chip.danger {
  background: rgba(122,45,45,0.88);
}

.portfolio-admin-overlay {
  inset: auto 12px 12px 12px;
  padding: 10px;
  border-radius: 16px;
  background: rgba(7,12,10,0.72);
  border: 1px solid rgba(255,255,255,0.08);
  backdrop-filter: blur(12px);
}

.portfolio-chip {
  min-height: 36px;
  border-radius: 999px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.08);
  font-size: 0.82rem;
}

@media (max-width: 1200px) {
  .portfolio-modal-body--project,
  .studio-showcase,
  .project-viewer-shell {
    grid-template-columns: 1fr;
  }

  .portfolio-crop-preview {
    min-height: 420px;
  }
}

@media (max-width: 860px) {
  .hero-admin-controls {
    position: static;
    transform: none;
    width: fit-content;
    margin: 0 auto 24px;
    border-radius: 24px;
  }

  .studio-showcase-media {
    min-height: 300px;
  }

  .project-viewer-card {
    width: min(100% - 12px, 980px);
    padding: calc(env(safe-area-inset-top, 0px) + 56px) 14px 16px;
    max-height: 96vh;
  }

  .project-viewer-frame {
    min-height: min(52vh, 520px);
    border-radius: 22px;
  }

  .project-viewer-copy {
    padding: 0;
  }

  .project-viewer-close {
    top: calc(env(safe-area-inset-top, 0px) + 10px);
    right: 10px;
  }

  .portfolio-media-admin-item {
    grid-template-columns: 62px minmax(0, 1fr);
  }

  .portfolio-media-admin-actions {
    grid-column: 1 / -1;
    justify-content: flex-start;
  }
}

@media (max-width: 640px) {
  .studio-gallery-open {
    padding: 10px 12px;
  }

  .studio-gallery-count,
  .portfolio-project-count,
  .portfolio-project-video-indicator {
    min-height: 28px;
    padding: 0 10px;
    font-size: 0.7rem;
  }

  .project-viewer-frame {
    min-height: min(42vh, 400px);
  }

  .project-viewer-dot {
    width: 22px;
  }
}

.project-viewer-meta{display:none !important;}

/* === inline editing + media panels vNext === */
.hero {
  isolation: isolate;
}

.hero-admin-controls {
  position: absolute;
  top: 28px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 6;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: center;
  padding: 10px 12px;
  border-radius: 999px;
  background: rgba(6, 10, 8, 0.72);
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow: 0 18px 40px rgba(0,0,0,0.22);
  backdrop-filter: blur(16px);
}

.hero-inline-actions,
.aftercare-admin-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.section-media-admin {
  display: grid;
  gap: 12px;
  padding: 14px;
  border-radius: 20px;
  background: linear-gradient(180deg, rgba(9, 14, 12, 0.94), rgba(6, 10, 8, 0.88));
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow: 0 20px 56px rgba(0,0,0,0.24);
  backdrop-filter: blur(16px);
}

.section-media-admin-head {
  display: grid;
  gap: 4px;
}

.section-media-admin-kicker {
  color: var(--accent-strong);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-size: 0.72rem;
  font-weight: 700;
}

.section-media-admin-head strong {
  color: #f3eee7;
  font-size: 0.98rem;
  line-height: 1.25;
}

.section-media-admin-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.section-media-admin-preview {
  position: relative;
  overflow: hidden;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.03);
}

.section-media-admin-preview img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.hero-media-panel {
  position: absolute;
  top: 108px;
  right: 30px;
  width: min(300px, calc(100vw - 40px));
  z-index: 5;
}

.hero-media-preview {
  aspect-ratio: 4 / 3;
}

.artist-image-wrap {
  position: relative;
  width: 100%;
  min-height: 620px;
  aspect-ratio: auto;
  overflow: visible;
  border: 0;
  background: transparent;
  box-shadow: none;
}

.artist-media-deck {
  position: relative;
  min-height: 620px;
  perspective: 1800px;
}

.artist-media-face {
  position: absolute;
  inset: 0;
  display: grid;
  grid-template-rows: minmax(0, 1fr) auto;
  gap: 16px;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  transition: transform 0.82s cubic-bezier(0.2, 0.75, 0.2, 1), opacity 0.42s ease;
}

.artist-media-front {
  transform: rotateY(0deg);
  opacity: 1;
}

.artist-media-back {
  transform: rotateY(180deg);
  opacity: 0;
}

.artist-image-stage,
.studio-gallery-stage {
  position: relative;
  overflow: hidden;
  min-height: 0;
  border-radius: 28px;
  border: 1px solid rgba(255,255,255,0.08);
  background: #0c0f0d;
  box-shadow: var(--shadow);
}

.studio-gallery-stage {
  appearance: none;
  -webkit-appearance: none;
  width: 100%;
  padding: 0;
  cursor: pointer;
}

.studio-gallery-stage img,
.artist-image-stage img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.artist-image-wrap.is-studio-view .artist-media-front {
  transform: rotateY(-180deg);
  opacity: 0;
}

.artist-image-wrap.is-studio-view .artist-media-back {
  transform: rotateY(0deg);
  opacity: 1;
}

body.admin-active .artist-image-wrap:hover .artist-image,
body.admin-active .artist-image-wrap:hover .studio-gallery-stage img {
  filter: brightness(0.86);
}

.artist-copy,
.artist-flip-shell {
  min-height: 620px;
}

.artist-copy-card,
.artist-studio-card {
  padding: 30px;
  border-radius: 28px;
  background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.025));
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow: 0 24px 70px rgba(0,0,0,0.18);
}

.studio-showcase-copy--solo {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: calc(100% - 6px);
}

.studio-showcase-copy--solo p + p {
  margin-top: 16px;
}

[data-inline-editable] {
  transition: box-shadow 0.22s ease, background 0.22s ease, border-color 0.22s ease;
}

[data-inline-editable][contenteditable="true"] {
  cursor: text;
}

[data-inline-editable][contenteditable="true"]:focus {
  outline: none;
}

.is-inline-editing [data-inline-editable][contenteditable="true"] {
  border-radius: 14px;
  background: rgba(255,255,255,0.05);
  box-shadow: inset 0 0 0 1px rgba(47,139,105,0.28);
}

.hero-content.is-inline-editing [data-inline-editable][contenteditable="true"] {
  padding: 10px 14px;
}

#heroDescription,
#artistText1,
#artistText2,
#studioText1,
#studioText2,
#aftercareIntro,
#careText1,
#careText2,
#careText3,
#careText4,
#careText5,
#careText6 {
  white-space: pre-line;
}

.hero-content.is-inline-editing .hero-actions a[contenteditable="true"],
.artist-copy-card.is-inline-editing .btn[contenteditable="true"],
.artist-studio-card.is-inline-editing .btn[contenteditable="true"] {
  cursor: text;
}

.hero-content.is-inline-editing .hero-actions a[contenteditable="true"] {
  pointer-events: auto;
}

.tag-row.is-tag-editor {
  display: block;
  min-height: 52px;
  padding: 14px 16px;
  border-radius: 18px;
  background: rgba(255,255,255,0.05);
  box-shadow: inset 0 0 0 1px rgba(47,139,105,0.28);
}

.tag-row.is-tag-editor .tag {
  display: none;
}

.tag-row.is-tag-editor::before {
  content: attr(data-helper);
  display: block;
  margin-bottom: 8px;
  color: #90b8a6;
  font-size: 0.78rem;
  letter-spacing: 0.03em;
}

.care-card {
  min-height: 100%;
}

.care-card.is-inline-editing {
  box-shadow: inset 0 0 0 1px rgba(47,139,105,0.28);
}

.care-card.is-inline-editing h3,
.care-card.is-inline-editing p {
  padding: 8px 10px;
  border-radius: 12px;
  background: rgba(255,255,255,0.04);
}

.artist-header-actions,
.aftercare-admin-actions {
  align-items: center;
}

.artist-panel-actions.is-disabled,
.hero-actions.is-disabled {
  opacity: 0.9;
}

@media (max-width: 1200px) {
  .hero-media-panel {
    position: relative;
    top: auto;
    right: auto;
    width: min(420px, 100%);
    margin: 92px auto 0;
  }
}

@media (max-width: 1100px) {
  .artist-image-wrap,
  .artist-media-deck,
  .artist-copy,
  .artist-flip-shell {
    min-height: auto;
  }

  .artist-media-face {
    position: relative;
    inset: auto;
  }

  .artist-media-front,
  .artist-media-back,
  .artist-image-wrap.is-studio-view .artist-media-front,
  .artist-image-wrap.is-studio-view .artist-media-back {
    transform: none;
    opacity: 1;
  }

  .artist-media-front {
    display: grid;
  }

  .artist-media-back {
    display: none;
  }

  .artist-image-wrap.is-studio-view .artist-media-front {
    display: none;
  }

  .artist-image-wrap.is-studio-view .artist-media-back {
    display: grid;
  }
}

@media (max-width: 860px) {
  .hero-admin-controls {
    width: min(calc(100% - 24px), 620px);
    top: 18px;
  }

  .hero-media-panel {
    margin-top: 24px;
  }

  .artist-copy-card,
  .artist-studio-card {
    padding: 22px;
    border-radius: 24px;
  }
}

/* ===== refined inline editing + unified artist/studio postcard ===== */
.hero-content.is-inline-editing [data-inline-editable][contenteditable="true"] {
  display: inline-block;
  padding: 0.18em 0.32em;
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(13, 21, 18, 0.78), rgba(10, 16, 14, 0.58));
  box-shadow:
    0 10px 24px rgba(0,0,0,0.16),
    inset 0 0 0 1px rgba(47,139,105,0.16);
  backdrop-filter: blur(10px);
}

.hero-content.is-inline-editing #heroDescription,
.hero-content.is-inline-editing .hero-actions a[contenteditable="true"] {
  display: inline-flex;
}

.hero-content.is-inline-editing h1 [data-inline-editable][contenteditable="true"] {
  margin: 0.06em 0;
}

.hero-content.is-inline-editing [data-inline-editable][contenteditable="true"]:focus {
  box-shadow:
    0 14px 34px rgba(0,0,0,0.2),
    inset 0 0 0 1px rgba(47,139,105,0.24),
    0 0 0 6px rgba(47,139,105,0.08);
}

.artist-postcard-shell {
  position: relative;
  perspective: 1800px;
}

.artist-postcard-card {
  position: relative;
  min-height: 620px;
  transform-style: preserve-3d;
  transition: transform 0.82s cubic-bezier(0.2, 0.75, 0.2, 1);
}

.artist-postcard-shell.is-flipped .artist-postcard-card {
  transform: rotateY(180deg);
}

.artist-postcard-face {
  position: absolute;
  inset: 0;
  display: grid;
  grid-template-columns: minmax(300px, 420px) minmax(0, 1fr);
  gap: 34px;
  align-items: stretch;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}

.artist-postcard-face.artist-flip-back {
  transform: rotateY(180deg);
}

.artist-postcard-media,
.artist-postcard-copy {
  min-height: 620px;
}

.artist-postcard-media {
  display: grid;
  grid-template-rows: minmax(0, 1fr) auto;
  gap: 16px;
}

.artist-postcard-stage,
.studio-gallery-stage {
  position: relative;
  overflow: hidden;
  min-height: 0;
  height: 100%;
  border-radius: 28px;
  border: 1px solid rgba(255,255,255,0.08);
  background: #0c0f0d;
  box-shadow: var(--shadow);
}

.artist-postcard-stage img,
.studio-gallery-stage img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.artist-postcard-copy {
  padding: 30px;
  border-radius: 28px;
  background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.025));
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow: 0 24px 70px rgba(0,0,0,0.18);
}

.artist-copy-card,
.artist-studio-card {
  min-height: 620px;
}

.artist-media-admin-panel {
  align-self: end;
}

.section-media-admin-note {
  margin: -2px 0 2px;
  color: #9cb8ad;
  font-size: 0.82rem;
  line-height: 1.4;
}

.artist-copy-card.is-inline-editing [data-inline-editable][contenteditable="true"],
.artist-studio-card.is-inline-editing [data-inline-editable][contenteditable="true"] {
  border-radius: 16px;
  padding: 0.22em 0.3em;
  background: rgba(255,255,255,0.04);
  box-shadow:
    inset 0 0 0 1px rgba(47,139,105,0.16),
    0 8px 24px rgba(0,0,0,0.08);
}

.artist-copy-card.is-inline-editing p[data-inline-editable][contenteditable="true"],
.artist-studio-card.is-inline-editing p[data-inline-editable][contenteditable="true"] {
  display: block;
  padding: 12px 14px;
}

.artist-copy-card.is-inline-editing .tag-row.is-tag-editor,
.artist-studio-card.is-inline-editing .tag-row.is-tag-editor {
  background: rgba(255,255,255,0.04);
  box-shadow: inset 0 0 0 1px rgba(47,139,105,0.16);
}

.studio-media-admin-list .portfolio-media-admin-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.studio-media-admin-list .portfolio-media-admin-chip {
  min-width: 48px;
}

@media (max-width: 1100px) {
  .artist-postcard-card {
    min-height: auto;
  }

  .artist-postcard-face {
    position: relative;
    inset: auto;
    grid-template-columns: 1fr;
  }

  .artist-postcard-face.artist-flip-back {
    display: none;
  }

  .artist-postcard-shell.is-flipped .artist-postcard-face.artist-flip-front {
    display: none;
  }

  .artist-postcard-shell.is-flipped .artist-postcard-face.artist-flip-back {
    display: grid;
    transform: none;
  }

  .artist-postcard-media,
  .artist-postcard-copy,
  .artist-copy-card,
  .artist-studio-card {
    min-height: auto;
  }

  .artist-postcard-stage,
  .studio-gallery-stage {
    min-height: 320px;
  }
}

@media (max-width: 860px) {
  .artist-postcard-copy {
    padding: 22px;
    border-radius: 24px;
  }
}

@media (max-width: 640px) {
  .hero-content.is-inline-editing [data-inline-editable][contenteditable="true"] {
    padding: 0.16em 0.24em;
    border-radius: 14px;
  }

  .artist-postcard-face {
    gap: 20px;
  }

  .artist-postcard-stage,
  .studio-gallery-stage {
    min-height: 280px;
    border-radius: 24px;
  }
}


/* === Artist / Studio polish overrides === */
.sr-only {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

.artist-postcard-face {
  align-items: start;
}

.artist-postcard-media {
  grid-template-rows: auto minmax(0, 1fr);
  align-content: start;
  min-height: 0;
}

.artist-postcard-copy {
  padding: 10px 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

.artist-copy-card,
.artist-studio-card {
  min-height: auto;
}

.artist-postcard-stage,
.studio-gallery-stage {
  height: auto;
  min-height: clamp(320px, 52vh, 760px);
  aspect-ratio: 3 / 4;
  border: 0;
  box-shadow: none;
  background: transparent;
}

.artist-postcard-stage {
  overflow: hidden;
  border-radius: 30px;
}

.studio-gallery-stage {
  overflow: hidden;
  border-radius: 30px;
}

.studio-gallery-stage::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0.04), rgba(0,0,0,0.28));
  pointer-events: none;
}

.studio-gallery-count {
  display: none !important;
}

.studio-gallery-open {
  display: none !important;
}

.studio-gallery-minimal-ui {
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: 18px;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  pointer-events: none;
}

.studio-gallery-strips {
  display: inline-flex;
  align-items: center;
  gap: 7px;
}

.studio-gallery-strips span {
  display: block;
  width: 26px;
  height: 4px;
  border-radius: 999px;
  background: rgba(255,255,255,0.34);
  box-shadow: 0 10px 24px rgba(0,0,0,0.12);
}

.studio-gallery-open-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: 999px;
  color: #f5efe8;
  background: rgba(8, 12, 10, 0.46);
  border: 1px solid rgba(255,255,255,0.08);
  backdrop-filter: blur(10px);
}

.artist-copy-card.is-inline-editing [data-inline-editable][contenteditable="true"],
.artist-studio-card.is-inline-editing [data-inline-editable][contenteditable="true"],
.hero-content.is-inline-editing [data-inline-editable][contenteditable="true"] {
  border-radius: 18px;
  background: rgba(255,255,255,0.04);
  box-shadow: 0 12px 30px rgba(0,0,0,0.10);
}

.artist-copy-card.is-inline-editing p[data-inline-editable][contenteditable="true"],
.artist-studio-card.is-inline-editing p[data-inline-editable][contenteditable="true"] {
  padding: 12px 14px;
}

.artist-copy-card.is-inline-editing [data-inline-editable][contenteditable="true"]:focus,
.artist-studio-card.is-inline-editing [data-inline-editable][contenteditable="true"]:focus,
.hero-content.is-inline-editing [data-inline-editable][contenteditable="true"]:focus {
  background: rgba(255,255,255,0.06);
  box-shadow:
    0 16px 36px rgba(0,0,0,0.14),
    0 0 0 1px rgba(47,139,105,0.12);
}

.hero-content.is-inline-editing [data-inline-editable][contenteditable="true"] {
  padding: 0.18em 0.34em;
}

.hero-content.is-inline-editing #heroDescription[data-inline-editable][contenteditable="true"] {
  padding: 14px 18px;
}

.hero-content.is-inline-editing h1 [data-inline-editable][contenteditable="true"] {
  display: inline-block;
}

.artist-copy-card.is-inline-editing .tag-row.is-tag-editor,
.artist-studio-card.is-inline-editing .tag-row.is-tag-editor {
  background: rgba(255,255,255,0.04);
  box-shadow: 0 12px 30px rgba(0,0,0,0.10);
}

.studio-media-admin-panel {
  min-height: 0;
  overflow: hidden;
  display: grid;
  gap: 16px;
  align-content: start;
}

.studio-media-admin-list {
  min-height: 0;
  max-height: min(46vh, 520px);
  overflow: auto;
  overscroll-behavior: contain;
  padding-right: 8px;
}

.studio-media-admin-list::-webkit-scrollbar {
  width: 8px;
}

.studio-media-admin-list::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,0.18);
  border-radius: 999px;
}

.studio-media-admin-list .portfolio-media-admin-item {
  align-items: center;
}

.project-viewer.studio-viewer .project-viewer-card {
  width: min(100% - 44px, 1240px);
  max-height: 94vh;
  padding: 34px 32px 24px;
}

.project-viewer.studio-viewer .project-viewer-shell {
  display: block;
}

.project-viewer.studio-viewer .project-viewer-stage {
  display: grid;
  grid-template-columns: 56px minmax(0, 1fr) 56px;
  gap: 22px;
  align-items: center;
}

.project-viewer.studio-viewer .project-viewer-frame {
  min-height: min(78vh, 860px);
  border: 0;
  background: transparent;
  box-shadow: none;
  border-radius: 30px;
  overflow: hidden;
}

.project-viewer.studio-viewer .project-viewer-copy {
  display: none !important;
}

.project-viewer.studio-viewer .project-viewer-nav {
  position: static;
  transform: none;
  width: 52px;
  height: 52px;
  background: rgba(8, 12, 10, 0.48);
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow: none;
}

.project-viewer.studio-viewer .project-viewer-dots {
  margin-top: 18px;
  justify-content: center;
}

.project-viewer.studio-viewer .project-viewer-dot {
  width: 34px;
  height: 4px;
  border-radius: 999px;
  background: rgba(255,255,255,0.22);
}

.project-viewer.studio-viewer .project-viewer-dot.active {
  background: var(--accent-strong);
  transform: none;
}

@media (max-width: 1100px) {
  .artist-postcard-stage,
  .studio-gallery-stage {
    min-height: clamp(280px, 48vh, 620px);
  }
}

@media (max-width: 860px) {
  .artist-postcard-copy {
    padding: 0;
  }

  .project-viewer.studio-viewer .project-viewer-card {
    width: min(100% - 16px, 760px);
    padding: calc(env(safe-area-inset-top, 0px) + 54px) 12px 18px;
  }

  .project-viewer.studio-viewer .project-viewer-stage {
    grid-template-columns: 42px minmax(0, 1fr) 42px;
    gap: 8px;
  }

  .project-viewer.studio-viewer .project-viewer-nav {
    width: 42px;
    height: 42px;
    font-size: 1.1rem;
  }
}

@media (max-width: 640px) {
  .studio-gallery-minimal-ui {
    left: 14px;
    right: 14px;
    bottom: 14px;
  }

  .studio-gallery-strips span {
    width: 20px;
  }

  .studio-gallery-open-icon {
    width: 34px;
    height: 34px;
  }

  .studio-media-admin-list {
    max-height: min(42vh, 420px);
  }

  .project-viewer.studio-viewer .project-viewer-frame {
    min-height: min(62vh, 540px);
    border-radius: 24px;
  }
}


/* === drawer layout fix === */
.section-media-admin-title {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.section-media-admin-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.media-drawer-collapse,
.media-drawer-handle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.05);
  color: #f5efe8;
  cursor: pointer;
  box-shadow: 0 16px 36px rgba(0,0,0,0.18);
  backdrop-filter: blur(12px);
}

.media-drawer-collapse:hover,
.media-drawer-handle:hover {
  transform: translateY(-1px);
}

.media-drawer {
  --drawer-width: 320px;
  --drawer-gap: 14px;
  --drawer-top: calc(var(--admin-bar-height) + 96px);
  position: fixed;
  top: var(--drawer-top);
  right: max(18px, calc((100vw - var(--content)) / 2 - var(--drawer-width) - var(--drawer-gap)));
  z-index: 80;
  width: min(var(--drawer-width), calc(100vw - 36px));
  max-height: min(74vh, calc(100vh - var(--drawer-top) - 18px));
  overflow: hidden;
  transition: transform 0.26s ease, opacity 0.22s ease;
}

.media-drawer--studio {
  --drawer-width: 360px;
}

.media-drawer.is-collapsed {
  transform: translateX(calc(100% + 22px));
  opacity: 0;
  pointer-events: none;
}

.media-drawer-handle {
  position: fixed;
  right: max(18px, calc((100vw - var(--content)) / 2 - 54px));
  z-index: 79;
}

.media-drawer-handle::before {
  content: attr(title);
  position: absolute;
  right: calc(100% + 10px);
  top: 50%;
  transform: translateY(-50%);
  padding: 7px 11px;
  border-radius: 999px;
  background: rgba(8, 12, 10, 0.72);
  border: 1px solid rgba(255,255,255,0.08);
  color: #eef4ef;
  font-size: 0.72rem;
  letter-spacing: 0.04em;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.18s ease, transform 0.18s ease;
}

.media-drawer-handle:hover::before {
  opacity: 1;
  transform: translateY(-50%) translateX(-2px);
}

#heroMediaPanelHandle {
  top: calc(var(--admin-bar-height) + 108px);
}

#artistImageOverlayHandle {
  top: calc(50vh - 30px);
}

#studioMediaPanelHandle {
  top: calc(50vh + 34px);
}

.hero-media-panel,
#heroMediaPanelHandle,
#artistImageOverlay,
#artistImageOverlayHandle,
#studioMediaPanel,
#studioMediaPanelHandle {
  --drawer-top: calc(var(--admin-bar-height) + 96px);
}

.hero-media-panel {
  top: var(--drawer-top);
  right: 28px;
  width: min(320px, calc(100vw - 44px));
}

.artist-media-admin-panel {
  align-self: start;
}

.studio-media-admin-panel {
  max-height: min(74vh, calc(100vh - var(--drawer-top) - 18px));
  grid-template-rows: auto auto auto minmax(0, 1fr);
}

.studio-media-admin-list {
  max-height: none;
  min-height: 0;
  overflow: auto;
}

.artist-postcard-shell {
  min-height: 620px;
}

.artist-postcard-card {
  height: 100%;
}

.artist-postcard-shell.is-editing {
  z-index: 2;
}

.artist-postcard-face {
  overflow: hidden;
}

.artist-postcard-media,
.artist-postcard-copy {
  min-height: 0;
  min-width: 0;
}

.artist-postcard-copy {
  min-height: 0;
}

.artist-copy-card,
.artist-studio-card {
  min-height: 0;
}

.artist-postcard-shell.is-editing .artist-postcard-copy {
  padding-top: 0;
}

.hero-content.is-inline-editing [data-inline-editable][contenteditable="true"] {
  background: linear-gradient(180deg, rgba(10,16,14,0.66), rgba(10,16,14,0.28));
  box-shadow: 0 14px 30px rgba(0,0,0,0.12);
}

.artist-copy-card.is-inline-editing [data-inline-editable][contenteditable="true"],
.artist-studio-card.is-inline-editing [data-inline-editable][contenteditable="true"] {
  background: linear-gradient(180deg, rgba(10,16,14,0.66), rgba(10,16,14,0.28));
  box-shadow: 0 14px 30px rgba(0,0,0,0.12);
}

.artist-copy-card.is-inline-editing [data-inline-editable][contenteditable="true"]:focus,
.artist-studio-card.is-inline-editing [data-inline-editable][contenteditable="true"]:focus,
.hero-content.is-inline-editing [data-inline-editable][contenteditable="true"]:focus {
  background: linear-gradient(180deg, rgba(12,20,17,0.74), rgba(10,16,14,0.36));
  box-shadow: 0 18px 38px rgba(0,0,0,0.16), 0 0 0 1px rgba(47,139,105,0.14);
}


@media (min-width: 1500px) {
  .media-drawer {
    --drawer-gap: 18px;
  }
}

@media (max-width: 1100px) {
  .artist-postcard-shell,
  .artist-postcard-card {
    min-height: 0;
    height: auto !important;
  }

  .media-drawer {
    position: relative;
    top: auto;
    right: auto;
    width: 100%;
    max-height: none;
    transform: none !important;
    opacity: 1 !important;
    pointer-events: auto !important;
    margin-top: 18px;
  }

  .media-drawer-handle,
  .media-drawer-collapse {
    display: none !important;
  }

  .studio-media-admin-panel {
    max-height: none;
  }
}



/* === media panel refresh === */
body.admin-active.media-panel-open::after {
  display: none;
}

.hero-admin-controls,
.artist-header-actions,
.artist-header-actions-row,
.hero-inline-actions {
  position: relative;
  z-index: 241;
}

.section-media-admin.media-panel {
  position: fixed;
  top: 50%;
  left: 50%;
  right: auto;
  transform: translate(-50%, -50%);
  width: min(520px, calc(100vw - 64px));
  max-height: min(78vh, calc(100vh - var(--admin-bar-height) - 72px));
  overflow: auto;
  z-index: 1001;
  background: linear-gradient(180deg, rgba(8, 12, 10, 0.98), rgba(5, 8, 7, 0.98));
  box-shadow: 0 36px 100px rgba(0,0,0,0.52);
  isolation: isolate;
}

.section-media-admin.media-panel.hidden {
  display: none !important;
}

.media-panel--studio {
  width: min(520px, calc(100vw - 48px));
}

.media-panel-close {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.05);
  color: #f5efe8;
  cursor: pointer;
  box-shadow: 0 16px 36px rgba(0,0,0,0.18);
  backdrop-filter: blur(12px);
  font-size: 1.45rem;
  line-height: 1;
}

.media-panel-close:hover {
  transform: translateY(-1px);
}

.hero-media-panel,
.artist-media-admin-panel,
.studio-media-admin-panel {
  align-self: start;
}

.media-drawer,
.media-drawer-handle,
.media-drawer-collapse {
  right: auto;
}

@media (max-width: 1100px) {
  .section-media-admin.media-panel {
    top: calc(var(--admin-bar-height) + 86px);
    left: 16px;
    right: 16px;
    transform: none;
    width: auto;
    max-height: min(74vh, calc(100vh - var(--admin-bar-height) - 86px));
  }
}

@media (max-width: 860px) {
  .hero-admin-controls {
    position: static;
    width: 100%;
    margin: 0 0 24px;
    justify-items: stretch;
  }

  .hero-admin-primary-actions,
  .artist-header-actions-row,
  .hero-inline-actions {
    justify-content: flex-start;
  }

  .artist-header-actions {
    justify-items: stretch;
  }

  .section-media-admin.media-panel {
    top: calc(var(--admin-bar-height) + 70px);
  }
}

@media (max-width: 640px) {
  .hero-admin-primary-actions,
  .artist-header-actions-row,
  .hero-inline-actions {
    flex-direction: column;
    align-items: stretch;
  }
}



.section-media-admin.media-panel:not(.hidden) {
  display: grid !important;
}


/* === admin panel final desktop fix === */
body.admin-active.media-panel-open::after {
  display: none !important;
}

.hero .hero-admin-controls {
  position: absolute !important;
  top: 28px !important;
  right: 0 !important;
  left: auto !important;
  transform: none !important;
  width: auto !important;
  margin: 0 !important;
  justify-items: end !important;
  z-index: 20 !important;
}

.hero .hero-admin-primary-actions,
.hero .hero-inline-actions {
  justify-content: flex-end !important;
}

.artist-header .artist-header-actions {
  display: grid !important;
  gap: 10px !important;
  justify-items: end !important;
  align-items: end !important;
}

.artist-header .artist-header-actions-row {
  display: flex !important;
  gap: 10px !important;
  flex-wrap: wrap !important;
  justify-content: flex-end !important;
}

.artist-header .media-panel-launch,
.hero .hero-media-open-btn {
  justify-self: end !important;
}

.section-media-admin.media-panel {
  position: fixed !important;
  top: calc(var(--admin-bar-height) + 92px) !important;
  right: 24px !important;
  left: auto !important;
  transform: none !important;
  width: min(420px, calc(100vw - 48px)) !important;
  max-height: min(76vh, calc(100vh - var(--admin-bar-height) - 116px)) !important;
  overflow: auto !important;
  z-index: 1001 !important;
}

.section-media-admin.media-panel:not(.hidden) {
  display: grid !important;
}

.media-panel--studio {
  width: min(520px, calc(100vw - 48px)) !important;
}

@media (max-width: 1100px) {
  .section-media-admin.media-panel {
    top: calc(var(--admin-bar-height) + 86px) !important;
    left: 16px !important;
    right: 16px !important;
    width: auto !important;
    transform: none !important;
  }
}

@media (max-width: 860px) {
  .hero .hero-admin-controls {
    position: static !important;
    width: 100% !important;
    margin: 0 0 24px !important;
    justify-items: stretch !important;
  }

  .hero .hero-admin-primary-actions,
  .hero .hero-inline-actions,
  .artist-header .artist-header-actions-row {
    justify-content: flex-start !important;
  }

  .artist-header .artist-header-actions {
    justify-items: stretch !important;
  }
}


/* Match artist postcard image sizing to studio postcard image */
.artist-postcard-media--artist .artist-image-stage {
  position: relative !important;
  inset: auto !important;
  height: auto !important;
  min-height: clamp(320px, 52vh, 760px) !important;
  aspect-ratio: 3 / 4 !important;
}

/* Keep artist image from overlapping the copy column */
.artist-flip-front .artist-postcard-media {
  position: relative;
  z-index: 1;
}

.artist-flip-front .artist-postcard-copy {
  position: relative;
  z-index: 2;
}

/* Final artist postcard image reset to match studio postcard behaviour */
.artist-postcard-media--artist .artist-image-stage {
  position: relative !important;
  inset: auto !important;
  overflow: hidden !important;
  min-height: clamp(320px, 52vh, 760px) !important;
  aspect-ratio: 3 / 4 !important;
}

.artist-postcard-media--artist .artist-image {
  position: static !important;
  top: auto !important;
  left: auto !important;
  width: 100% !important;
  height: 100% !important;
  transform: none !important;
  object-fit: cover !important;
}

.artist-flip-front .artist-postcard-media,
.artist-flip-front .artist-postcard-copy {
  position: static !important;
  z-index: auto !important;
}

/* Final About Me front-card reset: use the exact same layout sizing as the studio card */
.artist-postcard-face.artist-flip-front {
  grid-template-columns: minmax(300px, 420px) minmax(0, 1fr) !important;
  gap: 34px !important;
  align-items: start !important;
}

.artist-postcard-face.artist-flip-front .artist-postcard-media,
.artist-postcard-face.artist-flip-front .artist-postcard-copy {
  min-width: 0 !important;
}

.artist-postcard-face.artist-flip-front .artist-postcard-media--artist {
  width: 100% !important;
  max-width: none !important;
  justify-self: stretch !important;
  align-self: start !important;
}

.artist-postcard-face.artist-flip-front .artist-postcard-stage,
.artist-postcard-face.artist-flip-front .artist-image-stage {
  width: 100% !important;
  max-width: none !important;
  aspect-ratio: 3 / 4 !important;
  min-height: clamp(320px, 52vh, 760px) !important;
}

.artist-postcard-face.artist-flip-front .artist-image-stage {
  position: relative !important;
  inset: auto !important;
  overflow: hidden !important;
}

.artist-postcard-face.artist-flip-front .artist-image {
  position: static !important;
  top: auto !important;
  left: auto !important;
  width: 100% !important;
  height: 100% !important;
  transform: none !important;
  object-fit: cover !important;
}

/* Artist crop preview should mirror the live postcard framing exactly */
#artistCropFrame {
  max-width: 420px !important;
  aspect-ratio: 3 / 4 !important;
  border-radius: 30px !important;
}

#artistCropPreviewImage {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
}

/* Final artist postcard/crop sync: use the same tall live framing in the crop preview */
.artist-postcard-face.artist-flip-front .artist-image {
  position: absolute !important;
  top: 50% !important;
  left: 50% !important;
  width: 110% !important;
  height: 110% !important;
  object-fit: cover !important;
}

#artistCropFrame {
  max-width: 420px !important;
  min-height: clamp(320px, 52vh, 760px) !important;
  aspect-ratio: 3 / 4 !important;
  border-radius: 30px !important;
}

#artistCropPreviewImage {
  position: absolute !important;
  top: 50% !important;
  left: 50% !important;
  width: 110% !important;
  height: 110% !important;
  object-fit: cover !important;
}

/* Studio cover crop sync: postcard cover and crop preview use the same framing */
#studioImage {
  position: absolute !important;
  top: 50% !important;
  left: 50% !important;
  width: 110% !important;
  height: 110% !important;
  object-fit: cover !important;
}

#studioCoverCropFrame {
  max-width: 420px !important;
  min-height: clamp(320px, 52vh, 760px) !important;
  aspect-ratio: 3 / 4 !important;
  border-radius: 30px !important;
}

#studioCoverCropPreviewImage {
  position: absolute !important;
  top: 50% !important;
  left: 50% !important;
  width: 110% !important;
  height: 110% !important;
  object-fit: cover !important;
}

/* Studio lightbox refresh: show uploaded media fully, without the old framed card look */
.project-viewer.studio-viewer .project-viewer-backdrop {
  background: rgba(2, 4, 4, 0.92) !important;
  backdrop-filter: blur(10px) !important;
}

.project-viewer.studio-viewer .project-viewer-card {
  width: 100vw !important;
  max-width: none !important;
  height: 100vh !important;
  max-height: none !important;
  padding: 24px 28px 84px !important;
  overflow: hidden !important;
  border-radius: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.project-viewer.studio-viewer .project-viewer-shell {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 0 !important;
  height: 100% !important;
}

.project-viewer.studio-viewer .project-viewer-stage {
  position: relative !important;
  display: grid !important;
  place-items: center !important;
  height: 100% !important;
  min-height: 0 !important;
}

.project-viewer.studio-viewer .project-viewer-frame {
  width: min(100%, 1480px) !important;
  height: 100% !important;
  min-height: 0 !important;
  max-height: calc(100vh - 132px) !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  overflow: visible !important;
  display: grid !important;
  place-items: center !important;
}

.project-viewer.studio-viewer .project-viewer-frame img,
.project-viewer.studio-viewer .project-viewer-frame video,
.project-viewer.studio-viewer .project-viewer-media {
  width: auto !important;
  height: auto !important;
  max-width: 100% !important;
  max-height: calc(100vh - 148px) !important;
  object-fit: contain !important;
  background: transparent !important;
  display: block !important;
  margin: 0 auto !important;
}

.project-viewer.studio-viewer .project-viewer-copy {
  display: none !important;
}

.project-viewer.studio-viewer .project-viewer-nav {
  position: absolute !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 52px !important;
  height: 52px !important;
  background: rgba(7, 11, 10, 0.56) !important;
  border: 1px solid rgba(255,255,255,0.12) !important;
  box-shadow: 0 18px 34px rgba(0,0,0,0.18) !important;
  backdrop-filter: blur(10px) !important;
}

.project-viewer.studio-viewer .project-viewer-nav.prev {
  left: max(18px, env(safe-area-inset-left, 0px) + 8px) !important;
}

.project-viewer.studio-viewer .project-viewer-nav.next {
  right: max(18px, env(safe-area-inset-right, 0px) + 8px) !important;
}

.project-viewer.studio-viewer .project-viewer-close {
  top: max(18px, env(safe-area-inset-top, 0px) + 8px) !important;
  right: max(18px, env(safe-area-inset-right, 0px) + 8px) !important;
  width: 46px !important;
  height: 46px !important;
  background: rgba(7, 11, 10, 0.56) !important;
  border: 1px solid rgba(255,255,255,0.12) !important;
  box-shadow: 0 18px 34px rgba(0,0,0,0.18) !important;
  backdrop-filter: blur(10px) !important;
}

.project-viewer.studio-viewer .project-viewer-dots {
  position: absolute !important;
  left: 50% !important;
  bottom: max(18px, env(safe-area-inset-bottom, 0px) + 8px) !important;
  transform: translateX(-50%) !important;
  margin-top: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  max-width: calc(100vw - 32px) !important;
}

.project-viewer.studio-viewer .project-viewer-dots::before {
  content: attr(data-count);
  color: rgba(244, 239, 232, 0.88);
  font-size: 0.76rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  white-space: nowrap;
  margin-right: 8px;
}

.project-viewer.studio-viewer .project-viewer-dot {
  width: 26px !important;
  height: 3px !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,0.24) !important;
}

.project-viewer.studio-viewer .project-viewer-dot.active {
  background: var(--accent-strong) !important;
  transform: none !important;
}

@media (max-width: 860px) {
  .project-viewer.studio-viewer .project-viewer-card {
    padding: calc(env(safe-area-inset-top, 0px) + 16px) 12px calc(env(safe-area-inset-bottom, 0px) + 72px) !important;
  }

  .project-viewer.studio-viewer .project-viewer-frame {
    max-height: calc(100vh - 124px) !important;
  }

  .project-viewer.studio-viewer .project-viewer-frame img,
  .project-viewer.studio-viewer .project-viewer-frame video,
  .project-viewer.studio-viewer .project-viewer-media {
    max-height: calc(100vh - 140px) !important;
  }

  .project-viewer.studio-viewer .project-viewer-nav {
    width: 44px !important;
    height: 44px !important;
    font-size: 1.15rem !important;
  }
}

/* Final studio lightbox polish: center media, keep arrows at the image, remove duplicate count */
.project-viewer.studio-viewer .project-viewer-stage {
  grid-template-columns: auto auto auto !important;
  justify-content: center !important;
  align-content: center !important;
  align-items: center !important;
  gap: 18px !important;
  width: 100% !important;
}

.project-viewer.studio-viewer .project-viewer-frame {
  width: fit-content !important;
  max-width: calc(100vw - 220px) !important;
  height: auto !important;
  max-height: calc(100vh - 148px) !important;
  justify-self: center !important;
  align-self: center !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.project-viewer.studio-viewer .project-viewer-frame img,
.project-viewer.studio-viewer .project-viewer-frame video,
.project-viewer.studio-viewer .project-viewer-media {
  max-width: min(1480px, calc(100vw - 220px)) !important;
  max-height: calc(100vh - 148px) !important;
}

.project-viewer.studio-viewer .project-viewer-nav {
  position: static !important;
  transform: none !important;
}

.project-viewer.studio-viewer .project-viewer-dots::before {
  content: none !important;
  display: none !important;
}

@media (max-width: 860px) {
  .project-viewer.studio-viewer .project-viewer-stage {
    grid-template-columns: 44px auto 44px !important;
    gap: 8px !important;
  }

  .project-viewer.studio-viewer .project-viewer-frame {
    max-width: calc(100vw - 120px) !important;
  }

  .project-viewer.studio-viewer .project-viewer-frame img,
  .project-viewer.studio-viewer .project-viewer-frame video,
  .project-viewer.studio-viewer .project-viewer-media {
    max-width: calc(100vw - 120px) !important;
  }
}

/* Final hero admin polish: cleaner button stack and safer media panel placement */
.hero .hero-admin-controls {
  position: absolute !important;
  top: 26px !important;
  right: 24px !important;
  left: auto !important;
  transform: none !important;
  z-index: 240 !important;
  display: grid !important;
  grid-auto-flow: row !important;
  justify-items: end !important;
  align-content: start !important;
  gap: 10px !important;
  width: min(340px, calc(100vw - 48px)) !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
}

.hero .hero-admin-primary-actions {
  display: grid !important;
  justify-items: end !important;
  align-content: start !important;
  gap: 10px !important;
  width: 100% !important;
}

.hero .hero-inline-actions {
  justify-content: flex-end !important;
  gap: 10px !important;
  width: 100% !important;
}

.hero .hero-media-open-btn {
  justify-self: end !important;
  margin: 0 !important;
}

.hero .edit-trigger {
  outline: none !important;
}

.hero .media-panel--hero {
  top: calc(var(--admin-bar-height) + var(--header-height) + 96px) !important;
  right: 24px !important;
  width: min(420px, calc(100vw - 48px)) !important;
  max-height: min(72vh, calc(100vh - var(--admin-bar-height) - var(--header-height) - 118px)) !important;
  z-index: 1002 !important;
}

@media (max-width: 1100px) {
  .hero .hero-admin-controls {
    right: 16px !important;
    width: min(320px, calc(100vw - 32px)) !important;
  }

  .hero .media-panel--hero {
    top: calc(var(--admin-bar-height) + var(--header-height) + 84px) !important;
    left: auto !important;
    right: 16px !important;
    width: min(420px, calc(100vw - 32px)) !important;
    max-height: min(70vh, calc(100vh - var(--admin-bar-height) - var(--header-height) - 100px)) !important;
  }
}

@media (max-width: 860px) {
  .hero .hero-admin-controls {
    position: static !important;
    width: 100% !important;
    justify-items: stretch !important;
  }

  .hero .hero-admin-primary-actions {
    justify-items: stretch !important;
  }

  .hero .hero-inline-actions {
    justify-content: flex-start !important;
    width: 100% !important;
  }

  .hero .hero-media-open-btn {
    justify-self: stretch !important;
  }

  .hero .media-panel--hero {
    top: calc(var(--admin-bar-height) + var(--header-height) + 14px) !important;
    left: 16px !important;
    right: 16px !important;
    width: auto !important;
    max-height: min(72vh, calc(100vh - var(--admin-bar-height) - var(--header-height) - 30px)) !important;
  }
}


/* Final unified admin media panels: anchor each panel directly under its action buttons */
.hero .hero-admin-controls,
.artist-header .artist-header-actions {
  position: relative !important;
  z-index: 260 !important;
  display: grid !important;
  gap: 10px !important;
  align-content: start !important;
  justify-items: end !important;
}

.hero .hero-admin-controls {
  position: absolute !important;
  top: 26px !important;
  right: 24px !important;
  left: auto !important;
  transform: none !important;
  width: min(420px, calc(100vw - 48px)) !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
}

.hero .hero-admin-primary-actions {
  display: grid !important;
  justify-items: end !important;
  gap: 10px !important;
  width: 100% !important;
}

.hero .hero-inline-actions,
.artist-header .artist-header-actions-row {
  display: flex !important;
  gap: 10px !important;
  flex-wrap: wrap !important;
  justify-content: flex-end !important;
  width: 100% !important;
}

.hero .hero-media-open-btn,
.artist-header .media-panel-launch {
  justify-self: end !important;
  margin: 0 !important;
}

.hero .edit-trigger {
  outline: none !important;
}

.hero .hero-admin-controls > .section-media-admin.media-panel,
.artist-header .artist-header-actions > .section-media-admin.media-panel {
  position: absolute !important;
  top: calc(100% + 12px) !important;
  right: 0 !important;
  left: auto !important;
  transform: none !important;
  width: min(420px, calc(100vw - 48px)) !important;
  max-height: min(72vh, calc(100vh - var(--admin-bar-height) - var(--header-height) - 54px)) !important;
  margin: 0 !important;
  overflow: auto !important;
  z-index: 1002 !important;
}

.artist-header .artist-header-actions > .media-panel--studio {
  width: min(520px, calc(100vw - 48px)) !important;
}

body.admin-active .artist-postcard-shell.is-editing {
  z-index: 40 !important;
}

body.admin-active .artist-postcard-shell.is-editing .artist-postcard-face,
body.admin-active .artist-postcard-shell.is-editing .artist-postcard-copy {
  overflow: visible !important;
}

@media (max-width: 1100px) {
  .hero .hero-admin-controls {
    right: 16px !important;
    width: min(420px, calc(100vw - 32px)) !important;
  }

  .hero .hero-admin-controls > .section-media-admin.media-panel,
  .artist-header .artist-header-actions > .section-media-admin.media-panel {
    width: min(420px, calc(100vw - 32px)) !important;
  }

  .artist-header .artist-header-actions > .media-panel--studio {
    width: min(520px, calc(100vw - 32px)) !important;
    max-width: calc(100vw - 32px) !important;
  }
}

@media (max-width: 860px) {
  .hero .hero-admin-controls,
  .artist-header .artist-header-actions {
    position: static !important;
    width: 100% !important;
    justify-items: stretch !important;
  }

  .hero .hero-admin-primary-actions {
    justify-items: stretch !important;
  }

  .hero .hero-inline-actions,
  .artist-header .artist-header-actions-row {
    justify-content: flex-start !important;
  }

  .hero .hero-media-open-btn,
  .artist-header .media-panel-launch {
    justify-self: stretch !important;
  }

  .hero .hero-admin-controls > .section-media-admin.media-panel,
  .artist-header .artist-header-actions > .section-media-admin.media-panel {
    position: static !important;
    width: 100% !important;
    max-width: none !important;
    max-height: none !important;
    margin-top: 2px !important;
  }
}


/* Final hero admin alignment refinement */
.hero .hero-admin-controls {
  right: clamp(24px, calc((100% - 980px) / 2), 220px) !important;
  width: max-content !important;
  max-width: calc(100vw - 48px) !important;
}

.hero .hero-admin-primary-actions {
  width: max-content !important;
  justify-self: end !important;
}

.hero .hero-inline-actions {
  width: max-content !important;
  max-width: 100% !important;
}

.hero .hero-admin-controls > .section-media-admin.media-panel {
  right: 0 !important;
  left: auto !important;
  width: min(420px, calc(100vw - 48px)) !important;
  min-width: min(340px, calc(100vw - 48px)) !important;
}

@media (max-width: 1100px) {
  .hero .hero-admin-controls {
    right: 16px !important;
    width: max-content !important;
    max-width: calc(100vw - 32px) !important;
  }

  .hero .hero-admin-primary-actions,
  .hero .hero-inline-actions {
    width: max-content !important;
    max-width: 100% !important;
  }

  .hero .hero-admin-controls > .section-media-admin.media-panel {
    width: min(420px, calc(100vw - 32px)) !important;
    min-width: 0 !important;
  }
}

@media (max-width: 860px) {
  .hero .hero-admin-controls,
  .hero .hero-admin-primary-actions,
  .hero .hero-inline-actions {
    width: 100% !important;
    max-width: none !important;
  }

  .hero .hero-admin-controls {
    right: auto !important;
  }

  .hero .hero-admin-controls > .section-media-admin.media-panel {
    width: 100% !important;
    min-width: 0 !important;
  }
}


/* Keep hero save/cancel hidden until the real edit mode is opened */
.hero .hero-inline-actions.hidden {
  display: none !important;
}


/* Hair promo admin-only visibility hint */
.hair-promo-row {
  display: flex;
  align-items: center;
  gap: 10px;
}

.hair-promo-admin-hint {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.08);
  color: #d7dfd9;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  white-space: nowrap;
  box-shadow: 0 12px 28px rgba(0,0,0,0.16);
  backdrop-filter: blur(12px);
}

body.admin-active .hair-promo-wrap.is-admin-only .hair-spider-trigger {
  border-color: rgba(255,255,255,0.14);
}

@media (max-width: 640px) {
  .hair-promo-row {
    gap: 8px;
  }

  .hair-promo-admin-hint {
    min-height: 30px;
    padding: 0 10px;
    font-size: 0.65rem;
    letter-spacing: 0.06em;
  }
}
/* Hair promo spider status */
.hair-promo-wrap.is-enabled .hair-spider-trigger {
  background: radial-gradient(circle at center, rgba(31, 93, 71, 0.28), rgba(6, 16, 12, 0.98));
  border-color: rgba(47, 139, 105, 0.4);
  color: var(--accent-strong);
  box-shadow:
    0 14px 26px rgba(0, 0, 0, 0.24),
    0 0 0 1px rgba(47, 139, 105, 0.16),
    0 0 24px rgba(47, 139, 105, 0.18);
}

body.admin-active .hair-promo-wrap.is-admin-only .hair-spider-trigger {
  background: radial-gradient(circle at center, rgba(138, 32, 32, 0.34), rgba(18, 8, 8, 0.98));
  border-color: rgba(222, 92, 92, 0.5);
  color: #ff8f8f;
  box-shadow:
    0 14px 26px rgba(0, 0, 0, 0.24),
    0 0 0 1px rgba(222, 92, 92, 0.22),
    0 0 26px rgba(222, 92, 92, 0.2);
}

/* Hair promo placement refinement */
@media (min-width: 861px) {
  .hair-promo-wrap {
    right: 42px;
    top: 10px;
  }

  body.admin-active .hair-promo-wrap {
    top: calc(var(--admin-bar-height) + 10px);
  }

  .hair-promo-thread {
    height: 14px;
  }

  .hair-promo-flyout {
    position: fixed;
    top: calc(var(--header-height) + 18px);
    right: 28px;
    width: min(760px, calc(100vw - 64px));
    max-height: calc(100vh - var(--header-height) - 36px);
    padding-top: 30px;
  }

  body.admin-active .hair-promo-flyout {
    top: calc(var(--admin-bar-height) + var(--header-height) + 18px);
    max-height: calc(100vh - var(--admin-bar-height) - var(--header-height) - 36px);
  }

  .hair-promo-flyout::before {
    display: none;
  }

  .hair-promo-close {
    top: 18px;
    right: 18px;
    z-index: 3;
  }
}

/* Hair promo flyout should visually stay attached to the spider */
@media (min-width: 861px) {
  .hair-promo-wrap {
    top: 18px;
    right: 42px;
  }

  body.admin-active .hair-promo-wrap {
    top: calc(var(--admin-bar-height) + 18px);
  }

  .hair-promo-thread {
    height: 12px;
  }

  .hair-promo-flyout {
    position: absolute;
    top: calc(100% + 10px);
    right: -10px;
    width: min(760px, calc(100vw - 72px));
    max-height: min(860px, calc(100vh - 132px));
    padding-top: 26px;
  }

  body.admin-active .hair-promo-flyout {
    max-height: calc(100vh - var(--admin-bar-height) - 118px);
  }

  .hair-promo-flyout::before {
    display: block;
    top: -12px;
    right: 30px;
    height: 12px;
  }

  .hair-promo-close {
    top: 14px;
    right: 14px;
  }
}

/* Hair promo flyout: tighter visual connection to the spider */
@media (min-width: 861px) {
  .hair-promo-thread {
    height: 8px;
  }

  .hair-promo-flyout {
    top: calc(100% + 4px);
    right: 0;
    padding-top: 24px;
  }

  .hair-promo-flyout::before {
    display: block;
    top: -8px;
    right: 23px;
    width: 2px;
    height: 8px;
    background: linear-gradient(180deg, rgba(255,255,255,0.2), rgba(255,255,255,0.03));
  }
}

/* Hair promo final desktop anchor */
@media (min-width: 861px) {
  .hair-promo-wrap {
    top: 0;
    right: 34px;
    align-items: flex-end;
  }

  body.admin-active .hair-promo-wrap {
    top: var(--admin-bar-height);
  }

  .hair-promo-thread {
    height: calc(var(--header-height) - 48px);
    background: linear-gradient(180deg, rgba(255,255,255,0.2), rgba(255,255,255,0.05));
  }

  .hair-spider-trigger {
    width: 44px;
    height: 44px;
  }

  .hair-spider-trigger svg {
    width: 24px;
    height: 24px;
  }

  .hair-promo-flyout {
    position: absolute;
    top: calc(var(--header-height) + 2px);
    right: 0;
    width: min(760px, calc(100vw - 64px));
    max-height: calc(100vh - var(--header-height) - 24px);
    padding-top: 24px;
  }

  body.admin-active .hair-promo-flyout {
    max-height: calc(100vh - var(--admin-bar-height) - var(--header-height) - 24px);
  }

  .hair-promo-flyout::before {
    display: block;
    top: -10px;
    right: 22px;
    width: 2px;
    height: 10px;
    background: linear-gradient(180deg, rgba(255,255,255,0.22), rgba(255,255,255,0.04));
  }

  .hair-promo-close {
    top: 14px;
    right: 14px;
  }
}

/* Hair promo hard reset for desktop attachment */
@media (min-width: 861px) {
  .hair-promo-wrap {
    top: 0 !important;
    right: 36px !important;
    left: auto !important;
    align-items: flex-end !important;
  }

  body.admin-active .hair-promo-wrap {
    top: var(--admin-bar-height) !important;
  }

  .hair-promo-thread {
    height: calc(var(--header-height) - 56px) !important;
    background: linear-gradient(180deg, rgba(255,255,255,0.2), rgba(255,255,255,0.05)) !important;
  }

  .hair-promo-row {
    gap: 0 !important;
  }

  .hair-spider-trigger {
    width: 42px !important;
    height: 42px !important;
    padding: 0 !important;
  }

  .hair-spider-trigger svg {
    width: 24px !important;
    height: 24px !important;
  }

  .hair-promo-flyout {
    position: absolute !important;
    top: calc(100% + 6px) !important;
    right: 0 !important;
    left: auto !important;
    transform: none !important;
    width: min(760px, calc(100vw - 64px)) !important;
    max-height: calc(100vh - var(--header-height) - 28px) !important;
    padding-top: 24px !important;
  }

  body.admin-active .hair-promo-flyout {
    top: calc(100% + 6px) !important;
    max-height: calc(100vh - var(--admin-bar-height) - var(--header-height) - 28px) !important;
  }

  .hair-promo-flyout::before {
    display: block !important;
    top: -10px !important;
    right: 20px !important;
    width: 2px !important;
    height: 10px !important;
    background: linear-gradient(180deg, rgba(255,255,255,0.22), rgba(255,255,255,0.04)) !important;
  }

  .hair-promo-close {
    top: 14px !important;
    right: 14px !important;
    z-index: 3 !important;
  }
}

/* Hair promo: align thread with spider center */
@media (min-width: 861px) {
  .hair-promo-row {
    width: fit-content !important;
    margin-left: auto !important;
  }

  .hair-promo-thread {
    align-self: center !important;
    margin-right: 0 !important;
  }
}


/* COLLECTION SHOWCASES */
body.collection-editor-open { overflow: hidden; }

.section-collections {
  position: relative;
}

.collections-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 22px;
  flex-wrap: wrap;
}

.collections-head-copy {
  max-width: 760px;
}

.collections-head-actions {
  display: flex;
  justify-content: flex-end;
}

.collections-browser {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 18px;
  align-items: center;
}

.collections-browser-viewport {
  min-width: 0;
}

.collections-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 26px;
  align-items: stretch;
}

.collections-grid[data-columns="1"] {
  grid-template-columns: minmax(0, 1fr);
  max-width: 580px;
  margin-inline: auto;
}

.collections-strip-nav {
  width: 48px;
  height: 48px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.04);
  color: #f4efe8;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  cursor: pointer;
  transition: transform 0.18s ease, background 0.18s ease, border-color 0.18s ease;
}

.collections-strip-nav:hover {
  transform: translateY(-1px);
  background: rgba(255,255,255,0.07);
  border-color: rgba(47,139,105,0.22);
}

.collections-strip-nav:disabled {
  opacity: 0;
  pointer-events: none;
}

.collections-empty-state {
  padding: 30px;
  border-radius: 24px;
  border: 1px dashed rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.02);
  text-align: center;
}

.collections-empty-kicker {
  display: inline-block;
  margin-bottom: 10px;
  color: var(--accent-strong);
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.collection-showcase {
  height: 100%;
  display: grid;
  align-content: start;
  gap: 18px;
  padding: 26px 24px 24px;
  border-radius: 30px;
  background: linear-gradient(180deg, rgba(9, 14, 12, 0.92), rgba(7, 10, 9, 0.78));
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow: 0 26px 60px rgba(0,0,0,0.18);
}

.collection-showcase-stage--card {
  width: 100%;
  min-height: 0;
  display: block;
}

.collection-showcase-stage--card .collection-stack-shell {
  min-height: 430px;
}

.collection-showcase-stage--card .collection-stack {
  width: min(100%, 320px);
  height: 430px;
  margin-inline: auto;
}

.collection-showcase-copy {
  display: grid;
  gap: 10px;
}

.collection-showcase-copy h3 {
  margin: 0;
  font-size: clamp(1.4rem, 2vw, 1.85rem);
}

.collection-showcase-copy p {
  margin: 0;
  color: #ccd4ce;
}

.collection-showcase-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.collection-meta-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 0 14px;
  border-radius: 999px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  color: #e6ece7;
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.collection-showcase-actions {
  display: flex;
  justify-content: flex-start;
}

.collection-showcase-stage {
  width: min(100%, 520px);
  min-height: 470px;
  display: grid;
  grid-template-columns: 54px minmax(0, 1fr) 54px;
  gap: 18px;
  align-items: center;
}

.collection-showcase-stage--editor {
  width: 100%;
  min-height: 500px;
}

.collection-stack-shell {
  position: relative;
  min-height: 470px;
  display: grid;
  place-items: center;
}

.collection-stack {
  position: relative;
  width: min(100%, 370px);
  height: 470px;
}

.collection-stack--editor {
  width: min(100%, 390px);
  height: 500px;
}

.collection-stack-card {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 62%;
  aspect-ratio: 4 / 5;
  border-radius: 26px;
  overflow: hidden;
  background: linear-gradient(180deg, rgba(8, 12, 10, 0.96), rgba(6, 8, 8, 0.92));
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow: 0 30px 60px rgba(0,0,0,0.28);
  transition: transform 0.28s ease, opacity 0.28s ease, filter 0.28s ease, box-shadow 0.28s ease;
  pointer-events: none;
}

.collection-stack-card.shape-square {
  width: 68%;
  aspect-ratio: 1 / 1;
}

.collection-stack-card.shape-horizontal {
  width: 86%;
  aspect-ratio: 16 / 10;
}

.collection-stack-card.shape-vertical {
  width: 62%;
  aspect-ratio: 4 / 5;
}

.collection-stack-card--active {
  z-index: 3;
  opacity: 1;
  filter: none;
  transform: translate(-50%, -50%) scale(1);
}

.collection-stack-card--prev,
.collection-stack-card--next {
  z-index: 1;
  opacity: 0.34;
  filter: saturate(0.8);
}

.collection-stack-card--prev {
  transform: translate(calc(-50% - 36%), -50%) scale(0.86);
}

.collection-stack-card--next {
  transform: translate(calc(-50% + 36%), -50%) scale(0.86);
}

.collection-stack--editor .collection-stack-card--prev {
  transform: translate(calc(-50% - 32%), -50%) scale(0.88);
}

.collection-stack--editor .collection-stack-card--next {
  transform: translate(calc(-50% + 32%), -50%) scale(0.88);
}

.collection-stack-card.is-empty {
  width: 68%;
  opacity: 1;
  filter: none;
  transform: translate(-50%, -50%) scale(1);
}

.collection-stack-empty-label {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  padding: 24px;
  color: rgba(232, 237, 232, 0.76);
  text-align: center;
  font-size: 0.96rem;
  line-height: 1.55;
}

.collection-stack--editor .collection-stack-card.shape-square {
  width: 72%;
}

.collection-stack--editor .collection-stack-card.shape-horizontal {
  width: 90%;
}

.collection-stack--editor .collection-stack-card.shape-vertical {
  width: 64%;
}

.collection-stack-card img {
  position: absolute;
  top: 50%;
  left: 50%;
  width: auto;
  height: auto;
  max-width: none;
  max-height: none;
  display: block;
  object-fit: fill;
  transform: translate(-50%, -50%) scale(1);
  user-select: none;
  -webkit-user-drag: none;
  pointer-events: none;
}

.collection-stack-card img.fit-width {
  width: 100%;
  height: auto;
}

.collection-stack-card img.fit-height {
  width: auto;
  height: 100%;
}

.collection-editor-modal {
  position: fixed;
  inset: 0;
  z-index: 640;
  display: grid;
  place-items: center;
  padding: 26px;
}

.collection-editor-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(3, 5, 4, 0.82);
  backdrop-filter: blur(12px);
}

.collection-editor-card {
  position: relative;
  width: min(1380px, calc(100vw - 52px));
  max-height: min(92vh, 940px);
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  border-radius: 32px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.08);
  background: linear-gradient(180deg, rgba(10, 14, 12, 0.98), rgba(7, 9, 8, 0.95));
  box-shadow: 0 38px 110px rgba(0,0,0,0.46);
}

.collection-editor-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 22px;
  padding: 30px 32px 22px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}

.collection-editor-close {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.04);
  color: #f5efe8;
  font-size: 2rem;
  line-height: 1;
  cursor: pointer;
}

.collection-editor-body {
  display: grid;
  grid-template-columns: minmax(250px, 290px) minmax(0, 1fr);
  min-height: 0;
}

.collection-editor-sidebar {
  min-height: 0;
  padding: 26px 22px;
  overflow: auto;
  border-right: 1px solid rgba(255,255,255,0.07);
  background: linear-gradient(180deg, rgba(14, 19, 17, 0.94), rgba(9, 12, 11, 0.84));
}

.collection-editor-sidebar-head {
  display: grid;
  gap: 18px;
  margin-bottom: 18px;
}

.collection-manager-list {
  display: grid;
  gap: 14px;
}

.collection-manager-item {
  display: grid;
  gap: 14px;
  padding: 18px;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,0.08);
  background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.018));
  cursor: pointer;
  transition: border-color 0.24s ease, background 0.24s ease, transform 0.24s ease;
}

.collection-manager-item:hover,
.collection-manager-item:focus-visible,
.collection-manager-item.is-active {
  border-color: rgba(47,139,105,0.32);
  background: linear-gradient(180deg, rgba(22, 53, 43, 0.28), rgba(11, 18, 15, 0.5));
}

.collection-manager-item:focus-visible {
  outline: none;
}

.collection-manager-item-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.collection-manager-item-head strong {
  display: block;
  color: #f4efe8;
  font-size: 1.03rem;
}

.collection-manager-item-head small {
  display: block;
  margin-top: 5px;
  color: rgba(214, 223, 216, 0.72);
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.collection-manager-item-meta {
  display: grid;
  gap: 8px;
  color: rgba(223, 229, 224, 0.82);
  font-size: 0.94rem;
  line-height: 1.5;
}

.collection-manager-item-controls {
  display: flex;
  gap: 8px;
}

.collection-editor-main {
  min-width: 0;
  min-height: 0;
  display: grid;
  grid-template-columns: minmax(0, 1.06fr) minmax(340px, 0.94fr);
}

.collection-editor-preview-wrap {
  min-width: 0;
  min-height: 0;
  display: grid;
  align-content: start;
  gap: 18px;
  padding: 30px 26px 28px;
  border-right: 1px solid rgba(255,255,255,0.07);
}

.collection-stack-title {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 58px;
  padding: 0 20px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(2, 3, 3, 0.64);
  color: #f3eee7;
  font-weight: 700;
  font-size: 0.98rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.collection-editor-controls {
  min-width: 0;
  min-height: 0;
  overflow: auto;
  display: grid;
  align-content: start;
  gap: 18px;
  padding: 30px 28px 28px;
}

.collection-editor-meta-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.collection-editor-list {
  display: grid;
  gap: 14px;
}

@media (max-width: 1180px) {
  .collection-editor-card {
    width: min(1120px, calc(100vw - 36px));
  }

  .collection-editor-body,
  .collection-editor-main {
    grid-template-columns: 1fr;
  }

  .collection-editor-sidebar,
  .collection-editor-preview-wrap {
    border-right: none;
    border-bottom: 1px solid rgba(255,255,255,0.07);
  }
}

@media (max-width: 700px) {
  .collection-editor-modal {
    padding: 12px;
  }

  .collection-editor-card {
    width: calc(100vw - 24px);
    max-height: calc(100vh - 24px);
    border-radius: 24px;
  }

  .collection-editor-head,
  .collection-editor-sidebar,
  .collection-editor-preview-wrap,
  .collection-editor-controls {
    padding-left: 18px;
    padding-right: 18px;
  }

  .collection-editor-head {
    padding-top: 18px;
    padding-bottom: 16px;
  }
}

/* Collections front-stage refresh */
.section-collections {
  overflow: hidden;
  background:
    radial-gradient(circle at 16% 18%, rgba(27, 82, 63, 0.16), transparent 28%),
    radial-gradient(circle at 82% 12%, rgba(255, 255, 255, 0.04), transparent 24%),
    linear-gradient(180deg, rgba(7, 12, 11, 0.98), rgba(8, 16, 14, 0.94) 54%, rgba(7, 12, 11, 0.98));
}

.section-collections .section-shell {
  position: relative;
  z-index: 1;
}

.collections-browser {
  grid-template-columns: 58px minmax(0, 1fr) 58px;
  gap: 28px;
  align-items: center;
}

.collections-browser-viewport {
  min-width: 0;
  overflow: visible;
}

.collections-grid {
  position: relative;
  min-height: 760px;
  display: grid;
  place-items: center;
  overflow: visible;
}

.collections-grid[data-columns="1"] {
  max-width: none;
  margin-inline: 0;
}

.collections-strip-nav {
  width: 54px;
  height: 54px;
  background: rgba(255,255,255,0.035);
  border-color: rgba(255,255,255,0.06);
  box-shadow: 0 18px 30px rgba(0,0,0,0.2);
}

.collection-swipe-btn {
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.035);
  color: #f4efe8;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  cursor: pointer;
  transition: transform 0.18s ease, background 0.18s ease, border-color 0.18s ease, opacity 0.18s ease;
}

.collection-swipe-btn:hover {
  transform: translateY(-1px);
  background: rgba(255,255,255,0.075);
  border-color: rgba(47,139,105,0.24);
}

.collection-swipe-btn:disabled {
  opacity: 0;
  pointer-events: none;
}

.collection-showcase {
  position: absolute;
  top: 50%;
  left: 50%;
  width: min(100%, 760px);
  gap: 22px;
  padding: 34px 34px 30px;
  border-radius: 38px;
  background: linear-gradient(180deg, rgba(11, 17, 15, 0.82), rgba(8, 13, 12, 0.68));
  border: none;
  box-shadow: 0 30px 80px rgba(0,0,0,0.2);
  transition: transform 0.32s ease, opacity 0.32s ease, filter 0.32s ease, box-shadow 0.32s ease;
}

.collection-showcase--active {
  z-index: 3;
  opacity: 1;
  filter: none;
  transform: translate(-50%, -50%) scale(1);
  pointer-events: auto;
}

.collection-showcase--prev,
.collection-showcase--next {
  z-index: 1;
  width: min(100%, 620px);
  opacity: 0.42;
  filter: saturate(0.72);
  pointer-events: auto;
  cursor: pointer;
}

.collection-showcase--prev {
  transform: translate(calc(-50% - 31%), -50%) scale(0.82);
}

.collection-showcase--next {
  transform: translate(calc(-50% + 31%), -50%) scale(0.82);
}

.collection-showcase--prev .collection-showcase-copy p,
.collection-showcase--next .collection-showcase-copy p,
.collection-showcase--prev .collection-showcase-meta,
.collection-showcase--next .collection-showcase-meta,
.collection-showcase--prev .collection-showcase-actions,
.collection-showcase--next .collection-showcase-actions {
  display: none;
}

.collection-showcase--prev .collection-showcase-copy,
.collection-showcase--next .collection-showcase-copy {
  gap: 0;
}

.collection-showcase--prev .collection-showcase-copy h3,
.collection-showcase--next .collection-showcase-copy h3 {
  font-size: 1.35rem;
  opacity: 0.82;
}

.collection-showcase--prev .collection-swipe-btn,
.collection-showcase--next .collection-swipe-btn {
  opacity: 0;
  pointer-events: none;
}

.collection-showcase--prev .collection-showcase-stage,
.collection-showcase--next .collection-showcase-stage {
  width: 100%;
  min-height: 360px;
}

.collection-showcase--prev .collection-stack-shell,
.collection-showcase--next .collection-stack-shell {
  min-height: 360px;
}

.collection-showcase--prev .collection-stack,
.collection-showcase--next .collection-stack {
  width: min(100%, 280px);
  height: 360px;
}

.collection-showcase-copy {
  gap: 14px;
}

.collection-showcase-copy h3 {
  font-size: clamp(2rem, 3.4vw, 3rem);
  letter-spacing: 0.02em;
}

.collection-showcase-copy p {
  max-width: 34ch;
  color: rgba(224, 231, 225, 0.82);
  font-size: 1.02rem;
  line-height: 1.7;
}

.collection-showcase-meta {
  justify-content: flex-start;
}

.collection-showcase-stage {
  width: min(100%, 560px);
  min-height: 500px;
}

.collection-showcase-stage--card .collection-stack-shell {
  min-height: 450px;
}

.collection-showcase-stage--card .collection-stack {
  width: min(100%, 340px);
  height: 450px;
}

.collection-showcase-actions {
  margin-top: 2px;
}

@media (max-width: 1180px) {
  .collections-grid {
    min-height: 710px;
  }

  .collection-showcase {
    width: min(100%, 680px);
  }

  .collection-showcase--prev,
  .collection-showcase--next {
    width: min(100%, 540px);
  }
}

@media (max-width: 900px) {
  .collections-browser {
    grid-template-columns: 46px minmax(0, 1fr) 46px;
    gap: 14px;
  }

  .collections-grid {
    min-height: 640px;
  }

  .collection-showcase {
    position: relative;
    top: auto;
    left: auto;
    width: 100%;
    transform: none !important;
  }

  .collection-showcase--prev,
  .collection-showcase--next {
    display: none;
  }

  .collection-showcase-stage {
    width: 100%;
    grid-template-columns: 42px minmax(0, 1fr) 42px;
    gap: 12px;
    min-height: 420px;
  }

  .collection-showcase-stage--card .collection-stack-shell {
    min-height: 380px;
  }

  .collection-showcase-stage--card .collection-stack {
    width: min(100%, 300px);
    height: 380px;
  }
}

@media (max-width: 640px) {
  .section-collections {
    background:
      radial-gradient(circle at 20% 14%, rgba(27, 82, 63, 0.14), transparent 30%),
      linear-gradient(180deg, rgba(7, 12, 11, 0.98), rgba(8, 15, 14, 0.96));
  }

  .collection-showcase {
    padding: 24px 22px 22px;
    border-radius: 30px;
  }

  .collection-showcase-copy h3 {
    font-size: 1.85rem;
  }

  .collection-showcase-copy p {
    font-size: 0.96rem;
  }
}

.section-bg-contact {
  background: var(--bg-panel-1);
}

/* Instagram accents */
.header-social-link-instagram {
  color: #fff;
  border-color: rgba(187, 93, 209, 0.26);
  background:
    radial-gradient(circle at 20% 120%, rgba(254, 218, 119, 0.22), transparent 34%),
    radial-gradient(circle at 110% 0%, rgba(221, 42, 123, 0.18), transparent 38%),
    linear-gradient(135deg, rgba(81, 91, 212, 0.44), rgba(129, 52, 175, 0.42) 36%, rgba(221, 42, 123, 0.38) 68%, rgba(245, 133, 41, 0.34));
  box-shadow: 0 12px 26px rgba(91, 54, 148, 0.26);
}

.header-social-link-instagram:hover {
  border-color: rgba(221, 42, 123, 0.42);
  box-shadow: 0 16px 30px rgba(91, 54, 148, 0.34);
}

.header-social-link-instagram svg,
.contact-direct-icon-instagram svg {
  filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.18));
}

.contact-direct-card-instagram {
  border-color: rgba(177, 89, 212, 0.14);
  background:
    radial-gradient(circle at 15% 12%, rgba(254, 218, 119, 0.07), transparent 24%),
    radial-gradient(circle at 100% 0%, rgba(221, 42, 123, 0.07), transparent 34%),
    linear-gradient(145deg, rgba(81, 91, 212, 0.08), rgba(129, 52, 175, 0.06) 38%, rgba(221, 42, 123, 0.06) 72%, rgba(245, 133, 41, 0.05));
}

.contact-direct-card-instagram .contact-direct-icon-instagram {
  color: #fff;
  background:
    radial-gradient(circle at 20% 120%, rgba(254, 218, 119, 0.24), transparent 36%),
    linear-gradient(135deg, rgba(81, 91, 212, 0.78), rgba(129, 52, 175, 0.76) 36%, rgba(221, 42, 123, 0.72) 68%, rgba(245, 133, 41, 0.66));
  border-color: rgba(255, 255, 255, 0.14);
  box-shadow: 0 14px 26px rgba(91, 54, 148, 0.22);
}

.contact-direct-label-instagram {
  color: #d79cf0;
}

.contact-direct-card-instagram #contactInstagramHandle {
  color: #fff2ff;
}

.contact-direct-btn-instagram {
  color: #f6efff;
  border-color: rgba(187, 93, 209, 0.22);
  background:
    linear-gradient(135deg, rgba(81, 91, 212, 0.12), rgba(129, 52, 175, 0.1) 38%, rgba(221, 42, 123, 0.1) 72%, rgba(245, 133, 41, 0.08));
  box-shadow: 0 10px 22px rgba(48, 15, 82, 0.16);
}

.contact-direct-btn-instagram:hover {
  border-color: rgba(221, 42, 123, 0.32);
  background:
    linear-gradient(135deg, rgba(81, 91, 212, 0.18), rgba(129, 52, 175, 0.16) 38%, rgba(221, 42, 123, 0.16) 72%, rgba(245, 133, 41, 0.12));
}
/* Contact form captcha + footer layout */
.contact-panel-view[data-panel-view="email"] .contact-stage-card {
  display: flex;
  align-items: stretch;
}

.contact-form-panel {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  grid-template-areas:
    "name email"
    "message message"
    "message message"
    "footer footer";
  gap: 16px;
  flex: 1;
  min-height: 100%;
  align-content: stretch;
}

.field-name { grid-area: name; }
.field-email { grid-area: email; }
.field-message { grid-area: message; min-height: 0; }
.field-message textarea {
  min-height: 240px;
  height: 100%;
}

.contact-form-footer {
  grid-area: footer;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(220px, 320px);
  gap: 18px;
  align-items: end;
  margin-top: 6px;
}

.contact-form-security {
  display: grid;
  gap: 12px;
  align-content: start;
  min-height: 100%;
}

.contact-form-security-head {
  display: grid;
  gap: 6px;
}

.contact-form-security-label {
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-size: 0.72rem;
  color: var(--accent-strong);
}

#contactRecaptchaHint {
  margin: 0;
  font-size: 0.92rem;
  color: rgba(234, 237, 232, 0.72);
}

.contact-recaptcha-shell {
  min-height: 110px;
  padding: 16px;
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.035), rgba(255, 255, 255, 0.015));
  display: flex;
  align-items: center;
  justify-content: flex-start;
  overflow-x: auto;
  overflow-y: hidden;
}

.contact-recaptcha-shell.is-placeholder {
  justify-content: center;
}

.contact-recaptcha-placeholder {
  font-size: 0.92rem;
  line-height: 1.5;
  color: rgba(234, 237, 232, 0.72);
  text-align: center;
}

.contact-recaptcha-placeholder[data-state="error"] {
  color: #f2c6c6;
}

.contact-form-status {
  margin: 0;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.03);
  color: var(--text);
  font-size: 0.92rem;
  line-height: 1.5;
}

.contact-form-status[data-state="success"] {
  border-color: rgba(47, 139, 105, 0.28);
  background: rgba(22, 67, 52, 0.34);
  color: #ebf7f1;
}

.contact-form-status[data-state="error"] {
  border-color: rgba(200, 76, 76, 0.26);
  background: rgba(74, 24, 24, 0.36);
  color: #f7dede;
}

.contact-form-submit {
  min-height: 62px;
  align-self: end;
}

.contact-form-submit:disabled {
  opacity: 0.55;
  cursor: not-allowed;
  box-shadow: none;
}

.contact-form-panel.is-mailto-fallback .contact-form-footer {
  grid-template-columns: 1fr;
}

.contact-form-panel.is-mailto-fallback .contact-form-security {
  display: block;
  min-height: 0;
}

.contact-form-panel.is-mailto-fallback .contact-form-security-head {
  display: none;
}

.contact-form-panel.is-mailto-fallback .contact-recaptcha-shell {
  display: none;
}

.contact-form-panel.is-mailto-fallback .contact-form-status.hidden {
  display: none;
}

.contact-form-panel.is-mailto-fallback .contact-form-status:not(.hidden) {
  margin-bottom: 12px;
}

.contact-form-panel.is-mailto-fallback .contact-form-submit {
  width: 100%;
}

@media (max-width: 1100px) {
  .contact-form-panel {
    grid-template-columns: 1fr;
    grid-template-areas:
      "name"
      "email"
      "message"
      "footer";
  }

  .contact-form-footer {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 700px) {
  .contact-recaptcha-shell {
    padding: 12px;
  }
}
/* Collection editor polish */
.collection-editor-fields {
  align-items: start;
}

.collection-editor-fields > label:not(.toggle-control) {
  display: grid;
  gap: 10px;
  padding: 14px 16px;
  border-radius: 20px;
  background: linear-gradient(180deg, rgba(15, 21, 18, 0.82), rgba(9, 13, 11, 0.76));
  border: 1px solid rgba(255,255,255,0.08);
  color: #eef3ef;
}

.collection-editor-fields > label:not(.toggle-control) input,
.collection-editor-fields > label:not(.toggle-control) textarea {
  width: 100%;
  border: 1px solid rgba(255,255,255,0.1);
  background: rgba(7, 12, 10, 0.92);
  color: #f5efe8;
  border-radius: 14px;
  padding: 14px 16px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.03);
}

.collection-editor-fields > label:not(.toggle-control) input {
  min-height: 52px;
}

.collection-editor-fields > label:not(.toggle-control) textarea {
  min-height: 140px;
  resize: vertical;
  line-height: 1.55;
}

.collection-editor-fields > label:not(.toggle-control) input::placeholder,
.collection-editor-fields > label:not(.toggle-control) textarea::placeholder {
  color: #95a19a;
}

.collection-editor-fields > label:not(.toggle-control) input:focus,
.collection-editor-fields > label:not(.toggle-control) textarea:focus {
  outline: none;
  border-color: rgba(47,139,105,0.44);
  box-shadow: 0 0 0 1px rgba(47,139,105,0.18), 0 16px 34px rgba(0,0,0,0.16);
}

.collection-visible-toggle {
  width: 100%;
  align-self: stretch;
}

.collection-editor-item .portfolio-media-admin-actions {
  justify-content: flex-end;
  flex-wrap: wrap;
}

.portfolio-media-admin-chip.is-disabled {
  opacity: 0.34;
  pointer-events: none;
}

.portfolio-media-admin-chip.is-active {
  background: rgba(31,93,71,0.18);
  border-color: rgba(47,139,105,0.32);
}

/* Collections front polish */
.section-collections {
  background:
    radial-gradient(circle at 14% 16%, rgba(28, 86, 64, 0.12), transparent 30%),
    radial-gradient(circle at 84% 10%, rgba(255, 255, 255, 0.025), transparent 20%),
    linear-gradient(180deg, rgba(8, 14, 12, 0.98), rgba(8, 15, 14, 0.93) 52%, rgba(8, 13, 12, 0.98));
}

.collections-grid {
  min-height: 680px;
}

.collections-strip-nav {
  width: 42px;
  height: 42px;
  border-color: rgba(255,255,255,0.045);
  background: rgba(255,255,255,0.022);
  color: rgba(244, 239, 232, 0.72);
  box-shadow: none;
  backdrop-filter: blur(8px);
}

.collections-strip-nav:hover {
  background: rgba(255,255,255,0.05);
  border-color: rgba(47,139,105,0.16);
}

.collection-swipe-btn {
  width: 32px;
  height: 32px;
  border-color: rgba(255,255,255,0.05);
  background: rgba(255,255,255,0.018);
  color: rgba(244, 239, 232, 0.5);
  font-size: 0.84rem;
}

.collection-swipe-btn:hover {
  background: rgba(255,255,255,0.045);
  border-color: rgba(47,139,105,0.16);
  color: rgba(244, 239, 232, 0.88);
}

.collection-showcase {
  width: min(100%, 720px);
  padding: 32px 34px 28px;
  border-radius: 34px;
  background: linear-gradient(180deg, rgba(10, 16, 14, 0.64), rgba(8, 13, 12, 0.42));
  box-shadow: 0 26px 80px rgba(0,0,0,0.14);
}

.collection-showcase--active {
  width: min(100%, 980px);
  display: grid;
  grid-template-columns: minmax(260px, 0.88fr) minmax(420px, 1.12fr);
  grid-template-areas:
    "copy stage"
    "meta stage"
    "actions stage";
  align-items: center;
  column-gap: 34px;
  row-gap: 16px;
  padding: 38px 42px 34px;
  background: linear-gradient(180deg, rgba(10, 16, 14, 0.72), rgba(8, 13, 12, 0.5));
  box-shadow: 0 38px 90px rgba(0,0,0,0.18);
}

.collection-showcase--active .collection-showcase-stage {
  grid-area: stage;
  justify-self: end;
  width: min(100%, 680px);
  min-height: 560px;
  grid-template-columns: 34px minmax(0, 1fr) 34px;
  gap: 10px;
}

.collection-showcase--active .collection-showcase-copy {
  grid-area: copy;
  align-self: end;
  max-width: 28ch;
}

.collection-showcase--active .collection-showcase-meta {
  grid-area: meta;
  align-self: start;
}

.collection-showcase--active .collection-showcase-actions {
  grid-area: actions;
  align-self: start;
}

.collection-showcase--active .collection-showcase-stage--card .collection-stack-shell {
  min-height: 520px;
}

.collection-showcase--active .collection-showcase-stage--card .collection-stack {
  width: min(100%, 420px);
  height: 520px;
}

.collection-showcase--active .collection-stack-card.shape-square {
  width: 76%;
}

.collection-showcase--active .collection-stack-card.shape-horizontal {
  width: 96%;
}

.collection-showcase--active .collection-stack-card.shape-vertical {
  width: 68%;
}

.collection-showcase--active .collection-stack-card--prev {
  transform: translate(calc(-50% - 26%), -50%) scale(0.9);
  opacity: 0.22;
}

.collection-showcase--active .collection-stack-card--next {
  transform: translate(calc(-50% + 26%), -50%) scale(0.9);
  opacity: 0.22;
}

.collection-showcase--prev,
.collection-showcase--next {
  width: min(100%, 540px);
  opacity: 0.24;
  filter: saturate(0.68);
  background: linear-gradient(180deg, rgba(9, 14, 12, 0.24), rgba(7, 11, 10, 0.14));
  box-shadow: none;
}

.collection-showcase--prev {
  transform: translate(calc(-50% - 34%), -50%) scale(0.78);
}

.collection-showcase--next {
  transform: translate(calc(-50% + 34%), -50%) scale(0.78);
}

.collection-showcase--prev .collection-showcase-stage,
.collection-showcase--next .collection-showcase-stage {
  min-height: 320px;
}

.collection-showcase--prev .collection-stack-shell,
.collection-showcase--next .collection-stack-shell {
  min-height: 320px;
}

.collection-showcase--prev .collection-stack,
.collection-showcase--next .collection-stack {
  width: min(100%, 250px);
  height: 320px;
}

.collection-showcase-copy h3 {
  font-size: clamp(2.1rem, 3.4vw, 3.2rem);
}

.collection-showcase-copy p {
  max-width: 30ch;
  color: rgba(225, 232, 226, 0.82);
}

.collection-showcase-meta {
  gap: 14px;
}

@media (max-width: 1180px) {
  .collections-grid {
    min-height: 640px;
  }

  .collection-showcase--active {
    width: min(100%, 860px);
    grid-template-columns: 1fr;
    grid-template-areas:
      "stage"
      "copy"
      "meta"
      "actions";
    row-gap: 18px;
    padding: 32px 30px 28px;
  }

  .collection-showcase--active .collection-showcase-stage {
    justify-self: center;
    width: min(100%, 620px);
    min-height: 500px;
  }

  .collection-showcase--active .collection-showcase-stage--card .collection-stack-shell {
    min-height: 460px;
  }

  .collection-showcase--active .collection-showcase-stage--card .collection-stack {
    width: min(100%, 360px);
    height: 460px;
  }
}

@media (max-width: 900px) {
  .collections-grid {
    min-height: 560px;
  }

  .collections-strip-nav {
    width: 38px;
    height: 38px;
  }

  .collection-showcase--active {
    padding: 26px 24px 24px;
  }

  .collection-showcase--active .collection-showcase-stage {
    width: 100%;
    min-height: 420px;
    grid-template-columns: 32px minmax(0, 1fr) 32px;
    gap: 8px;
  }

  .collection-showcase--active .collection-showcase-stage--card .collection-stack-shell {
    min-height: 390px;
  }

  .collection-showcase--active .collection-showcase-stage--card .collection-stack {
    width: min(100%, 320px);
    height: 390px;
  }
}
/* Collections front display refinement */
.section-collections {
  background:
    radial-gradient(circle at 18% 18%, rgba(32, 98, 72, 0.11), transparent 28%),
    radial-gradient(circle at 82% 12%, rgba(255, 255, 255, 0.02), transparent 18%),
    linear-gradient(180deg, rgba(7, 13, 12, 0.94), rgba(8, 15, 14, 0.9) 50%, rgba(7, 12, 11, 0.96));
}

.collections-browser {
  grid-template-columns: 44px minmax(0, 1fr) 44px;
  gap: 18px;
  align-items: center;
}

.collections-grid {
  min-height: 700px;
}

.collections-strip-nav {
  width: 36px;
  height: 36px;
  border-color: rgba(255,255,255,0.035);
  background: rgba(255,255,255,0.018);
  color: rgba(244, 239, 232, 0.62);
  box-shadow: 0 10px 24px rgba(0,0,0,0.1);
  backdrop-filter: blur(10px);
}

.collections-strip-nav:hover {
  background: rgba(255,255,255,0.038);
  border-color: rgba(47,139,105,0.14);
  color: rgba(244, 239, 232, 0.9);
}

.collection-showcase {
  width: min(100%, 700px);
  padding: 26px 28px 24px;
  border-radius: 32px;
  border-color: rgba(255,255,255,0.035);
  background: linear-gradient(180deg, rgba(9, 15, 13, 0.52), rgba(8, 13, 12, 0.3));
  box-shadow: 0 24px 64px rgba(0,0,0,0.12);
}

.collection-showcase--active {
  width: min(100%, 1020px);
  grid-template-columns: minmax(260px, 0.8fr) minmax(460px, 1.2fr);
  column-gap: 42px;
  row-gap: 14px;
  padding: 34px 36px 30px;
  border-color: rgba(255,255,255,0.04);
  background: linear-gradient(180deg, rgba(9, 15, 13, 0.62), rgba(8, 13, 12, 0.36));
  box-shadow: 0 34px 90px rgba(0,0,0,0.16);
}

.collection-showcase--active .collection-showcase-copy {
  align-self: center;
  max-width: 30ch;
}

.collection-showcase--active .collection-showcase-stage {
  justify-self: center;
  width: min(100%, 740px);
  min-height: 600px;
  grid-template-columns: 28px minmax(0, 1fr) 28px;
  gap: 12px;
}

.collection-showcase--active .collection-showcase-stage--card .collection-stack-shell {
  min-height: 560px;
}

.collection-showcase--active .collection-showcase-stage--card .collection-stack {
  width: min(100%, 470px);
  height: 560px;
}

.collection-showcase--active .collection-stack-card.shape-square {
  width: 82%;
}

.collection-showcase--active .collection-stack-card.shape-horizontal {
  width: 100%;
}

.collection-showcase--active .collection-stack-card.shape-vertical {
  width: 72%;
}

.collection-showcase--active .collection-stack-card--prev {
  transform: translate(calc(-50% - 28%), -50%) scale(0.9);
  opacity: 0.2;
}

.collection-showcase--active .collection-stack-card--next {
  transform: translate(calc(-50% + 28%), -50%) scale(0.9);
  opacity: 0.2;
}

.collection-showcase--prev,
.collection-showcase--next {
  width: min(100%, 500px);
  opacity: 0.16;
  filter: saturate(0.62);
  border-color: rgba(255,255,255,0.02);
  background: linear-gradient(180deg, rgba(9, 14, 12, 0.18), rgba(7, 11, 10, 0.08));
  box-shadow: none;
}

.collection-showcase--prev {
  transform: translate(calc(-50% - 36%), -50%) scale(0.74);
}

.collection-showcase--next {
  transform: translate(calc(-50% + 36%), -50%) scale(0.74);
}

.collection-showcase--prev .collection-showcase-stage,
.collection-showcase--next .collection-showcase-stage {
  min-height: 300px;
}

.collection-showcase--prev .collection-stack-shell,
.collection-showcase--next .collection-stack-shell {
  min-height: 300px;
}

.collection-showcase--prev .collection-stack,
.collection-showcase--next .collection-stack {
  width: min(100%, 240px);
  height: 300px;
}

.collection-showcase-copy h3 {
  font-size: clamp(2.3rem, 3.6vw, 3.45rem);
  line-height: 0.96;
}

.collection-showcase-copy p {
  max-width: 31ch;
  color: rgba(226, 232, 227, 0.78);
  font-size: 1rem;
  line-height: 1.72;
}

.collection-showcase-meta {
  gap: 12px;
}

.collection-meta-badge {
  background: rgba(255,255,255,0.025);
  border-color: rgba(255,255,255,0.045);
}

.collection-swipe-btn {
  width: 28px;
  height: 28px;
  border-color: rgba(255,255,255,0.04);
  background: rgba(255,255,255,0.014);
  color: rgba(244, 239, 232, 0.44);
  font-size: 0.76rem;
}

.collection-swipe-btn:hover {
  background: rgba(255,255,255,0.034);
  border-color: rgba(47,139,105,0.12);
  color: rgba(244, 239, 232, 0.82);
}

@media (max-width: 1180px) {
  .collections-browser {
    grid-template-columns: 38px minmax(0, 1fr) 38px;
    gap: 14px;
  }

  .collections-grid {
    min-height: 640px;
  }

  .collection-showcase--active {
    width: min(100%, 880px);
    padding: 30px 30px 28px;
  }

  .collection-showcase--active .collection-showcase-stage {
    width: min(100%, 640px);
    min-height: 520px;
  }

  .collection-showcase--active .collection-showcase-stage--card .collection-stack-shell {
    min-height: 480px;
  }

  .collection-showcase--active .collection-showcase-stage--card .collection-stack {
    width: min(100%, 390px);
    height: 480px;
  }
}

@media (max-width: 900px) {
  .collections-grid {
    min-height: 560px;
  }

  .collections-strip-nav {
    width: 34px;
    height: 34px;
  }

  .collection-showcase--active {
    padding: 24px 22px 22px;
  }

  .collection-showcase--active .collection-showcase-stage {
    min-height: 430px;
    grid-template-columns: 28px minmax(0, 1fr) 28px;
    gap: 8px;
  }

  .collection-showcase--active .collection-showcase-stage--card .collection-stack-shell {
    min-height: 400px;
  }

  .collection-showcase--active .collection-showcase-stage--card .collection-stack {
    width: min(100%, 330px);
    height: 400px;
  }

  .collection-swipe-btn {
    width: 26px;
    height: 26px;
  }
}
/* Hero logo swap */
.hero-brand {
  position: relative;
  display: grid;
  place-items: center;
  margin: 0 auto;
  width: min(100%, 900px);
  line-height: 1;
}

.hero-brand::before {
  content: "";
  position: absolute;
  inset: 10% 8% 18%;
  background:
    radial-gradient(circle at center, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0.05) 36%, transparent 70%);
  filter: blur(28px);
  opacity: 0.92;
  pointer-events: none;
}

.hero-brand-logo {
  position: relative;
  z-index: 1;
  display: block;
  width: min(100%, 820px);
  max-height: min(40vw, 390px);
  object-fit: contain;
  mix-blend-mode: normal;
  filter:
    brightness(0)
    invert(1)
    contrast(1.08)
    drop-shadow(0 0 18px rgba(255, 255, 255, 0.18))
    drop-shadow(0 22px 40px rgba(0, 0, 0, 0.48));
  opacity: 0.985;
  user-select: none;
  -webkit-user-drag: none;
  pointer-events: none;
}

.hero-brand-copy {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.hero-content.is-inline-editing .hero-brand {
  line-height: 1.03;
}

.hero-content.is-inline-editing .hero-brand::before {
  display: none;
}

.hero-content.is-inline-editing .hero-brand-logo {
  display: none;
}

.hero-content.is-inline-editing .hero-brand-copy {
  position: static;
  width: auto;
  height: auto;
  margin: 0;
  overflow: visible;
  clip: auto;
  white-space: normal;
}

.hero-content.is-inline-editing .hero-brand-copy span {
  color: #b9aea1;
}

@media (max-width: 900px) {
  .hero-brand {
    width: min(100%, 700px);
  }

  .hero-brand::before {
    inset: 12% 6% 22%;
    filter: blur(24px);
  }

  .hero-brand-logo {
    width: min(100%, 620px);
    max-height: 290px;
  }
}

@media (max-width: 640px) {
  .hero-brand {
    width: min(100%, 480px);
  }

  .hero-brand::before {
    inset: 16% 4% 26%;
    filter: blur(18px);
  }

  .hero-brand-logo {
    width: min(100%, 460px);
    max-height: 220px;
  }
}
/* FAQ section background darken */
.section-aftercare.section-bg-contact {
  background:
    radial-gradient(circle at 16% 18%, rgba(28, 86, 64, 0.08), transparent 26%),
    linear-gradient(180deg, rgba(6, 10, 9, 0.98), rgba(7, 12, 11, 0.96));
}

/* Collections focus-stage refinement */
.section-collections {
  overflow: hidden;
  padding-bottom: clamp(96px, 12vw, 148px);
  background:
    radial-gradient(circle at 18% 18%, rgba(24, 76, 58, 0.2), transparent 30%),
    radial-gradient(circle at 80% 12%, rgba(255, 255, 255, 0.025), transparent 18%),
    linear-gradient(180deg, rgba(6, 9, 8, 0.98), rgba(7, 11, 11, 0.96) 54%, rgba(4, 6, 6, 1));
}

.section-collections::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  height: clamp(132px, 15vw, 190px);
  background: linear-gradient(180deg, rgba(4, 6, 6, 0), rgba(4, 6, 6, 0.78) 52%, rgba(3, 5, 5, 1));
  pointer-events: none;
}

.collections-browser {
  grid-template-columns: 52px minmax(0, 1fr) 52px;
  gap: 22px;
}

.collections-browser-viewport {
  position: relative;
  min-width: 0;
  overflow: hidden;
  border-radius: 44px;
  padding: clamp(30px, 4vw, 44px) clamp(20px, 4vw, 44px) clamp(72px, 8vw, 96px);
  background: linear-gradient(180deg, rgba(13, 16, 15, 0.94), rgba(7, 9, 9, 0.985));
  border: 1px solid rgba(255, 255, 255, 0.05);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.04),
    0 36px 90px rgba(0, 0, 0, 0.34);
  isolation: isolate;
}

.collections-browser-viewport::before,
.collections-browser-viewport::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  pointer-events: none;
  z-index: 2;
}

.collections-browser-viewport::before {
  top: 0;
  bottom: 0;
  background:
    radial-gradient(circle at center, rgba(33, 92, 69, 0.09), transparent 42%),
    linear-gradient(90deg, rgba(4, 6, 6, 0.96) 0%, rgba(4, 6, 6, 0.18) 14%, rgba(4, 6, 6, 0) 22%, rgba(4, 6, 6, 0) 78%, rgba(4, 6, 6, 0.18) 86%, rgba(4, 6, 6, 0.96) 100%);
}

.collections-browser-viewport::after {
  bottom: 0;
  height: 120px;
  background: linear-gradient(180deg, rgba(6, 8, 8, 0), rgba(6, 8, 8, 0.78) 60%, rgba(6, 8, 8, 0.96));
}

.collections-grid,
.collections-empty-state {
  position: relative;
  z-index: 1;
}

.collections-grid {
  min-height: 780px;
  overflow: hidden;
}

.collections-strip-nav {
  width: 40px;
  height: 40px;
  border-color: rgba(255, 255, 255, 0.05);
  background: rgba(255, 255, 255, 0.02);
  color: rgba(244, 239, 232, 0.76);
  box-shadow: 0 16px 32px rgba(0, 0, 0, 0.18);
  backdrop-filter: none;
}

.collections-strip-nav:hover {
  background: rgba(255, 255, 255, 0.05);
  border-color: rgba(47, 139, 105, 0.18);
}

.collection-showcase {
  overflow: hidden;
  width: min(100%, 700px);
  padding: 28px;
  border-radius: 34px;
  border: 1px solid rgba(255, 255, 255, 0.045);
  background: linear-gradient(180deg, rgba(10, 12, 12, 0.8), rgba(5, 7, 7, 0.94));
  box-shadow: 0 26px 60px rgba(0, 0, 0, 0.3);
}

.collection-showcase--active {
  width: min(100%, 1040px);
  grid-template-columns: minmax(280px, 0.78fr) minmax(480px, 1.22fr);
  grid-template-areas:
    "copy stage"
    "meta stage"
    "actions stage";
  column-gap: clamp(30px, 4vw, 46px);
  row-gap: 16px;
  padding: clamp(36px, 4vw, 46px);
  border-color: rgba(255, 255, 255, 0.06);
  background: linear-gradient(180deg, rgba(11, 13, 13, 0.985), rgba(6, 8, 8, 0.985));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.04),
    0 48px 110px rgba(0, 0, 0, 0.52);
}

.collection-showcase--active .collection-showcase-copy {
  align-self: center;
  max-width: 31ch;
}

.collection-showcase--active .collection-showcase-stage {
  justify-self: end;
  width: min(100%, 760px);
  min-height: 620px;
  grid-template-columns: 30px minmax(0, 1fr) 30px;
  gap: 14px;
}

.collection-showcase--active .collection-showcase-stage--card .collection-stack-shell {
  width: 100%;
  max-width: min(100%, 520px);
  min-height: 580px;
  justify-self: center;
  overflow: hidden;
  border-radius: 30px;
  background:
    radial-gradient(circle at top, rgba(32, 89, 66, 0.12), transparent 44%),
    linear-gradient(180deg, rgba(5, 6, 7, 0.98), rgba(9, 10, 10, 0.94));
  border: 1px solid rgba(255, 255, 255, 0.055);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.04),
    inset 0 -30px 60px rgba(0, 0, 0, 0.28),
    0 28px 70px rgba(0, 0, 0, 0.4);
}

.collection-showcase--active .collection-showcase-stage--card .collection-stack {
  width: min(100%, 430px);
  height: 580px;
}

.collection-showcase--active .collection-stack-card {
  border-color: rgba(255, 255, 255, 0.05);
  box-shadow: 0 38px 90px rgba(0, 0, 0, 0.42);
}

.collection-showcase--active .collection-stack-card--prev {
  transform: translate(calc(-50% - 34%), -50%) scale(0.74);
  opacity: 0.1;
  filter: blur(4px) saturate(0.45) brightness(0.62);
}

.collection-showcase--active .collection-stack-card--next {
  transform: translate(calc(-50% + 34%), -50%) scale(0.74);
  opacity: 0.1;
  filter: blur(4px) saturate(0.45) brightness(0.62);
}

.collection-showcase--prev,
.collection-showcase--next {
  width: min(100%, 360px);
  opacity: 0.12;
  filter: blur(8px) saturate(0.28) brightness(0.58);
  border-color: rgba(255, 255, 255, 0.015);
  background: linear-gradient(180deg, rgba(10, 12, 12, 0.28), rgba(5, 7, 7, 0.72));
  box-shadow: none;
}

.collection-showcase--prev {
  transform: translate(calc(-50% - 45%), -50%) scale(0.58);
}

.collection-showcase--next {
  transform: translate(calc(-50% + 45%), -50%) scale(0.58);
}

.collection-showcase--prev .collection-showcase-copy,
.collection-showcase--next .collection-showcase-copy {
  gap: 4px;
}

.collection-showcase--prev .collection-showcase-copy h3,
.collection-showcase--next .collection-showcase-copy h3 {
  font-size: 1.02rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  opacity: 0.4;
}

.collection-showcase--prev .collection-showcase-stage,
.collection-showcase--next .collection-showcase-stage {
  min-height: 220px;
}

.collection-showcase--prev .collection-stack-shell,
.collection-showcase--next .collection-stack-shell {
  min-height: 220px;
  overflow: hidden;
  border-radius: 22px;
}

.collection-showcase--prev .collection-stack,
.collection-showcase--next .collection-stack {
  width: min(100%, 170px);
  height: 220px;
}

.collection-showcase-copy h3 {
  font-size: clamp(2.5rem, 3.8vw, 3.9rem);
  line-height: 0.92;
}

.collection-showcase-copy p {
  max-width: 32ch;
  color: rgba(228, 233, 228, 0.78);
  font-size: 1.01rem;
  line-height: 1.76;
}

.collection-showcase-meta {
  gap: 12px;
}

.collection-meta-badge {
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(255, 255, 255, 0.08);
  color: rgba(241, 236, 230, 0.86);
}

.collection-swipe-btn {
  width: 30px;
  height: 30px;
  border-color: rgba(255, 255, 255, 0.06);
  background: rgba(255, 255, 255, 0.018);
  color: rgba(244, 239, 232, 0.54);
  font-size: 0.76rem;
}

.collection-swipe-btn:hover {
  background: rgba(255, 255, 255, 0.05);
  border-color: rgba(47, 139, 105, 0.16);
  color: rgba(244, 239, 232, 0.88);
}

@media (max-width: 1180px) {
  .collections-browser-viewport {
    border-radius: 36px;
    padding: 28px 18px 76px;
  }

  .collections-grid {
    min-height: 720px;
  }

  .collection-showcase--active {
    width: min(100%, 900px);
    grid-template-columns: 1fr;
    grid-template-areas:
      "stage"
      "copy"
      "meta"
      "actions";
    row-gap: 22px;
  }

  .collection-showcase--active .collection-showcase-stage {
    justify-self: center;
    width: min(100%, 660px);
    min-height: 540px;
  }

  .collection-showcase--active .collection-showcase-stage--card .collection-stack-shell {
    min-height: 500px;
  }

  .collection-showcase--active .collection-showcase-stage--card .collection-stack {
    width: min(100%, 390px);
    height: 500px;
  }
}

@media (max-width: 900px) {
  .section-collections {
    padding-bottom: 92px;
  }

  .collections-browser {
    grid-template-columns: 40px minmax(0, 1fr) 40px;
    gap: 10px;
  }

  .collections-browser-viewport {
    border-radius: 28px;
    padding: 18px 14px 48px;
  }

  .collections-browser-viewport::before {
    background:
      radial-gradient(circle at center, rgba(33, 92, 69, 0.07), transparent 54%),
      linear-gradient(90deg, rgba(4, 6, 6, 0.56), rgba(4, 6, 6, 0.05) 16%, rgba(4, 6, 6, 0.05) 84%, rgba(4, 6, 6, 0.56));
  }

  .collections-browser-viewport::after {
    height: 72px;
  }

  .collections-grid {
    min-height: 580px;
  }

  .collection-showcase {
    padding: 22px 18px 20px;
    border-radius: 26px;
  }

  .collection-showcase--active {
    padding: 26px 20px 22px;
    row-gap: 18px;
  }

  .collection-showcase--active .collection-showcase-stage {
    min-height: 460px;
    grid-template-columns: 28px minmax(0, 1fr) 28px;
    gap: 8px;
  }

  .collection-showcase--active .collection-showcase-stage--card .collection-stack-shell {
    min-height: 420px;
    max-width: 100%;
    border-radius: 24px;
  }

  .collection-showcase--active .collection-showcase-stage--card .collection-stack {
    width: min(100%, 330px);
    height: 420px;
  }

  .collection-showcase-copy h3 {
    font-size: clamp(2rem, 8vw, 3rem);
  }

  .collection-showcase-copy p {
    font-size: 0.96rem;
    line-height: 1.65;
  }

  .collections-strip-nav {
    width: 34px;
    height: 34px;
  }

  .collection-swipe-btn {
    width: 26px;
    height: 26px;
  }
}
.collection-showcase--active .collection-showcase-stage--card .collection-stack-shell,
.collection-showcase--prev .collection-stack-shell,
.collection-showcase--next .collection-stack-shell {
  margin-inline: auto;
}
/* Collections overview + image prominence refinement */
.collections-browser-viewport {
  border-radius: 0;
  padding: clamp(18px, 3vw, 32px) clamp(6px, 1.8vw, 16px) clamp(24px, 4vw, 40px);
  background: transparent;
  border: none;
  box-shadow: none;
}

.collections-browser-viewport::before {
  top: 0;
  bottom: 0;
  background: linear-gradient(90deg, rgba(4, 6, 6, 0.86) 0%, rgba(4, 6, 6, 0.18) 12%, rgba(4, 6, 6, 0) 19%, rgba(4, 6, 6, 0) 81%, rgba(4, 6, 6, 0.18) 88%, rgba(4, 6, 6, 0.86) 100%);
}

.collections-browser-viewport::after {
  height: 0;
  background: none;
}

.collections-grid {
  min-height: 860px;
}

.collection-showcase {
  overflow: visible;
}

.collection-showcase--active {
  overflow: visible;
  width: min(100%, 1100px);
  grid-template-columns: minmax(220px, 0.56fr) minmax(560px, 1.44fr);
  column-gap: clamp(28px, 4vw, 54px);
  row-gap: 14px;
  padding: 8px 0 0;
  border: none;
  background: transparent;
  box-shadow: none;
}

.collection-showcase--active .collection-showcase-copy {
  max-width: 25ch;
}

.collection-showcase--active .collection-showcase-copy h3 {
  font-size: clamp(2.15rem, 3vw, 3.35rem);
}

.collection-showcase--active .collection-showcase-stage {
  width: min(100%, 860px);
  min-height: 700px;
  grid-template-columns: 34px minmax(0, 1fr) 34px;
  gap: 16px;
}

.collection-showcase--active .collection-showcase-stage--card .collection-stack-shell {
  max-width: min(100%, 620px);
  min-height: 660px;
  overflow: visible;
  border-radius: 0;
  background: transparent;
  border: none;
  box-shadow: none;
}

.collection-showcase--active .collection-showcase-stage--card .collection-stack {
  width: min(100%, 500px);
  height: 660px;
}

.collection-showcase--active .collection-stack-card.shape-square {
  width: 92%;
}

.collection-showcase--active .collection-stack-card.shape-horizontal {
  width: 108%;
}

.collection-showcase--active .collection-stack-card.shape-vertical {
  width: 80%;
}

.collection-showcase--active .collection-stack-card--active {
  transform: translate(-50%, -50%) scale(1.03);
}

.collection-showcase--active .collection-stack-card--prev {
  transform: translate(calc(-50% - 36%), -50%) scale(0.8);
  opacity: 0.14;
  filter: blur(3px) saturate(0.46) brightness(0.72);
}

.collection-showcase--active .collection-stack-card--next {
  transform: translate(calc(-50% + 36%), -50%) scale(0.8);
  opacity: 0.14;
  filter: blur(3px) saturate(0.46) brightness(0.72);
}

.collection-showcase--prev,
.collection-showcase--next {
  width: min(100%, 320px);
  opacity: 0.14;
  filter: blur(10px) saturate(0.24) brightness(0.52);
  background: transparent;
  border: none;
  box-shadow: none;
}

.collection-showcase--prev {
  transform: translate(calc(-50% - 46%), -50%) scale(0.54);
}

.collection-showcase--next {
  transform: translate(calc(-50% + 46%), -50%) scale(0.54);
}

.collection-showcase--prev .collection-showcase-stage,
.collection-showcase--next .collection-showcase-stage {
  min-height: 180px;
}

.collection-showcase--prev .collection-stack-shell,
.collection-showcase--next .collection-stack-shell {
  min-height: 180px;
  overflow: visible;
  border: none;
  background: transparent;
  box-shadow: none;
}

.collection-showcase--prev .collection-stack,
.collection-showcase--next .collection-stack {
  width: min(100%, 150px);
  height: 190px;
}

.collection-showcase--prev .collection-showcase-copy h3,
.collection-showcase--next .collection-showcase-copy h3 {
  font-size: 0.94rem;
  opacity: 0.34;
}

.collection-showcase-copy p {
  line-height: 1.68;
}

.collection-meta-badge--position {
  background: rgba(47, 139, 105, 0.12);
  border-color: rgba(47, 139, 105, 0.16);
  color: rgba(235, 244, 239, 0.88);
}

.collections-overview {
  position: relative;
  z-index: 3;
  display: grid;
  gap: 16px;
  margin-top: 24px;
  padding-inline: clamp(6px, 1.2vw, 12px);
}

.collections-overview-status {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 16px;
}

.collections-overview-caption {
  color: rgba(190, 205, 197, 0.66);
  font-size: 0.75rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.collections-overview-status strong {
  color: #f1ece6;
  font-size: clamp(1.05rem, 1.8vw, 1.35rem);
  font-weight: 600;
  letter-spacing: 0.02em;
}

.collections-overview-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 10px;
}

.collections-overview-item {
  min-height: 78px;
  padding: 14px 16px;
  border-radius: 20px;
  border: 1px solid rgba(255, 255, 255, 0.05);
  background: rgba(255, 255, 255, 0.02);
  color: #f1ece6;
  text-align: left;
  display: grid;
  gap: 6px;
  cursor: pointer;
  transition: transform 0.18s ease, border-color 0.18s ease, background 0.18s ease, opacity 0.18s ease;
}

.collections-overview-item:hover {
  transform: translateY(-1px);
  border-color: rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.035);
}

.collections-overview-item.is-active {
  border-color: rgba(47, 139, 105, 0.24);
  background: linear-gradient(180deg, rgba(29, 66, 53, 0.38), rgba(11, 17, 15, 0.62));
  box-shadow: 0 18px 30px rgba(0, 0, 0, 0.16);
}

.collections-overview-item-index {
  color: rgba(160, 180, 170, 0.8);
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.collections-overview-item-label {
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.2;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.collections-overview-item-meta {
  color: rgba(201, 211, 204, 0.72);
  font-size: 0.78rem;
}

@media (max-width: 1180px) {
  .collections-browser-viewport {
    padding: 16px 4px 28px;
  }

  .collections-grid {
    min-height: 760px;
  }

  .collection-showcase--active {
    width: min(100%, 920px);
  }

  .collection-showcase--active .collection-showcase-stage {
    width: min(100%, 700px);
    min-height: 580px;
  }

  .collection-showcase--active .collection-showcase-stage--card .collection-stack-shell {
    min-height: 540px;
  }

  .collection-showcase--active .collection-showcase-stage--card .collection-stack {
    width: min(100%, 410px);
    height: 540px;
  }
}

@media (max-width: 900px) {
  .collections-browser-viewport {
    padding: 8px 0 18px;
  }

  .collections-browser-viewport::before {
    background: linear-gradient(90deg, rgba(4, 6, 6, 0.7), rgba(4, 6, 6, 0.08) 12%, rgba(4, 6, 6, 0.08) 88%, rgba(4, 6, 6, 0.7));
  }

  .collections-grid {
    min-height: 560px;
  }

  .collection-showcase--active {
    padding-top: 0;
    row-gap: 16px;
  }

  .collection-showcase--active .collection-showcase-stage {
    min-height: 460px;
    grid-template-columns: 28px minmax(0, 1fr) 28px;
    gap: 8px;
  }

  .collection-showcase--active .collection-showcase-stage--card .collection-stack-shell {
    min-height: 420px;
    max-width: 100%;
  }

  .collection-showcase--active .collection-showcase-stage--card .collection-stack {
    width: min(100%, 340px);
    height: 420px;
  }

  .collection-showcase--active .collection-stack-card.shape-horizontal {
    width: 100%;
  }

  .collections-overview {
    gap: 12px;
    margin-top: 18px;
    padding-inline: 0;
  }

  .collections-overview-status {
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
  }

  .collections-overview-list {
    display: flex;
    gap: 10px;
    overflow-x: auto;
    padding-bottom: 4px;
    scrollbar-width: thin;
    scroll-snap-type: x proximity;
  }

  .collections-overview-item {
    flex: 0 0 min(240px, 74vw);
    min-height: 72px;
    scroll-snap-align: start;
  }
}
/* Collections scalable side-rail layout */
.section-collections .section-shell {
  display: grid;
  grid-template-columns: minmax(0, 1fr) clamp(220px, 22vw, 270px);
  gap: clamp(18px, 2.4vw, 30px);
  align-items: start;
}

.collections-head {
  grid-column: 1 / -1;
}

.collections-browser {
  grid-column: 1;
}

.collections-overview {
  grid-column: 2;
  align-self: stretch;
  margin-top: 0;
  padding-top: 18px;
  position: sticky;
  top: calc(var(--header-height) + 22px);
  max-height: calc(100vh - var(--header-height) - 64px);
}

.collections-overview-status {
  position: sticky;
  top: 0;
  z-index: 2;
  padding-bottom: 10px;
  background: linear-gradient(180deg, rgba(5, 7, 7, 0.98), rgba(5, 7, 7, 0.82) 70%, rgba(5, 7, 7, 0));
}

.collections-overview-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
  overflow-y: auto;
  padding-right: 6px;
  max-height: calc(100vh - var(--header-height) - 128px);
  scrollbar-width: thin;
}

.collections-overview-item {
  min-height: 62px;
  padding: 12px 14px;
  border-radius: 16px;
  gap: 4px;
}

.collections-overview-item-label {
  font-size: 0.94rem;
}

.collections-browser-viewport {
  padding: clamp(10px, 1.8vw, 18px) 0 clamp(18px, 2.4vw, 28px);
}

.collections-grid {
  min-height: 720px;
}

.collection-showcase--active {
  width: min(100%, 980px);
  min-height: 720px;
  padding: 0;
  border: none;
  background: transparent;
  box-shadow: none;
  overflow: visible;
}

.collection-showcase--active .collection-showcase-stage {
  width: min(100%, 820px);
  min-height: 720px;
  grid-template-columns: 38px minmax(0, 1fr) 38px;
  gap: 12px;
}

.collection-showcase--active .collection-showcase-stage--card .collection-stack-shell {
  max-width: min(100%, 580px);
  min-height: 720px;
  overflow: hidden;
  position: relative;
  border-radius: 28px;
  background: transparent;
  border: none;
  box-shadow: none;
}

.collection-showcase--active .collection-showcase-stage--card .collection-stack-shell::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(4, 6, 6, 0.74) 0%, rgba(4, 6, 6, 0.34) 18%, rgba(4, 6, 6, 0.05) 42%, rgba(4, 6, 6, 0.18) 100%);
}

.collection-showcase--active .collection-showcase-stage--card .collection-stack {
  width: min(100%, 500px);
  height: 720px;
}

.collection-showcase--active .collection-showcase-copy,
.collection-showcase--active .collection-showcase-meta,
.collection-showcase--active .collection-showcase-actions {
  position: absolute;
  z-index: 4;
}

.collection-showcase--active .collection-showcase-copy {
  top: 28px;
  left: clamp(54px, 7.5%, 84px);
  max-width: min(310px, 36vw);
  padding: 18px 18px 14px;
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(4, 6, 6, 0.56), rgba(4, 6, 6, 0.14));
  backdrop-filter: blur(4px);
}

.collection-showcase--active .collection-showcase-copy h3 {
  font-size: clamp(2.2rem, 3.2vw, 3.35rem);
  line-height: 0.92;
  text-shadow: 0 14px 34px rgba(0, 0, 0, 0.34);
}

.collection-showcase--active .collection-showcase-copy p {
  max-width: 24ch;
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
  color: rgba(228, 233, 228, 0.84);
}

.collection-showcase--active .collection-showcase-meta {
  left: clamp(54px, 7.5%, 84px);
  bottom: 34px;
  justify-content: flex-start;
  flex-wrap: wrap;
}

.collection-showcase--active .collection-showcase-actions {
  top: 28px;
  right: clamp(54px, 7.5%, 84px);
}

.collection-showcase--active .collection-stack-card.shape-square {
  width: 90%;
}

.collection-showcase--active .collection-stack-card.shape-horizontal {
  width: 104%;
}

.collection-showcase--active .collection-stack-card.shape-vertical {
  width: 78%;
}

.collection-showcase--active .collection-stack-card--active {
  transform: translate(-50%, -50%) scale(1.02);
}

.collection-showcase--active .collection-stack-card--prev {
  transform: translate(calc(-50% - 34%), -50%) scale(0.8);
  opacity: 0.12;
  filter: blur(3px) saturate(0.42) brightness(0.7);
}

.collection-showcase--active .collection-stack-card--next {
  transform: translate(calc(-50% + 34%), -50%) scale(0.8);
  opacity: 0.12;
  filter: blur(3px) saturate(0.42) brightness(0.7);
}

.collection-showcase--prev,
.collection-showcase--next {
  width: min(100%, 300px);
  opacity: 0.12;
  filter: blur(10px) saturate(0.22) brightness(0.5);
}

.collection-showcase--prev {
  transform: translate(calc(-50% - 48%), -50%) scale(0.52);
}

.collection-showcase--next {
  transform: translate(calc(-50% + 48%), -50%) scale(0.52);
}

.collection-showcase--prev .collection-showcase-stage,
.collection-showcase--next .collection-showcase-stage {
  min-height: 180px;
}

.collection-showcase--prev .collection-stack-shell,
.collection-showcase--next .collection-stack-shell {
  min-height: 180px;
}

.collection-showcase--prev .collection-stack,
.collection-showcase--next .collection-stack {
  width: min(100%, 145px);
  height: 180px;
}

.collection-showcase--prev .collection-showcase-copy h3,
.collection-showcase--next .collection-showcase-copy h3 {
  font-size: 0.92rem;
}

@media (max-width: 1180px) {
  .section-collections .section-shell {
    grid-template-columns: minmax(0, 1fr) 220px;
    gap: 18px;
  }

  .collections-overview {
    padding-top: 10px;
  }

  .collections-grid {
    min-height: 650px;
  }

  .collection-showcase--active {
    min-height: 650px;
  }

  .collection-showcase--active .collection-showcase-stage {
    width: min(100%, 720px);
    min-height: 650px;
  }

  .collection-showcase--active .collection-showcase-stage--card .collection-stack-shell {
    max-width: min(100%, 500px);
    min-height: 650px;
  }

  .collection-showcase--active .collection-showcase-stage--card .collection-stack {
    width: min(100%, 430px);
    height: 650px;
  }

  .collection-showcase--active .collection-showcase-copy {
    max-width: min(280px, 42vw);
  }
}

@media (max-width: 900px) {
  .section-collections .section-shell {
    display: block;
  }

  .collections-overview {
    position: relative;
    top: auto;
    max-height: none;
    padding-top: 0;
  }

  .collections-overview-status {
    position: static;
    background: none;
    padding-bottom: 0;
  }

  .collections-overview-list {
    display: flex;
    gap: 10px;
    overflow-x: auto;
    overflow-y: hidden;
    max-height: none;
    padding-right: 0;
  }

  .collections-overview-item {
    flex: 0 0 min(240px, 74vw);
  }

  .collections-grid {
    min-height: 560px;
  }

  .collection-showcase--active {
    min-height: 560px;
  }

  .collection-showcase--active .collection-showcase-stage {
    width: 100%;
    min-height: 560px;
    grid-template-columns: 30px minmax(0, 1fr) 30px;
    gap: 8px;
  }

  .collection-showcase--active .collection-showcase-stage--card .collection-stack-shell {
    max-width: 100%;
    min-height: 560px;
    border-radius: 22px;
  }

  .collection-showcase--active .collection-showcase-stage--card .collection-stack {
    width: min(100%, 360px);
    height: 560px;
  }

  .collection-showcase--active .collection-showcase-copy {
    top: 18px;
    left: 46px;
    max-width: min(250px, 62vw);
    padding: 14px 14px 12px;
  }

  .collection-showcase--active .collection-showcase-copy h3 {
    font-size: clamp(1.9rem, 8vw, 2.6rem);
  }

  .collection-showcase--active .collection-showcase-copy p {
    -webkit-line-clamp: 3;
    font-size: 0.94rem;
  }

  .collection-showcase--active .collection-showcase-meta {
    left: 46px;
    bottom: 20px;
  }

  .collection-showcase--active .collection-showcase-actions {
    top: 18px;
    right: 46px;
  }
}
/* Collections minimal UI refinement */
.collection-showcase-stage--card {
  position: relative;
  display: block;
}

.collection-showcase-stage--card .collection-swipe-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 12;
  width: 44px;
  height: 44px;
  background: rgba(5, 7, 7, 0.32);
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.2);
  backdrop-filter: blur(6px);
}

.collection-showcase-stage--card .collection-swipe-btn--prev {
  left: 8px;
}

.collection-showcase-stage--card .collection-swipe-btn--next {
  right: 8px;
}

.collection-showcase-stage--card .collection-stack-shell {
  position: relative;
  z-index: 1;
}

.collection-showcase--active .collection-showcase-stage--card .collection-stack-shell::before {
  background: linear-gradient(180deg, rgba(4, 6, 6, 0.82) 0%, rgba(4, 6, 6, 0.46) 16%, rgba(4, 6, 6, 0.08) 34%, rgba(4, 6, 6, 0.14) 100%);
}

.collection-showcase-meta,
.collections-overview-status,
.collections-overview-item-index,
.collections-overview-item-meta {
  display: none !important;
}

.collection-showcase--active .collection-showcase-copy,
.collection-showcase--active .collection-showcase-actions {
  z-index: 10;
}

.collection-showcase--active .collection-showcase-copy {
  top: 34px;
  left: clamp(58px, 8%, 88px);
  max-width: min(280px, 34vw);
  padding: 0;
  border-radius: 0;
  background: none;
  backdrop-filter: none;
}

.collection-showcase--active .collection-showcase-copy h3 {
  margin-bottom: 10px;
  text-shadow: 0 18px 30px rgba(0, 0, 0, 0.4);
}

.collection-showcase--active .collection-showcase-copy p {
  max-width: 22ch;
  -webkit-line-clamp: 3;
  color: rgba(227, 232, 228, 0.82);
  font-size: 0.98rem;
}

.collections-overview {
  padding-top: 8px;
}

.collections-overview-list {
  gap: 2px;
  padding-left: 14px;
  padding-right: 0;
  border-left: 1px solid rgba(255, 255, 255, 0.06);
}

.collections-overview-item {
  position: relative;
  min-height: auto;
  padding: 10px 0 10px 16px;
  border: none;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  opacity: 0.56;
}

.collections-overview-item::before {
  content: "";
  position: absolute;
  left: -15px;
  top: 50%;
  width: 5px;
  height: 5px;
  border-radius: 999px;
  background: rgba(214, 222, 216, 0.38);
  transform: translateY(-50%);
  transition: background 0.18s ease, transform 0.18s ease, opacity 0.18s ease;
}

.collections-overview-item:hover {
  transform: none;
  border: none;
  background: transparent;
  opacity: 0.84;
}

.collections-overview-item.is-active {
  background: transparent;
  border: none;
  box-shadow: none;
  opacity: 1;
}

.collections-overview-item.is-active::before {
  background: rgba(62, 166, 124, 0.95);
  transform: translateY(-50%) scale(1.5);
}

.collections-overview-item-label {
  font-size: 0.98rem;
  font-weight: 500;
  line-height: 1.28;
  color: rgba(218, 224, 220, 0.72);
  transition: color 0.18s ease, transform 0.18s ease;
}

.collections-overview-item.is-active .collections-overview-item-label {
  color: #f4efe8;
  transform: translateX(2px);
}

@media (max-width: 900px) {
  .collection-showcase-stage--card .collection-swipe-btn {
    width: 38px;
    height: 38px;
  }

  .collection-showcase-stage--card .collection-swipe-btn--prev {
    left: 4px;
  }

  .collection-showcase-stage--card .collection-swipe-btn--next {
    right: 4px;
  }

  .collection-showcase--active .collection-showcase-copy {
    top: 22px;
    left: 42px;
    max-width: min(230px, 58vw);
  }

  .collection-showcase--active .collection-showcase-copy p {
    font-size: 0.92rem;
  }

  .collections-overview-list {
    border-left: none;
    padding-left: 0;
  }

  .collections-overview-item {
    padding: 10px 14px 10px 18px;
    opacity: 1;
  }

  .collections-overview-item::before {
    left: 0;
  }
}
/* Collections cohesive slider system */
.collections-overview {
  min-width: 0;
}

.collections-overview-list {
  overflow-y: auto;
  overflow-x: hidden;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.collections-overview-list::-webkit-scrollbar {
  width: 0;
  height: 0;
}

.collections-overview-item {
  width: 100%;
  max-width: 100%;
  min-width: 0;
}

.collections-overview-item-label {
  display: block;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.collection-showcase-stage--card {
  display: grid;
  align-items: center;
  grid-template-columns: 46px minmax(0, 1fr) 46px;
  gap: 14px;
}

.collection-showcase-stage--card .collection-swipe-btn {
  position: relative;
  top: auto;
  left: auto;
  right: auto;
  transform: none;
  z-index: 8;
  width: 40px;
  height: 40px;
  background: rgba(5, 7, 7, 0.28);
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.16);
  backdrop-filter: blur(4px);
}

.collection-showcase-stage--card .collection-stack-shell {
  position: relative;
  z-index: 1;
}

.collection-showcase--active {
  width: min(100%, 960px);
  min-height: 0;
}

.collection-showcase--active .collection-showcase-stage {
  width: min(100%, 760px);
  min-height: 650px;
  display: block;
}

.collection-showcase--active .collection-showcase-stage--card .collection-stack-shell {
  max-width: min(100%, 620px);
  min-height: 650px;
  margin-inline: auto;
  overflow: visible;
  border-radius: 22px;
}

.collection-showcase--active .collection-showcase-stage--card .collection-stack-shell::before {
  background: linear-gradient(180deg, rgba(4, 6, 6, 0.58) 0%, rgba(4, 6, 6, 0.24) 18%, rgba(4, 6, 6, 0.02) 38%, rgba(4, 6, 6, 0.08) 100%);
}

.collection-showcase--active .collection-showcase-stage--card .collection-stack {
  width: min(100%, 540px);
  height: 650px;
}

.collection-showcase--active .collection-stack-card.shape-square {
  width: 84%;
}

.collection-showcase--active .collection-stack-card.shape-horizontal {
  width: 100%;
}

.collection-showcase--active .collection-stack-card.shape-vertical {
  width: 72%;
}

.collection-showcase--active .collection-stack-card--prev {
  transform: translate(calc(-50% - 39%), -50%) scale(0.76);
  opacity: 0.24;
  filter: blur(1px) saturate(0.58) brightness(0.74);
}

.collection-showcase--active .collection-stack-card--next {
  transform: translate(calc(-50% + 39%), -50%) scale(0.76);
  opacity: 0.24;
  filter: blur(1px) saturate(0.58) brightness(0.74);
}

.collection-showcase--active .collection-showcase-copy {
  top: 28px;
  left: clamp(58px, 8%, 92px);
  max-width: min(260px, 32vw);
}

.collection-showcase--active .collection-showcase-copy p {
  max-width: 21ch;
}

.collections-mobile-pager {
  display: none;
}

.collections-mobile-nav {
  width: 40px;
  height: 40px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.03);
  color: #f4efe8;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}

.collections-mobile-nav:disabled {
  opacity: 0.32;
  cursor: default;
}

.collections-mobile-title {
  min-width: 0;
  text-align: center;
  font-size: 1rem;
  font-weight: 600;
  color: #f4efe8;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

@media (max-width: 1180px) {
  .section-collections .section-shell {
    grid-template-columns: minmax(0, 1fr) 190px;
    gap: 16px;
  }

  .collection-showcase--active .collection-showcase-stage {
    width: min(100%, 680px);
    min-height: 600px;
  }

  .collection-showcase--active .collection-showcase-stage--card .collection-stack-shell {
    max-width: min(100%, 560px);
    min-height: 600px;
  }

  .collection-showcase--active .collection-showcase-stage--card .collection-stack {
    width: min(100%, 480px);
    height: 600px;
  }
}

@media (max-width: 900px) {
  .collections-browser {
    grid-template-columns: 1fr;
    gap: 0;
  }

  .collections-browser > .collections-strip-nav,
  .collections-overview {
    display: none !important;
  }

  .collections-browser-viewport {
    padding: 0;
  }

  .collections-grid {
    min-height: auto;
    overflow: visible;
  }

  .collection-showcase {
    position: relative;
    top: auto;
    left: auto;
    width: 100%;
    transform: none !important;
  }

  .collection-showcase--prev,
  .collection-showcase--next {
    display: none;
  }

  .collection-showcase--active {
    display: grid;
    grid-template-columns: 1fr;
    grid-template-areas:
      "stage"
      "copy"
      "actions";
    row-gap: 18px;
    padding: 0;
  }

  .collection-showcase--active .collection-showcase-stage {
    width: 100%;
    min-height: auto;
    grid-area: stage;
  }

  .collection-showcase-stage--card {
    grid-template-columns: 40px minmax(0, 1fr) 40px;
    gap: 10px;
  }

  .collection-showcase-stage--card .collection-swipe-btn {
    width: 38px;
    height: 38px;
  }

  .collection-showcase--active .collection-showcase-stage--card .collection-stack-shell {
    max-width: min(100%, 360px);
    min-height: 420px;
    border-radius: 20px;
  }

  .collection-showcase--active .collection-showcase-stage--card .collection-stack {
    width: min(100%, 320px);
    height: 420px;
  }

  .collection-showcase--active .collection-stack-card.shape-square {
    width: 80%;
  }

  .collection-showcase--active .collection-stack-card.shape-horizontal {
    width: 96%;
  }

  .collection-showcase--active .collection-stack-card.shape-vertical {
    width: 70%;
  }

  .collection-showcase--active .collection-stack-card--prev {
    transform: translate(calc(-50% - 42%), -50%) scale(0.72);
    opacity: 0.22;
  }

  .collection-showcase--active .collection-stack-card--next {
    transform: translate(calc(-50% + 42%), -50%) scale(0.72);
    opacity: 0.22;
  }

  .collection-showcase--active .collection-showcase-copy,
  .collection-showcase--active .collection-showcase-actions {
    position: static;
  }

  .collection-showcase--active .collection-showcase-copy {
    grid-area: copy;
    max-width: none;
    padding: 0;
    background: none;
    backdrop-filter: none;
  }

  .collection-showcase--active .collection-showcase-copy h3 {
    font-size: clamp(1.9rem, 8vw, 2.6rem);
  }

  .collection-showcase--active .collection-showcase-copy p {
    display: block;
    max-width: 32ch;
    -webkit-line-clamp: unset;
    font-size: 0.94rem;
    line-height: 1.6;
  }

  .collection-showcase--active .collection-showcase-actions {
    grid-area: actions;
  }

  .collections-mobile-pager {
    display: grid;
    grid-template-columns: 40px minmax(0, 1fr) 40px;
    gap: 12px;
    align-items: center;
    margin-top: 18px;
  }
}
/* Collections final interaction reset */
.collections-browser {
  grid-template-columns: 1fr;
}

.collections-browser > .collections-strip-nav {
  display: none !important;
}

.collection-showcase-stage--card {
  grid-template-columns: 50px minmax(0, 1fr) 50px;
  gap: 16px;
}

.collection-showcase-stage--card .collection-swipe-btn {
  width: 42px;
  height: 42px;
  opacity: 0.9;
}

.collection-showcase--active .collection-showcase-stage {
  width: min(100%, 740px);
  min-height: 620px;
}

.collection-showcase--active .collection-showcase-stage--card .collection-stack-shell {
  max-width: min(100%, 560px);
  min-height: 620px;
  overflow: visible;
}

.collection-showcase--active .collection-showcase-stage--card .collection-stack-shell::before {
  background: linear-gradient(180deg, rgba(4, 6, 6, 0.42) 0%, rgba(4, 6, 6, 0.16) 18%, rgba(4, 6, 6, 0.01) 38%, rgba(4, 6, 6, 0.06) 100%);
}

.collection-showcase--active .collection-showcase-stage--card .collection-stack {
  width: min(100%, 520px);
  height: 620px;
}

.collection-showcase--active .collection-stack-card--prev {
  transform: translate(calc(-50% - 42%), -50%) scale(0.8);
  opacity: 0.34;
  filter: blur(0.6px) saturate(0.72) brightness(0.82);
}

.collection-showcase--active .collection-stack-card--next {
  transform: translate(calc(-50% + 42%), -50%) scale(0.8);
  opacity: 0.34;
  filter: blur(0.6px) saturate(0.72) brightness(0.82);
}

.collection-showcase--active .collection-showcase-copy {
  max-width: min(240px, 30vw);
}

.collection-showcase--active .collection-showcase-copy p {
  max-width: 20ch;
}

.collections-overview {
  padding-top: 0;
}

.collections-overview-list {
  gap: 6px;
  padding-left: 12px;
}

@media (max-width: 1180px) {
  .section-collections .section-shell {
    display: block;
  }

  .collections-overview {
    display: none !important;
  }

  .collections-mobile-pager {
    display: grid;
    grid-template-columns: 40px minmax(0, 1fr) 40px;
    gap: 12px;
    align-items: center;
    margin-top: 18px;
  }

  .collection-showcase--active {
    display: grid;
    grid-template-columns: 1fr;
    grid-template-areas:
      "stage"
      "copy"
      "actions";
    row-gap: 18px;
  }

  .collection-showcase--active .collection-showcase-stage {
    width: 100%;
    min-height: auto;
    grid-area: stage;
  }

  .collection-showcase--active .collection-showcase-stage--card .collection-stack-shell {
    max-width: min(100%, 500px);
    min-height: 560px;
    margin-inline: auto;
  }

  .collection-showcase--active .collection-showcase-stage--card .collection-stack {
    width: min(100%, 440px);
    height: 560px;
  }

  .collection-showcase--active .collection-showcase-copy,
  .collection-showcase--active .collection-showcase-actions {
    position: static;
  }

  .collection-showcase--active .collection-showcase-copy {
    grid-area: copy;
    max-width: min(520px, 100%);
    padding-inline: 6px;
  }

  .collection-showcase--active .collection-showcase-copy h3 {
    font-size: clamp(2rem, 6vw, 2.8rem);
  }

  .collection-showcase--active .collection-showcase-copy p {
    max-width: 34ch;
    display: block;
    -webkit-line-clamp: unset;
  }

  .collection-showcase--active .collection-showcase-actions {
    grid-area: actions;
  }
}

@media (max-width: 900px) {
  .collections-mobile-pager {
    margin-top: 14px;
  }

  .collection-showcase-stage--card {
    grid-template-columns: 40px minmax(0, 1fr) 40px;
    gap: 10px;
  }

  .collection-showcase-stage--card .collection-swipe-btn {
    width: 38px;
    height: 38px;
  }

  .collection-showcase--active .collection-showcase-stage--card .collection-stack-shell {
    max-width: min(100%, 360px);
    min-height: 430px;
  }

  .collection-showcase--active .collection-showcase-stage--card .collection-stack {
    width: min(100%, 320px);
    height: 430px;
  }

  .collection-showcase--active .collection-stack-card.shape-square {
    width: 82%;
  }

  .collection-showcase--active .collection-stack-card.shape-horizontal {
    width: 98%;
  }

  .collection-showcase--active .collection-stack-card.shape-vertical {
    width: 72%;
  }

  .collection-showcase--active .collection-stack-card--prev {
    transform: translate(calc(-50% - 44%), -50%) scale(0.76);
    opacity: 0.3;
  }

  .collection-showcase--active .collection-stack-card--next {
    transform: translate(calc(-50% + 44%), -50%) scale(0.76);
    opacity: 0.3;
  }
}

/* Collections editorial stage layout */
.section-collections .section-shell {
  display: grid;
  grid-template-columns: clamp(220px, 22vw, 280px) minmax(0, 1fr);
  grid-template-areas:
    "head head"
    "overview browser";
  align-items: start;
  column-gap: clamp(26px, 4vw, 52px);
  row-gap: 26px;
}

.section-collections .collections-head {
  grid-area: head;
  margin-bottom: 0;
}

.section-collections .collections-browser {
  grid-area: browser;
  display: block;
}

.section-collections .collections-overview {
  grid-area: overview;
  display: grid;
  align-content: start;
  gap: 12px;
  margin-top: 0;
  padding-top: 26px;
}

.section-collections .collections-overview-status {
  display: none !important;
}

.section-collections .collections-overview-list {
  display: grid;
  gap: 10px;
  max-height: min(680px, 70vh);
  overflow-y: auto;
  overflow-x: hidden;
  padding: 0;
  border: none;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.section-collections .collections-overview-list::-webkit-scrollbar {
  width: 0;
  height: 0;
}

.section-collections .collections-overview-item {
  position: relative;
  min-height: 0;
  width: 100%;
  max-width: 100%;
  padding: 14px 16px 14px 18px;
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  background: rgba(255, 255, 255, 0.02);
  box-shadow: none;
  text-align: left;
  opacity: 0.68;
  transition: transform 0.18s ease, opacity 0.18s ease, border-color 0.18s ease, background 0.18s ease;
}

.section-collections .collections-overview-item::before {
  content: "";
  position: absolute;
  left: 0;
  top: 14px;
  bottom: 14px;
  width: 3px;
  border-radius: 999px;
  background: rgba(112, 129, 120, 0.28);
  transition: background 0.18s ease, transform 0.18s ease;
}

.section-collections .collections-overview-item:hover {
  transform: translateX(4px);
  opacity: 0.92;
  border-color: rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.035);
}

.section-collections .collections-overview-item.is-active {
  opacity: 1;
  border-color: rgba(47, 139, 105, 0.26);
  background: linear-gradient(180deg, rgba(16, 31, 25, 0.74), rgba(8, 14, 12, 0.68));
}

.section-collections .collections-overview-item.is-active::before {
  background: rgba(62, 166, 124, 0.96);
  transform: scaleY(1.02);
}

.section-collections .collections-overview-item-label {
  display: block;
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.3;
  color: rgba(226, 232, 227, 0.76);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.section-collections .collections-overview-item.is-active .collections-overview-item-label {
  color: #f4efe8;
}

.section-collections .collections-strip-nav {
  display: none !important;
}

.section-collections .collections-browser-viewport {
  padding: 0;
  overflow: visible;
  border: none;
  border-radius: 0;
  background: none;
  box-shadow: none;
}

.section-collections .collections-browser-viewport::before,
.section-collections .collections-browser-viewport::after {
  content: none;
}

.section-collections .collections-grid {
  min-height: clamp(640px, 70vh, 780px);
  overflow: visible;
}

.section-collections .collection-showcase--prev,
.section-collections .collection-showcase--next {
  display: none !important;
}

.section-collections .collection-showcase--active {
  position: relative;
  top: auto;
  left: auto;
  width: min(100%, 860px);
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  grid-template-areas:
    "title"
    "stage"
    "desc"
    "actions";
  justify-items: center;
  row-gap: 18px;
  padding: 0;
  border: none;
  background: none;
  box-shadow: none;
  transform: none;
  filter: none;
  opacity: 1;
  overflow: visible;
}

.section-collections .collection-showcase--active .collection-showcase-copy {
  display: contents;
}

.section-collections .collection-showcase--active .collection-showcase-copy h3 {
  grid-area: title;
  margin: 0;
  max-width: 12ch;
  text-align: center;
  font-size: clamp(2.45rem, 4.4vw, 4.35rem);
  line-height: 0.94;
  letter-spacing: 0.02em;
}

.section-collections .collection-showcase--active .collection-showcase-copy p {
  grid-area: desc;
  margin: 0;
  max-width: 36ch;
  text-align: center;
  color: rgba(223, 229, 224, 0.78);
  font-size: 1rem;
  line-height: 1.68;
}

.section-collections .collection-showcase--active .collection-showcase-stage {
  grid-area: stage;
  width: 100%;
  min-height: 0;
  display: grid;
  place-items: center;
}

.section-collections .collection-showcase-stage--card {
  width: 100%;
  display: grid;
  grid-template-columns: auto auto;
  grid-template-areas:
    "stack stack"
    "prev next";
  justify-content: center;
  align-items: center;
  column-gap: 16px;
  row-gap: 18px;
}

.section-collections .collection-showcase-stage--card .collection-stack-shell {
  grid-area: stack;
  position: relative;
  width: min(100%, 640px);
  min-height: clamp(500px, 64vh, 680px);
  margin-inline: auto;
  overflow: visible;
  border-radius: 0;
  background: none;
  border: none;
  box-shadow: none;
  cursor: default;
  touch-action: pan-y;
  user-select: none;
}

.section-collections .collection-showcase-stage--card .collection-stack-shell.is-interactive {
  cursor: grab;
}

.section-collections .collection-showcase-stage--card .collection-stack-shell.is-interactive:active {
  cursor: grabbing;
}

.section-collections .collection-showcase-stage--card .collection-stack-shell::before {
  content: none;
}

.section-collections .collection-showcase-stage--card .collection-stack {
  width: min(100%, 540px);
  height: clamp(500px, 64vh, 680px);
}

.section-collections .collection-showcase-stage--card .collection-swipe-btn {
  position: static;
  top: auto;
  left: auto;
  right: auto;
  transform: none;
  width: 46px;
  height: 46px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.09);
  background: rgba(255, 255, 255, 0.03);
  color: rgba(244, 239, 232, 0.88);
}

.section-collections .collection-showcase-stage--card .collection-swipe-btn--prev {
  grid-area: prev;
  justify-self: end;
}

.section-collections .collection-showcase-stage--card .collection-swipe-btn--next {
  grid-area: next;
  justify-self: start;
}

.section-collections .collection-showcase-stage--card .collection-swipe-btn:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(47, 139, 105, 0.18);
}

.section-collections .collection-showcase--active .collection-stack-card {
  border-color: rgba(255, 255, 255, 0.04);
  box-shadow: 0 28px 68px rgba(0, 0, 0, 0.26);
}

.section-collections .collection-showcase--active .collection-stack-card.shape-square {
  width: 84%;
}

.section-collections .collection-showcase--active .collection-stack-card.shape-horizontal {
  width: 100%;
}

.section-collections .collection-showcase--active .collection-stack-card.shape-vertical {
  width: 72%;
}

.section-collections .collection-showcase--active .collection-stack-card--prev {
  transform: translate(calc(-50% - 32%), -50%) scale(0.82);
  opacity: 0.22;
  filter: blur(0.8px) saturate(0.6) brightness(0.78);
}

.section-collections .collection-showcase--active .collection-stack-card--next {
  transform: translate(calc(-50% + 32%), -50%) scale(0.82);
  opacity: 0.22;
  filter: blur(0.8px) saturate(0.6) brightness(0.78);
}

.section-collections .collection-showcase--active .collection-showcase-actions {
  grid-area: actions;
  position: static;
  justify-self: center;
}

.section-collections .collections-mobile-pager {
  display: none;
}

@media (max-width: 1100px) {
  .section-collections .section-shell {
    grid-template-columns: minmax(0, 1fr);
    grid-template-areas:
      "head"
      "pager"
      "browser";
  }

  .section-collections .collections-overview {
    display: none !important;
  }

  .section-collections .collections-mobile-pager {
    grid-area: pager;
    display: grid;
    grid-template-columns: 40px minmax(0, 1fr) 40px;
    gap: 12px;
    align-items: center;
    margin-top: -4px;
  }

  .section-collections .collections-browser {
    grid-area: browser;
  }

  .section-collections .collection-showcase--active {
    width: min(100%, 760px);
  }

  .section-collections .collection-showcase-stage--card .collection-stack-shell {
    width: min(100%, 560px);
    min-height: clamp(440px, 58vh, 620px);
  }

  .section-collections .collection-showcase-stage--card .collection-stack {
    width: min(100%, 480px);
    height: clamp(440px, 58vh, 620px);
  }
}

@media (max-width: 760px) {
  .section-collections .collection-showcase--active {
    row-gap: 14px;
  }

  .section-collections .collection-showcase--active .collection-showcase-copy h3 {
    font-size: clamp(2rem, 10vw, 3rem);
  }

  .section-collections .collection-showcase--active .collection-showcase-copy p {
    max-width: 30ch;
    font-size: 0.95rem;
    line-height: 1.58;
  }

  .section-collections .collection-showcase-stage--card {
    column-gap: 14px;
    row-gap: 14px;
  }

  .section-collections .collection-showcase-stage--card .collection-stack-shell {
    width: min(100%, 360px);
    min-height: clamp(340px, 46vh, 430px);
  }

  .section-collections .collection-showcase-stage--card .collection-stack {
    width: min(100%, 320px);
    height: clamp(340px, 46vh, 430px);
  }

  .section-collections .collection-showcase-stage--card .collection-swipe-btn {
    width: 40px;
    height: 40px;
  }

  .section-collections .collection-showcase--active .collection-stack-card.shape-square {
    width: 80%;
  }

  .section-collections .collection-showcase--active .collection-stack-card.shape-horizontal {
    width: 98%;
  }

  .section-collections .collection-showcase--active .collection-stack-card.shape-vertical {
    width: 70%;
  }

  .section-collections .collection-showcase--active .collection-stack-card--prev {
    transform: translate(calc(-50% - 24%), -50%) scale(0.8);
    opacity: 0.18;
  }

  .section-collections .collection-showcase--active .collection-stack-card--next {
    transform: translate(calc(-50% + 24%), -50%) scale(0.8);
    opacity: 0.18;
  }
}

/* Collections clean final rework */
.section-collections {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 12% 18%, rgba(29, 98, 73, 0.12), transparent 30%),
    radial-gradient(circle at 82% 10%, rgba(255, 255, 255, 0.03), transparent 18%),
    linear-gradient(180deg, rgba(7, 12, 11, 0.99), rgba(8, 14, 13, 0.96) 46%, rgba(6, 10, 10, 0.99));
}

.section-collections .section-shell {
  display: grid;
  grid-template-columns: minmax(180px, 220px) minmax(0, 1fr);
  grid-template-areas:
    "head head"
    "overview browser";
  align-items: start;
  column-gap: clamp(28px, 4vw, 56px);
  row-gap: clamp(24px, 3vw, 34px);
}

.section-collections .collections-head {
  grid-area: head;
  margin-bottom: 0;
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
}

.section-collections .collections-head-copy {
  max-width: min(820px, 100%);
}

.section-collections .collections-head-copy h2 {
  margin-bottom: 16px;
}

.section-collections .collections-head-copy p {
  max-width: 62ch;
  color: rgba(218, 225, 220, 0.8);
  font-size: 1.02rem;
  line-height: 1.72;
}

.section-collections .collections-browser {
  grid-area: browser;
  display: block;
  min-width: 0;
}

.section-collections .collections-strip-nav {
  display: none !important;
}

.section-collections .collections-browser-viewport {
  padding: 0;
  overflow: visible;
  border: none;
  border-radius: 0;
  background: none;
  box-shadow: none;
  isolation: isolate;
}

.section-collections .collections-browser-viewport::before,
.section-collections .collections-browser-viewport::after {
  content: none;
}

.section-collections .collections-grid {
  position: relative;
  display: block;
  min-height: 0;
  overflow: visible;
}

.section-collections .collections-grid > .collection-showcase:not(.collection-showcase--active) {
  display: none !important;
}

.section-collections .collections-empty-state {
  width: min(100%, 620px);
  margin: 0 auto;
  padding: 38px 32px;
  border-radius: 28px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  background: linear-gradient(180deg, rgba(10, 16, 15, 0.78), rgba(7, 11, 11, 0.66));
}

.section-collections .collections-overview {
  grid-area: overview;
  display: grid;
  align-content: start;
  gap: 12px;
  margin-top: 10px;
}

.section-collections .collections-overview-status {
  display: none !important;
}

.section-collections .collections-overview-list {
  position: relative;
  display: grid;
  gap: 2px;
  max-height: min(640px, 72vh);
  overflow-y: auto;
  overflow-x: hidden;
  padding: 2px 0 2px 22px;
  border: none;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.section-collections .collections-overview-list::before {
  content: "";
  position: absolute;
  left: 0;
  top: 6px;
  bottom: 6px;
  width: 1px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0.04) 24%, rgba(255, 255, 255, 0.08) 76%, rgba(255, 255, 255, 0.02));
}

.section-collections .collections-overview-list::-webkit-scrollbar {
  width: 0;
  height: 0;
}

.section-collections .collections-overview-item {
  position: relative;
  min-height: 0;
  width: 100%;
  max-width: 100%;
  padding: 14px 0 14px 18px;
  border: none;
  border-radius: 0;
  background: none;
  box-shadow: none;
  text-align: left;
  opacity: 0.52;
  transition: opacity 0.2s ease, transform 0.2s ease;
}

.section-collections .collections-overview-item::before {
  content: "";
  position: absolute;
  left: -25px;
  top: 50%;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  border: 1px solid rgba(170, 182, 176, 0.34);
  background: rgba(170, 182, 176, 0.18);
  transform: translateY(-50%);
  transition: transform 0.2s ease, background 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.section-collections .collections-overview-item:hover {
  opacity: 0.84;
  transform: translateX(4px);
}

.section-collections .collections-overview-item.is-active {
  opacity: 1;
}

.section-collections .collections-overview-item.is-active::before {
  border-color: rgba(69, 184, 138, 0.78);
  background: rgba(69, 184, 138, 0.96);
  box-shadow: 0 0 0 7px rgba(32, 109, 82, 0.18);
  transform: translateY(-50%) scale(1.05);
}

.section-collections .collections-overview-item-label {
  display: block;
  color: rgba(222, 229, 224, 0.7);
  font-size: 1rem;
  font-weight: 500;
  line-height: 1.3;
  letter-spacing: 0;
  text-transform: none;
  white-space: normal;
}

.section-collections .collections-overview-item.is-active .collections-overview-item-label {
  color: #f4efe8;
}

.section-collections .collection-showcase--active {
  position: relative;
  top: auto;
  left: auto;
  width: min(100%, 980px);
  margin-inline: auto;
  padding: 0;
  border: none;
  border-radius: 0;
  background: none;
  box-shadow: none;
  transform: none;
  filter: none;
  opacity: 1;
  overflow: visible;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  grid-template-areas:
    "header"
    "stage"
    "body"
    "actions";
  row-gap: clamp(18px, 2vw, 24px);
}

.section-collections .collection-showcase--active .collection-showcase-copy {
  display: contents;
}

.section-collections .collection-showcase--active .collection-showcase-copy h3 {
  grid-area: header;
  margin: 0;
  max-width: min(14ch, 100%);
  color: #f4efe8;
  font-size: clamp(2rem, 4.4vw, 3.5rem);
  line-height: 0.95;
  letter-spacing: 0.01em;
  text-transform: none;
  text-shadow: none;
}

.section-collections .collection-showcase--active.collection-showcase--placeholder-title .collection-showcase-copy h3 {
  font-size: clamp(1.6rem, 3vw, 2.35rem);
}

.section-collections .collection-showcase--active .collection-showcase-copy p {
  grid-area: body;
  margin: 0;
  max-width: 46ch;
  color: rgba(220, 227, 222, 0.78);
  font-size: 1rem;
  line-height: 1.74;
}

.section-collections .collection-showcase--active .collection-showcase-stage {
  grid-area: stage;
  position: relative;
  width: 100%;
  min-height: 0;
  display: grid;
  place-items: center;
  padding: clamp(24px, 3vw, 34px) clamp(16px, 3vw, 28px) 18px;
  border-radius: 36px;
  overflow: hidden;
  background:
    radial-gradient(circle at 50% 20%, rgba(34, 109, 81, 0.16), transparent 32%),
    linear-gradient(180deg, rgba(11, 17, 16, 0.88), rgba(7, 11, 11, 0.78));
  border: 1px solid rgba(255, 255, 255, 0.045);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.04),
    inset 0 -40px 80px rgba(0, 0, 0, 0.22),
    0 32px 90px rgba(0, 0, 0, 0.22);
}

.section-collections .collection-showcase-stage--card {
  width: min(100%, 900px);
  display: grid;
  grid-template-columns: 1fr auto auto 1fr;
  grid-template-areas:
    "stack stack stack stack"
    ". prev next .";
  align-items: center;
  justify-items: center;
  column-gap: 16px;
  row-gap: 18px;
}

.section-collections .collection-showcase-stage--card .collection-stack-shell {
  grid-area: stack;
  position: relative;
  width: min(100%, 820px);
  min-height: clamp(540px, 66vh, 760px);
  margin-inline: auto;
  overflow: visible;
  border: none;
  border-radius: 0;
  background: none;
  box-shadow: none;
  cursor: default;
  touch-action: pan-y;
  user-select: none;
}

.section-collections .collection-showcase-stage--card .collection-stack-shell::before {
  content: "";
  position: absolute;
  inset: 9% 6% 11%;
  border-radius: 40px;
  background: radial-gradient(circle at center, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0) 72%);
  pointer-events: none;
}

.section-collections .collection-showcase-stage--card .collection-stack-shell.is-interactive {
  cursor: grab;
}

.section-collections .collection-showcase-stage--card .collection-stack-shell.is-interactive:active {
  cursor: grabbing;
}

.section-collections .collection-showcase-stage--card .collection-stack {
  width: min(100%, 760px);
  height: clamp(540px, 66vh, 760px);
  margin-inline: auto;
}

.section-collections .collection-showcase--active .collection-stack-card {
  border-color: rgba(255, 255, 255, 0.05);
  box-shadow: 0 42px 90px rgba(0, 0, 0, 0.34);
}

.section-collections .collection-showcase--active .collection-stack-card.shape-square {
  width: 90%;
}

.section-collections .collection-showcase--active .collection-stack-card.shape-horizontal {
  width: 100%;
}

.section-collections .collection-showcase--active .collection-stack-card.shape-vertical {
  width: 78%;
}

.section-collections .collection-showcase--active .collection-stack-card--active {
  transform: translate(-50%, -50%) scale(1.01);
}

.section-collections .collection-showcase--active .collection-stack-card--prev {
  transform: translate(calc(-50% - 30%), -50%) scale(0.88);
  opacity: 0.16;
  filter: blur(2.5px) saturate(0.45) brightness(0.76);
}

.section-collections .collection-showcase--active .collection-stack-card--next {
  transform: translate(calc(-50% + 30%), -50%) scale(0.88);
  opacity: 0.16;
  filter: blur(2.5px) saturate(0.45) brightness(0.76);
}

.section-collections .collection-showcase-stage--card .collection-swipe-btn {
  position: static;
  top: auto;
  left: auto;
  right: auto;
  transform: none;
  width: 46px;
  height: 46px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.09);
  background: rgba(255, 255, 255, 0.03);
  color: rgba(244, 239, 232, 0.9);
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.2);
  backdrop-filter: blur(8px);
}

.section-collections .collection-showcase-stage--card .collection-swipe-btn:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(64, 167, 127, 0.28);
}

.section-collections .collection-showcase-stage--card .collection-swipe-btn--prev {
  grid-area: prev;
}

.section-collections .collection-showcase-stage--card .collection-swipe-btn--next {
  grid-area: next;
}

.section-collections .collection-showcase--active .collection-showcase-actions {
  grid-area: actions;
  position: static;
  justify-self: start;
  margin-top: 4px;
}

.section-collections .collections-mobile-pager {
  display: none;
}

@media (max-width: 1100px) {
  .section-collections .section-shell {
    grid-template-columns: minmax(0, 1fr);
    grid-template-areas:
      "head"
      "pager"
      "browser";
    row-gap: 20px;
  }

  .section-collections .collections-overview {
    display: none !important;
  }

  .section-collections .collections-mobile-pager {
    grid-area: pager;
    display: grid;
    grid-template-columns: 44px minmax(0, 1fr) 44px;
    gap: 14px;
    align-items: center;
  }

  .section-collections .collections-mobile-nav {
    width: 44px;
    height: 44px;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(255, 255, 255, 0.03);
    color: #f4efe8;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  .section-collections .collections-mobile-nav:disabled {
    opacity: 0.34;
  }

  .section-collections .collections-mobile-title {
    min-width: 0;
    text-align: center;
    font-size: 1rem;
    font-weight: 600;
    color: #f4efe8;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .section-collections .collection-showcase--active {
    width: min(100%, 860px);
  }

  .section-collections .collection-showcase--active .collection-showcase-copy h3 {
    max-width: 16ch;
    font-size: clamp(1.9rem, 5.6vw, 3rem);
  }

  .section-collections .collection-showcase--active.collection-showcase--placeholder-title .collection-showcase-copy h3 {
    font-size: clamp(1.55rem, 4.4vw, 2.1rem);
  }

  .section-collections .collection-showcase--active .collection-showcase-stage {
    padding: 22px 14px 18px;
    border-radius: 30px;
  }

  .section-collections .collection-showcase-stage--card {
    width: 100%;
  }

  .section-collections .collection-showcase-stage--card .collection-stack-shell {
    width: min(100%, 660px);
    min-height: clamp(460px, 58vh, 640px);
  }

  .section-collections .collection-showcase-stage--card .collection-stack {
    width: min(100%, 600px);
    height: clamp(460px, 58vh, 640px);
  }
}

@media (max-width: 760px) {
  .section-collections .collections-head {
    row-gap: 12px;
  }

  .section-collections .collections-head-copy h2 {
    font-size: clamp(2.1rem, 11vw, 3.2rem);
    margin-bottom: 12px;
  }

  .section-collections .collections-head-copy p {
    font-size: 0.96rem;
    line-height: 1.62;
  }

  .section-collections .collection-showcase--active {
    row-gap: 16px;
  }

  .section-collections .collection-showcase--active .collection-showcase-copy h3 {
    max-width: 13ch;
    font-size: clamp(1.75rem, 9vw, 2.45rem);
  }

  .section-collections .collection-showcase--active.collection-showcase--placeholder-title .collection-showcase-copy h3 {
    font-size: clamp(1.35rem, 7vw, 1.85rem);
  }

  .section-collections .collection-showcase--active .collection-showcase-copy p {
    max-width: 32ch;
    font-size: 0.94rem;
    line-height: 1.6;
  }

  .section-collections .collection-showcase--active .collection-showcase-stage {
    padding: 16px 10px 14px;
    border-radius: 24px;
  }

  .section-collections .collection-showcase-stage--card {
    column-gap: 12px;
    row-gap: 14px;
  }

  .section-collections .collection-showcase-stage--card .collection-stack-shell {
    width: min(100%, 380px);
    min-height: clamp(340px, 48vh, 460px);
  }

  .section-collections .collection-showcase-stage--card .collection-stack {
    width: min(100%, 340px);
    height: clamp(340px, 48vh, 460px);
  }

  .section-collections .collection-showcase--active .collection-stack-card.shape-square {
    width: 86%;
  }

  .section-collections .collection-showcase--active .collection-stack-card.shape-horizontal {
    width: 100%;
  }

  .section-collections .collection-showcase--active .collection-stack-card.shape-vertical {
    width: 74%;
  }

  .section-collections .collection-showcase--active .collection-stack-card--prev {
    transform: translate(calc(-50% - 20%), -50%) scale(0.9);
    opacity: 0.12;
  }

  .section-collections .collection-showcase--active .collection-stack-card--next {
    transform: translate(calc(-50% + 20%), -50%) scale(0.9);
    opacity: 0.12;
  }

  .section-collections .collection-showcase-stage--card .collection-swipe-btn {
    width: 42px;
    height: 42px;
  }
}

@media (max-width: 540px) {
  .section-collections .collections-mobile-pager {
    grid-template-columns: 40px minmax(0, 1fr) 40px;
    gap: 10px;
  }

  .section-collections .collections-mobile-nav {
    width: 40px;
    height: 40px;
  }

  .section-collections .collections-mobile-title {
    font-size: 0.96rem;
  }

  .section-collections .collection-showcase-stage--card .collection-stack-shell {
    width: min(100%, 310px);
    min-height: clamp(320px, 44vh, 400px);
  }

  .section-collections .collection-showcase-stage--card .collection-stack {
    width: min(100%, 290px);
    height: clamp(320px, 44vh, 400px);
  }

  .section-collections .collection-showcase-stage--card .collection-swipe-btn {
    width: 38px;
    height: 38px;
  }
}

/* Responsive final polish */
body {
  overflow-x: hidden;
}

body.nav-open {
  overflow: hidden;
}

body.nav-open::after {
  content: "";
  position: fixed;
  inset: 0;
  background: rgba(4, 6, 6, 0.52);
  backdrop-filter: blur(6px);
  z-index: 190;
}

@media (max-width: 1100px) {
  .section-shell {
    min-width: 0;
  }

  .project-viewer-card,
  .collection-editor-card,
  .hero-modal-card,
  .legal-modal-card,
  .artist-modal-card,
  .portfolio-modal-card {
    width: min(100% - 20px, 980px);
    max-height: calc(100vh - 20px);
  }

  .project-viewer-shell {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .project-viewer-copy {
    padding: 0;
  }

  .project-viewer-frame {
    min-height: clamp(320px, 56vh, 620px);
  }

  .collection-editor-head {
    padding: 24px 22px 18px;
  }

  .collection-editor-sidebar,
  .collection-editor-preview-wrap,
  .collection-editor-controls {
    padding: 22px 18px;
  }

  .collection-editor-main {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 860px) {
  :root {
    --header-height: 96px;
  }

  .header-inner {
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 12px;
  }

  .header-actions {
    min-width: 0;
    gap: 10px;
  }

  .header-socials {
    gap: 8px;
  }

  .site-nav {
    top: calc(100% + 12px);
    right: 0;
    width: min(340px, calc(100vw - 28px));
    max-height: calc(100vh - var(--header-height) - 28px);
    overflow: auto;
    overscroll-behavior: contain;
    padding: 18px 16px;
    gap: 4px;
  }

  .site-nav a {
    min-height: 48px;
    min-width: 0;
    padding: 0 14px;
    white-space: normal;
  }

  .site-nav a.site-nav-cta {
    margin-top: 10px;
  }

  .hero {
    min-height: auto;
  }

  .hero-inner {
    padding: clamp(74px, 12vh, 100px) 0 clamp(64px, 9vh, 88px);
  }

  .hero-content {
    max-width: min(100%, 680px);
  }

  .hero-content p {
    max-width: 34ch;
    margin-top: 18px;
    font-size: 1.02rem;
    line-height: 1.65;
  }

  .hero-actions {
    margin-top: 28px;
    gap: 12px;
  }

  .hero-actions .btn,
  .artist-panel-actions .btn {
    min-height: 52px;
  }

  .artist-header-actions,
  .aftercare-admin-actions,
  .portfolio-head-actions {
    width: 100%;
  }

  .contact-clean-layout {
    gap: 18px;
  }

  .contact-clean-sidebar,
  .contact-panel-shell {
    padding: 20px 18px;
    border-radius: 24px;
  }

  .contact-side-card {
    padding: 18px;
    border-radius: 20px;
  }

  .contact-panel-intro h3 {
    font-size: 1.25rem;
  }

  .contact-stage-card {
    padding: 20px;
    border-radius: 22px;
  }

  .map-frame-wrap iframe {
    min-height: 320px;
  }

  .contact-form-footer {
    grid-template-columns: 1fr;
  }

  .contact-form-submit {
    width: 100%;
  }

  .care-grid {
    gap: 14px;
  }

  .care-card {
    padding: 20px 18px;
  }

  .footer-inner {
    align-items: flex-start;
  }

  .footer-links {
    width: 100%;
    justify-content: flex-start;
    gap: 14px 18px;
  }

  .section-media-admin.media-panel {
    top: calc(var(--admin-bar-height) + var(--header-height) + 8px) !important;
    left: 12px !important;
    right: 12px !important;
    width: auto !important;
    max-height: calc(100vh - var(--admin-bar-height) - var(--header-height) - 20px) !important;
  }

  .portfolio-media-admin-item {
    grid-template-columns: 72px minmax(0, 1fr);
    align-items: start;
  }

  .portfolio-media-admin-actions {
    grid-column: 1 / -1;
    justify-content: flex-start;
  }

  .portfolio-media-admin-thumb {
    width: 72px;
    height: 72px;
  }

  .project-viewer-stage {
    display: grid;
    grid-template-columns: 40px minmax(0, 1fr) 40px;
    gap: 10px;
    align-items: center;
  }

  .project-viewer-nav {
    position: relative;
    top: auto;
    left: auto;
    right: auto;
    transform: none;
    width: 40px;
    height: 40px;
    font-size: 1.4rem;
  }

  .project-viewer-frame {
    min-height: clamp(300px, 54vh, 520px);
  }

  .project-viewer-dots {
    margin-top: 14px;
  }

  .collection-editor-card {
    width: min(100% - 18px, 980px);
  }

  .collection-editor-body {
    grid-template-columns: 1fr;
  }

  .collection-editor-sidebar,
  .collection-editor-preview-wrap {
    border-right: none;
    border-bottom: 1px solid rgba(255,255,255,0.07);
  }

  .collection-editor-preview-wrap {
    padding-bottom: 20px;
  }

  .collection-editor-controls {
    padding: 20px 18px 22px;
  }

  .collection-editor-list .portfolio-media-admin-item,
  .collection-editor-item {
    grid-template-columns: 72px minmax(0, 1fr);
  }

  .section-collections .collections-mobile-pager {
    margin-top: 0;
  }

  .section-collections .collection-showcase--active .collection-showcase-actions {
    justify-self: stretch;
    width: 100%;
  }

  .section-collections .collection-showcase--active .collection-showcase-actions .btn {
    width: 100%;
  }
}

@media (max-width: 640px) {
  :root {
    --header-height: 88px;
    --admin-bar-height: 54px;
  }

  .container {
    width: min(100% - 22px, var(--container));
  }

  .section {
    padding: 74px 0;
  }

  .header-inner {
    padding-bottom: 10px;
  }

  .brand-logo {
    width: 54px;
    height: 40px;
  }

  .header-socials {
    display: none;
  }

  .site-nav {
    width: calc(100vw - 22px);
    max-height: calc(100vh - var(--header-height) - 18px);
  }

  .hero-inner {
    padding: 62px 0 56px;
  }

  .hero-content p {
    max-width: 100%;
    font-size: 0.98rem;
  }

  .hero-actions,
  .artist-panel-actions,
  .portfolio-head-actions,
  .artist-header-actions,
  .aftercare-admin-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .hero-actions .btn,
  .artist-panel-actions .btn,
  .portfolio-head-actions > *,
  .artist-header-actions-row > *,
  .aftercare-admin-actions > *,
  .hero-inline-actions > *,
  .hero-admin-image-actions > *,
  .artist-image-overlay-actions > *,
  .studio-media-upload-actions > *,
  .portfolio-media-upload-actions > *,
  .panel-action-btn {
    width: 100%;
  }

  .tag-row {
    gap: 8px;
  }

  .tag {
    width: 100%;
    justify-content: center;
  }

  .contact-clean-sidebar,
  .contact-panel-shell {
    padding: 18px 16px;
    border-radius: 22px;
  }

  .contact-clean-sidebar-head {
    flex-direction: column;
    align-items: stretch;
  }

  .contact-side-card,
  .contact-side-hours-head {
    grid-template-columns: 48px 1fr;
    gap: 12px;
  }

  .contact-side-card-icon,
  .contact-direct-icon {
    width: 48px;
    height: 48px;
    border-radius: 16px;
  }

  .contact-stage-card {
    padding: 18px 16px;
  }

  .contact-direct-card {
    min-height: 0;
    padding: 18px 16px;
    border-radius: 20px;
  }

  .contact-panel-view {
    gap: 18px;
  }

  .contact-form-panel {
    gap: 14px;
  }

  .field-grow textarea {
    min-height: 220px;
  }

  .map-frame-wrap iframe {
    min-height: 260px;
  }

  .hours-table-card,
  .hours-vacation-card {
    padding: 18px 16px;
    border-radius: 18px;
  }

  .care-card {
    border-radius: 18px;
  }

  .footer-inner {
    gap: 14px;
  }

  .footer-left,
  .footer-links {
    width: 100%;
  }

  .footer-links {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
  }

  .project-viewer-card {
    padding: 52px 14px 16px;
    border-radius: 22px;
  }

  .project-viewer-stage {
    grid-template-columns: 36px minmax(0, 1fr) 36px;
    gap: 8px;
  }

  .project-viewer-nav {
    width: 36px;
    height: 36px;
    font-size: 1.2rem;
  }

  .project-viewer-frame {
    min-height: clamp(240px, 46vh, 420px);
    border-radius: 18px;
  }

  .project-viewer-copy h3 {
    font-size: clamp(1.25rem, 7vw, 1.7rem);
  }

  .project-viewer-copy p {
    font-size: 0.94rem;
    line-height: 1.6;
  }

  .hero-modal-card,
  .legal-modal-card,
  .artist-modal-card,
  .portfolio-modal-card,
  .collection-editor-card {
    width: calc(100% - 12px);
    border-radius: 20px;
  }

  .hero-modal-card,
  .legal-modal-card,
  .artist-modal-card,
  .portfolio-modal-card {
    padding: 18px 16px;
  }

  .hero-modal-head,
  .legal-modal-head,
  .artist-modal-head,
  .portfolio-modal-head,
  .collection-editor-head {
    gap: 12px;
  }

  .hero-crop-preview,
  .portfolio-crop-preview,
  .artist-crop-preview {
    min-height: 240px;
    padding: 12px;
  }

  .hero-crop-frame {
    aspect-ratio: 16 / 10;
  }

  .portfolio-modal-body--project {
    grid-template-columns: 1fr !important;
  }

  .portfolio-media-upload-actions,
  .hero-admin-image-actions,
  .section-media-admin-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .section-media-admin.media-panel {
    top: calc(var(--admin-bar-height) + var(--header-height) + 6px) !important;
    left: 8px !important;
    right: 8px !important;
    max-height: calc(100vh - var(--admin-bar-height) - var(--header-height) - 14px) !important;
    padding: 12px;
    border-radius: 18px;
  }

  .section-media-admin-head {
    flex-direction: column;
    align-items: stretch;
  }

  .media-panel-close {
    align-self: flex-end;
  }

  .portfolio-media-admin-item,
  .collection-editor-item {
    grid-template-columns: 1fr;
  }

  .portfolio-media-admin-thumb {
    width: 100%;
    height: 180px;
  }

  .portfolio-media-admin-actions,
  .collection-manager-item-controls {
    width: 100%;
  }

  .portfolio-media-admin-chip {
    flex: 1 1 140px;
    justify-content: center;
  }

  .collection-editor-head {
    padding: 18px 16px 16px;
  }

  .collection-editor-sidebar,
  .collection-editor-preview-wrap,
  .collection-editor-controls {
    padding: 18px 14px;
  }

  .collection-editor-close {
    width: 44px;
    height: 44px;
  }

  .collection-editor-fields > label:not(.toggle-control) {
    padding: 12px 14px;
    border-radius: 18px;
  }

  .collection-editor-fields > label:not(.toggle-control) input,
  .collection-editor-fields > label:not(.toggle-control) textarea {
    padding: 12px 14px;
  }

  .section-collections .collections-head-copy p,
  .section-collections .collection-showcase--active .collection-showcase-copy h3,
  .section-collections .collection-showcase--active .collection-showcase-copy p {
    max-width: 100%;
  }

  .section-collections .collection-showcase--active .collection-showcase-stage {
    padding: 14px 8px 12px;
    border-radius: 20px;
  }

  .section-collections .collection-showcase-stage--card {
    grid-template-columns: 36px minmax(0, 1fr) 36px;
    grid-template-areas: "prev stack next";
    column-gap: 8px;
    row-gap: 0;
  }

  .section-collections .collection-showcase-stage--card .collection-stack-shell {
    width: 100%;
    max-width: 280px;
    min-height: clamp(280px, 62vw, 360px);
  }

  .section-collections .collection-showcase-stage--card .collection-stack {
    width: 100%;
    max-width: 260px;
    height: clamp(280px, 62vw, 360px);
  }

  .section-collections .collection-showcase-stage--card .collection-swipe-btn {
    width: 36px;
    height: 36px;
  }

  .section-collections .collection-showcase--active .collection-stack-card.shape-square {
    width: 82%;
  }

  .section-collections .collection-showcase--active .collection-stack-card.shape-horizontal {
    width: 100%;
  }

  .section-collections .collection-showcase--active .collection-stack-card.shape-vertical {
    width: 72%;
  }

  .section-collections .collection-showcase--active .collection-stack-card--prev {
    transform: translate(calc(-50% - 16%), -50%) scale(0.88);
    opacity: 0.1;
  }

  .section-collections .collection-showcase--active .collection-stack-card--next {
    transform: translate(calc(-50% + 16%), -50%) scale(0.88);
    opacity: 0.1;
  }

  .hair-promo-wrap {
    right: 14px;
    left: auto;
    top: calc(var(--header-height) + 8px);
  }

  body.admin-active .hair-promo-wrap {
    top: calc(var(--admin-bar-height) + var(--header-height) + 8px);
  }

  .hair-promo-thread {
    display: none;
  }

  .hair-promo-flyout {
    top: calc(var(--header-height) + 52px);
    width: calc(100vw - 16px);
  }

  body.admin-active .hair-promo-flyout {
    top: calc(var(--admin-bar-height) + var(--header-height) + 52px);
  }
}

@media (max-width: 480px) {
  .admin-bar-inner {
    gap: 8px;
    align-items: stretch;
  }

  .admin-bar-actions .admin-mini-btn {
    width: 100%;
  }

  .collections-mobile-title {
    font-size: 0.92rem;
  }
}

/* Mobile fixes: artist/studio postcard + collections title */
@media (max-width: 1100px) {
  .section-artist .artist-postcard-shell,
  .section-artist .artist-flip-shell {
    perspective: none !important;
    min-height: 0 !important;
  }

  .section-artist .artist-postcard-card,
  .section-artist .artist-flip-card {
    display: block !important;
    min-height: 0 !important;
    height: auto !important;
    transform: none !important;
    transform-style: flat !important;
  }

  .section-artist .artist-postcard-face,
  .section-artist .artist-flip-face {
    position: relative !important;
    inset: auto !important;
    display: grid !important;
    grid-area: auto !important;
    grid-template-columns: 1fr !important;
    gap: 18px !important;
    align-items: start !important;
    min-height: 0 !important;
    height: auto !important;
    overflow: visible !important;
    transform: none !important;
    backface-visibility: visible !important;
    -webkit-backface-visibility: visible !important;
  }

  .section-artist .artist-postcard-face.artist-flip-back,
  .section-artist .artist-flip-back {
    display: none !important;
  }

  .section-artist .artist-postcard-shell.is-flipped .artist-postcard-face.artist-flip-front,
  .section-artist .artist-flip-shell.is-flipped .artist-flip-front {
    display: none !important;
  }

  .section-artist .artist-postcard-shell.is-flipped .artist-postcard-face.artist-flip-back,
  .section-artist .artist-flip-shell.is-flipped .artist-flip-back {
    display: grid !important;
  }

  .section-artist .artist-postcard-media,
  .section-artist .artist-postcard-copy,
  .section-artist .artist-copy-card,
  .section-artist .artist-studio-card {
    min-width: 0 !important;
    min-height: 0 !important;
    height: auto !important;
  }

  .section-artist .artist-postcard-media {
    display: block !important;
  }

  .section-artist .artist-postcard-copy {
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
  }

  .section-artist .artist-copy-card,
  .section-artist .artist-studio-card {
    display: grid !important;
    align-content: start !important;
    gap: 0 !important;
  }

  .section-artist .artist-postcard-stage,
  .section-artist .studio-gallery-stage,
  .section-artist .artist-image-stage {
    position: relative !important;
    inset: auto !important;
    width: min(100%, 440px) !important;
    max-width: 100% !important;
    min-height: 0 !important;
    height: auto !important;
    margin-inline: auto !important;
    aspect-ratio: 4 / 5 !important;
    overflow: hidden !important;
    border-radius: 28px !important;
    border: 1px solid rgba(255,255,255,0.08) !important;
    background: #0c0f0d !important;
    box-shadow: 0 24px 70px rgba(0,0,0,0.18) !important;
  }

  .section-artist .artist-postcard-face.artist-flip-front .artist-image,
  .section-artist .artist-postcard-face.artist-flip-back #studioImage,
  .section-artist .artist-image-stage img,
  .section-artist .studio-gallery-stage img {
    position: absolute !important;
    top: 50% !important;
    left: 50% !important;
    width: 110% !important;
    height: 110% !important;
    max-width: none !important;
    transform: translate(-50%, -50%) !important;
    object-fit: cover !important;
  }

  .section-artist .artist-header {
    display: grid;
    gap: 14px;
    align-items: start;
  }

  .section-artist .artist-header-actions {
    width: 100%;
    justify-content: flex-start;
  }

  .section-artist .artist-header-actions-row {
    width: 100%;
  }

  .section-artist #artistDisplayBlock,
  .section-artist #studioDisplayBlock,
  .section-artist .studio-showcase-copy {
    display: grid;
    gap: 0;
  }

  .section-artist .artist-panel-actions {
    margin-top: 20px;
  }
}

@media (max-width: 640px) {
  .section-artist .artist-postcard-face,
  .section-artist .artist-flip-face {
    gap: 16px !important;
  }

  .section-artist .artist-postcard-stage,
  .section-artist .studio-gallery-stage,
  .section-artist .artist-image-stage {
    width: 100% !important;
    border-radius: 24px !important;
  }

  .section-artist .artist-panel-actions {
    margin-top: 18px;
  }

  .section-collections .collection-showcase--active {
    grid-template-areas:
      "stage"
      "body"
      "actions";
    row-gap: 14px;
  }

  .section-collections .collection-showcase--active .collection-showcase-copy h3 {
    display: none !important;
  }

  .section-collections .collection-showcase--active .collection-showcase-copy p {
    margin-top: 2px;
  }
}

/* Admin editing mobile/tablet final pass */
body.collection-editor-open,
body.editor-overlay-open,
body.admin-active.media-panel-open {
  overflow: hidden;
  overscroll-behavior: contain;
}

.portfolio-style-manager-list {
  display: grid;
  gap: 12px;
}

.portfolio-style-manager-row {
  display: grid;
  gap: 12px;
  padding: 16px;
  border-radius: 20px;
  border: 1px solid rgba(255,255,255,0.08);
  background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.022));
}

.portfolio-style-manager-head {
  display: grid;
  gap: 10px;
}

.portfolio-style-manager-head input {
  width: 100%;
  min-height: 50px;
  padding: 13px 14px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.04);
  color: var(--text);
  outline: none;
}

.portfolio-style-slug {
  color: rgba(214, 223, 216, 0.76);
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  word-break: break-word;
}

.portfolio-style-row-actions,
.portfolio-style-manager-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.portfolio-style-manager-actions {
  justify-content: flex-end;
}

.portfolio-style-active-toggle {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-height: 40px;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.04);
  color: #f3eee7;
}

.portfolio-style-active-toggle input {
  width: 18px;
  height: 18px;
  accent-color: var(--accent);
}

.portfolio-style-empty {
  padding: 16px;
  border-radius: 18px;
  border: 1px dashed rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.025);
  color: rgba(223, 229, 224, 0.78);
}

@media (max-width: 1024px) {
  body.admin-active .inline-editor,
  body.admin-active .hero-inline-editor,
  body.admin-active .contact-editor.integrated-contact-editor,
  .legal-editor {
    width: 100%;
    max-width: 100%;
    gap: 16px;
    padding: 18px;
    border-radius: 22px;
  }

  body.admin-active .inline-editor label,
  .legal-editor label,
  .portfolio-style-manager-head,
  .collection-editor-fields > label:not(.toggle-control) {
    min-width: 0;
  }

  body.admin-active .inline-editor input,
  body.admin-active .inline-editor textarea,
  .hero-modal-controls input,
  .portfolio-modal-controls input,
  .portfolio-modal-controls textarea,
  .portfolio-modal-controls select,
  .artist-modal-controls input,
  .legal-editor input,
  .legal-editor textarea,
  .portfolio-style-manager-head input {
    font-size: 16px;
  }

  body.admin-active .inline-editor textarea,
  .legal-editor textarea {
    min-height: 140px;
  }

  .contact-editor-head,
  .hours-editor-head {
    display: grid;
    gap: 10px;
  }

  .hero-modal,
  .legal-modal,
  .artist-modal,
  .portfolio-modal,
  .collection-editor-modal {
    padding: 8px !important;
    place-items: stretch !important;
    align-items: stretch !important;
  }

  .hero-modal-card,
  .legal-modal-card,
  .artist-modal-card,
  .portfolio-modal-card,
  .collection-editor-card {
    width: 100% !important;
    max-width: none !important;
    min-height: calc(100dvh - 16px) !important;
    max-height: calc(100dvh - 16px) !important;
    border-radius: 24px !important;
    overflow: hidden !important;
  }

  .hero-modal-card,
  .legal-modal-card,
  .artist-modal-card,
  .portfolio-modal-card {
    display: grid !important;
    grid-template-rows: auto minmax(0, 1fr) !important;
    padding: 0 !important;
  }

  .hero-modal-head,
  .legal-modal-head,
  .artist-modal-head,
  .portfolio-modal-head,
  .collection-editor-head {
    position: sticky;
    top: 0;
    z-index: 5;
    margin-bottom: 0 !important;
    background: linear-gradient(180deg, rgba(10, 14, 12, 0.98), rgba(10, 14, 12, 0.94));
    border-bottom: 1px solid rgba(255,255,255,0.08);
  }

  .hero-modal-head,
  .legal-modal-head,
  .artist-modal-head,
  .portfolio-modal-head {
    padding: 18px 18px 14px !important;
  }

  .hero-modal-body,
  .artist-modal-body,
  .portfolio-modal-body,
  .portfolio-modal-body--styles {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
    min-height: 0;
    overflow: auto;
    padding: 0 18px 18px !important;
    align-content: start;
  }

  .legal-modal-display {
    min-height: 0;
    overflow: auto;
    padding: 0 18px 18px;
  }

  .legal-editor {
    min-height: 0;
    overflow: auto;
    margin: 0 18px 18px !important;
  }

  .hero-crop-preview,
  .artist-crop-preview,
  .portfolio-crop-preview {
    min-height: min(34dvh, 320px) !important;
  }

  .artist-crop-frame,
  .collection-image-crop-frame,
  .hero-crop-frame,
  .portfolio-crop-frame {
    max-width: min(100%, 360px) !important;
  }

  .collection-editor-body {
    min-height: 0;
    overflow: auto;
  }

  .collection-editor-sidebar {
    max-height: min(34dvh, 280px);
  }

  .collection-showcase-stage--editor {
    grid-template-columns: 40px minmax(0, 1fr) 40px;
    gap: 8px;
    align-items: center;
  }

  .collection-editor-preview-wrap .collection-stack-shell {
    width: 100%;
    max-width: min(100%, 320px);
    min-height: clamp(260px, 56vw, 360px);
    margin-inline: auto;
  }

  .collection-editor-preview-wrap .collection-stack--editor {
    width: min(100%, 280px);
    height: clamp(260px, 56vw, 360px);
    margin-inline: auto;
  }

  .collection-stack-title {
    min-height: 52px;
    padding-inline: 14px;
    font-size: 0.88rem;
    text-align: center;
  }

  .artist-modal-actions > *,
  .portfolio-modal-actions > *,
  .collection-editor-meta-actions > *,
  .portfolio-style-manager-actions > * {
    flex: 1 1 180px;
  }
}

@media (max-width: 767px) {
  body.admin-active .inline-editor,
  body.admin-active .hero-inline-editor,
  body.admin-active .contact-editor.integrated-contact-editor,
  .legal-editor {
    padding: 16px;
    border-radius: 20px;
  }

  .inline-editor-actions,
  .portfolio-style-manager-actions,
  .collection-editor-meta-actions {
    position: sticky;
    bottom: 0;
    z-index: 3;
    padding-top: 12px;
    background: linear-gradient(180deg, rgba(10,14,12,0), rgba(10,14,12,0.94) 28%);
  }

  .inline-editor-actions > *,
  .hero-inline-actions > *,
  .artist-modal-actions > *,
  .portfolio-modal-actions > *,
  .collection-editor-meta-actions > *,
  .portfolio-style-manager-actions > *,
  .hero-admin-image-actions > *,
  .section-media-admin-actions > *,
  .studio-media-upload-actions > *,
  .portfolio-media-upload-actions > * {
    width: 100% !important;
    flex: 1 1 100%;
  }

  .section-media-admin.media-panel {
    top: calc(env(safe-area-inset-top, 0px) + var(--admin-bar-height) + 8px) !important;
    bottom: max(8px, env(safe-area-inset-bottom, 0px)) !important;
    left: 8px !important;
    right: 8px !important;
    width: auto !important;
    max-height: none !important;
    padding: 0 !important;
    border-radius: 22px !important;
    overflow: hidden !important;
  }

  .section-media-admin.media-panel .section-media-admin-head {
    position: sticky;
    top: 0;
    z-index: 5;
    margin: 0;
    padding: 14px 14px 12px;
    background: linear-gradient(180deg, rgba(10,14,12,0.98), rgba(10,14,12,0.94));
    border-bottom: 1px solid rgba(255,255,255,0.08);
  }

  .section-media-admin.media-panel > :not(.section-media-admin-head) {
    padding-inline: 14px;
  }

  .section-media-admin.media-panel > .section-media-admin-preview {
    padding-top: 12px;
    min-height: 190px;
  }

  .section-media-admin.media-panel > .portfolio-media-admin-list,
  .section-media-admin.media-panel > .studio-media-admin-list {
    padding-bottom: max(14px, env(safe-area-inset-bottom, 0px));
  }

  .section-media-admin.media-panel .artist-image-btn,
  .section-media-admin.media-panel .admin-mini-btn {
    min-height: 48px;
    justify-content: center;
  }

  .studio-media-admin-list {
    max-height: none !important;
    padding-right: 0 !important;
  }

  .collection-editor-card {
    border-radius: 22px !important;
  }

  .collection-editor-head {
    padding: 16px 14px 14px !important;
  }

  .collection-editor-sidebar,
  .collection-editor-preview-wrap,
  .collection-editor-controls {
    padding-left: 14px !important;
    padding-right: 14px !important;
  }

  .collection-editor-sidebar {
    max-height: min(32dvh, 250px);
  }

  .collection-editor-preview-wrap {
    gap: 12px;
  }

  .collection-manager-item,
  .portfolio-style-manager-row,
  .collection-editor-fields > label:not(.toggle-control) {
    padding: 14px;
    border-radius: 18px;
  }

  .portfolio-media-admin-item,
  .collection-editor-item,
  .collection-editor-list .portfolio-media-admin-item,
  .studio-media-admin-list .portfolio-media-admin-item {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }

  .portfolio-media-admin-thumb {
    width: 100% !important;
    height: clamp(160px, 34vw, 220px) !important;
  }

  .portfolio-media-admin-meta,
  .portfolio-media-admin-actions,
  .collection-manager-item-controls {
    width: 100%;
  }

  .portfolio-media-admin-actions,
  .collection-manager-item-controls,
  .portfolio-style-row-actions {
    justify-content: stretch;
  }

  .portfolio-media-admin-chip {
    flex: 1 1 calc(50% - 8px);
    min-width: 0;
    justify-content: center;
  }

  .portfolio-style-active-toggle {
    width: 100%;
    justify-content: space-between;
  }
}

@media (max-width: 479px) {
  .hero-modal,
  .legal-modal,
  .artist-modal,
  .portfolio-modal,
  .collection-editor-modal {
    padding: 4px !important;
  }

  .hero-modal-card,
  .legal-modal-card,
  .artist-modal-card,
  .portfolio-modal-card,
  .collection-editor-card {
    min-height: calc(100dvh - 8px) !important;
    max-height: calc(100dvh - 8px) !important;
    border-radius: 18px !important;
  }

  .hero-modal-head,
  .legal-modal-head,
  .artist-modal-head,
  .portfolio-modal-head {
    padding: 14px 14px 12px !important;
  }

  .hero-modal-body,
  .artist-modal-body,
  .portfolio-modal-body,
  .portfolio-modal-body--styles {
    padding: 0 14px 14px !important;
  }

  .legal-modal-display {
    padding: 0 14px 14px;
  }

  .legal-editor {
    margin: 0 14px 14px !important;
    padding: 14px;
  }

  .hero-crop-preview,
  .artist-crop-preview,
  .portfolio-crop-preview {
    min-height: 210px !important;
    padding: 10px !important;
  }

  .artist-crop-frame,
  .collection-image-crop-frame,
  .hero-crop-frame,
  .portfolio-crop-frame {
    max-width: min(100%, 300px) !important;
  }

  .collection-editor-sidebar {
    max-height: min(30dvh, 220px);
  }

  .portfolio-media-admin-chip {
    flex-basis: 100%;
  }
}
