/* ===== 梦境后台 · Dreamland Backstage · Dual Theme ===== */

/* --- Night (default) --- */
html.dlbs-theme-night,
html:not(.dlbs-theme-light) {
  color-scheme: dark;
  --dlbs-bg: #0c0b0d;
  --dlbs-bg-alt: #121014;
  --dlbs-text: rgba(240, 223, 168, 0.94);
  --dlbs-text-muted: rgba(240, 223, 168, 0.68);
  --dlbs-text-muted-soft: rgba(240, 223, 168, 0.45);
  --dlbs-gold: #d4b87a;
  --dlbs-gold-bright: #f0dfa8;
  --dlbs-violet: #a894e8;
  --dlbs-teal: #6ec4b8;
  --dlbs-ember: #e8a86a;
  --dlbs-ink: #0c0b0d;
  --dlbs-glass: rgba(18, 16, 20, 0.82);
  --dlbs-line: rgba(212, 184, 122, 0.18);
  --muted: rgba(240, 223, 168, 0.68);
  --muted-soft: rgba(240, 223, 168, 0.45);
  --dlbs-surface: rgba(18, 16, 20, 0.82);
  --dlbs-surface-2: rgba(16, 14, 18, 0.65);
  --dlbs-surface-card: linear-gradient(145deg, rgba(22, 20, 26, 0.92), rgba(14, 13, 16, 0.88));
  --dlbs-surface-card-alt: linear-gradient(160deg, rgba(20, 18, 24, 0.9), rgba(12, 11, 13, 0.85));
  --dlbs-topbar-bg: rgba(12, 11, 13, 0.72);
  --dlbs-sidebar-bg: linear-gradient(180deg, rgba(14, 13, 16, 0.97), rgba(10, 9, 11, 0.92));
  --dlbs-stage-head-bg: linear-gradient(180deg, rgba(12, 11, 13, 0.55), transparent);
  --dlbs-input-bg: rgba(255, 255, 255, 0.04);
  --dlbs-subtle: rgba(255, 255, 255, 0.03);
  --dlbs-hover: rgba(212, 184, 122, 0.08);
  --dlbs-hover-strong: rgba(212, 184, 122, 0.14);
  --dlbs-dock-bg: rgba(12, 11, 13, 0.92);
  --dlbs-loading-bg: rgba(12, 11, 13, 0.75);
  --dlbs-toast-bg: rgba(18, 16, 20, 0.95);
  --dlbs-modal-bg: linear-gradient(165deg, rgba(22, 20, 26, 0.98), rgba(12, 11, 13, 0.98));
  --dlbs-modal-hero: radial-gradient(ellipse 80% 100% at 0% 0%, rgba(212, 184, 122, 0.18), transparent 55%), radial-gradient(ellipse 60% 80% at 100% 0%, rgba(168, 148, 232, 0.14), transparent 50%);
  --dlbs-progress-track: rgba(255, 255, 255, 0.06);
  --dlbs-dot-idle: rgba(255, 255, 255, 0.12);
  --dlbs-mark-fg: #0c0b0d;
  --dlbs-btn-ghost-hover: rgba(212, 184, 122, 0.24);
  --dlbs-btn-surface: rgba(212, 184, 122, 0.15);
  --dlbs-shadow-sm: 0 8px 28px rgba(0, 0, 0, 0.35);
  --dlbs-shadow-md: 0 16px 48px rgba(0, 0, 0, 0.4);
  --dlbs-shadow-lg: 0 32px 80px rgba(0, 0, 0, 0.55);
  --dlbs-aurora-1: rgba(212, 184, 122, 0.14);
  --dlbs-aurora-2: rgba(168, 148, 232, 0.12);
  --dlbs-aurora-3: rgba(110, 196, 184, 0.08);
  --dlbs-grid-line: rgba(212, 184, 122, 0.04);
  --dlbs-orb-1: rgba(212, 184, 122, 0.35);
  --dlbs-orb-2: rgba(168, 148, 232, 0.28);
  --dlbs-orb-3: rgba(110, 196, 184, 0.2);
  --dlbs-grain-opacity: 0.5;
  --dlbs-theme-meta: #0c0b0d;
}

/* --- Light · 晨曦金纸 --- */
html.dlbs-theme-light {
  color-scheme: light;
  --dlbs-bg: #f4f0e8;
  --dlbs-bg-alt: #faf7f0;
  --dlbs-text: #1a1714;
  --dlbs-text-muted: rgba(26, 23, 20, 0.64);
  --dlbs-text-muted-soft: rgba(26, 23, 20, 0.42);
  --dlbs-gold: #8f6b32;
  --dlbs-gold-bright: #6b4f24;
  --dlbs-violet: #5c4a94;
  --dlbs-teal: #2a756c;
  --dlbs-ember: #b86828;
  --dlbs-ink: #1a1714;
  --dlbs-glass: rgba(255, 255, 255, 0.88);
  --dlbs-line: rgba(143, 107, 50, 0.14);
  --muted: rgba(26, 23, 20, 0.64);
  --muted-soft: rgba(26, 23, 20, 0.42);
  --dlbs-surface: rgba(255, 255, 255, 0.94);
  --dlbs-surface-2: rgba(255, 255, 255, 0.98);
  --dlbs-surface-card: linear-gradient(180deg, #ffffff 0%, #fcfaf6 100%);
  --dlbs-surface-card-alt: linear-gradient(165deg, #ffffff, #f8f4ec);
  --dlbs-topbar-bg: rgba(252, 249, 243, 0.92);
  --dlbs-sidebar-bg: linear-gradient(180deg, #ffffff 0%, #f9f5ed 100%);
  --dlbs-stage-head-bg: linear-gradient(180deg, rgba(252, 249, 243, 0.98), transparent);
  --dlbs-input-bg: rgba(26, 23, 20, 0.035);
  --dlbs-subtle: rgba(143, 107, 50, 0.05);
  --dlbs-hover: rgba(143, 107, 50, 0.07);
  --dlbs-hover-strong: rgba(143, 107, 50, 0.12);
  --dlbs-dock-bg: rgba(255, 255, 255, 0.96);
  --dlbs-loading-bg: rgba(244, 240, 232, 0.92);
  --dlbs-toast-bg: rgba(255, 255, 255, 0.98);
  --dlbs-modal-bg: linear-gradient(168deg, #ffffff 0%, #f8f4ec 100%);
  --dlbs-modal-hero: radial-gradient(ellipse 90% 80% at 0% 0%, rgba(212, 184, 122, 0.22), transparent 58%), radial-gradient(ellipse 70% 60% at 100% 0%, rgba(168, 148, 232, 0.12), transparent 52%);
  --dlbs-progress-track: rgba(26, 23, 20, 0.08);
  --dlbs-dot-idle: rgba(26, 23, 20, 0.14);
  --dlbs-mark-fg: #faf7f0;
  --dlbs-btn-ghost-hover: rgba(143, 107, 50, 0.1);
  --dlbs-btn-surface: rgba(143, 107, 50, 0.08);
  --dlbs-shadow-sm: 0 1px 2px rgba(26, 23, 20, 0.04), 0 8px 24px rgba(26, 23, 20, 0.06);
  --dlbs-shadow-md: 0 2px 8px rgba(26, 23, 20, 0.05), 0 16px 40px rgba(26, 23, 20, 0.08);
  --dlbs-shadow-lg: 0 4px 16px rgba(26, 23, 20, 0.06), 0 32px 64px rgba(26, 23, 20, 0.1);
  --dlbs-aurora-1: rgba(212, 184, 122, 0.28);
  --dlbs-aurora-2: rgba(168, 148, 232, 0.16);
  --dlbs-aurora-3: rgba(110, 196, 184, 0.14);
  --dlbs-grid-line: rgba(143, 107, 50, 0.07);
  --dlbs-orb-1: rgba(232, 200, 140, 0.45);
  --dlbs-orb-2: rgba(186, 168, 232, 0.35);
  --dlbs-orb-3: rgba(140, 210, 196, 0.32);
  --dlbs-grain-opacity: 0.22;
  --dlbs-theme-meta: #f4f0e8;
}

.dlbs-page {
  --dlbs-sidebar: 18rem;
  --dlbs-serif: "Noto Serif SC", "Songti SC", serif;
  --dlbs-sans: "DM Sans", system-ui, "PingFang SC", "Microsoft YaHei", sans-serif;
  --text-xs: 0.8125rem;
  --text-sm: 0.9375rem;
  --text-base: 1rem;
  --text-md: 1.0625rem;
  --text-lg: 1.2rem;
  --text-xl: 1.45rem;
  --text-2xl: 1.75rem;
  --text-3xl: 2.25rem;
  background: var(--dlbs-bg);
  color: var(--dlbs-text);
  font-family: var(--dlbs-sans);
  font-size: var(--text-base);
  line-height: 1.55;
  margin: 0;
  min-height: 100dvh;
  transition: background 0.35s ease, color 0.35s ease;
}

.dlbs-page *, .dlbs-page *::before, .dlbs-page *::after { box-sizing: border-box; }

.dlbs-page button,
.dlbs-page input,
.dlbs-page select,
.dlbs-page textarea {
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
}

.dlbs-page button {
  color: inherit;
}

/* --- Background --- */
.dlbs-bg { inset: 0; pointer-events: none; position: fixed; z-index: 0; overflow: hidden; }
.dlbs-bg__aurora {
  background:
    radial-gradient(ellipse 80% 60% at 10% 0%, var(--dlbs-aurora-1) 0%, transparent 55%),
    radial-gradient(ellipse 60% 50% at 90% 5%, var(--dlbs-aurora-2) 0%, transparent 50%),
    radial-gradient(ellipse 50% 40% at 50% 100%, var(--dlbs-aurora-3) 0%, transparent 45%);
  inset: 0; position: absolute;
  animation: dlbs-aurora 18s ease-in-out infinite alternate;
}
@keyframes dlbs-aurora {
  0% { opacity: 0.85; transform: scale(1); }
  100% { opacity: 1; transform: scale(1.04) translateY(-1%); }
}
.dlbs-bg__grain {
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
  inset: 0; position: absolute; opacity: var(--dlbs-grain-opacity);
}
.dlbs-bg__grid {
  background-image: linear-gradient(var(--dlbs-grid-line) 1px, transparent 1px), linear-gradient(90deg, var(--dlbs-grid-line) 1px, transparent 1px);
  background-size: 48px 48px;
  inset: 0; position: absolute; mask-image: radial-gradient(ellipse 70% 60% at 50% 30%, black, transparent);
}
.dlbs-bg__orbs { inset: 0; position: absolute; overflow: hidden; }
.dlbs-bg__orb {
  border-radius: 50%; filter: blur(60px); opacity: 0.45; position: absolute;
  animation: dlbs-orb-float 14s ease-in-out infinite alternate;
}
.dlbs-bg__orb--1 { background: var(--dlbs-orb-1); height: 18rem; left: -4rem; top: 10%; width: 18rem; }
.dlbs-bg__orb--2 { animation-delay: -4s; background: var(--dlbs-orb-2); height: 22rem; right: -6rem; top: 30%; width: 22rem; }
.dlbs-bg__orb--3 { animation-delay: -8s; background: var(--dlbs-orb-3); bottom: 5%; height: 14rem; left: 35%; width: 14rem; }
@keyframes dlbs-orb-float {
  0% { transform: translate(0, 0) scale(1); }
  100% { transform: translate(2rem, -1.5rem) scale(1.08); }
}

/* --- Topbar --- */
.dlbs-topbar {
  align-items: center; backdrop-filter: blur(12px);
  background: var(--dlbs-topbar-bg); border-bottom: 1px solid var(--dlbs-line);
  display: flex; gap: 1rem; justify-content: space-between;
  padding: 0.85rem 1.25rem; position: sticky; top: 0; z-index: 20;
  transition: background 0.35s ease, border-color 0.35s ease;
}
.dlbs-topbar__actions { align-items: center; display: flex; gap: 0.5rem; margin-left: auto; }
.dlbs-topbar__brand {
  color: var(--dlbs-gold-bright);
  text-decoration: none;
}
.dlbs-topbar__brand .dl-brand__cn { font-size: var(--text-md); }
.dlbs-topbar__brand .dl-brand__sub { color: rgba(168, 148, 232, 0.58); }

.dlbs-topbar__mark {
  align-items: center; background: linear-gradient(135deg, var(--dlbs-gold), var(--dlbs-violet));
  border-radius: 0.45rem; color: var(--dlbs-mark-fg); display: flex;
  font-size: var(--text-sm); height: 1.75rem; justify-content: center; width: 1.75rem;
}
.dlbs-topbar__nav { display: flex; flex-wrap: wrap; gap: 0.35rem 0.85rem; }
.dlbs-topbar__nav a {
  color: var(--muted); font-size: var(--text-sm); text-decoration: none; transition: color 0.2s;
}
.dlbs-topbar__nav a:hover { color: var(--dlbs-gold-bright); }

/* --- Auth · Cinematic gateway (full-viewport split) --- */
.dlbs-root { min-height: calc(100dvh - 3.5rem); position: relative; z-index: 1; }

.dlbs-page:not(.dlbs-is-app) .dlbs-topbar { display: none; }
.dlbs-page:not(.dlbs-is-app) .dlbs-root,
.dlbs-page:not(.dlbs-is-app) .dlbs-auth { min-height: 100dvh; }

.dlbs-auth {
  min-height: 100dvh;
  position: relative;
}

.dlbs-auth__gate {
  display: grid;
  grid-template-columns: 1fr;
  min-height: 100dvh;
}

@media (min-width: 960px) {
  .dlbs-auth__gate {
    grid-template-columns: minmax(0, 1.15fr) minmax(22rem, 0.85fr);
  }
}

/* Left · brand canvas */
.dlbs-auth__canvas {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: min(52vh, 28rem);
  overflow: hidden;
  padding: clamp(1.5rem, 4vw, 3.5rem) clamp(1.25rem, 4vw, 3rem);
  position: relative;
}

@media (min-width: 960px) {
  .dlbs-auth__canvas {
    min-height: 100dvh;
    padding: clamp(2rem, 5vw, 4rem) clamp(2rem, 6vw, 5rem);
  }
}

.dlbs-auth__canvas-bg {
  inset: 0;
  overflow: hidden;
  pointer-events: none;
  position: absolute;
}

.dlbs-auth__watermark {
  color: var(--dlbs-gold);
  font-family: var(--dlbs-serif);
  font-size: clamp(8rem, 28vw, 16rem);
  font-weight: 600;
  left: -0.08em;
  letter-spacing: 0.12em;
  line-height: 1;
  opacity: 0.045;
  position: absolute;
  top: 50%;
  transform: translateY(-52%);
  user-select: none;
  white-space: nowrap;
}

.dlbs-auth__orbit {
  animation: dlbs-orbit-spin 22s linear infinite;
  border: 1px solid rgba(212, 184, 122, 0.12);
  border-radius: 50%;
  height: min(36rem, 90vw);
  left: 10%;
  position: absolute;
  top: 8%;
  width: min(36rem, 90vw);
}

.dlbs-auth__orbit--2 {
  animation-direction: reverse;
  animation-duration: 32s;
  border-color: rgba(168, 148, 232, 0.1);
  height: min(22rem, 55vw);
  left: auto;
  right: -8%;
  top: auto;
  bottom: 5%;
  width: min(22rem, 55vw);
}

@keyframes dlbs-orbit-spin {
  to { transform: rotate(360deg); }
}

.dlbs-auth__canvas-inner {
  animation: dlbs-canvas-in 1s cubic-bezier(0.22, 1, 0.36, 1) both;
  max-width: 36rem;
  position: relative;
  z-index: 1;
}

@keyframes dlbs-canvas-in {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}

.dlbs-auth__home {
  color: var(--muted-soft);
  display: inline-block;
  font-size: var(--text-xs);
  letter-spacing: 0.12em;
  margin-bottom: 2rem;
  text-decoration: none;
  transition: color 0.2s;
}

.dlbs-auth__home:hover {
  color: var(--dlbs-gold-bright);
}

.dlbs-auth__brand {
  margin-bottom: 1.5rem;
}

.dlbs-auth__brand .dl-brand__cn {
  color: var(--dlbs-gold-bright);
  font-size: var(--text-lg);
}

.dlbs-auth__brand .dl-brand__en {
  color: rgba(168, 148, 232, 0.62);
}

.dlbs-auth__eyebrow {
  color: var(--dlbs-gold);
  font-size: var(--text-xs);
  letter-spacing: 0.28em;
  margin: 0 0 1rem;
  text-transform: uppercase;
}

.dlbs-auth__title {
  display: flex;
  flex-direction: column;
  font-family: var(--dlbs-serif);
  font-size: clamp(2rem, 6vw, 3.25rem);
  font-weight: 600;
  gap: 0.15em;
  line-height: 1.12;
  margin: 0 0 1.25rem;
}

.dlbs-auth__title-line {
  animation: dlbs-line-in 0.85s cubic-bezier(0.22, 1, 0.36, 1) both;
  display: block;
}

.dlbs-auth__title-line:nth-child(2) {
  animation-delay: 0.12s;
}

@keyframes dlbs-line-in {
  from { opacity: 0; transform: translateY(18px); }
  to { opacity: 1; transform: translateY(0); }
}

.dlbs-gradient-text {
  background: linear-gradient(120deg, var(--dlbs-gold-bright) 0%, var(--dlbs-violet) 55%, var(--dlbs-teal) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.dlbs-auth__lead {
  animation: dlbs-line-in 0.85s cubic-bezier(0.22, 1, 0.36, 1) 0.22s both;
  color: var(--muted);
  font-size: clamp(var(--text-sm), 2.2vw, var(--text-md));
  line-height: 1.75;
  margin: 0 0 2rem;
  max-width: 28rem;
}

.dlbs-auth__stats {
  animation: dlbs-line-in 0.85s cubic-bezier(0.22, 1, 0.36, 1) 0.34s both;
  display: grid;
  gap: 0.65rem;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  max-width: 28rem;
}

.dlbs-auth__stat {
  backdrop-filter: blur(8px);
  background: rgba(212, 184, 122, 0.06);
  border: 1px solid rgba(212, 184, 122, 0.14);
  border-radius: 0.85rem;
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  padding: 0.75rem 0.65rem;
  transition: border-color 0.25s, background 0.25s;
}

.dlbs-auth__stat:hover {
  background: rgba(212, 184, 122, 0.1);
  border-color: rgba(212, 184, 122, 0.28);
}

.dlbs-auth__stat strong {
  color: var(--dlbs-gold-bright);
  font-family: var(--dlbs-serif);
  font-size: clamp(1.1rem, 3vw, 1.35rem);
  font-weight: 600;
  line-height: 1;
}

.dlbs-auth__stat span {
  color: var(--muted-soft);
  font-size: 0.62rem;
  letter-spacing: 0.06em;
  line-height: 1.35;
}

/* Right · login rail (flush edge, not floating) */
.dlbs-auth__rail {
  animation: dlbs-rail-in 0.9s cubic-bezier(0.22, 1, 0.36, 1) 0.15s both;
  backdrop-filter: blur(28px) saturate(1.1);
  background: linear-gradient(180deg, rgba(14, 13, 16, 0.94) 0%, rgba(8, 8, 9, 0.98) 100%);
  border-top: 1px solid var(--dlbs-line);
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: min(48vh, auto);
  position: relative;
}

html.dlbs-theme-light .dlbs-auth__rail {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(248, 244, 236, 0.98) 100%);
}

@media (min-width: 960px) {
  .dlbs-auth__rail {
    border-left: 1px solid var(--dlbs-line);
    border-top: none;
    min-height: 100dvh;
  }

  .dlbs-auth__rail::before {
    background: linear-gradient(180deg, var(--dlbs-gold) 0%, var(--dlbs-violet) 50%, var(--dlbs-teal) 100%);
    content: "";
    inset: 0 auto 0 0;
    opacity: 0.55;
    position: absolute;
    width: 2px;
  }
}

@keyframes dlbs-rail-in {
  from { opacity: 0; transform: translateX(24px); }
  to { opacity: 1; transform: translateX(0); }
}

.dlbs-auth__rail-inner {
  margin: 0 auto;
  max-width: 22rem;
  padding: clamp(1.5rem, 4vw, 2.5rem) clamp(1.25rem, 4vw, 2rem);
  width: 100%;
}

.dlbs-auth__rail-kicker {
  color: var(--dlbs-gold);
  font-size: 0.62rem;
  letter-spacing: 0.32em;
  margin: 0 0 0.45rem;
  text-transform: uppercase;
}

.dlbs-auth__rail-title {
  font-family: var(--dlbs-serif);
  font-size: var(--text-xl);
  font-weight: 600;
  letter-spacing: 0.04em;
  margin: 0 0 1.35rem;
}

.dlbs-auth__tabs,
.dlbs-auth__methods {
  display: flex;
  gap: 0.35rem;
  margin-bottom: 1rem;
}

.dlbs-auth__tab,
.dlbs-auth__method {
  background: transparent;
  border: 1px solid transparent;
  border-radius: 999px;
  color: var(--muted);
  cursor: pointer;
  font: inherit;
  font-size: var(--text-sm);
  padding: 0.45rem 0.9rem;
  transition: all 0.2s;
}

.dlbs-auth__tab.is-active,
.dlbs-auth__method.is-active {
  background: rgba(212, 184, 122, 0.12);
  border-color: var(--dlbs-line);
  color: var(--dlbs-gold-bright);
}

@media (max-width: 959px) {
  .dlbs-auth__stats {
    grid-template-columns: 1fr;
  }

  .dlbs-auth__stat {
    flex-direction: row;
    align-items: baseline;
    gap: 0.65rem;
    padding: 0.65rem 0.85rem;
  }

  .dlbs-auth__stat strong {
    min-width: 2.5rem;
  }
}

.dlbs-field { margin-bottom: 0.85rem; }
.dlbs-field label { color: var(--muted); display: block; font-size: var(--text-xs); margin-bottom: 0.35rem; }
.dlbs-field input, .dlbs-field select, .dlbs-field textarea {
  background: var(--dlbs-input-bg); border: 1px solid var(--dlbs-line); border-radius: 0.65rem;
  color: inherit; font: inherit; font-size: var(--text-md); padding: 0.7rem 0.85rem; width: 100%;
}
.dlbs-field input:focus, .dlbs-field select:focus, .dlbs-field textarea:focus {
  border-color: rgba(212, 184, 122, 0.45); outline: none;
}
.dlbs-field__row { display: flex; gap: 0.5rem; }
.dlbs-field__row input { flex: 1; }
.dlbs-auth__error {
  background: rgba(232, 100, 100, 0.12); border-radius: 0.5rem; color: #f0a0a0;
  font-size: var(--text-sm); margin: 0 0 0.75rem; padding: 0.55rem 0.75rem;
}
.dlbs-wechat-hint { color: var(--muted); font-size: var(--text-sm); margin: 0 0 0.75rem; }
.dlbs-wechat-profiles { display: grid; gap: 0.5rem; }
.dlbs-wechat-btn {
  align-items: center; background: rgba(7, 193, 96, 0.12); border: 1px solid rgba(7, 193, 96, 0.35);
  border-radius: 0.75rem; color: #8ee4b0; cursor: pointer; display: flex;
  font: inherit; font-size: var(--text-md); gap: 0.65rem; justify-content: space-between;
  padding: 0.85rem 1rem; transition: background 0.2s; width: 100%;
}
.dlbs-wechat-btn:hover { background: rgba(7, 193, 96, 0.2); }
.dlbs-auth__demo { border-top: 1px solid var(--dlbs-line); margin-top: 1.25rem; padding-top: 1rem; }
.dlbs-auth__demo-label { color: var(--muted-soft); font-size: var(--text-xs); margin: 0 0 0.65rem; }
.dlbs-auth__demo-grid { display: grid; gap: 0.45rem; }
.dlbs-demo-chip {
  align-items: center; background: rgba(212, 184, 122, 0.06); border: 1px solid var(--dlbs-line);
  border-radius: 0.65rem; color: inherit; cursor: pointer; display: flex;
  font: inherit; font-size: var(--text-sm); justify-content: space-between;
  padding: 0.65rem 0.85rem; transition: all 0.2s; width: 100%;
}
.dlbs-demo-chip:hover { background: rgba(212, 184, 122, 0.14); border-color: rgba(212, 184, 122, 0.35); }
.dlbs-demo-chip span { color: var(--dlbs-gold); font-size: var(--text-xs); }

/* --- Buttons --- */
.dlbs-btn {
  background: var(--dlbs-btn-surface); border: 1px solid var(--dlbs-line); border-radius: 0.65rem;
  color: var(--dlbs-gold-bright); cursor: pointer; font: inherit; font-size: var(--text-md);
  padding: 0.65rem 1.1rem; transition: all 0.2s;
}
.dlbs-btn:hover { background: var(--dlbs-btn-ghost-hover); }
.dlbs-btn--gold { background: linear-gradient(135deg, #c9a86a, #e8d4a8); border-color: transparent; color: var(--dlbs-ink); font-weight: 600; }
.dlbs-btn--gold:hover { filter: brightness(1.05); }
.dlbs-btn--ghost { background: transparent; }
.dlbs-btn--block { display: block; text-align: center; width: 100%; }
.dlbs-btn:disabled { cursor: not-allowed; opacity: 0.55; }

/* --- App shell v2 --- */
.dlbs-page.dlbs-is-app .dlbs-topbar { display: none; }
.dlbs-page.dlbs-is-app .dlbs-root { min-height: 100dvh; }

.dlbs-app {
  display: grid; grid-template-columns: 1fr;
  min-height: calc(100dvh - 3.5rem); width: 100%;
}
.dlbs-page.dlbs-is-app .dlbs-app { min-height: 100dvh; }
@media (min-width: 900px) {
  .dlbs-app { grid-template-columns: var(--dlbs-sidebar) minmax(0, 1fr); }
}

.dlbs-sidebar {
  backdrop-filter: blur(20px);
  background: var(--dlbs-sidebar-bg);
  border-right: 1px solid var(--dlbs-line);
  display: none; flex-direction: column;
  gap: 0.5rem; padding: 1.35rem 1rem 1.25rem;
  position: sticky; top: 3.5rem; height: calc(100dvh - 3.5rem);
  z-index: 10;
}
.dlbs-page.dlbs-is-app .dlbs-sidebar { top: 0; height: 100dvh; }
@media (min-width: 900px) { .dlbs-sidebar { display: flex; } }

.dlbs-sidebar__brand {
  margin-bottom: 0.25rem;
  padding: 0 0.15rem;
}
.dlbs-sidebar__brand .dl-brand__cn {
  color: var(--dlbs-gold-bright);
  font-size: var(--text-md);
}
.dlbs-sidebar__brand .dl-brand__en {
  color: rgba(168, 148, 232, 0.58);
}
.dlbs-sidebar__mark {
  align-items: center; background: linear-gradient(135deg, var(--dlbs-gold), var(--dlbs-violet));
  border-radius: 0.5rem; color: var(--dlbs-mark-fg); display: flex;
  font-family: var(--dlbs-serif); font-size: var(--text-sm); font-weight: 600;
  height: 1.85rem; justify-content: center; width: 1.85rem;
}
.dlbs-sidebar__brand-text {
  font-family: var(--dlbs-serif); font-size: var(--text-md); font-weight: 600;
  letter-spacing: 0.04em;
}

.dlbs-user {
  border-bottom: 1px solid var(--dlbs-line); margin-bottom: 0.5rem; padding-bottom: 1rem;
}
.dlbs-user__row { align-items: center; display: flex; gap: 0.75rem; margin-bottom: 0.65rem; }
.dlbs-user__info { flex: 1; min-width: 0; }
.dlbs-user__avatar {
  align-items: center; background: linear-gradient(135deg, var(--dlbs-gold), var(--dlbs-violet));
  border-radius: 50%; color: var(--dlbs-mark-fg); display: flex; flex-shrink: 0; font-family: var(--dlbs-serif);
  font-size: var(--text-lg); font-weight: 600; height: 2.65rem; justify-content: center; width: 2.65rem;
}
.dlbs-user__name { font-family: var(--dlbs-serif); font-size: var(--text-md); font-weight: 600; margin: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.dlbs-user__meta { color: var(--muted); font-size: var(--text-xs); margin: 0.15rem 0 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.dlbs-nav { display: flex; flex: 1; flex-direction: column; gap: 0.2rem; padding-top: 0.35rem; }
.dlbs-nav__btn {
  align-items: center; background: transparent; border: 1px solid transparent; border-radius: 0.75rem;
  color: var(--muted); cursor: pointer; display: flex; font: inherit; font-size: var(--text-sm);
  gap: 0.65rem; padding: 0.7rem 0.85rem; text-align: left; transition: all 0.22s; width: 100%;
}
.dlbs-nav__btn:hover { background: var(--dlbs-hover); border-color: rgba(212, 184, 122, 0.12); color: var(--dlbs-gold-bright); }
.dlbs-nav__btn.is-active {
  background: var(--dlbs-hover-strong); border-color: rgba(212, 184, 122, 0.28);
  box-shadow: inset 3px 0 0 var(--dlbs-gold); color: var(--dlbs-gold-bright);
}
.dlbs-nav__icon {
  color: var(--dlbs-gold); flex-shrink: 0; font-size: var(--text-xs); opacity: 0.85; width: 1.1rem;
}
.dlbs-nav__label { flex: 1; }
.dlbs-nav__badge {
  background: rgba(232, 168, 106, 0.25); border-radius: 999px; color: var(--dlbs-ember);
  font-size: var(--text-xs); min-width: 1.35rem; padding: 0.1rem 0.45rem; text-align: center;
}
.dlbs-sidebar__foot { display: grid; gap: 0.4rem; margin-top: auto; padding-top: 0.85rem; }

/* Stage — main content column */
.dlbs-stage {
  display: flex; flex-direction: column; min-width: 0; width: 100%;
}
.dlbs-stage__head {
  backdrop-filter: blur(12px);
  background: var(--dlbs-stage-head-bg);
  border-bottom: 1px solid rgba(212, 184, 122, 0.1);
  flex-shrink: 0; padding: 1.35rem 1.25rem 1.1rem;
  display: flex; align-items: flex-end; justify-content: space-between; gap: 1rem;
}
.dlbs-stage__intro { flex: 1; min-width: 0; }
.dlbs-stage__actions { flex-shrink: 0; }
@media (min-width: 900px) { .dlbs-stage__head { padding: 1.75rem 2rem 1.25rem; } }
.dlbs-stage__eyebrow {
  color: var(--muted-soft); font-size: var(--text-xs); letter-spacing: 0.16em;
  margin: 0 0 0.35rem; text-transform: uppercase;
}
.dlbs-stage__title {
  font-family: var(--dlbs-serif); font-size: clamp(1.5rem, 2.5vw, var(--text-2xl));
  font-weight: 600; letter-spacing: -0.01em; line-height: 1.15; margin: 0;
}

.dlbs-main {
  flex: 1; min-width: 0; overflow-x: clip;
  padding: 0 1.25rem calc(5.5rem + env(safe-area-inset-bottom));
}
@media (min-width: 900px) {
  .dlbs-main { padding: 0 2rem 2rem; }
}
.dlbs-main__canvas {
  margin: 0 auto; max-width: 72rem; padding-top: 1.25rem; width: 100%;
}
@media (min-width: 900px) { .dlbs-main__canvas { padding-top: 1.5rem; } }

.dlbs-head { align-items: flex-end; display: flex; flex-wrap: wrap; gap: 1rem; justify-content: space-between; margin-bottom: 1.25rem; }
.dlbs-head__title { font-family: var(--dlbs-serif); font-size: var(--text-2xl); font-weight: 600; margin: 0; }
.dlbs-head__sub { color: var(--muted); font-size: var(--text-md); margin: 0.35rem 0 0; }

/* Hub panels */
.dlbs-hub { display: flex; flex-direction: column; gap: 1.5rem; }
.dlbs-panel {
  backdrop-filter: blur(14px);
  background: var(--dlbs-surface-2);
  border: 1px solid var(--dlbs-line);
  border-radius: 1.15rem;
  box-shadow: var(--dlbs-shadow-sm);
  padding: 1.25rem 1.15rem;
  transition: background 0.35s ease, box-shadow 0.35s ease, border-color 0.35s ease;
}
@media (min-width: 640px) { .dlbs-panel { padding: 1.35rem 1.5rem; } }
.dlbs-panel__head { margin-bottom: 1.1rem; }
.dlbs-panel__label {
  color: var(--muted-soft); font-size: var(--text-xs); letter-spacing: 0.14em;
  margin: 0 0 0.3rem; text-transform: uppercase;
}
.dlbs-panel__title {
  font-family: var(--dlbs-serif); font-size: var(--text-lg); font-weight: 600; margin: 0;
}
.dlbs-panel__sub { color: var(--muted); font-size: var(--text-sm); margin: 0.3rem 0 0; }
.dlbs-panel--recent { border-color: rgba(110, 196, 184, 0.18); }

/* --- Hub --- */
.dlbs-summary {
  display: grid; gap: 0.65rem;
  grid-template-columns: repeat(2, minmax(0, 1fr)); margin-bottom: 0;
}
@media (min-width: 640px) {
  .dlbs-summary { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}
.dlbs-stat {
  backdrop-filter: blur(12px);
  background: var(--dlbs-surface);
  border: 1px solid var(--dlbs-line);
  border-radius: 0.95rem; padding: 0.95rem 1rem;
  box-shadow: var(--dlbs-shadow-sm);
  transition: border-color 0.25s, box-shadow 0.25s;
}
.dlbs-stat:hover { border-color: rgba(212, 184, 122, 0.28); }
.dlbs-stat__val { font-family: var(--dlbs-serif); font-size: var(--text-xl); font-weight: 600; margin: 0; }
.dlbs-stat__label { color: var(--muted); font-size: var(--text-xs); margin: 0.2rem 0 0; }

.dlbs-lines { display: grid; gap: 0.85rem; grid-template-columns: 1fr; width: 100%; }
@media (min-width: 640px) { .dlbs-lines { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (min-width: 960px) { .dlbs-lines { grid-template-columns: repeat(3, minmax(0, 1fr)); } }

.dlbs-line-card {
  backdrop-filter: blur(16px);
  background: var(--dlbs-surface-card-alt);
  border: 1px solid var(--dlbs-line);
  border-radius: 1rem; color: inherit; cursor: pointer; font-family: inherit;
  font-size: var(--text-base); overflow: hidden; padding: 0; position: relative;
  text-align: left; transition: transform 0.25s, border-color 0.25s, box-shadow 0.25s; width: 100%;
}
.dlbs-line-card:hover {
  border-color: rgba(212, 184, 122, 0.38);
  box-shadow: 0 16px 48px rgba(0, 0, 0, 0.4);
  transform: translateY(-3px);
}
.dlbs-line-card__glow {
  height: 3px; inset: 0 0 auto 0; position: absolute;
}
.dlbs-line-card--gold .dlbs-line-card__glow { background: linear-gradient(90deg, var(--dlbs-gold), transparent); }
.dlbs-line-card--violet .dlbs-line-card__glow { background: linear-gradient(90deg, var(--dlbs-violet), transparent); }
.dlbs-line-card--teal .dlbs-line-card__glow { background: linear-gradient(90deg, var(--dlbs-teal), transparent); }
.dlbs-line-card--ember .dlbs-line-card__glow { background: linear-gradient(90deg, var(--dlbs-ember), transparent); }
.dlbs-line-card__body { padding: 1.15rem 1.15rem 1rem; }
.dlbs-line-card__index { color: var(--muted-soft); font-family: var(--dlbs-serif); font-size: var(--text-xs); }
.dlbs-line-card__label { color: var(--dlbs-gold); font-size: var(--text-xs); letter-spacing: 0.12em; margin: 0.25rem 0 0; }
.dlbs-line-card__title { font-family: var(--dlbs-serif); font-size: var(--text-lg); font-weight: 600; margin: 0.35rem 0; }
.dlbs-line-card__price { color: var(--muted); font-size: var(--text-sm); margin: 0; }
.dlbs-line-card__stats {
  border-top: 1px solid var(--dlbs-line); color: var(--muted); display: flex;
  font-size: var(--text-sm); gap: 1rem; margin-top: 0.85rem; padding-top: 0.75rem;
}
.dlbs-line-card__stats strong { color: var(--dlbs-gold-bright); }

/* --- Orders --- */
.dlbs-order-grid {
  display: grid; gap: 0.85rem;
  grid-template-columns: minmax(0, 1fr); width: 100%;
}
@media (min-width: 720px) {
  .dlbs-order-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (min-width: 1200px) {
  .dlbs-order-grid--single { grid-template-columns: minmax(0, 1fr); }
}

.dlbs-order-card {
  backdrop-filter: blur(14px);
  background: var(--dlbs-surface-card);
  border: 1px solid var(--dlbs-line);
  border-radius: 1rem;
  box-shadow: var(--dlbs-shadow-sm);
  display: flex; flex-direction: column;
  overflow: hidden; position: relative;
  text-align: left; transition: border-color 0.25s, box-shadow 0.25s, transform 0.25s;
  width: 100%;
}
.dlbs-order-card--click {
  color: inherit; cursor: pointer; font: inherit; padding: 0;
}
.dlbs-order-card--click:hover {
  border-color: rgba(212, 184, 122, 0.38);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.35);
  transform: translateY(-2px);
}
.dlbs-order-card__media {
  aspect-ratio: 16 / 5; background: center/cover no-repeat;
  box-shadow: inset 0 -24px 40px rgba(0, 0, 0, 0.45);
  flex-shrink: 0; width: 100%;
}
.dlbs-order-card__body {
  display: flex; flex: 1; flex-direction: column; gap: 0.45rem;
  min-width: 0; padding: 1rem 1.1rem 1.05rem; width: 100%;
}
.dlbs-order-card__top {
  align-items: center; display: flex; flex-wrap: wrap;
  gap: 0.45rem 0.65rem; justify-content: space-between;
}
.dlbs-order-card__line {
  color: var(--muted-soft); font-size: var(--text-xs); letter-spacing: 0.12em; text-transform: uppercase;
}
.dlbs-order-card__title {
  font-family: var(--dlbs-serif); font-size: var(--text-md); font-weight: 600;
  line-height: 1.35; margin: 0; word-break: break-word;
}
.dlbs-order-card__sub {
  color: var(--muted); font-size: var(--text-sm); line-height: 1.45;
  margin: 0; word-break: break-word;
}
.dlbs-order-card__meta {
  align-items: center; display: flex; flex-wrap: wrap;
  gap: 0.5rem 0.75rem; margin-top: 0.15rem;
}
.dlbs-order-card__amount { color: var(--dlbs-gold-bright); font-size: var(--text-sm); font-weight: 600; }
.dlbs-order-card__flag {
  background: rgba(232, 168, 106, 0.18); border-radius: 999px;
  color: var(--dlbs-ember); font-size: var(--text-xs); padding: 0.15rem 0.55rem;
}
.dlbs-order-card__flag--pay { background: rgba(232, 168, 106, 0.22); }
.dlbs-order-card__progress { color: var(--muted-soft); font-size: var(--text-xs); margin: 0; }
.dlbs-order-card__cta {
  color: var(--dlbs-gold); font-size: var(--text-xs); letter-spacing: 0.06em;
  margin-top: auto; padding-top: 0.35rem;
}
.dlbs-progress--slim { height: 0.35rem; margin-top: 0.25rem; }

.dlbs-order {
  backdrop-filter: blur(12px); background: var(--dlbs-glass); border: 1px solid var(--dlbs-line);
  border-radius: 1rem; padding: 1.1rem 1.15rem;
}
.dlbs-order__row { align-items: flex-start; display: flex; flex-wrap: wrap; gap: 0.65rem; justify-content: space-between; }
.dlbs-order__title { font-size: var(--text-lg); font-weight: 600; margin: 0; }
.dlbs-order__sub { color: var(--muted); font-size: var(--text-sm); margin: 0.25rem 0 0; }
.dlbs-pill {
  border-radius: 999px; font-size: var(--text-xs); letter-spacing: 0.04em; padding: 0.25rem 0.65rem;
}
.dlbs-pill--active { background: rgba(110, 196, 184, 0.18); color: var(--dlbs-teal); }
.dlbs-pill--review { background: rgba(168, 148, 232, 0.18); color: var(--dlbs-violet); }
.dlbs-pill--completed { background: rgba(212, 184, 122, 0.15); color: var(--dlbs-gold); }
.dlbs-pill--pending { background: rgba(232, 168, 106, 0.15); color: var(--dlbs-ember); }
.dlbs-progress { background: var(--dlbs-progress-track); border-radius: 999px; height: 0.45rem; margin-top: 0.85rem; overflow: hidden; }
.dlbs-progress__fill { background: linear-gradient(90deg, var(--dlbs-gold), var(--dlbs-violet)); border-radius: inherit; height: 100%; transition: width 0.4s; }
.dlbs-milestones { display: grid; gap: 0.45rem; margin-top: 0.85rem; }
.dlbs-milestone {
  align-items: center; color: var(--muted); display: flex; font-size: var(--text-sm); gap: 0.55rem;
}
.dlbs-milestone.is-done { color: var(--dlbs-gold-bright); }
.dlbs-milestone__dot {
  background: var(--dlbs-dot-idle); border-radius: 50%; flex-shrink: 0; height: 0.5rem; width: 0.5rem;
}
.dlbs-milestone.is-done .dlbs-milestone__dot { background: var(--dlbs-gold); box-shadow: 0 0 8px rgba(212,184,122,0.5); }

/* --- Dreamer sub-views (reuse patterns) --- */
.dlbs-bento { display: grid; gap: 0.85rem; grid-template-columns: repeat(12, 1fr); }
.dlbs-card {
  backdrop-filter: blur(12px); background: var(--dlbs-glass); border: 1px solid var(--dlbs-line);
  border-radius: 1rem; padding: 1.1rem 1.15rem;
  transition: background 0.35s ease, box-shadow 0.35s ease;
}
.dlbs-card--span-12 { grid-column: span 12; }
.dlbs-card--span-8 { grid-column: span 12; }
.dlbs-card--span-6 { grid-column: span 12; }
.dlbs-card--span-4 { grid-column: span 12; }
@media (min-width: 768px) {
  .dlbs-card--span-8 { grid-column: span 8; }
  .dlbs-card--span-6 { grid-column: span 6; }
  .dlbs-card--span-4 { grid-column: span 4; }
}
.dlbs-card__label { color: var(--muted-soft); font-size: var(--text-xs); letter-spacing: 0.14em; margin: 0 0 0.35rem; }
.dlbs-card__title { font-family: var(--dlbs-serif); font-size: var(--text-xl); font-weight: 600; margin: 0; }
.dlbs-card__meta { color: var(--muted); font-size: var(--text-sm); margin: 0.35rem 0 0; }

.dlbs-hero__row { align-items: flex-start; display: flex; flex-wrap: wrap; gap: 1rem; justify-content: space-between; }
.dlbs-hero__name { font-family: var(--dlbs-serif); font-size: var(--text-2xl); font-weight: 600; margin: 0.25rem 0; }
.dlbs-tier-badge {
  border-radius: 999px; font-size: var(--text-sm); padding: 0.35rem 0.85rem;
}
.dlbs-tier-badge--starter { background: rgba(212,184,122,0.12); color: var(--dlbs-gold); }
.dlbs-tier-badge--growth { background: rgba(168,148,232,0.15); color: var(--dlbs-violet); }
.dlbs-tier-badge--flagship { background: rgba(232,168,106,0.15); color: var(--dlbs-ember); }

.dlbs-meters { display: grid; gap: 0.65rem; }
.dlbs-meter__top { display: flex; font-size: var(--text-sm); justify-content: space-between; margin-bottom: 0.3rem; }
.dlbs-meter__track { background: rgba(255,255,255,0.06); border-radius: 999px; height: 0.4rem; overflow: hidden; }
.dlbs-meter__fill { background: linear-gradient(90deg, var(--dlbs-gold), var(--dlbs-teal)); border-radius: inherit; height: 100%; }
.dlbs-meter.is-warn .dlbs-meter__fill { background: linear-gradient(90deg, var(--dlbs-ember), #e86464); }

.dlbs-quick { display: grid; gap: 0.5rem; grid-template-columns: repeat(2, 1fr); margin-bottom: 1rem; }
@media (min-width: 640px) { .dlbs-quick { grid-template-columns: repeat(4, 1fr); } }
.dlbs-quick__item {
  background: rgba(212,184,122,0.08); border: 1px solid var(--dlbs-line); border-radius: 0.85rem;
  color: inherit; cursor: pointer; font: inherit; font-size: var(--text-sm); padding: 0.75rem; text-align: center;
}
.dlbs-quick__item:hover { background: rgba(212,184,122,0.16); }

.dlbs-ticket-grid { display: grid; gap: 0.65rem; }
.dlbs-ticket { border-top: 1px solid var(--dlbs-line); padding-top: 0.75rem; }
.dlbs-ticket:first-child { border-top: none; padding-top: 0; }
.dlbs-ticket__title { font-size: var(--text-md); font-weight: 600; margin: 0; }
.dlbs-ticket__meta { color: var(--muted); font-size: var(--text-sm); margin: 0.25rem 0 0; }
.dlbs-reply { background: rgba(255,255,255,0.03); border-radius: 0.5rem; font-size: var(--text-sm); margin-top: 0.45rem; padding: 0.45rem 0.65rem; }

.dlbs-types { display: grid; gap: 0.5rem; grid-template-columns: repeat(auto-fit, minmax(8rem, 1fr)); }
.dlbs-type {
  background: rgba(255,255,255,0.03); border: 1px solid var(--dlbs-line); border-radius: 0.75rem;
  color: inherit; cursor: pointer; font: inherit; padding: 0.75rem; text-align: left;
}
.dlbs-type.is-active { border-color: rgba(212,184,122,0.45); background: rgba(212,184,122,0.1); }
.dlbs-type__name { font-size: var(--text-md); font-weight: 600; }
.dlbs-type__desc { color: var(--muted); font-size: var(--text-xs); margin-top: 0.2rem; }

.dlbs-report-grid { display: grid; gap: 0.75rem; grid-template-columns: repeat(auto-fit, minmax(16rem, 1fr)); }
.dlbs-report { background: var(--dlbs-glass); border: 1px solid var(--dlbs-line); border-radius: 1rem; padding: 1rem; }
.dlbs-report__title { font-size: var(--text-md); font-weight: 600; margin: 0.35rem 0; }
.dlbs-report__summary { color: var(--muted); font-size: var(--text-sm); margin: 0; }

.dlbs-empty { color: var(--muted); font-size: var(--text-md); padding: 2rem 0; text-align: center; }

/* --- Mobile dock --- */
.dlbs-dock {
  backdrop-filter: blur(16px); background: var(--dlbs-dock-bg); border-top: 1px solid var(--dlbs-line);
  box-shadow: 0 -4px 24px rgba(0, 0, 0, 0.06);
  bottom: 0; display: flex; gap: 0.25rem; justify-content: space-around;
  left: 0; padding: 0.45rem 0.5rem calc(0.45rem + env(safe-area-inset-bottom)); position: fixed; right: 0; z-index: 30;
}
@media (min-width: 900px) { .dlbs-dock { display: none; } }
.dlbs-dock__btn {
  align-items: center; background: transparent; border: none; border-radius: 0.65rem;
  color: var(--muted); cursor: pointer; display: flex; flex: 1; flex-direction: column;
  font: inherit; font-size: var(--text-xs); gap: 0.2rem; padding: 0.45rem 0.25rem;
  transition: color 0.2s, background 0.2s;
}
.dlbs-dock__btn.is-active {
  background: rgba(212, 184, 122, 0.1); color: var(--dlbs-gold-bright);
}
.dlbs-dock__icon { font-size: var(--text-sm); line-height: 1; opacity: 0.9; }

.dlbs-loading {
  align-items: center; backdrop-filter: blur(8px); background: var(--dlbs-loading-bg);
  display: none; flex-direction: column; gap: 1rem; inset: 0; justify-content: center;
  pointer-events: none; position: fixed; z-index: 100;
}
.dlbs-loading.is-active {
  display: flex; pointer-events: auto;
}
.dlbs-loading[hidden] { display: none !important; pointer-events: none !important; }
.dlbs-loading__ring {
  animation: dlbs-spin 0.9s linear infinite; border: 2px solid var(--dlbs-line);
  border-radius: 50%; border-top-color: var(--dlbs-gold); height: 2.5rem; width: 2.5rem;
}
@keyframes dlbs-spin { to { transform: rotate(360deg); } }
.dlbs-loading__text { color: var(--muted); font-size: var(--text-md); margin: 0; }
.dlbs-loading__cancel { margin-top: 0.5rem; }

.dlbs-page.dlbs-is-app .dlbs-stage__head {
  padding-top: calc(1.35rem + env(safe-area-inset-top));
}
@media (min-width: 900px) {
  .dlbs-page.dlbs-is-app .dlbs-stage__head { padding-top: 1.75rem; }
}
.dlbs-app { animation: dlbs-rise 0.45s ease-out both; }
@keyframes dlbs-rise {
  from { opacity: 0; transform: translateY(12px); }
  to { opacity: 1; transform: translateY(0); }
}

.dlbs-hub-hero {
  backdrop-filter: blur(16px); background: linear-gradient(135deg, rgba(212,184,122,0.1), rgba(168,148,232,0.08));
  border: 1px solid var(--dlbs-line); border-radius: 1.25rem;
  margin-bottom: 1.25rem; padding: 1.35rem 1.5rem; position: relative; overflow: hidden;
}
.dlbs-hub-hero::after {
  background: linear-gradient(105deg, transparent 40%, rgba(255,255,255,0.06) 50%, transparent 60%);
  content: ""; inset: 0; pointer-events: none; position: absolute;
  animation: dlbs-shimmer 6s ease-in-out infinite;
}
@keyframes dlbs-shimmer {
  0%, 100% { transform: translateX(-120%); }
  50% { transform: translateX(120%); }
}
.dlbs-hub-hero__badge {
  background: rgba(212,184,122,0.12); border: 1px solid rgba(212,184,122,0.25); border-radius: 999px;
  color: var(--dlbs-gold); display: inline-block; font-size: var(--text-xs); letter-spacing: 0.14em;
  margin-bottom: 0.65rem; padding: 0.25rem 0.65rem; text-transform: uppercase;
}
.dlbs-hub-hero__title { font-family: var(--dlbs-serif); font-size: clamp(1.5rem, 3vw, var(--text-3xl)); font-weight: 600; line-height: 1.2; margin: 0.35rem 0; }
.dlbs-hub-hero__sub { color: var(--muted); font-size: var(--text-md); margin: 0; }
.dlbs-gradient-text {
  background: linear-gradient(135deg, var(--dlbs-gold-bright), var(--dlbs-violet));
  -webkit-background-clip: text; background-clip: text; color: transparent;
}

.dlbs-stagger { animation: dlbs-stagger-in 0.55s ease-out both; animation-delay: calc(var(--i, 0) * 0.08s); }
@keyframes dlbs-stagger-in {
  from { opacity: 0; transform: translateY(14px); }
  to { opacity: 1; transform: translateY(0); }
}

.dlbs-stat--glow { box-shadow: 0 0 40px rgba(212,184,122,0.08); }
.dlbs-stat--alert { border-color: rgba(232,168,106,0.45); }
.dlbs-stat--alert .dlbs-stat__val { color: var(--dlbs-ember); }

.dlbs-alert-banner {
  align-items: center; background: linear-gradient(90deg, rgba(232,168,106,0.12), rgba(168,148,232,0.08));
  border: 1px solid rgba(232,168,106,0.35); border-radius: 1rem; display: flex; flex-wrap: wrap;
  gap: 1rem; justify-content: space-between; margin-bottom: 1rem; overflow: hidden;
  padding: 1rem 1.15rem; position: relative;
}
.dlbs-alert-banner__pulse {
  animation: dlbs-pulse 2s ease-in-out infinite; background: rgba(232,168,106,0.25);
  border-radius: 50%; height: 0.55rem; left: 1rem; position: absolute; top: 50%; transform: translateY(-50%);
  width: 0.55rem;
}
.dlbs-alert-banner strong { display: block; margin-left: 1.25rem; }
.dlbs-alert-banner p { color: var(--muted); font-size: var(--text-sm); margin: 0.2rem 0 0 1.25rem; }
@keyframes dlbs-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(232,168,106,0.5); opacity: 1; }
  50% { box-shadow: 0 0 0 8px rgba(232,168,106,0); opacity: 0.6; }
}

.dlbs-quick-dock {
  display: grid; gap: 0.65rem; grid-template-columns: repeat(2, 1fr); margin-bottom: 1.5rem;
}
@media (min-width: 640px) { .dlbs-quick-dock { grid-template-columns: repeat(4, 1fr); } }
.dlbs-quick-dock__item {
  backdrop-filter: blur(12px); background: rgba(255,255,255,0.03); border: 1px solid var(--dlbs-line);
  border-radius: 0.85rem; color: inherit; cursor: pointer; font: inherit; padding: 0.85rem 0.75rem;
  text-align: left; transition: all 0.25s;
}
.dlbs-quick-dock__item:hover { background: rgba(212,184,122,0.1); border-color: rgba(212,184,122,0.35); transform: translateY(-2px); }
.dlbs-quick-dock__item--alert { border-color: rgba(232,168,106,0.45); }
.dlbs-quick-dock__icon {
  color: var(--dlbs-gold); display: block; font-family: var(--dlbs-serif); font-size: var(--text-sm); margin-bottom: 0.35rem;
}

.dlbs-line-card__shine {
  background: linear-gradient(105deg, transparent 42%, rgba(255,255,255,0.07) 50%, transparent 58%);
  inset: 0; opacity: 0; pointer-events: none; position: absolute; transition: opacity 0.3s;
}
.dlbs-line-card:hover .dlbs-line-card__shine { animation: dlbs-card-shine 0.9s ease; opacity: 1; }
@keyframes dlbs-card-shine {
  from { transform: translateX(-100%); }
  to { transform: translateX(100%); }
}
.dlbs-line-card__desc { color: var(--muted); font-size: var(--text-sm); line-height: 1.45; margin: 0.35rem 0 0; }
.dlbs-line-card__pending { color: var(--dlbs-ember); }
.dlbs-line-card { position: relative; overflow: hidden; }

.dlbs-user__ring {
  background: linear-gradient(135deg, var(--dlbs-gold), var(--dlbs-violet)); border-radius: 50%;
  display: inline-block; padding: 2px;
}
.dlbs-user__badge {
  background: rgba(212,184,122,0.12); border: 1px solid var(--dlbs-line); border-radius: 999px;
  color: var(--dlbs-gold); display: inline-block; font-size: var(--text-xs); margin-top: 0.5rem; padding: 0.2rem 0.55rem;
}
.dlbs-app--enter { animation: dlbs-app-in 0.5s ease-out both; }
@keyframes dlbs-app-in {
  from { opacity: 0; filter: blur(4px); }
  to { opacity: 1; filter: blur(0); }
}

.dlbs-line-card__enter {
  color: var(--dlbs-gold); display: block; font-size: var(--text-xs); letter-spacing: 0.08em;
  margin-top: 0.75rem; opacity: 0; transform: translateY(4px); transition: all 0.25s;
}
.dlbs-line-card:hover .dlbs-line-card__enter { opacity: 1; transform: translateY(0); }

.dlbs-auth[hidden] { display: none !important; }

/* --- Templates shop --- */
.dlbs-seg { display: inline-flex; gap: 0.35rem; margin-bottom: 1.25rem; background: rgba(255,255,255,0.04); border-radius: 999px; padding: 0.25rem; }
.dlbs-seg__btn { background: transparent; border: none; border-radius: 999px; color: var(--muted); cursor: pointer; font: inherit; font-size: var(--text-sm); padding: 0.45rem 1rem; }
.dlbs-seg__btn.is-active { background: rgba(212,184,122,0.18); color: var(--dlbs-gold-bright); }
.dlbs-tpl-grid { display: grid; gap: 1rem; grid-template-columns: repeat(auto-fill, minmax(15rem, 1fr)); }
.dlbs-tpl-card { background: var(--dlbs-glass); border: 1px solid var(--dlbs-line); border-radius: 1rem; overflow: hidden; }
.dlbs-tpl-card__cover { aspect-ratio: 4/3; background: rgba(255,255,255,0.05) center/cover no-repeat; box-shadow: inset 0 -40px 60px rgba(0,0,0,0.45); }
.dlbs-tpl-card__body { padding: 1rem; }
.dlbs-tpl-card__ind { color: var(--muted-soft); font-size: var(--text-xs); margin: 0; }
.dlbs-tpl-card__name { font-family: var(--dlbs-serif); font-size: var(--text-lg); margin: 0.35rem 0; }
.dlbs-tpl-card__tag { color: var(--muted); font-size: var(--text-sm); line-height: 1.45; margin: 0 0 0.75rem; min-height: 2.8em; }
.dlbs-tpl-card__foot { align-items: center; display: flex; justify-content: space-between; gap: 0.5rem; }
.dlbs-tpl-card__price { color: var(--dlbs-gold-bright); font-size: var(--text-md); font-weight: 600; }
.dlbs-tpl-card__owned { color: var(--dlbs-teal); font-size: var(--text-xs); }
.dlbs-btn--sm { font-size: var(--text-sm); padding: 0.45rem 0.75rem; }
.dlbs-wechat-chip { background: rgba(212,184,122,0.1); border: 1px solid var(--dlbs-line); border-radius: 999px; color: var(--muted); font-size: var(--text-sm); padding: 0.4rem 0.85rem; white-space: nowrap; }

/* --- Custom --- */
.dlbs-contact-banner { align-items: center; background: linear-gradient(135deg, rgba(168,148,232,0.12), rgba(212,184,122,0.08)); border: 1px solid var(--dlbs-line); border-radius: 1rem; display: flex; flex-wrap: wrap; gap: 1rem; justify-content: space-between; margin-bottom: 1.25rem; padding: 1.1rem 1.25rem; }
.dlbs-contact-banner h3 { font-size: var(--text-md); margin: 0 0 0.25rem; }
.dlbs-contact-banner p { color: var(--muted); font-size: var(--text-sm); margin: 0; }
.dlbs-contact-banner__wx { text-align: right; }
.dlbs-contact-banner__wx span { color: var(--muted-soft); display: block; font-size: var(--text-xs); }
.dlbs-contact-banner__wx strong { color: var(--dlbs-gold-bright); font-size: var(--text-lg); }

/* --- Order detail --- */
.dlbs-order__badge { color: var(--dlbs-ember); display: inline-block; font-size: var(--text-xs); margin-top: 0.35rem; }
.dlbs-detail-grid { display: grid; gap: 0.85rem; grid-template-columns: repeat(12, 1fr); }
.dlbs-progress--lg { height: 0.55rem; margin-top: 0.5rem; }
.dlbs-timeline { border-left: 1px solid var(--dlbs-line); margin-left: 0.5rem; padding-left: 1.25rem; }
.dlbs-timeline__item { margin-bottom: 1rem; position: relative; }
.dlbs-timeline__dot { background: var(--dlbs-gold); border-radius: 50%; height: 0.55rem; left: -1.55rem; position: absolute; top: 0.35rem; width: 0.55rem; }
.dlbs-timeline__item--user .dlbs-timeline__dot { background: var(--dlbs-teal); }
.dlbs-timeline__meta { color: var(--muted-soft); font-size: var(--text-xs); margin: 0 0 0.2rem; }
.dlbs-timeline__title { font-size: var(--text-md); font-weight: 600; margin: 0 0 0.25rem; }
.dlbs-timeline__body { color: var(--muted); font-size: var(--text-sm); margin: 0; }
.dlbs-action-grid { display: grid; gap: 0.75rem; }
.dlbs-action { background: rgba(255,255,255,0.03); border: 1px solid var(--dlbs-line); border-radius: 0.85rem; padding: 1rem; }
.dlbs-action--preview { border-color: rgba(168,148,232,0.35); }
.dlbs-action--info { border-color: rgba(232,168,106,0.35); }
.dlbs-action--done { opacity: 0.72; }
.dlbs-action__label { color: var(--dlbs-ember); font-size: var(--text-xs); letter-spacing: 0.08em; margin: 0 0 0.35rem; text-transform: uppercase; }
.dlbs-action__body { color: var(--muted); font-size: var(--text-sm); margin: 0.35rem 0 0.75rem; }
.dlbs-action__fields { color: var(--muted); font-size: var(--text-sm); margin: 0 0 0.75rem; padding-left: 1.1rem; }
.dlbs-action__form textarea { width: 100%; margin-bottom: 0.5rem; }
.dlbs-action__btns { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-top: 0.5rem; }
.dlbs-coming-soon { padding: 3rem 1rem; text-align: center; }
.dlbs-coming-soon h2 { font-family: var(--dlbs-serif); font-size: var(--text-2xl); }

/* --- Dreamer subscribe --- */
.dlbs-dreamer-gate__hero { margin-bottom: 1.5rem; text-align: center; }
.dlbs-dreamer-gate__title { font-family: var(--dlbs-serif); font-size: clamp(1.75rem, 4vw, 2.5rem); font-weight: 600; line-height: 1.15; margin: 0.5rem 0; }
.dlbs-dreamer-gate__lead { color: var(--muted); font-size: var(--text-md); margin: 0 auto; max-width: 32rem; }
.dlbs-plan-grid { display: grid; gap: 1rem; grid-template-columns: repeat(auto-fit, minmax(16rem, 1fr)); }
.dlbs-plan { backdrop-filter: blur(16px); background: var(--dlbs-glass); border: 1px solid var(--dlbs-line); border-radius: 1.15rem; display: flex; flex-direction: column; padding: 1.25rem; position: relative; }
.dlbs-plan--featured { background: linear-gradient(160deg, rgba(212,184,122,0.14), rgba(168,148,232,0.1)); border-color: rgba(212,184,122,0.4); box-shadow: 0 20px 60px rgba(0,0,0,0.35); }
.dlbs-plan--featured::before { background: var(--dlbs-gold); border-radius: 999px; color: var(--dlbs-ink); content: "最受欢迎"; font-size: var(--text-xs); font-weight: 600; left: 50%; padding: 0.2rem 0.65rem; position: absolute; top: -0.55rem; transform: translateX(-50%); }
.dlbs-plan__note { color: var(--muted-soft); font-size: var(--text-xs); margin: 0; }
.dlbs-plan__name { font-family: var(--dlbs-serif); font-size: var(--text-xl); margin: 0.35rem 0; }
.dlbs-plan__price { font-size: var(--text-2xl); font-weight: 600; margin: 0; }
.dlbs-plan__price span { color: var(--dlbs-gold-bright); }
.dlbs-plan__equiv { color: var(--muted); font-size: var(--text-xs); margin: 0.25rem 0 0.75rem; }
.dlbs-plan__list { color: var(--muted); flex: 1; font-size: var(--text-sm); line-height: 1.5; margin: 0 0 0.75rem; padding-left: 1.1rem; }
.dlbs-plan__meta { color: var(--muted-soft); font-size: var(--text-xs); margin-bottom: 0.75rem; }
.dlbs-plan__form input { margin-bottom: 0.5rem; width: 100%; }
.dlbs-nav--inline { flex-direction: row; flex-wrap: wrap; margin-bottom: 1rem; }

.dlbs-toast {
  background: var(--dlbs-toast-bg); border: 1px solid var(--dlbs-line); border-radius: 0.65rem;
  bottom: calc(4.5rem + env(safe-area-inset-bottom)); box-shadow: var(--dlbs-shadow-md); color: var(--dlbs-gold-bright);
  font-size: var(--text-md); left: 50%; opacity: 0; padding: 0.75rem 1.1rem;
  pointer-events: none; position: fixed; transform: translateX(-50%) translateY(0.5rem);
  transition: all 0.25s; z-index: 50;
}
.dlbs-toast.is-visible { opacity: 1; transform: translateX(-50%) translateY(0); }
@media (min-width: 900px) { .dlbs-toast { bottom: 1.5rem; } }

.dlbs-back {
  align-items: center; background: transparent; border: none; color: var(--muted);
  cursor: pointer; display: inline-flex; font: inherit; font-size: var(--text-sm); gap: 0.35rem; margin-bottom: 0.75rem; padding: 0;
}
.dlbs-back:hover { color: var(--dlbs-gold-bright); }

/* --- Membership chip & modal --- */
.dlbs-membership-chip {
  align-items: center; background: linear-gradient(135deg, rgba(212,184,122,0.12), rgba(168,148,232,0.08));
  border: 1px solid rgba(212,184,122,0.28); border-radius: 0.85rem; cursor: pointer;
  display: flex; flex-wrap: wrap; gap: 0.35rem 0.65rem; padding: 0.55rem 0.75rem;
  position: relative; text-align: left; transition: border-color 0.25s, box-shadow 0.25s, transform 0.2s;
  width: 100%; overflow: hidden;
}
.dlbs-membership-chip:hover {
  border-color: rgba(212,184,122,0.5); box-shadow: 0 8px 28px rgba(0,0,0,0.35); transform: translateY(-1px);
}
.dlbs-membership-chip__spark {
  background: linear-gradient(90deg, transparent, rgba(240,223,168,0.35), transparent);
  height: 100%; left: -40%; pointer-events: none; position: absolute; top: 0; width: 40%;
  animation: dlbs-chip-shine 3.5s ease-in-out infinite;
}
@keyframes dlbs-chip-shine {
  0%, 80% { transform: translateX(0); opacity: 0; }
  90% { opacity: 1; }
  100% { transform: translateX(320%); opacity: 0; }
}
.dlbs-membership-chip__label {
  color: var(--muted-soft); font-size: var(--text-xs); letter-spacing: 0.14em; text-transform: uppercase; width: 100%;
}
.dlbs-membership-chip__tier {
  color: var(--dlbs-gold-bright); font-family: var(--dlbs-serif); font-size: var(--text-md); font-weight: 600;
}
.dlbs-membership-chip__price {
  color: var(--dlbs-gold); font-size: var(--text-sm); font-weight: 600;
}
.dlbs-membership-chip__price small { color: var(--muted); font-size: var(--text-xs); font-weight: 400; }
.dlbs-membership-chip__cta {
  color: var(--muted); font-size: var(--text-xs); margin-left: auto;
}
.dlbs-membership-chip__guest { color: var(--muted); font-size: var(--text-sm); }
.dlbs-membership-chip--starter { border-color: rgba(110,196,184,0.35); background: linear-gradient(135deg, rgba(110,196,184,0.1), rgba(212,184,122,0.06)); }
.dlbs-membership-chip--growth { border-color: rgba(212,184,122,0.45); background: linear-gradient(135deg, rgba(212,184,122,0.16), rgba(168,148,232,0.08)); }
.dlbs-membership-chip--flagship {
  border-color: rgba(168,148,232,0.45);
  background: linear-gradient(135deg, rgba(168,148,232,0.14), rgba(212,184,122,0.1));
  box-shadow: 0 0 24px rgba(168,148,232,0.12);
}
.dlbs-membership-chip--guest { border-style: dashed; }

.dlbs-modal-overlay {
  align-items: center; backdrop-filter: blur(8px); background: rgba(6,5,8,0.72);
  display: flex; inset: 0; justify-content: center; opacity: 0; padding: 1rem;
  pointer-events: none; position: fixed; transition: opacity 0.3s; z-index: 100;
}
.dlbs-modal-overlay.is-open { opacity: 1; pointer-events: auto; }
.dlbs-modal {
  background: var(--dlbs-modal-bg);
  border: 1px solid var(--dlbs-line); border-radius: 1.35rem;
  box-shadow: var(--dlbs-shadow-lg); max-height: min(92dvh, 52rem);
  max-width: 44rem; overflow: hidden; position: relative; transform: translateY(1rem) scale(0.98);
  transition: transform 0.35s cubic-bezier(0.22, 1, 0.36, 1); width: 100%;
}
.dlbs-modal-overlay.is-open .dlbs-modal { transform: translateY(0) scale(1); }
.dlbs-modal__hero {
  background: var(--dlbs-modal-hero);
  border-bottom: 1px solid var(--dlbs-line); padding: 1.35rem 1.35rem 1.1rem; position: relative;
}
.dlbs-modal__close {
  align-items: center; background: rgba(255,255,255,0.06); border: 1px solid var(--dlbs-line);
  border-radius: 999px; color: var(--muted); cursor: pointer; display: flex; height: 2rem;
  justify-content: center; position: absolute; right: 1rem; top: 1rem; width: 2rem;
}
.dlbs-modal__close:hover { color: var(--dlbs-gold-bright); }
.dlbs-modal__eyebrow { color: var(--dlbs-gold); font-size: var(--text-xs); letter-spacing: 0.2em; margin: 0; text-transform: uppercase; }
.dlbs-modal__title { font-family: var(--dlbs-serif); font-size: var(--text-2xl); font-weight: 600; line-height: 1.2; margin: 0.35rem 0; }
.dlbs-modal__lead { color: var(--muted); font-size: var(--text-sm); line-height: 1.5; margin: 0; max-width: 32rem; }
.dlbs-modal__body { max-height: calc(92dvh - 10rem); overflow-y: auto; padding: 1.1rem 1.35rem 1.35rem; }
.dlbs-modal__current {
  align-items: center; background: rgba(212,184,122,0.08); border: 1px solid rgba(212,184,122,0.25);
  border-radius: 1rem; display: flex; flex-wrap: wrap; gap: 0.75rem 1rem; margin-bottom: 1rem; padding: 0.85rem 1rem;
}
.dlbs-modal__current-tier { font-family: var(--dlbs-serif); font-size: var(--text-xl); font-weight: 600; margin: 0; }
.dlbs-modal__current-meta { color: var(--muted); font-size: var(--text-sm); margin: 0; }
.dlbs-modal__plans { display: grid; gap: 0.85rem; }
.dlbs-modal-plan {
  background: rgba(255,255,255,0.02); border: 1px solid var(--dlbs-line); border-radius: 1rem;
  padding: 1rem 1.05rem; position: relative;
}
.dlbs-modal-plan.is-current { border-color: rgba(110,196,184,0.45); background: rgba(110,196,184,0.06); }
.dlbs-modal-plan.is-featured { border-color: rgba(212,184,122,0.4); background: linear-gradient(160deg, rgba(212,184,122,0.1), rgba(168,148,232,0.06)); }
.dlbs-modal-plan.is-upgrade { border-color: rgba(168,148,232,0.35); }
.dlbs-modal-plan__badge {
  background: rgba(212,184,122,0.18); border-radius: 999px; color: var(--dlbs-gold);
  display: inline-block; font-size: var(--text-xs); margin-bottom: 0.35rem; padding: 0.15rem 0.5rem;
}
.dlbs-modal-plan__head { align-items: flex-start; display: flex; flex-wrap: wrap; gap: 0.5rem 1rem; justify-content: space-between; margin-bottom: 0.65rem; }
.dlbs-modal-plan__name { font-family: var(--dlbs-serif); font-size: var(--text-lg); font-weight: 600; margin: 0; }
.dlbs-modal-plan__price { color: var(--dlbs-gold-bright); font-size: var(--text-xl); font-weight: 600; margin: 0; }
.dlbs-modal-plan__price small { color: var(--muted); font-size: var(--text-xs); font-weight: 400; }
.dlbs-modal-plan__list { color: var(--muted); font-size: var(--text-sm); line-height: 1.55; margin: 0 0 0.75rem; padding-left: 1.1rem; }
.dlbs-modal-plan__foot { align-items: center; display: flex; flex-wrap: wrap; gap: 0.5rem; justify-content: space-between; }
.dlbs-modal-plan__meta { color: var(--muted-soft); font-size: var(--text-xs); }
.dlbs-modal__foot {
  border-top: 1px solid var(--dlbs-line); display: flex; flex-wrap: wrap; gap: 0.65rem;
  justify-content: space-between; margin-top: 1rem; padding-top: 1rem;
}
.dlbs-modal__hint { color: var(--muted-soft); font-size: var(--text-xs); margin: 0; max-width: 18rem; }

/* --- Payment & flow UX --- */
.dlbs-pay-banner {
  align-items: flex-start; background: linear-gradient(135deg, rgba(232,168,106,0.12), rgba(212,184,122,0.08));
  border: 1px solid rgba(232,168,106,0.35); border-radius: 1rem; display: flex; gap: 0.85rem;
  margin-bottom: 1.25rem; padding: 1rem 1.1rem;
}
.dlbs-pay-banner__icon {
  align-items: center; background: rgba(232,168,106,0.2); border-radius: 0.65rem; color: var(--dlbs-ember);
  display: flex; flex-shrink: 0; font-family: var(--dlbs-serif); font-size: var(--text-lg); font-weight: 600;
  height: 2.5rem; justify-content: center; width: 2.5rem;
}
.dlbs-pay-banner strong { color: var(--dlbs-gold-bright); display: block; margin-bottom: 0.25rem; }
.dlbs-pay-banner p { color: var(--muted); font-size: var(--text-sm); line-height: 1.5; margin: 0; }
.dlbs-pay-banner__wx { color: var(--dlbs-gold-bright); font-weight: 600; }
.dlbs-order__badge--pay { background: rgba(232,168,106,0.2); color: var(--dlbs-ember); }

.dlbs-pay-checkout {
  background: linear-gradient(165deg, rgba(18, 17, 20, 0.98), rgba(12, 11, 13, 0.96));
  border: 1px solid rgba(212, 184, 122, 0.28);
  border-radius: 1.15rem;
  margin-bottom: 1.25rem;
  overflow: hidden;
}
.dlbs-pay-checkout__hero {
  background: linear-gradient(135deg, rgba(232, 168, 106, 0.14), rgba(212, 184, 122, 0.06));
  border-bottom: 1px solid rgba(212, 184, 122, 0.18);
  padding: 1.15rem 1.25rem 1rem;
  text-align: center;
}
.dlbs-pay-checkout__eyebrow {
  color: var(--muted);
  font-size: var(--text-sm);
  margin: 0 0 0.35rem;
}
.dlbs-pay-checkout__amount {
  color: var(--dlbs-gold-bright);
  font-family: var(--dlbs-serif);
  font-size: clamp(2.2rem, 8vw, 3rem);
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1;
  margin: 0;
}
.dlbs-pay-checkout__amount span {
  font-size: 0.55em;
  margin-right: 0.08em;
  opacity: 0.85;
}
.dlbs-pay-checkout__hint {
  color: var(--muted-soft);
  font-size: var(--text-xs);
  line-height: 1.45;
  margin: 0.55rem 0 0;
}
.dlbs-pay-checkout__methods {
  display: grid;
  gap: 0.45rem;
  grid-template-columns: 1fr 1fr;
  padding: 0.75rem 1rem 0;
}
.dlbs-pay-tab {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--dlbs-line);
  border-radius: 999px;
  color: var(--muted);
  cursor: pointer;
  font: inherit;
  font-size: var(--text-sm);
  padding: 0.45rem 0.75rem;
  transition: border-color 0.2s, background 0.2s, color 0.2s;
}
.dlbs-pay-tab.is-active {
  background: rgba(7, 193, 96, 0.12);
  border-color: rgba(7, 193, 96, 0.45);
  color: #9ae6b4;
}
.dlbs-pay-tab[data-pay-tab="alipay"].is-active {
  background: rgba(22, 119, 255, 0.12);
  border-color: rgba(22, 119, 255, 0.45);
  color: #9ec5ff;
}
.dlbs-pay-checkout__body {
  display: grid;
  gap: 1rem;
  grid-template-columns: minmax(0, 1fr);
  padding: 1rem 1.15rem 1.15rem;
}
@media (min-width: 720px) {
  .dlbs-pay-checkout__body {
    grid-template-columns: minmax(180px, 220px) minmax(0, 1fr);
    align-items: start;
  }
}
.dlbs-pay-checkout__qr {
  background: #fff;
  border-radius: 1rem;
  padding: 0.75rem;
  text-align: center;
}
.dlbs-pay-checkout__qr img {
  display: block;
  height: auto;
  margin: 0 auto;
  max-width: 100%;
  width: min(100%, 200px);
}
.dlbs-pay-checkout__scan {
  color: #666;
  font-size: 11px;
  line-height: 1.45;
  margin: 0.55rem 0 0;
}
.dlbs-pay-checkout__steps {
  color: var(--muted);
  font-size: var(--text-sm);
  line-height: 1.55;
  margin: 0 0 0.85rem;
  padding-left: 1.1rem;
}
.dlbs-pay-checkout__steps em {
  color: var(--dlbs-gold-bright);
  font-style: normal;
  font-weight: 600;
}
.dlbs-pay-checkout__copy {
  display: grid;
  gap: 0.5rem;
  margin-bottom: 0.65rem;
}
.dlbs-pay-checkout__memo {
  color: var(--muted-soft);
  font-size: var(--text-xs);
  line-height: 1.45;
  margin: 0 0 0.65rem;
}
.dlbs-pay-checkout__done { margin-bottom: 0.45rem; }
.dlbs-pay-checkout__secure {
  color: var(--muted-soft);
  font-size: var(--text-xs);
  margin: 0;
  text-align: center;
}
.dlbs-pay-checkout--done {
  padding: 1rem 1.15rem;
}
.dlbs-pay-checkout__status {
  align-items: flex-start;
  display: flex;
  gap: 0.75rem;
}
.dlbs-pay-checkout__status-icon {
  align-items: center;
  background: rgba(110, 196, 184, 0.18);
  border-radius: 999px;
  color: #9ae6d0;
  display: flex;
  flex-shrink: 0;
  font-size: 1rem;
  height: 2rem;
  justify-content: center;
  width: 2rem;
}
.dlbs-pay-checkout__status strong {
  color: var(--dlbs-gold-bright);
  display: block;
  margin-bottom: 0.25rem;
}
.dlbs-pay-checkout__status p {
  color: var(--muted);
  font-size: var(--text-sm);
  line-height: 1.5;
  margin: 0;
}
.dlbs-pay-checkout__foot {
  color: var(--muted-soft);
  font-size: var(--text-xs);
  margin: 0.75rem 0 0;
}

.dlbs-pay-sheet {
  inset: 0;
  position: fixed;
  z-index: 120;
}
.dlbs-pay-sheet__backdrop {
  background: rgba(4, 4, 6, 0.72);
  backdrop-filter: blur(6px);
  inset: 0;
  position: absolute;
}
.dlbs-pay-sheet__panel {
  background: var(--dlbs-surface, #121114);
  border: 1px solid rgba(212, 184, 122, 0.22);
  border-radius: 1.25rem 1.25rem 0 0;
  bottom: 0;
  box-shadow: 0 -24px 80px rgba(0, 0, 0, 0.45);
  left: 0;
  max-height: min(94vh, 820px);
  overflow-y: auto;
  padding: 0.85rem 1rem calc(1.25rem + env(safe-area-inset-bottom));
  position: absolute;
  right: 0;
}
@media (min-width: 720px) {
  .dlbs-pay-sheet__panel {
    border-radius: 1.25rem;
    bottom: auto;
    left: 50%;
    max-width: 720px;
    top: 50%;
    transform: translate(-50%, -50%);
    width: calc(100% - 2rem);
  }
}
.dlbs-pay-sheet__close {
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid var(--dlbs-line);
  border-radius: 999px;
  color: var(--muted);
  cursor: pointer;
  font-size: 1.25rem;
  height: 2rem;
  line-height: 1;
  position: absolute;
  right: 0.85rem;
  top: 0.85rem;
  width: 2rem;
  z-index: 2;
}
.dlbs-pay-sheet__head {
  margin-bottom: 0.65rem;
  padding-right: 2.5rem;
}
.dlbs-pay-sheet__head h2 {
  font-family: var(--dlbs-serif);
  font-size: var(--text-xl);
  margin: 0 0 0.2rem;
}
.dlbs-pay-sheet__head p {
  color: var(--muted);
  font-size: var(--text-sm);
  margin: 0;
}
.dlbs-pay-sheet .dlbs-pay-checkout {
  margin-bottom: 0;
}

.dlbs-flow-dock {
  display: flex; flex-wrap: wrap; gap: 0.5rem; margin-bottom: 1rem; position: sticky; top: 3.75rem; z-index: 5;
}
.dlbs-flow-dock__item {
  align-items: center; background: rgba(212,184,122,0.12); border: 1px solid rgba(212,184,122,0.3);
  border-radius: 999px; color: var(--dlbs-gold-bright); cursor: pointer; display: inline-flex;
  font-size: var(--text-sm); gap: 0.4rem; padding: 0.45rem 0.85rem; transition: background 0.2s;
}
.dlbs-flow-dock__item:hover { background: rgba(212,184,122,0.22); }
.dlbs-flow-dock__dot { background: var(--dlbs-ember); border-radius: 50%; height: 0.45rem; width: 0.45rem; }

.dlbs-action__btns--row { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-top: 0.65rem; }
.dlbs-action__note { color: var(--muted); font-size: var(--text-sm); margin-top: 0.65rem; }
.dlbs-action__note summary { cursor: pointer; }
.dlbs-field--compact { margin-bottom: 0.55rem; }
.dlbs-field--compact label { color: var(--muted-soft); display: block; font-size: var(--text-xs); margin-bottom: 0.2rem; }
.dlbs-field--compact input {
  background: rgba(255,255,255,0.04); border: 1px solid var(--dlbs-line); border-radius: 0.55rem;
  color: inherit; padding: 0.55rem 0.65rem; width: 100%;
}

/* --- Ticket quick UX --- */
.dlbs-ticket--click {
  background: var(--dlbs-glass); border: 1px solid var(--dlbs-line); border-radius: 1rem; cursor: pointer;
  padding: 0.85rem 1rem; text-align: left; transition: border-color 0.2s, transform 0.2s; width: 100%;
  color: inherit; font: inherit;
}
.dlbs-ticket--click:hover { border-color: rgba(212,184,122,0.35); transform: translateY(-1px); }
.dlbs-ticket__preview { color: var(--muted); font-size: var(--text-sm); line-height: 1.45; margin: 0.35rem 0 0; }
.dlbs-ticket__enter { color: var(--dlbs-gold); display: block; font-size: var(--text-xs); margin-top: 0.5rem; }
.dlbs-ticket-quick { max-width: 32rem; }
.dlbs-ticket-quick__lead { color: var(--muted); font-size: var(--text-sm); margin: 0 0 0.85rem; }
.dlbs-ticket-quick input, .dlbs-ticket-quick textarea {
  background: var(--dlbs-input-bg); border: 1px solid var(--dlbs-line); border-radius: 0.65rem;
  color: inherit; display: block; font: inherit; margin-bottom: 0.65rem; padding: 0.65rem 0.75rem; width: 100%;
}
.dlbs-types--row { display: flex; flex-wrap: wrap; gap: 0.4rem; margin-bottom: 0.75rem; }
.dlbs-type--compact {
  background: rgba(255,255,255,0.04); border: 1px solid var(--dlbs-line); border-radius: 999px;
  color: var(--muted); cursor: pointer; font-size: var(--text-sm); padding: 0.35rem 0.75rem;
}
.dlbs-type--compact.is-active { background: rgba(212,184,122,0.18); border-color: rgba(212,184,122,0.4); color: var(--dlbs-gold-bright); }
.dlbs-ticket-desc {
  background: rgba(255,255,255,0.03); border: 1px solid var(--dlbs-line); border-radius: 0.75rem;
  color: var(--muted); font-size: var(--text-sm); line-height: 1.5; margin-bottom: 1rem; padding: 0.75rem 0.85rem;
}
.dlbs-chat { display: flex; flex-direction: column; gap: 0.65rem; margin-bottom: 1rem; max-height: 50vh; overflow-y: auto; }
.dlbs-chat__meta { color: var(--muted-soft); font-size: var(--text-xs); margin: 0 0 0.2rem; }
.dlbs-chat__bubble {
  background: rgba(255,255,255,0.04); border: 1px solid var(--dlbs-line); border-radius: 0.85rem;
  display: inline-block; font-size: var(--text-sm); line-height: 1.5; max-width: 92%; padding: 0.65rem 0.85rem;
}
.dlbs-chat__item--me .dlbs-chat__bubble { background: rgba(110,196,184,0.1); border-color: rgba(110,196,184,0.3); }
.dlbs-chat__item--staff .dlbs-chat__bubble { background: rgba(212,184,122,0.1); border-color: rgba(212,184,122,0.25); }
.dlbs-chat__item--me { align-self: flex-end; text-align: right; }
.dlbs-reply-bar {
  align-items: center; background: rgba(12,11,13,0.95); border: 1px solid var(--dlbs-line); border-radius: 999px;
  bottom: calc(4.5rem + env(safe-area-inset-bottom)); display: flex; gap: 0.5rem;
  left: 1rem; padding: 0.35rem 0.35rem 0.35rem 1rem; position: fixed; right: 1rem; z-index: 15;
}
@media (min-width: 900px) {
  .dlbs-reply-bar { left: calc(var(--dlbs-sidebar) + 1.5rem); max-width: 36rem; right: auto; bottom: 1.5rem; }
}
.dlbs-reply-bar input {
  background: transparent; border: none; color: inherit; flex: 1; font: inherit; font-size: var(--text-md); outline: none;
}
.dlbs-reply-bar .dlbs-btn { border-radius: 999px; flex-shrink: 0; }

/* --- Custom workflow --- */
.dlbs-custom-flow {
  display: flex; align-items: center; flex-wrap: wrap; gap: 0.25rem 0;
  margin-bottom: 1.25rem; overflow-x: auto; padding-bottom: 0.25rem;
}
.dlbs-custom-flow__step {
  align-items: center; color: var(--muted-soft); display: flex; flex-direction: column;
  font-size: var(--text-xs); gap: 0.35rem; min-width: 3.5rem; text-align: center;
}
.dlbs-custom-flow__step span {
  align-items: center; border: 1px solid rgba(212, 184, 122, 0.2); border-radius: 50%;
  color: var(--muted); display: flex; font-size: var(--text-xs); height: 1.65rem; justify-content: center; width: 1.65rem;
}
.dlbs-custom-flow__step.is-done { color: var(--dlbs-gold-bright); }
.dlbs-custom-flow__step.is-done span {
  background: rgba(212, 184, 122, 0.15); border-color: rgba(212, 184, 122, 0.45); color: var(--dlbs-gold);
}
.dlbs-custom-flow__line {
  background: rgba(212, 184, 122, 0.15); flex: 1; height: 1px; min-width: 1rem;
}
.dlbs-panel--custom { border-color: rgba(168, 148, 232, 0.2); }
.dlbs-custom-modes {
  display: grid; gap: 0.85rem; grid-template-columns: 1fr;
}
@media (min-width: 640px) { .dlbs-custom-modes { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
.dlbs-custom-mode {
  background: var(--dlbs-surface-card-alt);
  border: 1px solid var(--dlbs-line); border-radius: 1rem; color: inherit;
  cursor: pointer; font: inherit; padding: 1.15rem 1.1rem; text-align: left;
  transition: border-color 0.25s, transform 0.25s, box-shadow 0.25s; width: 100%;
}
.dlbs-custom-mode:hover {
  border-color: rgba(212, 184, 122, 0.38); box-shadow: 0 12px 36px rgba(0, 0, 0, 0.35); transform: translateY(-2px);
}
.dlbs-custom-mode__tag {
  color: var(--muted-soft); font-size: var(--text-xs); letter-spacing: 0.14em;
}
.dlbs-custom-mode__title {
  font-family: var(--dlbs-serif); font-size: var(--text-lg); font-weight: 600; margin: 0.45rem 0 0.25rem;
}
.dlbs-custom-mode__tagline { color: var(--muted); font-size: var(--text-sm); line-height: 1.45; margin: 0; }
.dlbs-custom-mode__desc { color: var(--muted-soft); font-size: var(--text-xs); margin: 0.35rem 0 0; }
.dlbs-custom-mode__cta { color: var(--dlbs-gold); display: block; font-size: var(--text-xs); margin-top: 0.75rem; }
.dlbs-custom-form { display: flex; flex-direction: column; gap: 0; }
.dlbs-custom-form__grid {
  display: grid; gap: 0.65rem; grid-template-columns: 1fr;
}
@media (min-width: 640px) { .dlbs-custom-form__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
.dlbs-custom-form__hint {
  color: var(--muted); font-size: var(--text-sm); line-height: 1.5; margin: 0.5rem 0 0.85rem;
}
.dlbs-custom-form textarea { min-height: 4.5rem; resize: vertical; }
.dlbs-custom-start-row { margin-bottom: 1rem; }
.dlbs-custom-wechat {
  align-items: center; background: rgba(255, 255, 255, 0.03); border: 1px solid var(--dlbs-line);
  border-radius: 999px; display: flex; flex-wrap: wrap; gap: 0.5rem 0.75rem;
  margin-bottom: 1.25rem; padding: 0.55rem 0.85rem; width: fit-content;
}
.dlbs-custom-wechat span { color: var(--muted-soft); font-size: var(--text-xs); }
.dlbs-custom-wechat strong { color: var(--dlbs-gold-bright); font-size: var(--text-sm); }
.dlbs-head__mode {
  color: var(--dlbs-violet); font-size: var(--text-xs); letter-spacing: 0.14em;
  margin: 0 0 0.25rem; text-transform: uppercase;
}
.dlbs-custom-brief { margin-bottom: 0.85rem; }
.dlbs-custom-brief__grid {
  align-items: flex-start; display: flex; flex-wrap: wrap; gap: 1rem; justify-content: space-between;
}
.dlbs-custom-brief__note { color: var(--muted); font-size: var(--text-sm); line-height: 1.5; margin: 0.5rem 0 0; }
.dlbs-custom-ref-link {
  color: var(--dlbs-gold); font-size: var(--text-sm); text-decoration: none; word-break: break-all;
}
.dlbs-custom-ref-link:hover { text-decoration: underline; }
.dlbs-custom-dl { display: grid; gap: 0.45rem; margin: 0.65rem 0 0; }
.dlbs-custom-dl div { display: grid; gap: 0.15rem; grid-template-columns: 4rem 1fr; }
.dlbs-custom-dl dt { color: var(--muted-soft); font-size: var(--text-xs); }
.dlbs-custom-dl dd { color: var(--muted); font-size: var(--text-sm); margin: 0; }
.dlbs-custom-quote { margin-bottom: 0.85rem; }
.dlbs-custom-quote--pending { border-color: rgba(168, 148, 232, 0.35); }
.dlbs-custom-quote__head {
  align-items: center; display: flex; flex-wrap: wrap; gap: 0.65rem; justify-content: space-between; margin: 0.35rem 0;
}
.dlbs-custom-quote__amount {
  color: var(--dlbs-gold-bright); font-family: var(--dlbs-serif); font-size: var(--text-xl); font-weight: 600;
}
.dlbs-custom-quote__body, .dlbs-custom-quote__note {
  color: var(--muted); font-size: var(--text-sm); line-height: 1.55; margin: 0.35rem 0 0; white-space: pre-wrap;
}
.dlbs-action--quote { border-color: rgba(168, 148, 232, 0.35); }
.dlbs-action__quote-body {
  background: var(--dlbs-subtle); border-radius: 0.65rem; color: var(--muted);
  font-family: inherit; font-size: var(--text-sm); line-height: 1.55; margin: 0.5rem 0 0.75rem;
  padding: 0.75rem 0.85rem; white-space: pre-wrap;
}

/* --- Theme icon (minimal) --- */
.dlbs-theme-icon {
  align-items: center; background: var(--dlbs-subtle); border: 1px solid var(--dlbs-line);
  border-radius: 50%; color: var(--muted); cursor: pointer; display: inline-flex;
  height: 2.35rem; justify-content: center; padding: 0; transition: color 0.22s, background 0.22s, border-color 0.22s, transform 0.2s;
  width: 2.35rem;
}
.dlbs-theme-icon:hover {
  background: var(--dlbs-hover-strong); border-color: rgba(212, 184, 122, 0.35);
  color: var(--dlbs-gold-bright); transform: translateY(-1px);
}
.dlbs-theme-icon__svg { height: 1.05rem; width: 1.05rem; }

/* --- Shopify connect --- */
.dlbs-panel--shopify {
  border-color: rgba(110, 196, 184, 0.22);
  overflow: hidden;
  padding-top: 0;
}
.dlbs-panel--shopify-connected { border-color: rgba(110, 196, 184, 0.35); }
.dlbs-shopify-brandbar {
  align-items: center;
  background: linear-gradient(135deg, rgba(149, 191, 71, 0.1), rgba(110, 196, 184, 0.06));
  border-bottom: 1px solid var(--dlbs-line);
  display: flex;
  gap: 0.75rem;
  justify-content: space-between;
  margin: 0 -1.25rem 1.15rem;
  padding: 0.85rem 1.25rem;
}
html.dlbs-theme-light .dlbs-shopify-brandbar {
  background: linear-gradient(135deg, rgba(149, 191, 71, 0.12), rgba(255, 255, 255, 0.65));
}
.dlbs-shopify-head__logo {
  align-items: center;
  display: flex;
  flex-shrink: 0;
  min-height: 1.65rem;
}
.dlbs-shopify-logo {
  display: block;
  height: 1.35rem;
  width: auto;
}
.dlbs-shopify-logo--light { display: none; }
html.dlbs-theme-light .dlbs-shopify-logo--dark { display: none; }
html.dlbs-theme-light .dlbs-shopify-logo--light { display: block; }
.dlbs-shopify-partner {
  border: 1px solid rgba(110, 196, 184, 0.28);
  border-radius: 999px;
  color: var(--dlbs-teal);
  font-size: 0.58rem;
  letter-spacing: 0.16em;
  padding: 0.28rem 0.62rem;
  text-transform: uppercase;
  white-space: nowrap;
}
.dlbs-shopify-head {
  align-items: flex-start; display: flex; flex-wrap: wrap; gap: 0.85rem 1rem;
  justify-content: space-between; margin-bottom: 1rem;
}
.dlbs-shopify-split {
  display: grid; gap: 1rem; grid-template-columns: 1fr;
}
@media (min-width: 768px) { .dlbs-shopify-split { grid-template-columns: 1.2fr 0.8fr; } }
.dlbs-shopify-path {
  background: var(--dlbs-subtle); border: 1px solid var(--dlbs-line); border-radius: 0.95rem; padding: 1rem 1.05rem;
}
.dlbs-shopify-path--new { border-style: dashed; }
.dlbs-shopify-path h3 { font-family: var(--dlbs-serif); font-size: var(--text-md); margin: 0 0 0.45rem; }
.dlbs-shopify-path__desc { color: var(--muted); font-size: var(--text-sm); line-height: 1.55; margin: 0 0 0.85rem; }
.dlbs-shopify-form .dlbs-field { margin-bottom: 0.75rem; }
.dlbs-shopify-hint, .dlbs-shopify-note {
  color: var(--muted-soft); font-size: var(--text-xs); line-height: 1.5; margin: 0.65rem 0 0;
}
.dlbs-shopify-scopes { color: var(--muted); font-size: var(--text-sm); line-height: 1.55; margin: 0 0 1rem; }
.dlbs-shopify-actions { display: flex; flex-wrap: wrap; gap: 0.5rem; }
html.dlbs-theme-light .dlbs-shopify-path { background: var(--dlbs-bg-alt); }

/* --- Light theme refinements --- */
html.dlbs-theme-light .dlbs-btn--gold {
  background: linear-gradient(135deg, #9a7340, #c4a064);
  box-shadow: 0 2px 12px rgba(143, 107, 50, 0.28);
  color: #fff;
}
html.dlbs-theme-light .dlbs-btn--gold:hover { filter: brightness(1.06); }
html.dlbs-theme-light .dlbs-gradient-text {
  background: linear-gradient(135deg, #8f6b32, #5c4a94);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
html.dlbs-theme-light .dlbs-user__avatar,
html.dlbs-theme-light .dlbs-sidebar__mark,
html.dlbs-theme-light .dlbs-topbar__mark {
  color: var(--dlbs-mark-fg);
}
html.dlbs-theme-light .dlbs-auth__rail {
  box-shadow: inset 1px 0 0 rgba(143, 107, 50, 0.08);
}
html.dlbs-theme-light .dlbs-auth__stat {
  background: rgba(143, 107, 50, 0.05);
  border-color: rgba(143, 107, 50, 0.1);
}
html.dlbs-theme-light .dlbs-auth__watermark {
  opacity: 0.06;
}
html.dlbs-theme-light .dlbs-line-card:hover,
html.dlbs-theme-light .dlbs-order-card--click:hover,
html.dlbs-theme-light .dlbs-custom-mode:hover {
  box-shadow: var(--dlbs-shadow-md);
}
html.dlbs-theme-light .dlbs-dock {
  box-shadow: 0 -1px 0 var(--dlbs-line), 0 -8px 32px rgba(26, 23, 20, 0.06);
}
html.dlbs-theme-light .dlbs-card,
html.dlbs-theme-light .dlbs-action,
html.dlbs-theme-light .dlbs-tpl-card,
html.dlbs-theme-light .dlbs-ticket--click {
  background: var(--dlbs-surface-2);
  box-shadow: var(--dlbs-shadow-sm);
}
html.dlbs-theme-light .dlbs-action { background: var(--dlbs-bg-alt); }
html.dlbs-theme-light .dlbs-reply,
html.dlbs-theme-light .dlbs-ticket-desc,
html.dlbs-theme-light .dlbs-type {
  background: var(--dlbs-subtle);
}
html.dlbs-theme-light .dlbs-meter__track { background: var(--dlbs-progress-track); }
html.dlbs-theme-light .dlbs-seg { background: var(--dlbs-subtle); }
html.dlbs-theme-light .dlbs-demo-chip { background: var(--dlbs-subtle); }
html.dlbs-theme-light .dlbs-demo-chip:hover { background: var(--dlbs-hover-strong); }
html.dlbs-theme-light .dlbs-modal-plan { background: var(--dlbs-bg-alt); }
html.dlbs-theme-light .dlbs-modal__close { background: var(--dlbs-subtle); }
html.dlbs-theme-light .dlbs-reply-bar {
  background: var(--dlbs-surface-2); box-shadow: var(--dlbs-shadow-md);
}
html.dlbs-theme-light .dlbs-custom-wechat { background: var(--dlbs-surface-2); box-shadow: var(--dlbs-shadow-sm); }
html.dlbs-theme-light .dlbs-pay-banner {
  background: linear-gradient(135deg, rgba(232, 168, 106, 0.12), rgba(212, 184, 122, 0.1));
}
html.dlbs-theme-light .dlbs-pill--active { background: rgba(42, 117, 108, 0.12); }
html.dlbs-theme-light .dlbs-pill--review { background: rgba(92, 74, 148, 0.1); }
html.dlbs-theme-light .dlbs-pill--completed { background: rgba(143, 107, 50, 0.1); }
html.dlbs-theme-light .dlbs-pill--pending { background: rgba(184, 104, 40, 0.1); }
html.dlbs-theme-light .dlbs-nav__btn.is-active {
  box-shadow: inset 3px 0 0 var(--dlbs-gold), var(--dlbs-shadow-sm);
}
html.dlbs-theme-light .dlbs-panel--recent { border-color: rgba(42, 117, 108, 0.22); }
html.dlbs-theme-light .dlbs-panel--custom { border-color: rgba(92, 74, 148, 0.18); }
html.dlbs-theme-light .dlbs-order-card__media {
  box-shadow: inset 0 -24px 40px rgba(26, 23, 20, 0.12);
}
html.dlbs-theme-light .dlbs-tpl-card__cover {
  box-shadow: inset 0 -40px 60px rgba(26, 23, 20, 0.08);
}
