.eyebrow { text-transform: uppercase; letter-spacing: .18em; font-size: 11px; color: var(--muted); }
.gold { color: var(--gold); }
.gold-pill { background: rgba(216,188,124,.14); color: var(--gold); border: 1px solid rgba(216,188,124,.24); }
.muted, .muted-light { color: var(--muted); }
.glass, .panel { background: linear-gradient(180deg, rgba(255,255,255,0.07), rgba(255,255,255,0.04)); border: 1px solid var(--border); box-shadow: var(--shadow); backdrop-filter: blur(16px); }
.panel { border-radius: 24px; padding: 20px; }
.black-card-preview, .black-card-large { background: linear-gradient(160deg, #171a1e, #050607 55%, #17120b); border: 1px solid rgba(216,188,124,.24); }
.black-card-preview { min-height: 220px; border-radius: 26px; padding: 22px; display: flex; flex-direction: column; justify-content: space-between; }
.black-card-large { border-radius: 28px; padding: 22px; }
.hero-copy h2 { margin: 10px 0 10px; font-size: clamp(26px, 3vw, 40px); }
.hero-copy p { color: var(--muted); }
.card-chip { width: 48px; height: 36px; border-radius: 10px; background: linear-gradient(160deg, #f2d999, #8d6e3c); }
.card-brand { font-size: 24px; font-weight: 700; letter-spacing: .04em; }
.card-number { color: #f4ead0; letter-spacing: .14em; font-size: 12px; }
.card-footer-row { display: flex; align-items: center; justify-content: space-between; color: #e5dac0; font-size: 13px; }
.field-label { display: block; margin: 14px 0 8px; color: var(--muted); font-size: 13px; }
.input {
  width: 100%;
  border: 1px solid rgba(255,255,255,0.11);
  background: rgba(255,255,255,0.05);
  color: var(--text);
  border-radius: 16px;
  padding: 14px 15px;
  outline: none;
}
.textarea { min-height: 112px; resize: vertical; }
.input::placeholder { color: #8d887d; }
.input:focus { border-color: rgba(216,188,124,.6); box-shadow: 0 0 0 4px rgba(216,188,124,.08); }
.primary-btn, .secondary-btn, .ghost-btn, .nav-btn {
  border: 0;
  cursor: pointer;
  border-radius: 16px;
  padding: 13px 16px;
  transition: .2s ease;
}
.primary-btn { background: linear-gradient(180deg, #e0c98f, #b9924f); color: #15110a; font-weight: 700; }
.secondary-btn { background: rgba(216,188,124,.12); color: var(--gold); border: 1px solid rgba(216,188,124,.24); }
.ghost-btn { background: rgba(255,255,255,.04); color: var(--text); border: 1px solid var(--border); }
.nav-btn { background: rgba(255,255,255,.04); color: var(--muted); }
.nav-btn.active { background: linear-gradient(180deg, rgba(216,188,124,.22), rgba(216,188,124,.08)); color: var(--text); border: 1px solid rgba(216,188,124,.22); }
.primary-btn:hover, .secondary-btn:hover, .ghost-btn:hover, .nav-btn:hover { transform: translateY(-1px); }
.divider { height: 1px; background: rgba(255,255,255,.08); margin: 18px 0; }
.status-list { display: grid; gap: 12px; }
.status-list > div { display: flex; justify-content: space-between; gap: 12px; color: var(--muted); }
.status-list strong { color: var(--text); }
.small-label { display: block; font-size: 12px; text-transform: uppercase; letter-spacing: .14em; color: var(--muted); margin-bottom: 4px; }
.big-mono { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 20px; letter-spacing: .08em; }
.big-text { font-size: 22px; font-weight: 600; }
.pill { display: inline-flex; align-items: center; justify-content: center; min-width: 88px; padding: 8px 12px; border-radius: 999px; font-size: 12px; font-weight: 700; letter-spacing: .08em; }
.qr-wrap { background: white; padding: 10px; border-radius: 16px; }
.metric-card {
  border-radius: 20px;
  padding: 16px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.08);
  display: grid;
  gap: 6px;
}
.metric-card span { color: var(--muted); font-size: 13px; }
.metric-card strong { font-size: 22px; }
.dark-tile { background: rgba(255,255,255,.03); }
.card-list { display: grid; gap: 12px; }
.card-item {
  border-radius: 18px;
  padding: 14px 16px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
}
.card-item h4 { margin: 0 0 8px; }
.card-item p { margin: 0; color: var(--muted); line-height: 1.55; }
.card-item small { display: inline-block; margin-top: 8px; color: var(--muted); }
.table-wrap { overflow: auto; border-radius: 20px; border: 1px solid rgba(255,255,255,.08); }
.table { width: 100%; border-collapse: collapse; min-width: 680px; }
.table th, .table td { padding: 14px 16px; text-align: left; border-bottom: 1px solid rgba(255,255,255,.06); }
.table th { color: var(--muted); font-size: 12px; text-transform: uppercase; letter-spacing: .12em; }
.table td { color: var(--text); }
.toast {
  position: fixed;
  left: 50%;
  transform: translateX(-50%);
  bottom: 94px;
  min-width: 260px;
  max-width: calc(100vw - 32px);
  padding: 14px 16px;
  border-radius: 18px;
  text-align: center;
  box-shadow: var(--shadow);
  z-index: 30;
}
.toast.success { background: rgba(19, 87, 56, .95); color: #eafff5; border: 1px solid rgba(126,217,177,.35); }
.toast.error { background: rgba(97, 34, 34, .96); color: #fff0f0; border: 1px solid rgba(208,109,109,.28); }


.nav-btn, .nav-link-card, .text-link, .brand-link {
  text-decoration: none;
}
.nav-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.brand-link { color: inherit; }
.page-hero {
  display: grid;
  gap: 16px;
}
.page-intro {
  color: var(--muted);
  line-height: 1.6;
  max-width: 840px;
}
.page-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.quick-links {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
}
.nav-link-card {
  border-radius: 18px;
  padding: 16px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  color: var(--text);
  display: grid;
  gap: 8px;
}
.nav-link-card small { color: var(--muted); }
.subnav {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.subnav .nav-btn { min-width: 120px; }
.badge-inline {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border-radius: 999px;
  padding: 8px 12px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.08);
  color: var(--muted);
  font-size: 13px;
}
.content-stack { display: grid; gap: 20px; }
.info-note {
  border-radius: 18px;
  padding: 14px 16px;
  background: rgba(216,188,124,.08);
  border: 1px solid rgba(216,188,124,.18);
  color: #f2e6c8;
}
.panel-title-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin-bottom: 14px;
}
.readonly-note { color: var(--muted); font-size: 13px; }


.content-entry-card h4 { margin-bottom: 8px; }
.content-entry-top { display: flex; justify-content: space-between; gap: 12px; align-items: flex-start; }
.content-entry-top small { color: var(--muted); }

.detail-page-grid { display: grid; grid-template-columns: minmax(0, 1.35fr) minmax(300px, .65fr); gap: 22px; align-items: start; }
.detail-main { display: grid; gap: 18px; }
.detail-hero h2 { margin: 10px 0 10px; font-size: clamp(28px, 4vw, 42px); }
.detail-section + .detail-section { margin-top: 24px; padding-top: 22px; border-top: 1px solid rgba(255,255,255,.08); }
.detail-paragraph { color: var(--text); line-height: 1.75; }
.detail-bullets { margin: 0; padding-left: 18px; display: grid; gap: 10px; color: var(--text); }
.detail-bullets li { line-height: 1.7; }
.text-link { color: var(--gold); font-size: 13px; font-weight: 700; letter-spacing: .04em; }
.detail-link-card { display: block; text-decoration: none; color: inherit; }
.full-btn { width: 100%; }

.danger-btn {
  border: 1px solid rgba(208,109,109,.28);
  background: rgba(97, 34, 34, .24);
  color: #ffd9d9;
  border-radius: 16px;
  padding: 13px 16px;
  cursor: pointer;
  transition: .2s ease;
}
.danger-btn:hover { transform: translateY(-1px); }
.danger-btn:disabled,
.ghost-btn:disabled {
  opacity: .5;
  cursor: not-allowed;
  transform: none;
}
.mt-sm { margin-top: 10px; }

.cms-editor-panel .textarea-sm { min-height: 86px; }
.cms-cover-preview-wrap { display: grid; gap: 8px; }
.cms-cover-preview {
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.04);
  min-height: 160px;
}
.cms-cover-preview img,
.entry-cover,
.detail-cover {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.cms-cover-preview img { min-height: 160px; max-height: 200px; }
.cms-cover-placeholder,
.entry-cover-fallback,
.detail-cover-fallback {
  min-height: 160px;
  display: grid;
  place-items: center;
  color: var(--muted);
  background: linear-gradient(160deg, rgba(216,188,124,.14), rgba(255,255,255,.03));
}
.entry-cover {
  border-radius: 14px;
  height: 180px;
  margin-bottom: 14px;
}
.entry-cover-fallback { border-radius: 14px; height: 180px; margin-bottom: 14px; }
.detail-cover-wrap { margin-bottom: 18px; }
.detail-cover,
.detail-cover-fallback {
  border-radius: 20px;
  overflow: hidden;
  min-height: 220px;
  max-height: 320px;
}

.upload-note {
  border-radius: 14px;
  padding: 10px 12px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  color: var(--muted);
  font-size: 13px;
}
.hidden { display: none !important; }


.content-entry-side {
  display: grid;
  gap: 8px;
  justify-items: end;
}
.photo-badge strong { color: var(--text); }
.gallery-preview-btn {
  padding: 9px 12px;
  border-radius: 12px;
  font-size: 12px;
}
.cms-gallery-preview-wrap {
  display: grid;
  gap: 8px;
}
.cms-gallery-preview-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.gallery-preview-image-wrap {
  position: relative;
}
.gallery-order-chip {
  position: absolute;
  top: 10px;
  left: 10px;
  min-width: 34px;
  height: 34px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  padding: 0 10px;
  background: rgba(8,10,14,.78);
  border: 1px solid rgba(255,255,255,.14);
  color: var(--text);
  font-size: 12px;
  font-weight: 700;
}
.gallery-badge-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.mini-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  min-height: 26px;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.1);
  color: var(--text);
  font-size: 11px;
  font-weight: 600;
}
.mini-badge.gold {
  background: rgba(216,188,124,.14);
  border-color: rgba(216,188,124,.28);
  color: var(--gold);
}
.mini-badge.subtle {
  color: var(--muted);
}
.gallery-preview-card {
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.04);
  display: grid;
  cursor: grab;
  transition: transform .16s ease, border-color .16s ease, box-shadow .16s ease, opacity .16s ease;
}
.gallery-preview-card.dragging {
  opacity: .42;
  transform: scale(.98);
  cursor: grabbing;
}
.gallery-preview-card.drop-target {
  border-color: rgba(216,188,124,.45);
  box-shadow: 0 0 0 3px rgba(216,188,124,.08);
}
.gallery-preview-card img {
  width: 100%;
  height: 120px;
  object-fit: cover;
  display: block;
}
.gallery-preview-meta {
  padding: 12px 12px 4px;
  display: grid;
  gap: 4px;
}
.gallery-preview-meta small {
  color: var(--muted);
  word-break: break-word;
}
.gallery-preview-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 0 12px 12px;
}
.gallery-empty {
  border-radius: 16px;
  border: 1px dashed rgba(255,255,255,.15);
  padding: 16px;
  color: var(--muted);
  background: rgba(255,255,255,.03);
  grid-column: 1 / -1;
}
.detail-gallery-shell {
  display: grid;
  gap: 12px;
}
.detail-thumb-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(78px, 1fr));
  gap: 10px;
}
.detail-thumb,
.detail-gallery-card {
  border: 1px solid rgba(255,255,255,.1);
  background: rgba(255,255,255,.04);
  border-radius: 16px;
  overflow: hidden;
  padding: 0;
  cursor: pointer;
}
.detail-thumb.active,
.detail-gallery-card.active,
.detail-thumb:hover,
.detail-gallery-card:hover {
  border-color: rgba(216,188,124,.45);
  box-shadow: 0 0 0 3px rgba(216,188,124,.08);
}
.detail-thumb img,
.detail-gallery-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.detail-thumb img { height: 76px; }
.detail-gallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 12px;
}
.detail-gallery-card img { height: 130px; }

.detail-main-image-btn {
  position: relative;
  border: 0;
  padding: 0;
  background: transparent;
  cursor: zoom-in;
  border-radius: 20px;
  overflow: hidden;
}
.detail-main-image-btn:hover .detail-cover {
  transform: scale(1.01);
}
.detail-cover {
  transition: transform .18s ease;
}
.detail-zoom-chip {
  position: absolute;
  right: 14px;
  bottom: 14px;
  border-radius: 999px;
  padding: 8px 12px;
  background: rgba(8,10,14,.72);
  border: 1px solid rgba(255,255,255,.14);
  color: #f6f3ea;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .04em;
}
.detail-lightbox {
  position: fixed;
  inset: 0;
  z-index: 200;
  display: grid;
  place-items: center;
}
.detail-lightbox-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.82);
  backdrop-filter: blur(6px);
}
.detail-lightbox-dialog {
  position: relative;
  width: min(96vw, 1200px);
  height: min(92vh, 900px);
  display: grid;
  grid-template-columns: 60px minmax(0, 1fr) 60px;
  align-items: center;
  gap: 12px;
  z-index: 1;
}
.detail-lightbox-stage {
  position: relative;
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
  border-radius: 20px;
  overflow: hidden;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
}
.detail-lightbox-image {
  max-width: 100%;
  max-height: 100%;
  object-fit: cover;
  display: block;
}
.detail-lightbox-close,
.detail-lightbox-nav {
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(8,10,14,.62);
  color: #fff;
  width: 48px;
  height: 48px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  cursor: pointer;
  font-size: 28px;
}
.detail-lightbox-close {
  position: absolute;
  top: 16px;
  right: 16px;
  z-index: 2;
}
.detail-lightbox-caption {
  position: absolute;
  left: 50%;
  bottom: 16px;
  transform: translateX(-50%);
  border-radius: 999px;
  padding: 8px 12px;
  background: rgba(8,10,14,.72);
  border: 1px solid rgba(255,255,255,.12);
  color: #fff;
  font-size: 13px;
}
body.lightbox-open {
  overflow: hidden;
}


.card-showcase {
  display: grid;
  gap: 14px;
}

.card-action-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}


.elite-card-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.segmented-switch {
  display: inline-flex;
  gap: 8px;
  padding: 6px;
  border-radius: 999px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
}

.compact-btn {
  padding: 10px 14px;
  border-radius: 999px;
  min-width: 86px;
}

.compact-btn.active {
  background: linear-gradient(180deg, rgba(216,188,124,.26), rgba(216,188,124,.10));
  color: var(--text);
  border: 1px solid rgba(216,188,124,.28);
  box-shadow: 0 10px 24px rgba(216,188,124,.12), inset 0 1px 0 rgba(255,255,255,.06);
}

.elite-card-scene {
  --tilt-x: 0deg;
  --tilt-y: 0deg;
  position: relative;
  width: 100%;
  aspect-ratio: 525 / 318;
  border-radius: 28px;
  perspective: 2400px;
  cursor: pointer;
  touch-action: none;
  -webkit-tap-highlight-color: transparent;
  transform: translateY(0) rotateX(var(--tilt-x)) rotateY(var(--tilt-y));
  transition: transform .35s ease, filter .35s ease;
  will-change: transform;
  isolation: isolate;
}

.elite-card-scene.large {
  max-width: 675px;
}

.elite-card-scene:hover,
.elite-card-scene:focus-visible {
  transform: translateY(-3px) rotateX(var(--tilt-x)) rotateY(var(--tilt-y));
  filter: drop-shadow(0 22px 42px rgba(0,0,0,.34));
}

.elite-card-scene::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 28px;
  background:
    radial-gradient(circle at top right, rgba(255,240,188,.10), transparent 22%),
    linear-gradient(120deg, transparent 10%, rgba(255,255,255,.07) 48%, transparent 78%);
  opacity: .75;
  pointer-events: none;
  mix-blend-mode: screen;
}

.elite-card-scene::after {
  content: '';
  position: absolute;
  inset: 7% 4% -2% 4%;
  border-radius: 32px;
  background: radial-gradient(circle at center, rgba(216,188,124,.18), rgba(0,0,0,0) 66%);
  filter: blur(24px);
  opacity: .85;
  pointer-events: none;
  z-index: -1;
}

.elite-card-flipper {
  position: relative;
  width: 100%;
  height: 100%;
  transform-style: preserve-3d;
  -webkit-transform-style: preserve-3d;
  transition: transform .95s cubic-bezier(.22, 1, .36, 1);
}

.elite-card-scene.is-flipped .elite-card-flipper {
  transform: rotateY(180deg);
}

.elite-card-face {
  position: absolute;
  inset: 0;
  border-radius: 28px;
  overflow: hidden;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  transform-style: preserve-3d;
  -webkit-transform-style: preserve-3d;
  background: transparent;
  display: grid;
  place-items: center;
  transition: opacity .45s ease;
}

.elite-card-face img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  user-select: none;
  -webkit-user-drag: none;
  filter: none;
}

.elite-card-front {
  transform: rotateY(0deg) translateZ(1px);
  opacity: 1;
}

.elite-card-back {
  transform: rotateY(180deg) translateZ(1px);
  opacity: 0;
}

.elite-card-scene.is-flipped .elite-card-front {
  opacity: 0;
}

.elite-card-scene.is-flipped .elite-card-back {
  opacity: 1;
}

.elite-card-back-badge {
  position: absolute;
  top: 10.8%;
  right: 6%;
  width: auto;
  min-width: 0;
  max-width: 20%;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: 0;
  box-shadow: none;
  backdrop-filter: none;
}

.elite-card-back-badge span {
  color: #f4e0a6;
  font-weight: 700;
  font-size: clamp(11px, 1.35vw, 14px);
  letter-spacing: .16em;
  text-transform: uppercase;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  text-shadow: 0 1px 6px rgba(0, 0, 0, 0.35);
}

@media (max-width: 640px) {
  .elite-card-back-badge {
    top: 11.2%;
    right: 5.2%;
    max-width: 22%;
  }

  .elite-card-back-badge span {
    font-size: clamp(10px, 1.8vw, 12px);
    letter-spacing: .12em;
  }
}

.resident-card-panel {
  background: linear-gradient(180deg, rgba(255,255,255,0.07), rgba(255,255,255,0.04));
}

.resident-card-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(320px, .8fr);
  gap: 24px;
  align-items: start;
}

.resident-card-summary {
  display: grid;
  gap: 12px;
}

.member-key-grid,
.member-stats-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.member-strong-code {
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 18px;
  letter-spacing: .08em;
}

.member-qr-panel {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 18px;
  border-radius: 22px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
}

@media (max-width: 980px) {
  .resident-card-hero {
    grid-template-columns: 1fr;
  }

  .elite-card-scene.large {
    max-width: none;
  }
}

@media (max-width: 640px) {
  .member-key-grid,
  .member-stats-grid {
    grid-template-columns: 1fr;
  }

  .member-qr-panel {
    flex-direction: column;
    align-items: flex-start;
  }

  .compact-btn {
    min-width: 72px;
    padding: 9px 12px;
  }

  .card-action-row {
    grid-template-columns: 1fr;
  }

  .elite-card-face,
  .elite-card-scene,
  .elite-card-scene::before,
  .elite-card-scene::after {
    border-radius: 20px;
  }
}

.customer-shell .page-actions .badge-inline span:not(:first-child) { display: inline; }
.customer-topbar { margin-bottom: 14px; }
.compact-actions { gap: 10px; }
.home-member-bar { display:flex; align-items:flex-start; justify-content:space-between; gap:18px; flex-wrap:wrap; }
.member-mini-stats { display:grid; grid-template-columns:repeat(2,minmax(140px,1fr)); gap:12px; }
.mini-stat { border:1px solid rgba(216,188,124,.18); background:rgba(255,255,255,.04); border-radius:18px; padding:14px 16px; }
.mini-stat span { display:block; font-size:12px; color:var(--muted); margin-bottom:6px; }
.mini-stat strong { font-size:18px; color:#f4ead0; }
.home-card-strip { display:grid; grid-template-columns: 1fr minmax(260px, 420px); align-items:center; gap:18px; }
.hero-card-link { display:block; border-radius:28px; overflow:hidden; box-shadow:var(--shadow); border:1px solid rgba(216,188,124,.22); }
.hero-card-image { display:block; width:100%; height:auto; }
.customer-nav { gap: 8px; padding: 10px 12px; }
.customer-nav > * { flex: 1 1 0; min-width: 0; }
.customer-nav .nav-btn { text-align:center; padding:14px 10px; font-size:14px; }
.settings-list { display:grid; gap:14px; }
.settings-item { display:flex; align-items:center; gap:16px; padding:18px; border-radius:22px; background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); color:var(--text); text-decoration:none; text-align:left; }
.settings-item.button-like { width:100%; border:none; cursor:pointer; }
.settings-item strong { display:block; margin-bottom:4px; }
.settings-item small { color:var(--muted); }
.settings-icon { width:48px; height:48px; border-radius:16px; display:grid; place-items:center; background:rgba(216,188,124,.14); color:var(--gold); font-size:22px; flex:none; }
.reward-list { display:grid; gap:16px; }
.reward-card { display:grid; grid-template-columns: 120px minmax(0,1fr) 160px; align-items:center; gap:16px; padding:16px; }
.reward-thumb { width:120px; height:120px; border-radius:20px; overflow:hidden; background:rgba(255,255,255,.05); }
.reward-thumb img { width:100%; height:100%; object-fit:cover; display:block; }
.reward-thumb-placeholder { width:100%; height:100%; display:grid; place-items:center; color:var(--muted); }
.reward-info h3 { margin:6px 0 6px; }
.reward-info p { color:var(--muted); margin:0 0 8px; }
.reward-meta { color:var(--gold); font-weight:700; }
.reward-action { display:flex; justify-content:flex-end; }
.member-links-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:12px; }
.member-page-panel .resident-card-hero { grid-template-columns: 1.15fr .85fr; }

/* Vault-inspired customer UI */
.vault-shell {
  max-width: 460px;
  padding: 0 0 112px;
  background: #000;
  min-height: 100vh;
}
.vault-header { margin-bottom: 0; }
.vault-brand-bar {
  background: linear-gradient(180deg, #950013, #9f0014);
  color: #fff;
  padding: 16px 18px 18px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.vault-app-name {
  font-size: 11px;
  letter-spacing: .22em;
  color: rgba(255,255,255,.78);
  text-transform: uppercase;
}
.vault-app-subtitle {
  font-size: 24px;
  font-weight: 700;
  letter-spacing: .01em;
  margin-top: 4px;
}
.vault-logout { background: rgba(255,255,255,.1); border-color: rgba(255,255,255,.16); }
.vault-profile-strip {
  background: #050505;
  padding: 16px 18px;
  display: grid;
  grid-template-columns: 64px 1fr auto;
  align-items: center;
  gap: 14px;
}
.vault-avatar {
  width: 64px;
  height: 64px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: linear-gradient(180deg, #3b3b3b, #1d1d1d);
  border: 2px solid rgba(255,255,255,.15);
  color: #fff;
  font-size: 26px;
  font-weight: 700;
}
.vault-profile-name { font-size: 20px; font-weight: 700; color: #fff; line-height: 1.1; }
.vault-profile-meta { font-size: 12px; color: rgba(255,255,255,.65); margin-top: 4px; }
.vault-points-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #fff;
  font-weight: 700;
  font-size: 15px;
}
.vault-points-pill strong { font-size: 18px; color: #fff; }
.vault-points-pill span {
  width: 46px;
  height: 46px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: #fff;
  color: #000;
  font-size: 24px;
  line-height: 1;
}
.vault-points-pill.small-pill strong { font-size: 16px; }
.vault-points-pill.small-pill span { width: 38px; height: 38px; font-size: 20px; }
.vault-main-content {
  gap: 0;
  background: #000;
  padding-bottom: 12px;
}
.vault-section-title {
  background: linear-gradient(180deg, #950013, #9f0014);
  color: #fff;
  font-size: 28px;
  line-height: 1;
  padding: 18px 14px 14px;
  font-weight: 500;
  text-transform: uppercase;
}
.vault-section-title.light {
  background: transparent;
  color: #fff;
  font-size: 18px;
  padding: 16px 14px 10px;
  text-transform: none;
}
.vault-section-split { background: #000; }
.vault-news-hero {
  padding: 0;
  background: #000;
  border: 0;
  border-radius: 0;
  overflow: hidden;
  box-shadow: none;
}
.vault-news-hero-link { color: inherit; text-decoration: none; display: block; }
.vault-news-image-wrap { background: #141414; }
.vault-news-image,
.vault-news-fallback {
  width: 100%;
  height: 360px;
  object-fit: cover;
  display: block;
}
.vault-news-fallback {
  display: grid;
  place-items: center;
  color: rgba(255,255,255,.8);
  background: linear-gradient(160deg, #133f3e, #bccdc2);
}
.vault-news-copy {
  padding: 16px 14px 18px;
  background: #000;
  color: #fff;
}
.vault-news-kicker { color: rgba(255,255,255,.55); font-size: 12px; letter-spacing: .12em; text-transform: uppercase; margin-bottom: 8px; }
.vault-news-copy h2 { margin: 0 0 8px; font-size: 28px; line-height: 1.05; }
.vault-news-copy p { margin: 0; color: rgba(255,255,255,.78); line-height: 1.55; }
.vault-promo-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 3px;
  padding: 0 0 12px;
  background: #000;
}
.vault-promo-card {
  text-decoration: none;
  color: inherit;
  background: #fff;
}
.vault-promo-thumb-wrap { background: #ddd; }
.vault-promo-thumb {
  width: 100%;
  height: 148px;
  object-fit: cover;
  display: block;
}
.vault-promo-copy {
  display: grid;
  gap: 4px;
  padding: 10px;
  background: #fff;
  min-height: 94px;
}
.vault-promo-copy strong { color: #101010; font-size: 15px; line-height: 1.25; }
.vault-promo-copy span { color: #6a6a6a; font-size: 12px; line-height: 1.4; }
.vault-shortcuts-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  padding: 0 14px 16px;
  background: #000;
}
.vault-shortcut-card {
  display: flex;
  gap: 12px;
  align-items: center;
  text-decoration: none;
  color: #fff;
  background: #101010;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 18px;
  padding: 14px;
}
.vault-shortcut-icon {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 14px;
  background: rgba(255,255,255,.08);
  font-size: 20px;
}
.vault-shortcut-card strong { display: block; font-size: 15px; }
.vault-shortcut-card small { color: rgba(255,255,255,.6); display: block; margin-top: 3px; line-height: 1.4; }
.vault-bottom-nav {
  background: #f1f1f1;
  border-top: 1px solid rgba(0,0,0,.08);
  padding: 8px 8px 10px;
  gap: 0;
}
.vault-bottom-nav .nav-btn {
  background: transparent;
  border: 0;
  color: #9a9a9a;
  border-radius: 16px;
  display: grid;
  gap: 4px;
  place-items: center;
  padding: 8px 4px;
}
.vault-bottom-nav .nav-btn.active {
  background: transparent;
  border: 0;
  color: #b50117;
}
.nav-ico { font-size: 22px; line-height: 1; }
.nav-label { font-size: 12px; font-weight: 500; }
.vault-tabs-panel {
  background: #000;
  padding: 0 0 8px;
}
.vault-reward-tabs {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0;
  background: #930013;
}
.vault-reward-tab {
  border: 0;
  background: transparent;
  color: rgba(255,255,255,.52);
  padding: 14px 6px;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .03em;
}
.vault-reward-tab.active { color: #fff; }
.vault-reward-group {
  padding: 0;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  background: #000;
}
.panel-white { background: #000; }
.vault-reward-group-title {
  background: #050505;
  color: #fff;
  font-size: 22px;
  padding: 16px 14px;
  border-top: 1px solid rgba(255,255,255,.06);
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.vault-reward-list {
  gap: 14px;
  padding: 12px 0 18px;
}
.vault-reward-card {
  display: grid;
  grid-template-columns: 110px minmax(0, 1fr) 124px;
  gap: 14px;
  align-items: center;
  background: #efefef;
  border-radius: 0;
  padding: 14px;
  border: 0;
}
.vault-reward-thumb,
.vault-reward-thumb img { border-radius: 0; }
.vault-reward-thumb { width: 110px; height: 110px; }
.vault-reward-info h3 {
  font-size: 17px;
  line-height: 1.3;
  margin: 0 0 16px;
  color: #161616;
  font-weight: 500;
}
.vault-points-text {
  color: #8f0012;
  font-size: 18px;
  font-weight: 500;
}
.vault-reward-action { justify-content: flex-end; }
.vault-redeem-btn {
  min-width: 116px;
  border-radius: 999px;
  padding: 15px 16px;
  border: 0;
  font-size: 16px;
  cursor: pointer;
  background: #bcc0c6;
  color: #fff;
}
.vault-redeem-btn.ready { background: #bfc3c9; }
.vault-redeem-btn.disabled { opacity: .85; }
.vault-settings-list {
  background: #000;
  display: grid;
  gap: 2px;
  padding: 16px 0 12px;
}
.vault-settings-item {
  display: flex;
  align-items: center;
  gap: 18px;
  padding: 16px 18px;
  text-decoration: none;
  color: #fff;
  background: transparent;
  border: 0;
  text-align: left;
}
.vault-settings-item.button-like { width: 100%; cursor: pointer; }
.vault-settings-icon {
  width: 44px;
  height: 44px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  color: #fff;
  flex: none;
}
.vault-settings-icon svg {
  width: 34px;
  height: 34px;
  display: block;
}
.vault-settings-item span:last-child { font-size: 18px; }

@media (max-width: 640px) {
  .vault-news-image, .vault-news-fallback { height: 300px; }
  .vault-reward-card {
    grid-template-columns: 88px minmax(0, 1fr);
    align-items: start;
  }
  .vault-reward-thumb { width: 88px; height: 88px; }
  .vault-reward-action { grid-column: 1 / -1; justify-content: flex-end; }
  .vault-redeem-btn { min-width: 128px; }
  .vault-promo-thumb { height: 116px; }
  .vault-promo-copy { min-height: 88px; }
}
.nav-ico svg { width: 24px; height: 24px; display: block; }


/* Vault refinement pass */
.vault-shell {
  max-width: 430px;
  padding-bottom: 104px;
  box-shadow: 0 0 0 1px rgba(255,255,255,.05);
}
.vault-brand-bar {
  padding: 12px 16px 14px;
  min-height: 72px;
}
.vault-app-name {
  font-size: 10px;
  letter-spacing: .24em;
}
.vault-app-subtitle {
  font-size: 16px;
  font-weight: 700;
  margin-top: 6px;
}
.vault-profile-strip {
  padding: 14px 16px;
  grid-template-columns: 54px 1fr auto;
  gap: 12px;
}
.vault-avatar {
  width: 54px;
  height: 54px;
  font-size: 22px;
}
.vault-profile-name {
  font-size: 18px;
  font-weight: 600;
}
.vault-profile-meta {
  font-size: 11px;
  margin-top: 2px;
}
.vault-points-pill strong {
  font-size: 32px;
  font-weight: 500;
  line-height: 1;
}
.vault-points-pill span {
  width: 48px;
  height: 48px;
  font-size: 26px;
  font-weight: 800;
}
.vault-main-content {
  padding-bottom: 18px;
}
.vault-section-title {
  background: #9d0015;
  color: #fff;
  font-size: 19px;
  line-height: 1;
  padding: 12px 14px 13px;
  font-weight: 500;
  text-transform: none;
  letter-spacing: 0;
}
.vault-section-split {
  background: #000;
}
.vault-news-hero {
  padding: 0;
  border-top: 4px solid #000;
  border-bottom: 4px solid #000;
}
.vault-news-frame {
  background: #dde7de;
}
.vault-news-image,
.vault-news-fallback {
  height: 420px;
}
.vault-promo-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 4px;
  padding: 0 0 14px;
}
.vault-promo-card.image-only {
  background: #000;
}
.vault-promo-card.image-only .vault-promo-thumb {
  height: 144px;
}
.vault-promo-card.image-only .vault-promo-thumb-wrap {
  background: #111;
}
.vault-bottom-nav {
  padding: 7px 6px 10px;
}
.vault-bottom-nav .nav-btn {
  padding: 7px 2px;
  gap: 5px;
}
.nav-ico svg {
  width: 25px;
  height: 25px;
}
.nav-label {
  font-size: 11px;
  font-weight: 500;
}
.vault-tabs-panel {
  padding: 0;
}
.vault-reward-tabs {
  border-top: 4px solid #000;
  background: #970013;
}
.vault-reward-tab {
  padding: 12px 6px 11px;
  font-size: 11px;
  letter-spacing: .01em;
}
.vault-reward-group-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 18px;
  padding: 14px;
}
.vault-reward-group-title span {
  color: rgba(255,255,255,.85);
  font-size: 20px;
  line-height: 1;
}
.vault-reward-list {
  gap: 8px;
  padding: 8px 0 14px;
}
.vault-reward-card {
  grid-template-columns: 76px minmax(0,1fr) 104px;
  gap: 12px;
  padding: 10px 12px;
  background: #efefef;
  min-height: 92px;
}
.vault-reward-thumb { width: 76px; height: 76px; }
.vault-reward-info h3 {
  font-size: 14px;
  line-height: 1.3;
  margin: 0 0 8px;
}
.vault-points-text {
  font-size: 14px;
  font-weight: 600;
}
.vault-redeem-btn {
  min-width: 96px;
  padding: 12px 12px;
  background: #b9bcc4;
  color: #fff;
  font-size: 14px;
  font-weight: 600;
}
.vault-settings-list {
  padding: 16px 0 14px;
  gap: 6px;
}
.vault-settings-item {
  gap: 18px;
  padding: 15px 18px;
}
.vault-settings-icon {
  width: 48px;
  height: 48px;
  border-radius: 0;
}
.vault-settings-icon svg {
  width: 36px;
  height: 36px;
}
.vault-settings-item span:last-child {
  font-size: 17px;
  letter-spacing: .01em;
}
@media (max-width: 640px) {
  .vault-news-image, .vault-news-fallback { height: 330px; }
  .vault-promo-card.image-only .vault-promo-thumb { height: 118px; }
  .vault-reward-card {
    grid-template-columns: 68px minmax(0,1fr) 92px;
    gap: 10px;
    padding: 10px;
  }
  .vault-reward-thumb { width: 68px; height: 68px; }
  .vault-reward-action { grid-column: auto; justify-content: flex-end; }
  .vault-redeem-btn { min-width: 88px; padding: 11px 10px; font-size: 13px; }
}


/* Top white app bar refinement */
.vault-header-with-appbar {
  position: sticky;
  top: 0;
  z-index: 18;
  background: #000;
}
.vault-appbar-top {
  height: 78px;
  background: #f5f5f5;
  color: #111;
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  padding: calc(env(safe-area-inset-top, 0px) + 10px) 14px 12px;
  box-shadow: 0 1px 0 rgba(0,0,0,.08);
}
.vault-appbar-copy {
  min-width: 0;
  display: grid;
  gap: 2px;
}
.vault-appbar-title {
  font-size: 18px;
  line-height: 1.15;
  font-weight: 700;
  color: #131313;
}
.vault-appbar-subtitle {
  font-size: 11px;
  line-height: 1.2;
  color: #9b9b9b;
}
.vault-appbar-actions {
  display: inline-flex;
  align-items: center;
  gap: 2px;
}
.vault-appbar-icon {
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  background: transparent;
  border: 0;
  border-radius: 999px;
  color: #171717;
  padding: 0;
  text-decoration: none;
}
.vault-appbar-icon svg {
  width: 22px;
  height: 22px;
  display: block;
}
.vault-brand-banner {
  min-height: 58px;
  padding: 8px 14px;
  background: linear-gradient(180deg, #8f0012, #ad0018);
  display: flex;
  align-items: center;
  justify-content: flex-end;
  border-bottom: 1px solid rgba(0,0,0,.3);
}
.vault-brand-banner-logo {
  color: #fff;
  font-size: 20px;
  line-height: 1;
  letter-spacing: .06em;
  font-weight: 700;
  text-transform: uppercase;
}
.vault-brand-bar,
.vault-app-name,
.vault-app-subtitle,
.vault-logout {
  display: none !important;
}
.vault-profile-strip {
  padding-top: 16px;
}
.vault-member-panel {
  margin: 0 12px 0;
  border-radius: 0 0 24px 24px;
}
.vault-member-panel .resident-card-hero {
  grid-template-columns: 1fr;
}
.vault-member-panel .elite-card-toolbar {
  padding-top: 0;
}
@media (max-width: 520px) {
  .vault-appbar-top {
    height: 72px;
    grid-template-columns: 38px minmax(0, 1fr) auto;
    gap: 10px;
    padding-left: 12px;
    padding-right: 10px;
  }
  .vault-appbar-title {
    font-size: 16px;
  }
  .vault-brand-banner {
    min-height: 52px;
    padding: 7px 12px;
  }
  .vault-brand-banner-logo {
    font-size: 18px;
  }
}


/* ===== Admin Dashboard Tabs + Members patch merged ===== */
/* Admin single-page content manager patch */
.admin-cms-panel { display: grid; gap: 16px; }
.admin-cms-head { align-items: center; }
.admin-tabbar {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.admin-tab-btn {
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  color: var(--muted);
  border-radius: 999px;
  padding: 11px 16px;
  cursor: pointer;
  transition: .2s ease;
}
.admin-tab-btn.active {
  background: linear-gradient(180deg, rgba(216,188,124,.22), rgba(216,188,124,.10));
  color: var(--text);
  border-color: rgba(216,188,124,.28);
}
.admin-content-layout {
  display: grid;
  grid-template-columns: minmax(280px, .82fr) minmax(0, 1.18fr);
  gap: 18px;
  align-items: start;
}
.admin-side-list {
  position: sticky;
  top: 88px;
  max-height: calc(100vh - 130px);
  overflow: auto;
}
.admin-content-list {
  display: grid;
  gap: 12px;
}
.content-admin-card {
  display: grid;
  grid-template-columns: 96px minmax(0,1fr);
  gap: 12px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.04);
  padding: 12px;
}
.content-admin-card.active {
  border-color: rgba(216,188,124,.28);
  box-shadow: 0 0 0 1px rgba(216,188,124,.08);
}
.content-admin-card-image {
  width: 96px;
  height: 96px;
  border-radius: 14px;
  object-fit: cover;
  display: block;
}
.content-admin-card-image.fallback {
  display: grid;
  place-items: center;
  background: rgba(255,255,255,.05);
  color: var(--muted);
}
.content-admin-card-body {
  min-width: 0;
  display: grid;
  gap: 8px;
}
.content-admin-card-top {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: flex-start;
}
.content-admin-card-top strong { display: block; }
.content-admin-card-top small { color: var(--muted); white-space: nowrap; }
.content-admin-card-body p {
  margin: 0;
  color: var(--muted);
  line-height: 1.55;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.content-admin-card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.content-admin-card-actions .ghost-btn {
  padding: 10px 12px;
  text-decoration: none;
}
.admin-editor-panel {
  display: grid;
  gap: 14px;
}
.admin-editor-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 16px;
}
.compact-row { margin-bottom: 10px; }
.admin-gallery-list { margin-top: 12px; }
.gallery-empty {
  border-radius: 16px;
  border: 1px dashed rgba(255,255,255,.12);
  color: var(--muted);
  padding: 18px;
  text-align: center;
}
@media (max-width: 980px) {
  .admin-content-layout {
    grid-template-columns: 1fr;
  }
  .admin-side-list {
    position: static;
    max-height: none;
  }
}
@media (max-width: 700px) {
  .admin-editor-grid,
  .content-admin-card {
    grid-template-columns: 1fr;
  }
  .content-admin-card-image { width: 100%; height: 180px; }
}


/* Admin members tab patch */
.member-grid-4 {
  grid-template-columns: repeat(4, minmax(0,1fr));
}
.member-admin-card-topline {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
}
.member-admin-card-topline .mini-badge {
  white-space: nowrap;
}
.member-admin-meta {
  display: grid;
  gap: 4px;
  color: var(--muted);
  font-size: .92rem;
}
.member-admin-meta strong {
  color: var(--text);
  font-size: 1rem;
}
.member-admin-meta small {
  color: var(--muted);
}
@media (max-width: 980px) {
  .member-grid-4 {
    grid-template-columns: repeat(2, minmax(0,1fr));
  }
}
@media (max-width: 700px) {
  .member-grid-4 {
    grid-template-columns: 1fr;
  }
}


/* Member luxury detail card */
.member-luxury-card {
  margin-top: 22px;
  padding: 22px;
  border-radius: 24px;
  border: 1px solid rgba(255,255,255,.08);
  background:
    radial-gradient(circle at top right, rgba(214,175,74,.16), transparent 30%),
    linear-gradient(145deg, rgba(11,16,27,.98), rgba(17,23,37,.94));
  box-shadow: 0 24px 70px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.05);
}
.member-luxury-hero {
  display: flex;
  align-items: center;
  gap: 18px;
  padding-bottom: 18px;
  margin-bottom: 18px;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.member-luxury-avatar {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-size: 1.55rem;
  font-weight: 800;
  letter-spacing: .04em;
  color: #f8ebc1;
  background:
    radial-gradient(circle at 30% 30%, rgba(236,209,120,.28), rgba(236,209,120,.08) 40%, rgba(255,255,255,.03) 75%),
    linear-gradient(145deg, rgba(71,54,16,.95), rgba(19,15,9,.98));
  border: 1px solid rgba(227,190,87,.35);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08), 0 12px 24px rgba(0,0,0,.28);
}
.member-luxury-copy {
  display: grid;
  gap: 8px;
  min-width: 0;
}
.member-luxury-copy h5 {
  margin: 0;
  font-size: 1.35rem;
}
.member-luxury-code {
  color: rgba(255,255,255,.7);
  font-size: .95rem;
  letter-spacing: .08em;
}
.member-luxury-tags {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.member-detail-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 12px;
}
.member-detail-item,
.member-point-card,
.member-redemption-item {
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
}
.member-detail-item {
  padding: 14px 14px 16px;
  display: grid;
  gap: 6px;
}
.member-detail-item span {
  color: var(--muted);
  font-size: .8rem;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.member-detail-item strong {
  font-size: 1rem;
  line-height: 1.35;
  word-break: break-word;
}
.member-insights-grid {
  margin-top: 18px;
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 18px;
}
.member-insight-panel {
  padding: 18px;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(6,10,17,.42);
}
.member-point-summary {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 12px;
  margin-top: 12px;
}
.member-point-card {
  padding: 16px;
  display: grid;
  gap: 8px;
}
.member-point-card span {
  color: var(--muted);
  font-size: .82rem;
}
.member-point-card strong {
  font-size: 1.4rem;
  color: #f3d988;
  letter-spacing: .02em;
}
.member-redemption-list {
  display: grid;
  gap: 10px;
  margin-top: 12px;
}
.member-redemption-item {
  padding: 14px;
  display: grid;
  gap: 8px;
}
.member-redemption-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.member-redemption-title {
  font-weight: 700;
}
.member-redemption-meta {
  color: var(--muted);
  font-size: .86rem;
}
.member-redemption-foot {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  flex-wrap: wrap;
  color: var(--muted);
  font-size: .82rem;
}
.member-redemption-empty {
  padding: 18px;
  border-radius: 18px;
  border: 1px dashed rgba(255,255,255,.12);
  color: var(--muted);
  text-align: center;
}
@media (max-width: 980px) {
  .member-detail-grid {
    grid-template-columns: repeat(2, minmax(0,1fr));
  }
  .member-insights-grid {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 700px) {
  .member-luxury-card {
    padding: 18px;
    border-radius: 20px;
  }
  .member-luxury-hero {
    align-items: flex-start;
  }
  .member-detail-grid,
  .member-point-summary {
    grid-template-columns: 1fr;
  }
}


.member-qr-panel {
  margin-top: 18px;
  padding: 18px;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.08);
  background:
    radial-gradient(circle at top right, rgba(227,190,87,.12), transparent 38%),
    rgba(6,10,17,.42);
}
.member-qr-layout {
  display: grid;
  grid-template-columns: 164px 1fr;
  gap: 18px;
  align-items: center;
  margin-top: 12px;
}
.member-qr-canvas-wrap {
  width: 164px;
  height: 164px;
  padding: 12px;
  border-radius: 22px;
  background: linear-gradient(145deg, rgba(255,255,255,.1), rgba(255,255,255,.03));
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06), 0 10px 24px rgba(0,0,0,.22);
  display: grid;
  place-items: center;
}
.member-qr-canvas-wrap canvas {
  width: 140px;
  height: 140px;
  background: #fff;
  border-radius: 14px;
}
.member-qr-copy {
  display: grid;
  gap: 10px;
}
.member-qr-code {
  font-size: 1.05rem;
  letter-spacing: .08em;
  color: #f5df95;
  font-weight: 700;
  word-break: break-all;
}
.member-qr-note {
  margin: 0;
  color: var(--muted);
  line-height: 1.6;
}
@media (max-width: 700px) {
  .member-qr-layout {
    grid-template-columns: 1fr;
  }
  .member-qr-canvas-wrap {
    margin: 0 auto;
  }
}


.member-qr-meta {
  display: grid;
  gap: 4px;
  min-width: 0;
}
.member-qr-panel {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 16px;
  align-items: center;
}
@media (max-width: 640px) {
  .member-qr-panel {
    grid-template-columns: 1fr;
    justify-items: start;
  }
}


.vault-auth-chip {
  min-height: 36px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.12);
  background: #ffffff;
  color: #111111;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .01em;
}

.vault-auth-chip-logout {
  background: #111111;
  color: #ffffff;
  border-color: #111111;
}

.resident-login-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(320px, .9fr);
  gap: 20px;
}

.resident-login-panel {
  align-self: stretch;
}

@media (max-width: 900px) {
  .resident-login-hero {
    grid-template-columns: 1fr;
  }
}


.resident-login-shell {
  position: relative;
}

.resident-login-topbar {
  align-items: start;
}

.resident-login-copy {
  display: grid;
  gap: 16px;
}

.resident-session-flash {
  border-radius: 18px;
  padding: 13px 16px;
  background: linear-gradient(180deg, rgba(216,188,124,.16), rgba(216,188,124,.08));
  border: 1px solid rgba(216,188,124,.24);
  color: #f5e8c8;
  font-weight: 600;
}

.resident-session-card {
  border-radius: 28px;
  padding: 22px;
  background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.03));
  border: 1px solid rgba(216,188,124,.18);
  box-shadow: 0 18px 60px rgba(0,0,0,.28);
  display: grid;
  gap: 18px;
}

.resident-session-card-empty {
  border-style: dashed;
  border-color: rgba(255,255,255,.14);
}

.resident-session-head {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 16px;
}

.resident-session-head h3,
.resident-reset-head h4,
.resident-login-panel-head h3 {
  margin: 8px 0 6px;
}

.resident-session-dot {
  width: 14px;
  height: 14px;
  border-radius: 999px;
  background: radial-gradient(circle at 35% 35%, #d2ffd6 0%, #6cf59d 42%, #12914b 100%);
  box-shadow: 0 0 0 6px rgba(108,245,157,.14);
  flex: 0 0 auto;
  margin-top: 10px;
}

.resident-session-dot.idle {
  background: radial-gradient(circle at 35% 35%, #fff6d1 0%, #d4a954 42%, #8b6b31 100%);
  box-shadow: 0 0 0 6px rgba(216,188,124,.14);
}

.resident-session-grid,
.resident-login-security-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.resident-checklist {
  display: grid;
  gap: 12px;
}

.resident-check-item {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  border-radius: 18px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
}

.resident-check-item span {
  width: 42px;
  height: 42px;
  border-radius: 14px;
  display: inline-grid;
  place-items: center;
  background: rgba(216,188,124,.14);
  color: var(--gold);
  font-size: 12px;
  letter-spacing: .12em;
  font-weight: 700;
}

.resident-login-panel {
  border-radius: 30px;
  padding: 24px;
}

.resident-login-panel-head,
.resident-reset-head {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 12px;
}

.resident-login-options {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 14px;
  flex-wrap: wrap;
}

.remember-choice {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  cursor: pointer;
  color: var(--text);
}

.remember-choice input {
  width: 18px;
  height: 18px;
  accent-color: #c8a25a;
}

.remember-choice span {
  display: grid;
  gap: 2px;
}

.remember-choice small {
  color: var(--muted);
}

.resident-reset-panel {
  margin-top: 6px;
}

.resident-login-shell.is-session-live .resident-login-panel {
  border-color: rgba(108,245,157,.18);
}

.resident-login-shell.is-session-empty .resident-login-panel {
  border-color: rgba(216,188,124,.18);
}

@media (max-width: 900px) {
  .resident-session-grid,
  .resident-login-security-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .resident-login-panel,
  .resident-session-card {
    padding: 18px;
    border-radius: 24px;
  }

  .resident-session-head,
  .resident-login-panel-head,
  .resident-reset-head {
    flex-direction: column;
  }
}


.resident-auth-switch {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
  margin-bottom: 18px;
  padding: 8px;
  border-radius: 22px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.08);
}

.resident-auth-switch-btn {
  min-height: 46px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.08);
  background: transparent;
  color: var(--text);
  font-weight: 700;
}

.resident-auth-switch-btn.active {
  background: linear-gradient(180deg, rgba(216,188,124,.22), rgba(216,188,124,.08));
  border-color: rgba(216,188,124,.28);
  color: #f7ecd2;
}

.admin-invite-list {
  display: grid;
  gap: 14px;
}

.admin-invite-panel .content-admin-card {
  align-items: center;
}

.admin-invite-panel .content-admin-card-image.fallback {
  min-width: 74px;
  min-height: 74px;
  font-size: 24px;
}

.invite-claimed {
  opacity: .86;
}


.admin-invite-toolbar {
  display: grid;
  grid-template-columns: minmax(220px, 1.3fr) minmax(260px, 1fr);
  gap: 14px;
  align-items: end;
}

.admin-invite-search-wrap {
  min-width: 0;
}

.admin-filter-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.admin-filter-bar .ghost-btn.active {
  background: linear-gradient(180deg, rgba(216,188,124,.22), rgba(216,188,124,.08));
  border-color: rgba(216,188,124,.28);
  color: #f7ecd2;
}

.invite-actions-wrap {
  flex-wrap: wrap;
  gap: 8px;
}

.invite-meta-line {
  flex: 1 1 100%;
}

.invite-status-disabled {
  opacity: .78;
}

@media (max-width: 900px) {
  .admin-invite-toolbar {
    grid-template-columns: 1fr;
  }
}


/* index landing polish v12 */
.main-content > * { min-width: 0; }
.hero-card > *,
.auth-grid > * { min-width: 0; }
.panel-title-stack {
  display: grid;
  gap: 8px;
  margin-bottom: 12px;
}
.landing-hero-card {
  grid-template-columns: minmax(0, 1.18fr) minmax(340px, .82fr);
  gap: 24px;
  align-items: center;
  padding: 26px;
  overflow: hidden;
}
.landing-hero-copy h2 {
  margin: 10px 0 12px;
  font-size: clamp(32px, 4.2vw, 54px);
  line-height: 1.08;
  letter-spacing: -0.03em;
  max-width: 14ch;
}
.landing-hero-copy p {
  max-width: 62ch;
  color: var(--muted);
  line-height: 1.7;
}
.landing-link-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  align-items: stretch;
}
.landing-link-grid .nav-link-card {
  min-height: 92px;
  padding: 18px;
}
.landing-link-grid .nav-link-card strong {
  font-size: 18px;
  line-height: 1.15;
}
.landing-link-grid .nav-link-card small {
  line-height: 1.45;
}
.landing-card-showcase {
  width: min(100%, 470px);
  justify-self: end;
  gap: 16px;
}
.landing-card-showcase .elite-card-toolbar {
  align-items: center;
}
.landing-card-showcase .elite-card-scene {
  width: 100%;
  max-width: 100%;
}
.landing-card-showcase .card-action-row {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.landing-auth-grid {
  grid-template-columns: minmax(0, 1.08fr) minmax(320px, .92fr);
  align-items: stretch;
}
.landing-auth-card {
  min-height: 100%;
  padding: 24px;
}
.landing-auth-card h3 {
  margin: 0;
  font-size: clamp(28px, 3.2vw, 38px);
  line-height: 1.12;
}
.landing-auth-card .muted {
  line-height: 1.7;
}
.landing-auth-actions {
  justify-content: flex-start;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, max-content));
  gap: 12px;
}
.landing-auth-actions .primary-btn,
.landing-auth-actions .ghost-btn {
  min-width: 220px;
}
.landing-auth-note {
  display: grid;
  align-content: start;
}
@media (max-width: 1120px) {
  .landing-link-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .landing-hero-copy h2 {
    max-width: 16ch;
  }
}
@media (max-width: 1024px) {
  .landing-hero-card {
    grid-template-columns: 1fr;
  }
  .landing-card-showcase {
    justify-self: stretch;
    width: 100%;
    max-width: none;
  }
  .landing-auth-grid {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 720px) {
  .landing-link-grid {
    grid-template-columns: 1fr;
  }
  .landing-card-showcase .card-action-row,
  .landing-auth-actions {
    grid-template-columns: 1fr;
  }
  .landing-auth-actions .primary-btn,
  .landing-auth-actions .ghost-btn {
    min-width: 0;
    width: 100%;
  }
}


.admin-invite-launch-panel {
  overflow: hidden;
}

.admin-launch-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(260px, 0.9fr);
  gap: 18px;
  align-items: center;
}

.admin-launch-copy {
  min-width: 0;
}

.admin-launch-actions {
  display: flex;
  justify-content: flex-end;
  align-items: center;
}

.admin-launch-actions .ghost-btn,
.admin-launch-actions .primary-btn {
  min-width: 220px;
  justify-content: center;
}

.invite-manager-hero .row {
  align-items: center;
}

.invite-manager-panel {
  overflow: hidden;
}

@media (max-width: 900px) {
  .admin-launch-grid {
    grid-template-columns: 1fr;
  }

  .admin-launch-actions {
    justify-content: flex-start;
  }
}


.admin-invite-meta-toolbar{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,220px));
  gap:14px;
  align-items:end;
}
.compact-input{
  min-height:48px;
}
.admin-pagination-bar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
.pagination-note{
  flex:1 1 220px;
  text-align:center;
}
@media (max-width: 720px){
  .admin-pagination-bar{
    justify-content:center;
  }
  .pagination-note{
    order:3;
    flex-basis:100%;
  }
}


.reward-config-note .info-note.no-margin {
  margin-top: 0;
  min-height: 48px;
  display: flex;
  align-items: center;
}
.vault-reward-hint {
  margin-top: 4px;
  color: #5d6167;
  font-size: 12px;
  line-height: 1.28;
}
.vault-redeem-btn.ready {
  background: #babec5;
}
.vault-redeem-btn.disabled {
  background: #c2c5cb;
  color: rgba(255,255,255,.96);
}


/* Admin CMS layout polish v31 */
.admin-editor-panel {
  gap: 18px;
}
.admin-editor-panel > .field-label:first-of-type {
  margin-top: 0;
}
.admin-media-intro {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 12px;
}
.admin-media-intro-card {
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.025);
  min-width: 0;
}
.admin-media-intro-card h5 {
  margin: 4px 0 6px;
  font-size: 15px;
}
.admin-media-intro-card p {
  margin: 0;
  font-size: 13px;
  line-height: 1.55;
  color: rgba(255,255,255,.72);
}
.admin-media-grid {
  grid-template-columns: 1fr;
  align-items: start;
  gap: 16px;
}
.admin-upload-panel {
  display: grid;
  gap: 12px;
  min-width: 0;
  padding: 16px;
  border-radius: 20px;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.08);
}
.admin-upload-panel .field-label {
  margin-top: 0;
}
.admin-upload-panel .panel-title-row {
  margin-bottom: 0;
}
.admin-upload-panel .compact-row {
  margin-bottom: 0;
}
.admin-upload-panel h5 {
  margin: 0;
  font-size: 15px;
}
.admin-upload-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.admin-upload-head > div {
  min-width: 0;
}
.admin-upload-help {
  margin: 6px 0 0;
  font-size: 13px;
  line-height: 1.5;
  color: rgba(255,255,255,.72);
}
.badge-soft {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 32px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid rgba(214,179,92,.35);
  background: rgba(214,179,92,.10);
  color: #e7d39b;
  font-size: 12px;
  white-space: nowrap;
}
.admin-advanced-block {
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 14px;
  padding: 10px 12px 12px;
  background: rgba(255,255,255,.02);
}
.admin-advanced-block summary {
  cursor: pointer;
  list-style: none;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .03em;
  color: rgba(255,255,255,.78);
}
.admin-advanced-block summary::-webkit-details-marker {
  display: none;
}
.admin-advanced-block[open] summary {
  margin-bottom: 10px;
}
.admin-advanced-block .input {
  margin-top: 0;
}
.cms-cover-preview-wrap {
  gap: 12px;
}
.cms-cover-preview {
  min-height: 220px;
}
.cms-cover-preview img {
  min-height: 220px;
  max-height: 280px;
}
.cms-cover-placeholder {
  min-height: 220px;
  text-align: center;
  padding: 18px;
}
.admin-upload-panel input[type="file"].input {
  padding: 10px 12px;
  min-height: 52px;
}
.admin-upload-actions {
  justify-content: flex-start;
}
.admin-upload-actions .primary-btn,
.admin-upload-actions .ghost-btn,
.admin-upload-actions .secondary-btn {
  min-width: 180px;
}
#contentCoverImageUrl {
  font-size: 13px;
}
#contentGalleryPreviewList {
  margin-top: 4px;
}
.admin-gallery-list.gallery-preview-list {
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 14px;
}
.gallery-preview-card {
  min-width: 0;
}
.gallery-preview-actions {
  flex-wrap: wrap;
}
.gallery-preview-actions .gallery-preview-btn,
.gallery-preview-actions .danger-btn {
  flex: 1 1 120px;
  justify-content: center;
}
#contentStatusNote,
#contentUploadStatus,
#contentGalleryUploadStatus,
#contentCoverMeta {
  word-break: break-word;
}
.reward-config-note {
  min-width: 0;
}

.admin-step-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 26px;
  padding: 0 10px;
  border-radius: 999px;
  margin-bottom: 8px;
  background: rgba(214,179,92,.14);
  border: 1px solid rgba(214,179,92,.28);
  color: #e7d39b;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.admin-upload-field-stack {
  display: grid;
  gap: 10px;
}
.admin-upload-btn {
  justify-content: center;
  min-width: 0;
}
@media (max-width: 1100px) {
  .admin-media-intro {
    grid-template-columns: 1fr;
  }
  .admin-media-grid {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 768px) {
  .admin-upload-head {
    flex-direction: column;
    align-items: stretch;
  }
  .badge-soft {
    align-self: flex-start;
  }
  .admin-upload-panel,
  .admin-media-intro-card {
    padding: 14px;
    border-radius: 18px;
  }
  .cms-cover-preview,
  .cms-cover-preview img,
  .cms-cover-placeholder {
    min-height: 180px;
  }
  .admin-upload-actions .primary-btn,
  .admin-upload-actions .ghost-btn,
  .admin-upload-actions .secondary-btn {
    width: 100%;
    min-width: 0;
  }
  .gallery-preview-actions .gallery-preview-btn,
  .gallery-preview-actions .danger-btn {
    flex: 1 1 100%;
  }
}

/* Redemption flow v42 */
.vault-redeem-btn.ready {
  background: linear-gradient(180deg, #c41221 0%, #8f0012 100%);
  color: #fff;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.18), 0 10px 20px rgba(143,0,18,.24);
}
.vault-redeem-btn.ready:hover {
  background: linear-gradient(180deg, #d01929 0%, #990014 100%);
}
.vault-issued-card {
  display: grid;
  grid-template-columns: 94px minmax(0,1fr) auto;
  gap: 14px;
  align-items: center;
  padding: 14px;
  background: linear-gradient(180deg, rgba(255,255,255,.95), rgba(244,244,244,.98));
  border: 1px solid rgba(255,255,255,.1);
}
.vault-issued-card + .vault-issued-card {
  border-top: 0;
}
.vault-issued-card__thumb,
.vault-issued-card__thumb img {
  width: 94px;
  height: 94px;
  border-radius: 10px;
  object-fit: cover;
}
.vault-issued-card__thumb {
  position: relative;
  background: #ddd;
  overflow: hidden;
}
.vault-used-stamp {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 88%;
  max-width: 120px;
  transform: translate(-50%, -50%) rotate(-13deg);
  pointer-events: none;
  opacity: .96;
  filter: drop-shadow(0 3px 10px rgba(120, 0, 0, .16));
}
.vault-issued-card__body {
  min-width: 0;
}
.vault-issued-card__title-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}
.vault-issued-card__title-row h3 {
  margin: 0;
  color: #111;
  font-size: 16px;
  line-height: 1.3;
}
.vault-issued-card__points {
  color: #8f0012;
  font-weight: 700;
  font-size: 14px;
  white-space: nowrap;
}
.vault-issued-card__code {
  margin-top: 12px;
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  padding: 0 14px;
  border-radius: 999px;
  background: #111;
  color: #fff;
  letter-spacing: .18em;
  font-size: 15px;
  font-weight: 800;
}
.vault-issued-card__hint {
  margin-top: 8px;
  color: #730211;
  font-size: 12px;
  font-weight: 600;
}
.vault-issued-card__meta {
  margin-top: 8px;
  color: #545860;
  font-size: 12px;
  line-height: 1.4;
}
.vault-issued-card__action {
  display: flex;
  justify-content: flex-end;
}
.vault-code-copy-btn,
.vault-code-status {
  min-width: 112px;
  min-height: 42px;
  padding: 0 16px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 700;
}
.vault-code-copy-btn {
  border: 0;
  background: #111;
  color: #fff;
  cursor: pointer;
}
.vault-code-status {
  background: #e7e7e7;
  color: #333;
}
.vault-code-status-used {
  background: #d8e7d9;
  color: #1f5b2a;
}
.vault-code-status-expired {
  background: #f3e0e0;
  color: #8a1d1d;
}
.vault-issued-card.is-used,
.vault-issued-card.is-expired {
  opacity: .96;
}
@media (max-width: 720px) {
  .vault-issued-card {
    grid-template-columns: 80px minmax(0,1fr);
  }
  .vault-issued-card__thumb,
  .vault-issued-card__thumb img {
    width: 80px;
    height: 80px;
  }
  .vault-issued-card__action {
    grid-column: 1 / -1;
    justify-content: flex-start;
  }
  .vault-code-copy-btn,
  .vault-code-status {
    min-width: 0;
    width: 100%;
  }
}

/* Redemption QR + expiry v43 */
.reward-config-note--full {
  grid-column: 1 / -1;
}
.vault-issued-card {
  grid-template-columns: 94px minmax(0,1fr) 132px auto;
}
.vault-issued-card__qr {
  display: grid;
  justify-items: center;
  gap: 8px;
}
.vault-issued-card__qr-canvas {
  width: 112px;
  height: 112px;
  border-radius: 14px;
  background: #fff;
  padding: 8px;
  box-shadow: 0 8px 18px rgba(17,17,17,.12);
}
.vault-issued-card__qr-note {
  color: #6a0d16;
  font-size: 11px;
  font-weight: 700;
  text-align: center;
}
.vault-issued-card__qr-fallback {
  min-height: 112px;
  width: 112px;
  display: grid;
  place-items: center;
  text-align: center;
  padding: 12px;
  border-radius: 14px;
  background: #fff;
  color: #111;
  font-weight: 800;
  letter-spacing: .08em;
}
.vault-issued-card__qr--status {
  justify-items: end;
}
.vault-issued-card__action {
  align-self: center;
}
@media (max-width: 960px) {
  .vault-issued-card {
    grid-template-columns: 80px minmax(0,1fr) 112px;
  }
  .vault-issued-card__action {
    grid-column: 2 / 4;
    justify-content: flex-start;
  }
}
@media (max-width: 720px) {
  .vault-issued-card {
    grid-template-columns: 80px minmax(0,1fr);
  }
  .vault-issued-card__qr {
    grid-column: 1 / -1;
    justify-items: flex-start;
  }
  .vault-issued-card__qr-canvas,
  .vault-issued-card__qr-fallback {
    width: 104px;
    height: 104px;
  }
}


.about-panel,
.about-copy-card,
.about-contact-card {
  background: linear-gradient(180deg, rgba(18, 22, 28, 0.96), rgba(10, 12, 16, 0.98));
  border: 1px solid rgba(196, 161, 96, 0.18);
  border-radius: 28px;
  box-shadow: 0 22px 44px rgba(0, 0, 0, 0.34);
}

.about-panel {
  padding: 28px 24px;
}

.about-copy-card,
.about-contact-card {
  margin-top: 18px;
  padding: 24px;
}

.about-kicker {
  display: inline-block;
  margin-bottom: 14px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(196, 161, 96, 0.12);
  border: 1px solid rgba(196, 161, 96, 0.2);
  color: #d9bf84;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.about-title {
  margin: 0 0 12px;
  color: #f7f4ee;
  font-size: clamp(1.9rem, 5vw, 2.8rem);
  line-height: 1.08;
}

.about-lead,
.about-copy-card p {
  margin: 0;
  color: rgba(245, 242, 232, 0.82);
  font-size: 15px;
  line-height: 1.78;
}

.about-copy-card p + .about-section-heading,
.about-copy-card .about-section-heading + p {
  margin-top: 14px;
}

.about-section-heading {
  margin: 0;
  color: #f3e8cb;
  font-size: 15px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.about-quote {
  margin-top: 22px;
  padding: 18px 18px 18px 20px;
  border-left: 3px solid rgba(196, 161, 96, 0.55);
  background: rgba(255, 255, 255, 0.03);
  border-radius: 18px;
  color: #f5f2e8;
  font-size: 15px;
  line-height: 1.7;
}

.about-contact-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.about-contact-label {
  margin-bottom: 6px;
  color: #d9bf84;
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.about-contact-value {
  color: #f5f2e8;
  font-size: 14px;
  line-height: 1.65;
}

@media (max-width: 680px) {
  .about-panel,
  .about-copy-card,
  .about-contact-card {
    border-radius: 22px;
  }

  .about-panel,
  .about-copy-card,
  .about-contact-card {
    padding: 20px 18px;
  }

  .about-contact-grid {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .about-title {
    font-size: 1.85rem;
  }
}


.about-inline-link {
  color: #e7cf90;
  text-decoration: none;
  border-bottom: 1px solid rgba(231, 207, 144, 0.35);
}

.about-inline-link:hover {
  color: #f6df9f;
  border-bottom-color: rgba(246, 223, 159, 0.7);
}


.faq-list-card {
  display: grid;
  gap: 18px;
}

.faq-item {
  padding-bottom: 18px;
  border-bottom: 1px solid rgba(212, 175, 55, 0.12);
}

.faq-item:last-child {
  padding-bottom: 0;
  border-bottom: none;
}

.faq-item .about-section-heading {
  margin-bottom: 8px;
}

.faq-item p {
  margin: 0;
}


.resident-language-picker.hidden{display:none!important}
.resident-language-picker{position:fixed;inset:0;z-index:1400}
.resident-language-picker__backdrop{position:absolute;inset:0;background:rgba(5,8,12,.68);backdrop-filter:blur(6px)}
.resident-language-picker__dialog{position:relative;max-width:420px;margin:12vh auto 0;background:linear-gradient(180deg,rgba(26,29,36,.98),rgba(12,14,19,.98));border:1px solid rgba(212,167,76,.25);border-radius:24px;padding:24px 22px 18px;box-shadow:0 28px 60px rgba(0,0,0,.45);color:#f6ead0}
.resident-language-picker__eyebrow{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:#c8a14e;margin-bottom:10px}
.resident-language-picker__dialog h3{margin:0 0 8px;font-size:1.35rem;color:#fff}
.resident-language-picker__subtitle{margin:0 0 16px;color:rgba(255,255,255,.72);line-height:1.55}
.resident-language-picker__current{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:12px 14px;border-radius:16px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);margin-bottom:16px;font-size:.94rem}
.resident-language-picker__current strong{color:#fff}
.resident-language-picker__options{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.resident-language-picker__option,.resident-language-picker__cancel{appearance:none;border:none;border-radius:16px;padding:14px 16px;font:inherit;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,background .18s ease}
.resident-language-picker__option{background:rgba(255,255,255,.06);color:#fff;border:1px solid rgba(255,255,255,.08)}
.resident-language-picker__option.is-active{background:linear-gradient(180deg,#b11217,#8f0f15);border-color:rgba(255,255,255,.14);box-shadow:0 12px 28px rgba(177,18,23,.35)}
.resident-language-picker__option:hover,.resident-language-picker__cancel:hover{transform:translateY(-1px)}
.resident-language-picker__cancel{width:100%;margin-top:14px;background:transparent;color:rgba(255,255,255,.8);border:1px solid rgba(255,255,255,.12)}

.admin-locale-section {
  margin-top: 1rem;
  padding: 1rem;
  border: 1px solid rgba(196, 165, 105, 0.22);
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(17,17,17,0.92), rgba(10,10,10,0.96));
}

.admin-locale-head {
  align-items: center;
}

.admin-locale-switch {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.locale-tab-btn {
  min-width: 56px;
  padding: 0.55rem 0.9rem;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.04);
  color: #f4efe6;
  font-weight: 700;
  letter-spacing: 0.08em;
}

.locale-tab-btn.active {
  background: rgba(196, 165, 105, 0.18);
  border-color: rgba(196, 165, 105, 0.48);
  color: #f7dca4;
  box-shadow: 0 0 0 1px rgba(196,165,105,0.15) inset;
}

.locale-editor-panel {
  display: none;
  margin-top: 0.9rem;
  padding: 1rem;
  border-radius: 20px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
}

.locale-editor-panel.active {
  display: block;
}

.locale-editor-label {
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: rgba(247, 220, 164, 0.92);
  margin-bottom: 0.7rem;
}

@media (max-width: 820px) {
  .admin-locale-head {
    align-items: flex-start;
  }

  .admin-locale-switch {
    width: 100%;
  }

  .locale-tab-btn {
    flex: 1 1 calc(50% - 0.5rem);
  }

  .admin-locale-section,
  .locale-editor-panel {
    border-radius: 18px;
  }
}


.static-page-tabbar {
  margin-top: 16px;
}

.static-page-editor-shell {
  display: grid;
  gap: 14px;
}

.static-locale-switch {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 8px;
}

.static-locale-editor-panel {
  display: none;
}

.static-locale-editor-panel.active {
  display: block;
}

.static-page-editor-note {
  margin-top: 6px;
}

.static-editor-html {
  min-height: 220px;
}

.static-editor-footer {
  min-height: 140px;
}

.static-page-content-card :is(p, li) {
  line-height: 1.7;
}

.static-page-content-card :is(h2, h3) {
  margin-top: 22px;
}

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


/* News gallery on home: swipe/scroll images without opening detail */
.vault-news-scroll {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  overflow-y: hidden;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  touch-action: auto;
  padding: 0;
  scrollbar-width: none;
}
.vault-news-dots {
  display: flex;
  justify-content: center;
  gap: 6px;
  margin-top: 10px;
}
.vault-news-dot {
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: rgba(255,255,255,.28);
}
.vault-news-dot.is-active {
  width: 20px;
  background: rgba(255,255,255,.86);
}
.vault-news-scroll::-webkit-scrollbar {
  display: none;
}
.vault-news-slide {
  flex: 0 0 100%;
  min-width: 100%;
  scroll-snap-align: start;
}
.vault-news-hero {
  cursor: default;
}


/* News slides: keep every image frame same size while preserving full artwork */
body[data-page="home"] .vault-news-image-wrap {
  position: relative;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border-radius: 26px;
  background: #111;
}
body[data-page="home"] .vault-news-image-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: blur(18px);
  transform: scale(1.08);
  opacity: .75;
}
body[data-page="home"] .vault-news-image-bg,
body[data-page="home"] .vault-news-image {
  pointer-events: none;
  -webkit-user-drag: none;
  user-select: none;
}
body[data-page="home"] .vault-news-scroll {
  overscroll-behavior-x: contain;
  overscroll-behavior-y: auto;
}
body[data-page="home"] .vault-news-image {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}
body[data-page="home"] .vault-news-fallback {
  display: grid;
  place-items: center;
  width: 100%;
  height: 100%;
}
body[data-page="home"] .vault-news-slide {
  display: block;
}
