:root {
  --bg: #320001;
  --bg-accent: #68060d;
  --panel: rgba(255, 245, 226, 0.92);
  --panel-strong: rgba(255, 250, 240, 0.98);
  --text: #2b1600;
  --text-soft: #7e5a2b;
  --line: rgba(135, 67, 18, 0.2);
  --gold: #d9a13d;
  --gold-deep: #9e6414;
  --red: #c2332d;
  --red-deep: #7a1116;
  --success: #176a3a;
  --warning: #8f5500;
  --error: #8a0f1d;
  --shadow: 0 24px 80px rgba(24, 0, 0, 0.28);
  --display-font: "KaiTi", "STKaiti", "FangSong", serif;
  --body-font: "Microsoft YaHei", "PingFang SC", "Noto Sans SC", sans-serif;
}

html {
  scroll-behavior: smooth;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  min-height: 100vh;
  font-family: var(--body-font);
  color: var(--text);
  background:
    radial-gradient(circle at top left, rgba(255, 197, 74, 0.2), transparent 28%),
    radial-gradient(circle at top right, rgba(255, 110, 73, 0.18), transparent 22%),
    linear-gradient(145deg, var(--bg) 0%, var(--bg-accent) 48%, #240001 100%);
}

body.modal-open {
  overflow: hidden;
}

body::before,
body::after {
  content: "";
  position: fixed;
  inset: auto;
  width: 280px;
  height: 280px;
  border: 1px solid rgba(255, 202, 111, 0.15);
  border-radius: 999px;
  pointer-events: none;
}

body::before {
  top: 4rem;
  right: -4rem;
}

body::after {
  bottom: 2rem;
  left: -7rem;
}

.page-shell {
  width: min(1120px, calc(100vw - 2rem));
  margin: 0 auto;
  padding: 2rem 0 3rem;
}

.admin-shell {
  width: min(1640px, calc(100vw - 1.5rem));
}

.admin-layout {
  display: grid;
  grid-template-columns: 280px minmax(0, 1fr);
  gap: 1.25rem;
  align-items: start;
}

.admin-sidebar {
  position: sticky;
  top: 1rem;
  align-self: start;
}

.admin-sidebar-card {
  padding: 1.25rem;
}

.sidebar-title {
  margin-top: 0.55rem;
  font-size: clamp(1.35rem, 2vw, 1.8rem);
}

.sidebar-copy {
  margin: 0.75rem 0 0;
  color: var(--text-soft);
  line-height: 1.7;
}

.admin-nav {
  display: grid;
  gap: 0.6rem;
  margin-top: 1rem;
}

.admin-nav-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.8rem;
  min-height: 4.25rem;
  padding: 0.85rem 1rem;
  border-radius: 20px;
  border: 1px solid rgba(122, 17, 22, 0.1);
  background: rgba(255, 255, 255, 0.55);
  color: #5c2214;
  font-weight: 700;
  text-decoration: none;
  transition: transform 160ms ease, box-shadow 160ms ease, background 160ms ease;
}

.admin-nav-link:hover {
  transform: translateY(-1px);
  box-shadow: 0 14px 28px rgba(122, 17, 22, 0.08);
}

.admin-nav-link.is-active {
  background: linear-gradient(135deg, rgba(122, 17, 22, 0.12), rgba(217, 161, 61, 0.22));
  border-color: rgba(158, 100, 20, 0.24);
  color: #5c150f;
}

.admin-nav-copy {
  display: grid;
  gap: 0.2rem;
  min-width: 0;
}

.admin-nav-label {
  font-size: 0.98rem;
}

.admin-nav-meta {
  color: #8a6440;
  font-size: 0.78rem;
  font-weight: 600;
  line-height: 1.35;
}

.admin-nav-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2rem;
  min-height: 2rem;
  padding: 0 0.55rem;
  border-radius: 999px;
  background: rgba(122, 17, 22, 0.08);
  color: #6d1d11;
  font-size: 0.82rem;
  font-weight: 800;
  flex-shrink: 0;
}

.sidebar-note {
  margin-top: 1rem;
  padding: 1rem;
  border-radius: 22px;
  background: rgba(217, 161, 61, 0.1);
  border: 1px solid rgba(158, 100, 20, 0.12);
}

.sidebar-note-label {
  margin: 0;
  font-size: 0.82rem;
  font-weight: 700;
  color: #7a1116;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.sidebar-note-copy {
  margin: 0.45rem 0 0;
  color: #6b4a22;
  line-height: 1.65;
}

.admin-main {
  display: grid;
  gap: 1.25rem;
  min-width: 0;
}

.admin-hero {
  margin: 0;
}

.admin-subnav-shell {
  display: grid;
  gap: 0.8rem;
  margin: 0;
}

.admin-subnav-head {
  display: grid;
  grid-template-columns: minmax(220px, 0.9fr) minmax(0, 1fr);
  gap: 0.6rem 1rem;
  align-items: end;
}

.admin-subnav-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 0.52rem;
}

.admin-subnav-links {
  display: grid;
  gap: 0.5rem;
}

.hero-meta-line {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  margin: 0.9rem 0 0;
  padding: 0.55rem 0.9rem;
  border-radius: 999px;
  background: rgba(122, 17, 22, 0.08);
  color: #651217;
  font-weight: 700;
}

.hero-meta-label {
  color: #7d5231;
}

.hero-metrics {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 0.85rem;
  margin-top: 1.2rem;
}

.hero-metric {
  padding: 1rem;
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.58);
  border: 1px solid rgba(255, 220, 154, 0.45);
}

.hero-metric-label {
  margin: 0;
  font-size: 0.84rem;
  font-weight: 700;
  color: #7a1116;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.hero-metric strong {
  display: block;
  margin-top: 0.45rem;
  font-size: clamp(1.55rem, 3vw, 2.3rem);
  line-height: 1;
  color: #4b0d0d;
}

.hero-metric span {
  display: block;
  margin-top: 0.45rem;
  color: var(--text-soft);
  line-height: 1.5;
}

.dashboard-section {
  display: grid;
  gap: 0.95rem;
  scroll-margin-top: 1rem;
}

.section-intro {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1rem;
  padding: 0 0.25rem;
}

.section-copy {
  margin: 0;
  max-width: 32rem;
  color: rgba(255, 243, 226, 0.82);
  line-height: 1.7;
}

.section-meta {
  margin: 0.35rem 0 0;
  color: rgba(255, 230, 185, 0.8);
  font-size: 0.9rem;
  line-height: 1.5;
}

.section-panels {
  display: grid;
  gap: 1.25rem;
}

.domain-anchor-target {
  scroll-margin-top: 7rem;
}

.section-domain-nav {
  display: grid;
  gap: 1rem;
  padding: 1.1rem 1.2rem 1.2rem;
  border-radius: 26px;
  background: linear-gradient(180deg, rgba(113, 22, 18, 0.3), rgba(69, 12, 11, 0.18));
  border: 1px solid rgba(255, 215, 153, 0.2);
  box-shadow: inset 0 1px 0 rgba(255, 247, 225, 0.08);
}

.section-domain-summary {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1rem;
}

.section-domain-summary-copy {
  margin: 0;
  max-width: 42rem;
  color: rgba(255, 234, 202, 0.84);
  line-height: 1.7;
}

.section-domain-grid {
  display: grid;
  gap: 0.9rem;
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.section-domain-card {
  display: grid;
  gap: 0.9rem;
  padding: 1rem;
  border-radius: 22px;
  background: rgba(255, 247, 232, 0.92);
  border: 1px solid rgba(197, 126, 39, 0.18);
  box-shadow: 0 14px 30px rgba(65, 14, 11, 0.08);
}

.section-domain-card-header {
  display: flex;
  align-items: flex-start;
  gap: 0.8rem;
}

.section-domain-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.1rem;
  height: 2.1rem;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(163, 24, 20, 0.92), rgba(225, 139, 46, 0.88));
  color: #fffaf0;
  font-size: 0.88rem;
  font-weight: 800;
  flex-shrink: 0;
}

.section-domain-card-copy {
  min-width: 0;
}

.section-domain-title {
  margin: 0;
  font-size: 1rem;
  color: #57150f;
}

.section-domain-meta {
  margin: 0.32rem 0 0;
  color: #89532e;
  font-size: 0.84rem;
  line-height: 1.6;
}

.section-domain-links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

.section-domain-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2rem;
  padding: 0.42rem 0.75rem;
  border-radius: 999px;
  background: rgba(122, 17, 22, 0.08);
  border: 1px solid rgba(122, 17, 22, 0.12);
  color: #6c2117;
  font-size: 0.82rem;
  font-weight: 700;
  text-decoration: none;
  transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}

.section-domain-link:hover,
.section-domain-link:focus-visible {
  transform: translateY(-1px);
  background: rgba(122, 17, 22, 0.14);
  box-shadow: 0 10px 18px rgba(65, 14, 11, 0.08);
}

.section-domain-link.is-primary {
  background: linear-gradient(135deg, rgba(166, 24, 20, 0.92), rgba(222, 133, 34, 0.9));
  border-color: rgba(166, 24, 20, 0.28);
  color: #fff9ef;
}

.section-domain-link.is-current {
  background: rgba(122, 17, 22, 0.16);
  border-color: rgba(166, 24, 20, 0.28);
  color: #5f170f;
  box-shadow: inset 0 0 0 1px rgba(166, 24, 20, 0.08);
}

.campaign-workspace-layout {
  display: grid;
  grid-template-columns: minmax(250px, 290px) minmax(0, 1fr) minmax(280px, 320px);
  gap: 1rem;
  align-items: start;
}

.campaign-workspace-nav {
  position: sticky;
  top: 1rem;
  align-self: start;
  display: grid;
  gap: 1rem;
}

.campaign-workspace-insight {
  position: sticky;
  top: 1rem;
  align-self: start;
}

.campaign-workspace-layout .section-domain-nav {
  padding: 0.95rem;
}

.campaign-workspace-layout .section-domain-summary {
  align-items: flex-start;
  flex-direction: column;
}

.campaign-workspace-layout .section-domain-grid {
  grid-template-columns: 1fr;
}

.campaign-workspace-layout .section-domain-card {
  gap: 0.7rem;
  padding: 0.9rem;
}

.campaign-workspace-content {
  min-width: 0;
  display: grid;
  gap: 1rem;
}

.campaign-workspace-side-card {
  padding: 1rem;
}

.campaign-workspace-side-card-task {
  gap: 0.8rem;
}

.campaign-workspace-side-card-insight {
  min-width: 0;
}

.campaign-workspace-side-head {
  display: grid;
  gap: 0.35rem;
  margin-bottom: 0.9rem;
}

.campaign-workspace-side-copy {
  display: grid;
  gap: 0.28rem;
}

.campaign-workspace-side-title {
  margin: 0;
  font-size: 1.15rem;
  color: #5a1a10;
}

.campaign-workspace-side-meta {
  margin: 0;
  color: #86684d;
  font-size: 0.8rem;
  line-height: 1.5;
}

.campaign-workspace-empty-state {
  padding: 0.95rem 1rem;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px dashed rgba(122, 17, 22, 0.16);
  color: #8a6a4d;
  font-size: 0.84rem;
  line-height: 1.6;
}

.campaign-workspace-object-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-bottom: 0.72rem;
}

.campaign-workspace-object-stat {
  display: inline-flex;
  align-items: center;
  gap: 0.42rem;
  min-height: 1.82rem;
  padding: 0.22rem 0.62rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(148, 163, 184, 0.16);
  color: #64748b;
  font-size: 0.72rem;
}

.campaign-workspace-object-stat strong {
  font-weight: 700;
}

.campaign-workspace-object-stat em {
  font-style: normal;
  font-weight: 800;
  color: #0f172a;
}

.campaign-workspace-object-stat.is-active {
  background: #dbeafe;
  border-color: #93c5fd;
  color: #1d4ed8;
}

.campaign-workspace-object-stat.is-accent {
  background: #eff6ff;
  border-color: #dbeafe;
  color: #1e3a8a;
}

.campaign-workspace-object-controls {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 106px;
  gap: 0.55rem;
  margin-bottom: 0.72rem;
}

.campaign-workspace-object-search,
.campaign-workspace-object-filter {
  min-height: 2.44rem;
  padding: 0.56rem 0.72rem;
  border-radius: 14px;
  border: 1px solid #cbd5e1;
  background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
  color: #0f172a;
  font-size: 0.84rem;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.88);
}

.campaign-workspace-object-search:focus,
.campaign-workspace-object-filter:focus {
  outline: none;
  border-color: #60a5fa;
  box-shadow: 0 0 0 4px rgba(59, 130, 246, 0.12);
}

.campaign-workspace-object-toolbar {
  display: flex;
  justify-content: flex-start;
  margin-bottom: 0.75rem;
}

.campaign-workspace-object-stack {
  display: grid;
  gap: 0.6rem;
}

.campaign-workspace-task-list {
  display: grid;
  gap: 0.58rem;
}

.campaign-workspace-task-link {
  display: grid;
  gap: 0.24rem;
  padding: 0.76rem 0.84rem;
  border-radius: 18px;
  border: 1px solid rgba(191, 219, 254, 0.68);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(248, 250, 252, 0.98) 100%);
  color: #0f172a;
  text-decoration: none;
  transition:
    transform 160ms ease,
    box-shadow 160ms ease,
    border-color 160ms ease,
    background 160ms ease;
}

.campaign-workspace-task-link strong {
  font-size: 0.86rem;
  line-height: 1.34;
}

.campaign-workspace-task-link span {
  color: #64748b;
  font-size: 0.76rem;
  line-height: 1.42;
}

.campaign-workspace-task-link:hover,
.campaign-workspace-task-link:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(96, 165, 250, 0.9);
  box-shadow: 0 12px 24px rgba(37, 99, 235, 0.08);
}

.campaign-workspace-task-link.is-active {
  background: linear-gradient(180deg, rgba(239, 246, 255, 0.94) 0%, rgba(248, 250, 252, 0.98) 100%);
  border-color: rgba(96, 165, 250, 0.86);
  box-shadow: 0 10px 20px rgba(37, 99, 235, 0.06);
}

.campaign-workspace-task-link.is-current {
  background: #dbeafe;
  border-color: #93c5fd;
  color: #1d4ed8;
}

.campaign-workspace-task-link.is-current span {
  color: #1e40af;
}

.campaign-workspace-stage-card {
  display: grid;
  gap: 0.82rem;
  padding: 0.96rem 1rem;
}

.campaign-workspace-stage-head {
  display: grid;
  gap: 0.24rem;
}

.campaign-workspace-stage-title {
  margin: 0;
  color: #0f172a;
  font-size: 1rem;
  line-height: 1.3;
}

.campaign-workspace-stage-meta {
  margin: 0;
  color: #64748b;
  font-size: 0.8rem;
  line-height: 1.45;
}

.campaign-workspace-stage-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 0.65rem;
}

.campaign-workspace-stage-link {
  display: grid;
  gap: 0.24rem;
  min-height: 4.9rem;
  padding: 0.82rem 0.9rem;
  border-radius: 20px;
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  border: 1px solid rgba(191, 219, 254, 0.68);
  color: #0f172a;
  text-decoration: none;
  transition:
    transform 160ms ease,
    box-shadow 160ms ease,
    border-color 160ms ease,
    background 160ms ease;
}

.campaign-workspace-stage-link strong {
  font-size: 0.88rem;
  line-height: 1.34;
}

.campaign-workspace-stage-link span {
  color: #64748b;
  font-size: 0.75rem;
  line-height: 1.4;
}

.campaign-workspace-stage-link:hover,
.campaign-workspace-stage-link:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(96, 165, 250, 0.9);
  box-shadow: 0 14px 24px rgba(37, 99, 235, 0.08);
}

.campaign-workspace-stage-link.is-active {
  background: linear-gradient(135deg, #dbeafe 0%, #eff6ff 100%);
  border-color: #93c5fd;
  color: #1d4ed8;
}

.campaign-workspace-stage-link.is-current {
  box-shadow: inset 0 0 0 1px rgba(59, 130, 246, 0.12);
}

.campaign-workspace-stage-link.is-active span {
  color: #1e40af;
}

.campaign-workspace-focus-shell {
  display: grid;
  gap: 0.82rem;
  padding: 0.96rem 1rem;
}

.campaign-workspace-focus-head {
  display: grid;
  gap: 0.24rem;
}

.campaign-workspace-focus-title {
  margin: 0;
  color: #0f172a;
  font-size: 1rem;
  line-height: 1.3;
}

.campaign-workspace-focus-meta-copy {
  margin: 0;
  color: #64748b;
  font-size: 0.8rem;
  line-height: 1.5;
}

.campaign-workspace-focus-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(235px, 1fr));
  gap: 0.78rem;
}

.campaign-workspace-focus-card {
  display: grid;
  gap: 0.78rem;
  min-height: 100%;
  padding: 0.96rem 1rem;
  border-radius: 22px;
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  border: 1px solid rgba(191, 219, 254, 0.72);
  box-shadow: 0 14px 24px rgba(15, 23, 42, 0.04);
}

.campaign-workspace-focus-card.is-active {
  background: linear-gradient(135deg, #dbeafe 0%, #eff6ff 100%);
  border-color: #93c5fd;
  box-shadow:
    0 18px 28px rgba(37, 99, 235, 0.08),
    inset 0 0 0 1px rgba(59, 130, 246, 0.08);
}

.campaign-workspace-focus-copy {
  display: grid;
  gap: 0.32rem;
}

.campaign-workspace-focus-kicker {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  min-height: 1.7rem;
  padding: 0.16rem 0.56rem;
  border-radius: 999px;
  background: #eff6ff;
  border: 1px solid #dbeafe;
  color: #1d4ed8;
  font-size: 0.72rem;
  font-weight: 700;
}

.campaign-workspace-focus-title-link {
  width: fit-content;
  color: #0f172a;
  font-size: 0.95rem;
  font-weight: 800;
  line-height: 1.4;
  text-decoration: none;
}

.campaign-workspace-focus-title-link:hover,
.campaign-workspace-focus-title-link:focus-visible {
  color: #1d4ed8;
}

.campaign-workspace-focus-description {
  margin: 0;
  color: #64748b;
  font-size: 0.79rem;
  line-height: 1.52;
}

.campaign-workspace-focus-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.48rem;
}

.campaign-workspace-focus-pill {
  display: inline-flex;
  align-items: center;
  min-height: 1.72rem;
  padding: 0.16rem 0.58rem;
  border-radius: 999px;
  background: rgba(226, 232, 240, 0.66);
  border: 1px solid rgba(203, 213, 225, 0.9);
  color: #475569;
  font-size: 0.72rem;
  font-weight: 700;
}

.campaign-workspace-focus-pill.is-current {
  background: #dbeafe;
  border-color: #bfdbfe;
  color: #1d4ed8;
}

.campaign-workspace-focus-pill.is-success {
  background: #ecfdf5;
  border-color: #a7f3d0;
  color: #047857;
}

.campaign-workspace-focus-pill.is-warning {
  background: #fff7ed;
  border-color: #fed7aa;
  color: #c2410c;
}

.campaign-workspace-focus-pill.is-accent {
  background: #eff6ff;
  border-color: #bfdbfe;
  color: #1d4ed8;
}

.campaign-workspace-focus-step-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.48rem;
}

.campaign-workspace-focus-step {
  display: inline-flex;
  align-items: center;
  min-height: 1.86rem;
  padding: 0.22rem 0.62rem;
  border-radius: 999px;
  background: #ffffff;
  border: 1px solid rgba(191, 219, 254, 0.88);
  color: #334155;
  font-size: 0.74rem;
  font-weight: 700;
  text-decoration: none;
  transition:
    border-color 160ms ease,
    background 160ms ease,
    color 160ms ease,
    transform 160ms ease;
}

.campaign-workspace-focus-step:hover,
.campaign-workspace-focus-step:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(96, 165, 250, 0.96);
  color: #1d4ed8;
}

.campaign-workspace-focus-step.is-current {
  background: #1d4ed8;
  border-color: #1d4ed8;
  color: #eff6ff;
}

.campaign-workspace-object-button {
  display: grid;
  gap: 0.2rem;
  width: 100%;
  padding: 0.78rem 0.86rem;
  border: 1px solid rgba(122, 17, 22, 0.12);
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.88) 0%, rgba(249, 244, 237, 0.92) 100%);
  text-align: left;
  color: #5b2516;
  cursor: pointer;
  transition:
    transform 160ms ease,
    box-shadow 160ms ease,
    border-color 160ms ease,
    background 160ms ease;
}

.campaign-workspace-object-button:hover,
.campaign-workspace-object-button:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(166, 24, 20, 0.22);
  box-shadow: 0 12px 24px rgba(85, 25, 14, 0.08);
}

.campaign-workspace-object-button.is-active {
  border-color: rgba(166, 24, 20, 0.3);
  background: linear-gradient(135deg, rgba(166, 24, 20, 0.1), rgba(222, 133, 34, 0.16));
  box-shadow: inset 0 0 0 1px rgba(166, 24, 20, 0.08);
}

.campaign-workspace-object-button[data-tone="warning"] {
  border-style: dashed;
}

.campaign-workspace-object-title {
  font-size: 0.95rem;
  font-weight: 800;
  line-height: 1.4;
}

.campaign-workspace-object-meta-line,
.campaign-workspace-object-submeta {
  color: #86684d;
  font-size: 0.78rem;
  line-height: 1.5;
}

.campaign-workspace-insight-rail {
  display: grid;
  gap: 0.8rem;
}

.campaign-workspace-insight-card {
  padding: 0.92rem 0.96rem;
  border-radius: 20px;
  background: linear-gradient(180deg, rgba(255, 252, 247, 0.96) 0%, rgba(244, 236, 226, 0.94) 100%);
  border: 1px solid rgba(176, 118, 72, 0.12);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.86);
}

.campaign-workspace-insight-card-head {
  display: grid;
  gap: 0.22rem;
}

.campaign-workspace-insight-card-head strong {
  color: #5a1a10;
  font-size: 0.95rem;
  line-height: 1.4;
}

.campaign-workspace-insight-card-head span {
  color: #8a6b50;
  font-size: 0.76rem;
  line-height: 1.45;
}

.campaign-workspace-insight-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-top: 0.72rem;
}

.campaign-workspace-insight-chip {
  display: inline-flex;
  align-items: center;
  min-height: 1.8rem;
  padding: 0.18rem 0.62rem;
  border-radius: 999px;
  background: rgba(122, 17, 22, 0.08);
  color: #6d1d11;
  font-size: 0.74rem;
  font-weight: 700;
}

.campaign-workspace-insight-metric-list {
  display: grid;
  gap: 0.58rem;
  margin-top: 0.82rem;
}

.campaign-workspace-insight-metric {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.8rem;
  padding: 0.62rem 0.68rem;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.7);
}

.campaign-workspace-insight-metric span {
  color: #8a6b50;
  font-size: 0.76rem;
  line-height: 1.45;
}

.campaign-workspace-insight-metric strong {
  color: #5a1a10;
  font-size: 0.82rem;
  line-height: 1.45;
  text-align: right;
}

.campaign-flow-summary-list {
  display: grid;
  gap: 0.82rem;
  margin-top: 0.98rem;
}

.section-panels-two {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.section-panels-stack {
  grid-template-columns: 1fr;
}

.hero-card,
.panel {
  backdrop-filter: blur(12px);
  background: linear-gradient(180deg, var(--panel) 0%, var(--panel-strong) 100%);
  border: 1px solid rgba(255, 220, 154, 0.5);
  border-radius: 28px;
  box-shadow: var(--shadow);
}

.hero-card {
  padding: 2rem;
  position: relative;
  overflow: hidden;
}

.hero-card::after {
  content: "";
  position: absolute;
  inset: auto -5rem -5rem auto;
  width: 220px;
  height: 220px;
  background: radial-gradient(circle, rgba(217, 161, 61, 0.3), transparent 65%);
}

.hero-card.compact {
  padding-bottom: 1.5rem;
}

.hero-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.eyebrow,
.panel-kicker {
  margin: 0;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-size: 0.8rem;
  color: var(--red);
}

h1,
h2 {
  margin: 0;
  font-family: var(--display-font);
  line-height: 1.15;
}

h1 {
  margin-top: 0.6rem;
  font-size: clamp(2rem, 5vw, 4rem);
  color: #4b0d0d;
}

h2 {
  font-size: clamp(1.4rem, 3vw, 2rem);
  color: #5a1a10;
}

.hero-copy,
.panel-hint,
.result-message,
.status-text {
  color: var(--text-soft);
}

.hero-copy {
  max-width: 60ch;
  font-size: 1rem;
  line-height: 1.75;
}

.tag-badge-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 1.5rem;
}

.tag-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.65rem 1rem;
  border-radius: 999px;
  background: rgba(122, 17, 22, 0.1);
  border: 1px solid rgba(122, 17, 22, 0.12);
  color: #651217;
  font-weight: 700;
}

.tag-badge.subtle {
  color: #6d4a22;
  background: rgba(217, 161, 61, 0.14);
}

.content-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.25rem;
  margin-top: 1.25rem;
}

.admin-grid {
  grid-template-columns: 1fr;
}

.panel {
  padding: 1.5rem;
}

.panel-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1.25rem;
}

.panel-hint {
  margin: 0;
  max-width: 16rem;
  text-align: right;
  line-height: 1.6;
  font-size: 0.95rem;
}

.claim-form {
  display: grid;
  gap: 1rem;
}

.field {
  display: grid;
  gap: 0.45rem;
  font-weight: 700;
  color: #68200f;
}

.field input,
.field select,
.field textarea {
  width: 100%;
  border: 1px solid rgba(122, 17, 22, 0.18);
  border-radius: 18px;
  padding: 1rem 1.1rem;
  font-size: 1rem;
  background: rgba(255, 255, 255, 0.78);
  color: #3f1d00;
  outline: none;
  transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease;
}

.field textarea {
  min-height: 7rem;
  resize: vertical;
}

.checkbox-field {
  align-content: start;
}

.checkbox-field input[type="checkbox"] {
  width: 1.1rem;
  height: 1.1rem;
  margin: 0;
  padding: 0;
  border: none;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  accent-color: var(--red);
}

.checkbox-field input[type="checkbox"]:focus {
  transform: none;
  box-shadow: none;
  border-color: transparent;
}

.field input:focus,
.field select:focus,
.field textarea:focus {
  transform: translateY(-1px);
  box-shadow: 0 0 0 4px rgba(217, 161, 61, 0.18);
  border-color: rgba(158, 100, 20, 0.5);
}

.admin-form {
  display: grid;
  gap: 1rem;
}

.auth-shell {
  width: min(720px, calc(100vw - 2rem));
}

.auth-panel {
  margin-top: 1.25rem;
}

.admin-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.field-wide {
  grid-column: 1 / -1;
}

[hidden] {
  display: none !important;
}

.admin-action-row {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
}

.filter-toolbar {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.9rem;
  margin-bottom: 0.9rem;
}

.claims-toolbar {
  grid-template-columns: minmax(220px, 0.9fr) minmax(0, 1.6fr);
}

.filter-field {
  gap: 0.35rem;
  font-size: 0.95rem;
}

.inline-field {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
}

.inline-field span {
  white-space: nowrap;
}

.retention-field {
  color: #68200f;
  font-weight: 700;
}

.retention-field input {
  width: 6.5rem;
  min-width: 6.5rem;
  padding: 0.7rem 0.9rem;
}

.retention-note {
  max-width: none;
  margin: 0.75rem 0 1rem;
  text-align: left;
}

.filter-field span {
  font-size: 0.84rem;
  letter-spacing: 0.02em;
}

.filter-field input,
.filter-field select {
  min-height: 3rem;
  padding: 0.85rem 1rem;
}

.filter-field-search {
  grid-column: span 2;
}

.download-panel {
  margin-top: 1rem;
  padding: 1rem;
  border-radius: 22px;
  background: rgba(217, 161, 61, 0.08);
  border: 1px solid rgba(158, 100, 20, 0.12);
}

.download-links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 0.75rem;
}

.download-link,
.ghost-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
}

.download-summary {
  max-width: none;
  margin-top: 0.85rem;
  text-align: left;
}

.reward-tier-field {
  margin-top: 0;
}

.reward-tier-card {
  display: grid;
  gap: 0.95rem;
  padding: 1rem;
  border-radius: 22px;
  background: rgba(217, 161, 61, 0.08);
  border: 1px solid rgba(158, 100, 20, 0.12);
}

.reward-tier-card-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}

.reward-tier-card-label {
  display: block;
  color: #5a1a10;
  font-size: 0.96rem;
  font-weight: 800;
}

.reward-tier-card-copy {
  max-width: none;
  margin: 0.35rem 0 0;
  text-align: left;
  color: var(--text-soft);
  line-height: 1.65;
}

.reward-tier-card-actions {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  flex-wrap: wrap;
}

.reward-tier-preset-block {
  display: grid;
  gap: 0.7rem;
  padding: 0.95rem 1rem;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.52);
  border: 1px solid rgba(158, 100, 20, 0.1);
}

.reward-tier-preset-head {
  display: grid;
  gap: 0.3rem;
}

.reward-tier-preset-label {
  color: #5a1a10;
  font-size: 0.9rem;
  font-weight: 800;
}

.reward-tier-preset-copy {
  margin: 0;
  color: var(--text-soft);
  line-height: 1.6;
}

.reward-tier-preset-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 0.7rem;
}

.reward-tier-preset-button {
  display: grid;
  gap: 0.28rem;
  justify-items: start;
  min-height: 5.15rem;
  padding: 0.95rem 1rem;
  border: 1px solid rgba(158, 100, 20, 0.16);
  border-radius: 18px;
  background: rgba(217, 161, 61, 0.08);
  color: #5e2312;
  text-align: left;
}

.reward-tier-preset-button strong {
  font-size: 0.96rem;
}

.reward-tier-preset-button span {
  color: #7f5830;
  font-size: 0.82rem;
  line-height: 1.55;
}

.reward-tier-list {
  display: grid;
  gap: 0.8rem;
}

.reward-tier-row {
  display: grid;
  grid-template-columns:
    auto
    minmax(120px, 0.85fr)
    minmax(108px, 0.72fr)
    minmax(108px, 0.62fr)
    minmax(220px, 1.35fr)
    auto;
  gap: 0.75rem;
  align-items: end;
  padding: 0.95rem;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.68);
  border: 1px solid rgba(158, 100, 20, 0.12);
}

.reward-tier-index {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.75rem;
  min-height: 2.95rem;
  border-radius: 16px;
  background: rgba(217, 161, 61, 0.18);
  color: #6b2514;
  font-weight: 900;
}

.reward-tier-cell {
  gap: 0.35rem;
}

.reward-tier-cell span,
.reward-tier-share span {
  font-size: 0.8rem;
  letter-spacing: 0.02em;
}

.reward-tier-cell input {
  min-height: 2.95rem;
  padding: 0.78rem 0.9rem;
}

.reward-tier-share {
  display: grid;
  gap: 0.3rem;
  min-height: 2.95rem;
  padding: 0.72rem 0.9rem;
  border-radius: 18px;
  background: rgba(217, 161, 61, 0.1);
  border: 1px solid rgba(158, 100, 20, 0.12);
}

.reward-tier-share strong {
  color: #5a1a10;
  font-size: 1rem;
}

.reward-tier-remove-button {
  min-height: 2.95rem;
}

.reward-tier-summary {
  max-width: none;
  margin: 0;
  text-align: left;
}

.reward-tier-meta {
  display: grid;
  gap: 0.45rem;
}

.reward-tier-insight {
  max-width: none;
  margin: 0;
  text-align: left;
}

.reward-tier-validation {
  min-height: 1.25rem;
  margin: 0;
}

.package-import-panel {
  margin-top: 1rem;
}

.package-import-header {
  margin-bottom: 0.85rem;
}

.package-import-header h3 {
  margin: 0.45rem 0 0;
  font-family: var(--display-font);
  font-size: 1.2rem;
  color: #5a1a10;
}

.package-import-row {
  align-items: flex-end;
}

.inline-file-field {
  min-width: min(360px, 100%);
  flex: 1 1 360px;
}

.inline-file-field input[type="file"] {
  padding: 0.85rem 1rem;
}

.package-import-copy,
.package-import-summary {
  max-width: none;
  margin-top: 0.85rem;
  text-align: left;
}

.package-import-result {
  margin-top: 1rem;
}

.status-text-inline {
  margin-top: 0;
  margin-bottom: 1rem;
}

.filter-summary {
  max-width: none;
  margin: 0;
  text-align: left;
}

.filter-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
  margin-bottom: 1rem;
}

.pagination-controls {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: wrap;
}

.pagination-field {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.pagination-field span {
  white-space: nowrap;
}

.pagination-field select {
  min-width: 6.5rem;
}

.pagination-status {
  color: var(--text-soft);
  font-weight: 700;
  white-space: nowrap;
}

.primary-button,
.ghost-button,
.copy-link-button {
  border: none;
  border-radius: 999px;
  cursor: pointer;
  font: inherit;
  transition: transform 160ms ease, opacity 160ms ease, filter 160ms ease;
}

.primary-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 3.25rem;
  padding: 0.95rem 1.4rem;
  background: linear-gradient(135deg, var(--red) 0%, var(--red-deep) 100%);
  color: #fff8ec;
  font-weight: 700;
  text-decoration: none;
  box-shadow: 0 18px 40px rgba(122, 17, 22, 0.26);
}

.primary-button.secondary-tone {
  background: linear-gradient(135deg, var(--gold) 0%, var(--gold-deep) 100%);
  color: #4c2600;
  margin-top: 1rem;
}

.primary-button.danger-button {
  background: linear-gradient(135deg, #a1171e 0%, #69080d 100%);
  box-shadow: 0 18px 40px rgba(105, 8, 13, 0.28);
}

.ghost-button,
.copy-link-button {
  padding: 0.7rem 1rem;
  background: rgba(217, 161, 61, 0.14);
  color: #753b05;
  font-weight: 700;
}

.compact-button {
  min-height: 2.4rem;
  padding: 0.55rem 0.9rem;
  font-size: 0.92rem;
}

.primary-button:hover,
.ghost-button:hover,
.copy-link-button:hover {
  transform: translateY(-1px);
  filter: brightness(1.02);
}

.primary-button:disabled {
  cursor: not-allowed;
  opacity: 0.6;
  transform: none;
}

.status-text {
  min-height: 1.5rem;
  margin: 1rem 0 0;
  font-weight: 700;
}

.status-text[data-tone="success"] {
  color: var(--success);
}

.status-text[data-tone="warning"] {
  color: var(--warning);
}

.status-text[data-tone="error"] {
  color: var(--error);
}

.panel-hint[data-tone="warning"] {
  color: var(--warning);
  font-weight: 700;
}

.result-panel {
  position: relative;
  overflow: hidden;
}

.result-panel::before {
  content: "";
  position: absolute;
  inset: 0 auto auto 0;
  width: 100%;
  height: 6px;
  background: linear-gradient(90deg, var(--gold) 0%, #ffd58a 50%, var(--red) 100%);
}

.reward-box {
  margin-top: 1rem;
  padding: 1rem;
  border-radius: 22px;
  background: rgba(122, 17, 22, 0.06);
  border: 1px solid rgba(122, 17, 22, 0.12);
}

.reward-label {
  margin: 0 0 0.65rem;
  color: #7a1116;
  font-weight: 700;
}

.reward-command-row {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  justify-content: space-between;
}

.redirect-notice {
  margin-top: 0.85rem;
}

code {
  display: inline-block;
  padding: 0.3rem 0.55rem;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.7);
  color: #6a120d;
  word-break: break-all;
}

.step-list {
  margin: 1rem 0 0;
  padding-left: 1.1rem;
  color: #6b4a22;
  line-height: 1.7;
}

.table-wrap {
  overflow-x: auto;
}

.table-wrap-scroll {
  max-height: min(68vh, 34rem);
  overflow: auto;
  overscroll-behavior: contain;
}

.data-table {
  width: 100%;
  border-collapse: collapse;
}

.data-table th,
.data-table td {
  padding: 0.95rem 0.8rem;
  border-bottom: 1px solid var(--line);
  text-align: left;
  vertical-align: top;
}

.data-table th {
  color: #6d4620;
  font-weight: 700;
}

.data-table tbody tr.is-selected td {
  background: rgba(217, 161, 61, 0.08);
}

.data-table tbody tr.is-updated td {
  background: rgba(255, 220, 154, 0.22);
  animation: package-row-updated-flash 2.2s ease;
}

.copy-url-cell {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  min-width: 0;
}

.copy-url-cell code {
  display: block;
  flex: 1 1 auto;
  min-width: 0;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.copy-url-cell .copy-link-button {
  flex: 0 0 auto;
}

.status-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2rem;
  padding: 0.35rem 0.85rem;
  border-radius: 999px;
  font-size: 0.9rem;
  font-weight: 700;
  border: 1px solid transparent;
}

.status-pill.is-active {
  color: #0f5c34;
  background: rgba(23, 106, 58, 0.1);
  border-color: rgba(23, 106, 58, 0.18);
}

.status-pill.is-paused {
  color: #8f5500;
  background: rgba(217, 161, 61, 0.18);
  border-color: rgba(158, 100, 20, 0.18);
}

.two-line-cell {
  display: grid;
  gap: 0.3rem;
}

.two-line-cell strong {
  color: #4a160d;
}

.two-line-cell span {
  color: var(--text-soft);
  font-size: 0.92rem;
  line-height: 1.5;
}

.package-reward-summary {
  color: #7a4b24;
}

.package-reward-summary.is-default {
  color: var(--text-soft);
}

.package-inline-editor-row td {
  padding-top: 0;
}

.package-inline-editor-cell {
  padding-left: 0.8rem;
  padding-right: 0.8rem;
}

.package-inline-editor-card {
  display: grid;
  gap: 1rem;
  padding: 1rem 1.05rem 1.05rem;
  border-radius: 22px;
  background: rgba(217, 161, 61, 0.08);
  border: 1px solid rgba(158, 100, 20, 0.14);
}

.package-inline-editor-card.is-updated {
  box-shadow: 0 0 0 1px rgba(217, 161, 61, 0.28), 0 18px 36px rgba(158, 100, 20, 0.12);
  animation: package-card-updated-flash 2.2s ease;
}

.package-inline-editor-card.is-quick {
  margin-bottom: 0.85rem;
  background:
    radial-gradient(circle at top right, rgba(217, 161, 61, 0.16), transparent 34%),
    rgba(217, 161, 61, 0.08);
}

.package-inline-editor-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.85rem;
  flex-wrap: wrap;
}

.package-inline-editor-copy {
  display: grid;
  gap: 0.35rem;
  min-width: 0;
}

.package-inline-editor-title {
  margin: 0;
  color: #5a1a10;
  font-size: 1.02rem;
}

.package-inline-editor-summary,
.package-inline-editor-hint {
  margin: 0;
  color: var(--text-soft);
  line-height: 1.6;
}

.package-inline-editor-grid {
  align-items: end;
}

.package-inline-preset-section {
  display: grid;
  gap: 0.6rem;
}

.package-inline-preset-label {
  color: #6d4620;
  font-size: 0.86rem;
  font-weight: 800;
}

.package-inline-preset-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

.package-inline-preset-button {
  min-height: 2.55rem;
}

.package-inline-editor-actions {
  margin-top: 0;
  align-items: center;
}

.package-inline-editor-status {
  margin: 0;
}

.package-quick-search-panel {
  margin-bottom: 0.85rem;
}

.package-quick-editor-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  justify-content: flex-end;
}

.package-import-template-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  align-items: center;
}

.batch-files,
.table-actions {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: 0.55rem;
}

.table-action-cell {
  width: 1%;
  white-space: nowrap;
}

.table-actions .compact-button {
  white-space: nowrap;
}

.empty-cell {
  color: var(--text-soft);
  text-align: center;
  padding-top: 1.25rem;
  padding-bottom: 1.25rem;
}

.modal-shell {
  position: fixed;
  inset: 0;
  z-index: 40;
  display: grid;
  place-items: center;
  padding: 1rem;
}

.modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(35, 0, 5, 0.6);
  backdrop-filter: blur(8px);
}

.modal-card {
  position: relative;
  z-index: 1;
  width: min(100%, 640px);
  padding: 1.4rem;
  border-radius: 28px;
  border: 1px solid rgba(255, 220, 154, 0.38);
  background: linear-gradient(180deg, var(--panel) 0%, var(--panel-strong) 100%);
  box-shadow: var(--shadow);
}

.danger-modal {
  border-color: rgba(122, 17, 22, 0.18);
  background:
    radial-gradient(circle at top right, rgba(194, 51, 45, 0.08), transparent 32%),
    linear-gradient(180deg, rgba(255, 247, 239, 0.98) 0%, rgba(255, 244, 232, 0.98) 100%);
}

.modal-copy {
  margin: 0.85rem 0 0;
  color: var(--text-soft);
  line-height: 1.7;
}

.danger-summary {
  margin-top: 1rem;
  padding: 1rem;
  border-radius: 20px;
  background: rgba(122, 17, 22, 0.06);
  border: 1px solid rgba(122, 17, 22, 0.12);
}

.danger-summary-label {
  margin: 0 0 0.55rem;
  font-size: 0.9rem;
  font-weight: 700;
  color: #7a1116;
}

.danger-list {
  margin: 1rem 0;
  padding-left: 1.2rem;
  color: #6a4220;
  line-height: 1.7;
}

.modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 0.75rem;
  flex-wrap: wrap;
}

.package-detail-actions {
  margin-top: 0.85rem;
  justify-content: flex-start;
}

.package-reward-editor {
  margin-top: 1rem;
}

.package-reward-editor-hint {
  margin: 0 0 0.9rem;
}

.package-detail-preset-section {
  display: grid;
  gap: 0.6rem;
  margin: 0 0 0.95rem;
}

.package-detail-preset-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

.package-reward-editor-actions {
  margin-top: 0;
}

.package-detail-shell {
  z-index: 48;
  align-items: center;
  padding: 1.5rem;
}

.package-detail-modal {
  width: min(100%, 1120px);
  max-height: calc(100vh - 3rem);
  border-radius: 28px;
  overflow: auto;
  padding: 1.35rem 1.35rem 1.6rem;
}

.package-detail-modal .modal-copy,
.package-detail-modal .panel-hint {
  max-width: none;
  text-align: left;
}

.package-detail-header {
  margin-bottom: 0.75rem;
}

.package-detail-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  margin-top: 1rem;
}

.detail-card {
  padding: 1rem;
  border-radius: 22px;
  background: rgba(217, 161, 61, 0.08);
  border: 1px solid rgba(158, 100, 20, 0.12);
}

.detail-card-wide {
  grid-column: 1 / -1;
  margin-top: 1rem;
}

.system-status-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.detail-card-title {
  margin: 0 0 0.85rem;
  font-size: 1rem;
  color: #5a1a10;
}

.detail-list {
  margin: 0;
  display: grid;
  gap: 0.8rem;
}

.detail-list-row {
  display: grid;
  gap: 0.25rem;
}

.detail-list dt {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--text-soft);
}

.detail-list dd {
  margin: 0;
  color: #3f1d00;
  line-height: 1.55;
  word-break: break-word;
}

.detail-link {
  color: #7a1116;
  text-decoration: underline;
  text-underline-offset: 0.15em;
}

.detail-code-block {
  margin: 0;
  padding: 1rem;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.78);
  color: #4a160d;
  white-space: pre-wrap;
  word-break: break-word;
  line-height: 1.6;
  overflow-x: auto;
}

body.admin-page {
  color: #0f172a;
  background:
    radial-gradient(circle at top left, rgba(59, 130, 246, 0.12), transparent 24%),
    radial-gradient(circle at top right, rgba(14, 165, 233, 0.1), transparent 26%),
    linear-gradient(180deg, #f4f7fb 0%, #eef3f9 52%, #e8eef7 100%);
  writing-mode: horizontal-tb;
  text-orientation: mixed;
}

body.admin-page::before,
body.admin-page::after {
  width: 360px;
  height: 360px;
  border-color: rgba(37, 99, 235, 0.08);
}

body.admin-page .page-shell {
  padding-top: 1rem;
  padding-bottom: 1.8rem;
}

body.admin-page h1,
body.admin-page h2,
body.admin-page .package-import-header h3 {
  font-family: "Segoe UI", "PingFang SC", "Microsoft YaHei", sans-serif;
  letter-spacing: -0.02em;
  text-wrap: balance;
  word-break: keep-all;
}

body.admin-page h1 {
  margin-top: 0.34rem;
  max-width: none;
  font-size: clamp(1.44rem, 2vw, 1.92rem);
  font-weight: 800;
  line-height: 1.06;
  color: #291611;
}

body.admin-page h2 {
  font-size: clamp(1.08rem, 1.55vw, 1.34rem);
  font-weight: 750;
  line-height: 1.18;
  color: #321813;
}

body.admin-page .admin-layout {
  grid-template-columns: 92px 248px minmax(0, 1fr);
  gap: 0.88rem;
  align-items: start;
}

body.admin-page .admin-sidebar {
  grid-column: 1;
  position: sticky;
  top: 0.72rem;
  align-self: start;
}

body.admin-page .admin-subnav-shell {
  grid-column: 2;
}

body.admin-page .admin-main {
  grid-column: 3;
  min-width: 0;
  gap: 1rem;
}

body.admin-page .admin-sidebar-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  min-height: calc(100vh - 1.44rem);
  padding: 0.9rem 0.56rem 0.72rem;
  border-radius: 26px;
  background:
    radial-gradient(circle at top left, rgba(59, 130, 246, 0.16), transparent 28%),
    linear-gradient(180deg, rgba(15, 23, 42, 0.99) 0%, rgba(17, 24, 39, 0.98) 48%, rgba(30, 41, 59, 0.97) 100%);
  border: 1px solid rgba(148, 163, 184, 0.16);
  box-shadow: 0 24px 60px rgba(15, 23, 42, 0.24);
}

body.admin-page .admin-brand {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.4rem;
  width: 100%;
  padding-bottom: 0.72rem;
  margin-bottom: 0.7rem;
  border-bottom: 1px solid rgba(148, 163, 184, 0.14);
}

body.admin-page .admin-brand-mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.9rem;
  height: 2.9rem;
  border-radius: 18px;
  background: linear-gradient(135deg, #2563eb 0%, #1d4ed8 100%);
  color: #eff6ff;
  font-weight: 900;
  font-size: 1rem;
  letter-spacing: 0.08em;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.18),
    0 14px 28px rgba(37, 99, 235, 0.28);
}

body.admin-page .admin-brand-copy {
  display: none;
}

body.admin-page .admin-brand-copy strong {
  color: #f8fafc;
  font-size: 0.7rem;
  font-weight: 800;
  line-height: 1.28;
  letter-spacing: 0.01em;
}

body.admin-page .admin-brand-copy span {
  display: none;
}

body.admin-page .admin-sidebar-card .panel-kicker {
  display: none;
}

body.admin-page .sidebar-title,
body.admin-page .sidebar-copy,
body.admin-page .sidebar-note {
  display: none;
}

body.admin-page .admin-nav {
  flex: 1;
  width: 100%;
  gap: 0.28rem;
  margin-top: 0.12rem;
}

body.admin-page .admin-nav-link {
  position: relative;
  display: grid;
  justify-items: center;
  align-content: center;
  gap: 0.26rem;
  min-height: 4.15rem;
  padding: 0.52rem 0.28rem;
  border-radius: 18px;
  border: 1px solid transparent;
  background: rgba(255, 255, 255, 0.02);
  color: #f8fafc;
  box-shadow: none;
  text-align: center;
}

body.admin-page .admin-nav-link::before {
  content: "";
  position: absolute;
  inset: 0.42rem auto 0.42rem 0;
  width: 2px;
  border-radius: 999px;
  background: transparent;
  transition: background 160ms ease;
}

body.admin-page .admin-nav-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: 13px;
  background: rgba(96, 165, 250, 0.08);
  color: #93c5fd;
  font-size: 0.82rem;
  font-weight: 900;
  line-height: 1;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

body.admin-page .admin-nav-label {
  font-size: 0.72rem;
  font-weight: 800;
  line-height: 1.22;
  color: inherit;
  word-break: break-word;
}

body.admin-page .admin-nav-link:hover {
  border-color: rgba(148, 163, 184, 0.14);
  background: rgba(255, 255, 255, 0.06);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

body.admin-page .admin-nav-link.is-active {
  background: linear-gradient(135deg, rgba(239, 246, 255, 0.98) 0%, rgba(219, 234, 254, 0.96) 100%);
  border-color: rgba(59, 130, 246, 0.22);
  color: #0f172a;
  box-shadow: 0 12px 24px rgba(37, 99, 235, 0.12);
}

body.admin-page .admin-nav-link.is-active::before {
  background: linear-gradient(180deg, #2563eb 0%, #38bdf8 100%);
}

body.admin-page .admin-nav-link.is-active .admin-nav-icon {
  background: rgba(37, 99, 235, 0.1);
  color: #1d4ed8;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.38);
}

body.admin-page .admin-nav-meta {
  display: none;
}

body.admin-page .admin-nav-count {
  display: none;
}

body.admin-page .sidebar-note {
  margin-top: auto;
}

body.admin-page .hero-card,
body.admin-page .panel {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.99) 0%, rgba(248, 250, 252, 0.98) 100%);
  border: 1px solid rgba(148, 163, 184, 0.18);
  box-shadow: 0 20px 48px rgba(15, 23, 42, 0.08);
}

body.admin-page .panel {
  padding: 1.08rem;
}

body.admin-page .admin-hero {
  padding: 0.72rem 0.82rem 0.76rem;
  border-radius: 22px;
}

body.admin-page .admin-hero::after {
  display: none;
}

body.admin-page .admin-overview-strip {
  display: none;
  padding: 0.58rem 0.72rem 0.62rem;
  border-radius: 20px;
}

body.admin-page[data-admin-section="workbench"] .admin-overview-strip {
  display: block;
}

body.admin-page .admin-subnav-shell {
  display: grid;
  align-content: start;
  gap: 0.62rem;
  min-height: calc(100vh - 1.44rem);
  max-height: calc(100vh - 1.44rem);
  padding: 0.78rem 0.7rem 0.76rem;
  position: sticky;
  top: 0.72rem;
  z-index: 8;
  overflow: auto;
  border-radius: 26px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.99) 0%, rgba(248, 250, 252, 0.98) 100%);
  border: 1px solid rgba(226, 232, 240, 0.94);
  box-shadow: 0 18px 42px rgba(15, 23, 42, 0.08);
}

body.admin-page .admin-subnav-head {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.14rem;
  align-items: start;
  padding-bottom: 0.48rem;
  border-bottom: 1px solid rgba(226, 232, 240, 0.9);
}

body.admin-page .admin-subnav-head .panel-kicker {
  justify-self: start;
  margin: 0;
  background: rgba(37, 99, 235, 0.08);
  color: #1d4ed8;
}

body.admin-page .admin-subnav-head .panel-hint {
  display: none;
}

body.admin-page .admin-subnav-tabs {
  display: grid;
  align-content: start;
  gap: 0.42rem;
}

body.admin-page .admin-subnav-links {
  display: grid;
  gap: 0.54rem;
  padding-top: 0.82rem;
  border-top: 1px solid rgba(226, 232, 240, 0.88);
}

body.admin-page .admin-subnav-links .section-domain-subtab-group {
  gap: 0.28rem;
}

body.admin-page .hero-card::after {
  inset: auto -2rem -2rem auto;
  width: 180px;
  height: 180px;
  background: radial-gradient(circle, rgba(59, 130, 246, 0.12), transparent 68%);
}

.admin-hero-main {
  min-width: 0;
}

.admin-breadcrumb {
  margin: 0;
  color: #94a3b8;
  font-size: 0.74rem;
  font-weight: 700;
  line-height: 1.28;
  letter-spacing: 0.01em;
}

.admin-hero-heading {
  display: grid;
  gap: 0.22rem;
  min-width: 0;
}

.admin-hero-title-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.42rem 0.54rem;
}

.admin-hero-tools {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0.42rem;
}

.admin-context-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.28rem;
}

.admin-context-chip {
  display: inline-flex;
  align-items: center;
  min-height: 1.38rem;
  padding: 0.14rem 0.46rem;
  border-radius: 999px;
  background: #eef4ff;
  border: 1px solid #dbeafe;
  color: #1e3a8a;
  font-size: 0.68rem;
  font-weight: 700;
  white-space: nowrap;
}

.admin-context-chip.is-accent {
  background: #dbeafe;
  border-color: #bfdbfe;
  color: #1d4ed8;
}

.admin-context-chip.is-success {
  background: #ecfdf5;
  border-color: #a7f3d0;
  color: #047857;
}

.admin-context-chip.is-warning {
  background: #fff7ed;
  border-color: #fed7aa;
  color: #c2410c;
}

.admin-workspace-meta {
  max-width: 72ch;
  margin: 0.3rem 0 0;
  color: #64748b;
  font-size: 0.74rem;
  line-height: 1.36;
  text-wrap: pretty;
}

.admin-hero-side {
  display: none;
}

.page-focus-card {
  display: grid;
  gap: 0.4rem;
  min-height: 0;
  padding: 0.56rem 0.6rem;
  border-radius: 16px;
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  border: 1px solid rgba(191, 219, 254, 0.72);
}

.page-focus-card-muted {
  background: linear-gradient(180deg, #f8fbff 0%, #f1f5f9 100%);
}

.page-focus-label {
  margin: 0;
  color: #2563eb;
  font-size: 0.64rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.page-focus-card strong {
  color: #0f172a;
  font-size: 0.88rem;
  line-height: 1.16;
}

.page-focus-copy {
  margin: 0;
  color: #64748b;
  font-size: 0.74rem;
  line-height: 1.34;
  text-wrap: pretty;
}

.page-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.34rem;
}

.page-chip {
  display: inline-flex;
  align-items: center;
  min-height: 1.48rem;
  padding: 0.2rem 0.46rem;
  border-radius: 999px;
  background: #eff6ff;
  border: 1px solid #dbeafe;
  color: #1d4ed8;
  font-size: 0.7rem;
  font-weight: 700;
  white-space: nowrap;
}

.page-checklist {
  display: grid;
  gap: 0.26rem;
  padding-top: 0.38rem;
  margin-top: 0.08rem;
  border-top: 1px solid rgba(226, 232, 240, 0.9);
}

.page-checklist-item {
  position: relative;
  margin: 0;
  padding-left: 0.82rem;
  color: #475569;
  font-size: 0.72rem;
  line-height: 1.3;
  text-wrap: pretty;
}

.page-checklist-item::before {
  content: "";
  position: absolute;
  top: 0.46rem;
  left: 0;
  width: 0.34rem;
  height: 0.34rem;
  border-radius: 999px;
  background: linear-gradient(135deg, #2563eb 0%, #38bdf8 100%);
}

body.admin-page .hero-actions {
  align-items: flex-start;
  gap: 0.72rem;
}

body.admin-page .hero-meta-line {
  margin: 0;
  padding: 0.18rem 0.46rem;
  border-radius: 999px;
  background: #f8fafc;
  border: 1px solid rgba(226, 232, 240, 0.94);
  color: #334155;
  font-size: 0.72rem;
  white-space: nowrap;
}

body.admin-page .hero-meta-label {
  color: #94a3b8;
}

body.admin-page .admin-hero h1 {
  margin: 0;
  font-size: clamp(1.28rem, 1.8vw, 1.72rem);
  line-height: 1.08;
  color: #0f172a;
}

body.admin-page .hero-metrics {
  grid-template-columns: repeat(auto-fit, minmax(118px, 1fr));
  gap: 0.36rem;
  margin-top: 0;
}

body.admin-page .hero-metric {
  padding: 0.42rem 0.48rem 0.4rem;
  border-radius: 12px;
  background: #ffffff;
  border: 1px solid rgba(226, 232, 240, 0.94);
  box-shadow: none;
}

body.admin-page .hero-metric-label {
  color: #64748b;
  font-size: 0.64rem;
  letter-spacing: 0.04em;
  text-transform: none;
  white-space: nowrap;
}

body.admin-page .hero-metric strong {
  color: #0f172a;
  font-weight: 800;
  margin-top: 0.08rem;
  font-size: clamp(0.98rem, 1.2vw, 1.2rem);
  line-height: 1.02;
}

body.admin-page .hero-metric span {
  color: #94a3b8;
  margin-top: 0.08rem;
  font-size: 0.68rem;
  line-height: 1.2;
}

body.admin-page .section-intro {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 0.05rem;
  gap: 0.4rem 0.9rem;
}

body.admin-page .section-copy {
  display: none;
}

body.admin-page .section-meta {
  color: #64748b;
  font-size: 0.76rem;
  line-height: 1.28;
  white-space: nowrap;
}

body.admin-page .panel-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(180px, 0.58fr);
  align-items: center;
  gap: 0.36rem 0.68rem;
  padding-bottom: 0.54rem;
  margin-bottom: 0.6rem;
  border-bottom: 1px solid rgba(191, 219, 254, 0.72);
}

body.admin-page .panel-header > div {
  width: 100%;
  min-width: 0;
}

body.admin-page .panel-header .panel-hint {
  max-width: none;
  text-align: left;
  justify-self: end;
  align-self: center;
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

body.admin-page .panel-hint {
  max-width: 26rem;
  color: #64748b;
  font-size: 0.76rem;
  line-height: 1.34;
  text-wrap: pretty;
}

body.admin-page .panel-hint[data-tone="warning"] {
  color: #c2410c;
}

body.admin-page .panel-subdomain-nav {
  display: grid;
  gap: 0.7rem;
  padding: 0.88rem 0.96rem;
  margin-bottom: 0.88rem;
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(248, 250, 252, 0.98) 0%, rgba(241, 245, 249, 0.96) 100%);
  border: 1px solid rgba(191, 219, 254, 0.72);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.92);
}

body.admin-page .campaign-workspace-layout {
  grid-template-columns: minmax(0, 1fr) minmax(214px, 236px);
  grid-template-areas:
    "nav insight"
    "content insight";
  gap: 0.72rem;
}

body.admin-page .campaign-workspace-nav,
body.admin-page .campaign-workspace-insight {
  top: 0.85rem;
}

body.admin-page .campaign-workspace-nav {
  grid-area: nav;
  position: static;
  gap: 0.62rem;
  min-width: 0;
}

body.admin-page .campaign-workspace-content {
  grid-area: content;
  gap: 0.82rem;
}

body.admin-page .campaign-workspace-insight {
  grid-area: insight;
}

body.admin-page .campaign-workspace-side-card,
body.admin-page .campaign-workspace-stage-card,
body.admin-page .campaign-workspace-focus-shell {
  padding: 0.72rem 0.76rem;
}

body.admin-page .section-domain-nav {
  display: grid;
  gap: 0.88rem;
  padding: 0;
  margin-top: 0;
  border-radius: 0;
  background: none;
  border: 0;
  box-shadow: none;
}

body.admin-page .section-domain-summary {
  display: grid;
  gap: 0.34rem;
  align-items: start;
}

body.admin-page .section-domain-summary-copy {
  margin: 0;
  max-width: none;
  color: #64748b;
  font-size: 0.8rem;
  line-height: 1.55;
}

body.admin-page .section-domain-tab-list {
  display: grid;
  gap: 0.2rem;
}

body.admin-page .section-domain-tree-group {
  display: grid;
  gap: 0.14rem;
  padding: 0.1rem 0;
}

body.admin-page .section-domain-tab {
  display: grid;
  grid-template-columns: 1.4rem minmax(0, 1fr);
  align-items: center;
  gap: 0.52rem;
  width: 100%;
  min-height: 2.02rem;
  padding: 0.34rem 0.46rem;
  border-radius: 10px;
  background: transparent;
  border: 1px solid transparent;
  color: #334155;
  box-shadow: none;
  position: relative;
}

body.admin-page .section-domain-tab:hover,
body.admin-page .section-domain-tab:focus-visible {
  background: rgba(248, 250, 252, 0.96);
  border-color: rgba(226, 232, 240, 0.94);
  box-shadow: none;
}

body.admin-page .section-domain-tab.is-active {
  background: rgba(248, 250, 252, 0.98);
  border-color: rgba(226, 232, 240, 0.94);
  color: #0f172a;
  box-shadow: none;
}

body.admin-page .section-domain-tab.is-current {
  background: rgba(239, 246, 255, 0.98);
  border-color: rgba(191, 219, 254, 0.88);
  color: #0f172a;
}

body.admin-page .section-domain-tab.is-active::before,
body.admin-page .section-domain-tab.is-current::before {
  content: "";
  position: absolute;
  left: -0.72rem;
  top: 0.38rem;
  bottom: 0.38rem;
  width: 3px;
  border-radius: 999px;
  background: #2563eb;
}

body.admin-page .section-domain-group-heading {
  cursor: pointer;
}

body.admin-page .section-domain-tab-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.18rem;
  height: 1.18rem;
  border-radius: 8px;
  background: rgba(37, 99, 235, 0.08);
  color: #1d4ed8;
  font-size: 0.64rem;
  font-weight: 800;
  flex-shrink: 0;
}

body.admin-page .section-domain-tab.is-active .section-domain-tab-badge {
  background: rgba(37, 99, 235, 0.14);
  color: #1d4ed8;
}

body.admin-page .section-domain-tab-label {
  color: inherit;
  font-size: 0.79rem;
  font-weight: 700;
  line-height: 1.24;
}

body.admin-page .section-domain-subtab-rail {
  display: grid;
  gap: 0.62rem;
  padding-left: 0.72rem;
  margin-left: 0.7rem;
  border-left: 1px solid rgba(226, 232, 240, 0.92);
}

body.admin-page .section-domain-subtab-group {
  display: grid;
  gap: 0.22rem;
  align-items: stretch;
}

body.admin-page .section-domain-subtab-title {
  margin: 0 0 0.08rem;
  color: #94a3b8;
  font-size: 0.7rem;
  font-weight: 700;
  line-height: 1.45;
}

body.admin-page .admin-subnav-tabs .section-domain-subtab-group {
  position: relative;
  padding-left: 1.48rem;
  margin-left: 0.1rem;
}

body.admin-page .admin-subnav-tabs .section-domain-subtab-group::before {
  content: "";
  position: absolute;
  left: 0.42rem;
  top: 0.14rem;
  bottom: 0.16rem;
  width: 1px;
  background: linear-gradient(180deg, rgba(191, 219, 254, 0.88), rgba(226, 232, 240, 0.48));
}

body.admin-page .section-domain-subtab {
  justify-content: flex-start;
  min-height: 1.68rem;
  padding: 0.22rem 0.5rem;
  font-size: 0.72rem;
  font-weight: 700;
  background: transparent;
  border: 1px solid transparent;
  color: #475569;
  box-shadow: none;
  border-radius: 8px;
}

body.admin-page .section-domain-subtab:hover,
body.admin-page .section-domain-subtab:focus-visible {
  background: rgba(248, 250, 252, 0.96);
  border-color: rgba(226, 232, 240, 0.94);
  color: #1e293b;
  box-shadow: none;
}

body.admin-page .section-domain-subtab.is-current {
  background: rgba(239, 246, 255, 0.9);
  border-color: rgba(191, 219, 254, 0.88);
  color: #1d4ed8;
  box-shadow: none;
}

body.admin-page .panel-subdomain-copy {
  margin: 0;
  color: #64748b;
  font-size: 0.8rem;
  line-height: 1.46;
  text-wrap: pretty;
}

body.admin-page .panel-subdomain-links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

body.admin-page .campaign-workspace-group-shell {
  display: grid;
  gap: 0.72rem;
  padding: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
}

body.admin-page .campaign-workspace-group-shell > .reward-label,
body.admin-page .campaign-workspace-group-shell > .panel-hint,
body.admin-page .campaign-workspace-group-shell > .panel-subdomain-links {
  display: none;
}

body.admin-page .campaign-workspace-group-shell > #campaignOpenPageEntryHint {
  display: block;
  max-width: none;
  margin: 0;
  padding: 0.62rem 0.76rem;
  border-radius: 16px;
  background: #f8fbff;
  border: 1px solid rgba(191, 219, 254, 0.72);
  color: #475569;
}

body.admin-page .campaign-workspace-group-shell > .section-panels,
body.admin-page .campaign-workspace-group-shell > .domain-anchor-target {
  margin-top: 0;
}

body.admin-page .workspace-entity-overview {
  display: grid;
  gap: 0.68rem;
  padding: 0.82rem 0.88rem;
  margin-bottom: 0.72rem;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid rgba(226, 232, 240, 0.92);
  box-shadow: none;
}

body.admin-page .workspace-entity-head {
  display: grid;
  gap: 0.52rem;
}

body.admin-page .workspace-entity-copy {
  display: grid;
  gap: 0.28rem;
}

body.admin-page .workspace-entity-kicker {
  margin: 0;
  color: #2563eb;
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: none;
}

body.admin-page .workspace-entity-title {
  margin: 0;
  color: #0f172a;
  font-size: 1rem;
  line-height: 1.24;
}

body.admin-page .workspace-entity-meta {
  margin: 0;
  color: #64748b;
  font-size: 0.76rem;
  line-height: 1.42;
  text-wrap: pretty;
}

body.admin-page .workspace-entity-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.34rem;
}

body.admin-page .workspace-entity-chip {
  display: inline-flex;
  align-items: center;
  min-height: 1.62rem;
  padding: 0.18rem 0.56rem;
  border-radius: 999px;
  background: #eff6ff;
  border: 1px solid #dbeafe;
  color: #1d4ed8;
  font-size: 0.7rem;
  font-weight: 700;
}

body.admin-page .workspace-entity-chip.is-accent {
  background: #dbeafe;
  border-color: #bfdbfe;
  color: #1d4ed8;
}

body.admin-page .workspace-entity-chip.is-success {
  background: #ecfdf5;
  border-color: #a7f3d0;
  color: #047857;
}

body.admin-page .workspace-entity-chip.is-warning {
  background: #fff7ed;
  border-color: #fed7aa;
  color: #c2410c;
}

body.admin-page .workspace-entity-metric-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(112px, 1fr));
  gap: 0.44rem;
}

body.admin-page .workspace-entity-overview.is-compact .workspace-entity-metric-grid,
body.admin-page .workspace-entity-metric-grid.is-compact {
  grid-template-columns: repeat(auto-fit, minmax(102px, 1fr));
  gap: 0.4rem;
}

body.admin-page .workspace-entity-metric {
  display: grid;
  gap: 0.16rem;
  min-height: 3.72rem;
  padding: 0.56rem 0.62rem;
  border-radius: 14px;
  background: rgba(248, 250, 252, 0.82);
  border: 1px solid rgba(226, 232, 240, 0.9);
}

body.admin-page .workspace-entity-overview.is-compact .workspace-entity-metric {
  min-height: 3.44rem;
  padding: 0.52rem 0.58rem;
  border-radius: 12px;
}

body.admin-page .workspace-entity-metric span {
  color: #64748b;
  font-size: 0.68rem;
  line-height: 1.3;
}

body.admin-page .workspace-entity-metric strong {
  color: #0f172a;
  font-size: 0.84rem;
  line-height: 1.3;
}

body.admin-page .workspace-entity-overview.is-compact .workspace-entity-metric strong {
  font-size: 0.8rem;
}

body.admin-page .workspace-entity-shortcuts {
  display: grid;
  gap: 0.46rem;
}

body.admin-page .workspace-entity-shortcuts-label {
  margin: 0;
  color: #64748b;
  font-size: 0.74rem;
  font-weight: 700;
}

body.admin-page .workspace-entity-shortcut-links {
  gap: 0.46rem;
}

body.admin-page .workbench-dispatch-list {
  display: grid;
  gap: 0.52rem;
}

body.admin-page .workbench-dispatch-table {
  display: grid;
  gap: 0.46rem;
}

body.admin-page .workbench-dispatch-head,
body.admin-page .workbench-dispatch-row {
  display: grid;
  grid-template-columns: minmax(152px, 0.9fr) minmax(0, 1.2fr) minmax(0, 1.3fr) auto;
  align-items: center;
  gap: 0.58rem 0.78rem;
}

body.admin-page .workbench-dispatch-head {
  padding: 0 0.18rem;
}

body.admin-page .workbench-dispatch-head-cell {
  color: #94a3b8;
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.03em;
}

body.admin-page .workbench-dispatch-head-cell.is-actions {
  justify-self: end;
}

body.admin-page .workbench-dispatch-row {
  padding: 0.74rem 0.82rem;
  border-radius: 18px;
  background: #ffffff;
  border: 1px solid rgba(226, 232, 240, 0.94);
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.035);
}

body.admin-page .workbench-dispatch-row.is-warning {
  background: linear-gradient(180deg, rgba(255, 251, 235, 0.98) 0%, rgba(255, 247, 237, 0.98) 100%);
  border-color: rgba(251, 191, 36, 0.42);
  box-shadow:
    0 12px 24px rgba(194, 65, 12, 0.05),
    inset 0 0 0 1px rgba(251, 191, 36, 0.08);
}

body.admin-page .workbench-dispatch-row.is-success {
  background: linear-gradient(180deg, rgba(240, 253, 244, 0.98) 0%, rgba(236, 253, 245, 0.98) 100%);
  border-color: rgba(16, 185, 129, 0.26);
}

body.admin-page .workbench-dispatch-cell {
  min-width: 0;
  display: grid;
  gap: 0.12rem;
}

body.admin-page .workbench-dispatch-cell.is-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0.34rem;
}

body.admin-page .workbench-dispatch-kicker {
  margin: 0;
  color: #2563eb;
  font-size: 0.66rem;
  font-weight: 800;
  letter-spacing: 0.04em;
}

body.admin-page .workbench-dispatch-row h3 {
  margin: 0;
  color: #0f172a;
  font-size: 0.86rem;
  line-height: 1.2;
}

body.admin-page .workbench-dispatch-cell strong {
  color: #0f172a;
  font-size: 0.8rem;
  line-height: 1.22;
}

body.admin-page .workbench-dispatch-cell span,
body.admin-page .workbench-dispatch-cell p {
  margin: 0;
  color: #64748b;
  font-size: 0.72rem;
  line-height: 1.34;
}

body.admin-page .workbench-dispatch-status {
  display: inline-flex;
  align-items: center;
  justify-self: start;
  min-height: 1.38rem;
  padding: 0.12rem 0.42rem;
  border-radius: 999px;
  background: #eff6ff;
  border: 1px solid #dbeafe;
  color: #1d4ed8;
  font-size: 0.68rem;
  font-weight: 800;
}

body.admin-page .workbench-dispatch-status.is-warning {
  background: rgba(251, 191, 36, 0.14);
  border-color: rgba(251, 191, 36, 0.42);
  color: #92400e;
}

body.admin-page .workbench-dispatch-status.is-success {
  background: rgba(16, 185, 129, 0.12);
  border-color: rgba(16, 185, 129, 0.28);
  color: #047857;
}

body.admin-page .workbench-dispatch-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 1.7rem;
  padding: 0.18rem 0.58rem;
  border-radius: 10px;
  background: #ffffff;
  border: 1px solid #dbeafe;
  color: #334155;
  font-size: 0.72rem;
  font-weight: 700;
  text-decoration: none;
  transition:
    border-color 160ms ease,
    background 160ms ease,
    color 160ms ease,
    transform 160ms ease;
}

body.admin-page .workbench-dispatch-link:hover,
body.admin-page .workbench-dispatch-link:focus-visible {
  transform: translateY(-1px);
  border-color: #93c5fd;
  background: #f8fbff;
  color: #1d4ed8;
}

body.admin-page .panel-task-blocks {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 0.5rem;
  margin-bottom: 0.64rem;
}

body.admin-page .panel-task-blocks.is-dispatch-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.62rem;
}

body.admin-page .panel-task-blocks.is-risk-list {
  grid-template-columns: 1fr;
  gap: 0.44rem;
}

body.admin-page #workbenchRiskList {
  display: grid;
  gap: 0.52rem;
}

body.admin-page .workbench-risk-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  gap: 0.62rem 0.86rem;
  padding: 0.76rem 0.82rem;
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.99) 0%, rgba(248, 250, 252, 0.98) 100%);
  border: 1px solid rgba(226, 232, 240, 0.94);
  box-shadow: 0 10px 22px rgba(15, 23, 42, 0.04);
}

body.admin-page .workbench-risk-item.is-warning {
  border-color: rgba(251, 191, 36, 0.42);
  background: linear-gradient(180deg, rgba(255, 251, 235, 0.98) 0%, rgba(255, 247, 237, 0.98) 100%);
  box-shadow:
    0 12px 24px rgba(194, 65, 12, 0.06),
    inset 0 0 0 1px rgba(251, 191, 36, 0.08);
}

body.admin-page .workbench-risk-item.is-success {
  border-color: rgba(16, 185, 129, 0.26);
  background: linear-gradient(180deg, rgba(240, 253, 244, 0.98) 0%, rgba(236, 253, 245, 0.98) 100%);
}

body.admin-page .workbench-risk-main {
  display: grid;
  gap: 0.26rem;
  min-width: 0;
}

body.admin-page .workbench-risk-topline {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.38rem;
}

body.admin-page .workbench-risk-kicker {
  margin: 0;
  color: #b45309;
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.04em;
}

body.admin-page .workbench-risk-priority {
  display: inline-flex;
  align-items: center;
  min-height: 1.36rem;
  padding: 0.14rem 0.44rem;
  border-radius: 999px;
  background: rgba(251, 191, 36, 0.18);
  color: #92400e;
  font-size: 0.68rem;
  font-weight: 800;
}

body.admin-page .workbench-risk-item h3 {
  margin: 0;
  color: #0f172a;
  font-size: 0.88rem;
  line-height: 1.22;
}

body.admin-page .workbench-risk-item p:last-child {
  margin: 0;
  color: #64748b;
  font-size: 0.74rem;
  line-height: 1.4;
}

body.admin-page .workbench-risk-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.34rem;
  margin-top: 0.08rem;
}

body.admin-page .workbench-risk-meta-item {
  display: inline-flex;
  align-items: center;
  min-height: 1.42rem;
  padding: 0.12rem 0.42rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(226, 232, 240, 0.94);
  color: #475569;
  font-size: 0.68rem;
  font-weight: 700;
}

body.admin-page .workbench-risk-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-self: center;
  gap: 0.34rem;
}

body.admin-page .panel-task-block {
  display: grid;
  gap: 0.44rem;
  min-height: 100%;
  padding: 0.68rem 0.74rem;
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.99) 0%, rgba(248, 250, 252, 0.98) 100%);
  border: 1px solid rgba(191, 219, 254, 0.72);
  box-shadow: 0 6px 14px rgba(15, 23, 42, 0.035);
  transition:
    border-color 160ms ease,
    box-shadow 160ms ease,
    background 160ms ease,
    transform 160ms ease;
}

body.admin-page .panel-task-blocks.is-dispatch-grid .panel-task-block {
  align-content: start;
  min-height: 8.4rem;
}

body.admin-page .panel-task-blocks.is-risk-list .panel-task-block {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  gap: 0.48rem 0.86rem;
  min-height: auto;
}

body.admin-page .panel-task-block.is-active {
  background: linear-gradient(135deg, #dbeafe 0%, #eff6ff 100%);
  border-color: #93c5fd;
  box-shadow:
    0 18px 30px rgba(37, 99, 235, 0.08),
    inset 0 0 0 1px rgba(59, 130, 246, 0.08);
}

body.admin-page .panel-task-block.is-current {
  transform: translateY(-1px);
}

body.admin-page .panel-task-block.is-warning {
  background: linear-gradient(180deg, rgba(255, 251, 235, 0.98) 0%, rgba(255, 247, 237, 0.98) 100%);
  border-color: rgba(251, 191, 36, 0.45);
  box-shadow:
    0 14px 26px rgba(194, 65, 12, 0.08),
    inset 0 0 0 1px rgba(251, 191, 36, 0.08);
}

body.admin-page .panel-task-block.is-warning .panel-task-block-kicker,
body.admin-page .panel-task-block.is-warning h3 {
  color: #9a3412;
}

body.admin-page .panel-task-block.is-success {
  background: linear-gradient(180deg, rgba(240, 253, 244, 0.98) 0%, rgba(236, 253, 245, 0.98) 100%);
  border-color: rgba(16, 185, 129, 0.3);
  box-shadow:
    0 14px 26px rgba(5, 150, 105, 0.08),
    inset 0 0 0 1px rgba(16, 185, 129, 0.08);
}

body.admin-page .panel-task-block.is-success .panel-task-block-kicker,
body.admin-page .panel-task-block.is-success h3 {
  color: #047857;
}

body.admin-page .panel-task-block-copy {
  display: grid;
  gap: 0.12rem;
}

body.admin-page .panel-task-block-kicker {
  margin: 0;
  color: #2563eb;
  font-size: 0.66rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: none;
}

body.admin-page .panel-task-block h3 {
  margin: 0;
  color: #0f172a;
  font-size: 0.84rem;
  line-height: 1.22;
}

body.admin-page .panel-task-block p:last-child {
  margin: 0;
  color: #64748b;
  font-size: 0.71rem;
  line-height: 1.32;
  text-wrap: pretty;
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

body.admin-page .panel-task-block-links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.36rem;
}

body.admin-page .panel-task-blocks.is-dispatch-grid .panel-task-block-links {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.34rem;
}

body.admin-page .panel-task-blocks.is-dispatch-grid .panel-task-block-links .panel-task-block-link:only-child {
  grid-column: 1 / -1;
}

body.admin-page .panel-task-blocks.is-risk-list .panel-task-block-links {
  justify-content: flex-end;
  align-self: center;
}

body.admin-page .panel-task-block-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 1.76rem;
  padding: 0.2rem 0.58rem;
  border-radius: 10px;
  background: #ffffff;
  border: 1px solid #dbeafe;
  color: #334155;
  font-size: 0.72rem;
  font-weight: 700;
  text-decoration: none;
  transition:
    border-color 160ms ease,
    background 160ms ease,
    color 160ms ease,
    transform 160ms ease;
}

body.admin-page .panel-task-block-link:hover,
body.admin-page .panel-task-block-link:focus-visible {
  transform: translateY(-1px);
  border-color: #93c5fd;
  color: #1d4ed8;
  background: #f8fbff;
}

body.admin-page .panel-task-block-link.is-current {
  background: #1d4ed8;
  border-color: #1d4ed8;
  color: #eff6ff;
}

body.admin-page .campaign-workspace-stage-head,
body.admin-page .campaign-workspace-focus-head,
body.admin-page .campaign-workspace-side-head {
  margin-bottom: 0.78rem;
}

body.admin-page .campaign-workspace-stage-list {
  grid-template-columns: repeat(auto-fit, minmax(118px, 1fr));
  gap: 0.48rem;
}

body.admin-page .campaign-workspace-stage-link {
  min-height: 3.7rem;
  padding: 0.62rem 0.68rem;
  border-radius: 16px;
}

body.admin-page .campaign-workspace-stage-link strong {
  font-size: 0.82rem;
}

body.admin-page .campaign-workspace-stage-link span {
  font-size: 0.72rem;
}

body.admin-page .campaign-workspace-focus-list {
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 0.56rem;
}

body.admin-page .campaign-workspace-focus-card {
  gap: 0.58rem;
  padding: 0.76rem 0.82rem;
  border-radius: 18px;
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.04);
}

body.admin-page .campaign-workspace-focus-card:not(.is-active) .campaign-workspace-focus-step-list {
  display: none;
}

body.admin-page .campaign-workspace-focus-card:not(.is-active) .campaign-workspace-focus-description {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

body.admin-page .campaign-workspace-focus-copy {
  gap: 0.28rem;
}

body.admin-page .campaign-workspace-focus-kicker {
  min-height: 1.58rem;
  padding: 0.14rem 0.5rem;
  font-size: 0.68rem;
}

body.admin-page .campaign-workspace-focus-title-link {
  font-size: 0.9rem;
}

body.admin-page .campaign-workspace-focus-description {
  font-size: 0.76rem;
  line-height: 1.46;
}

body.admin-page .campaign-workspace-focus-meta {
  gap: 0.42rem;
}

body.admin-page .campaign-workspace-focus-pill {
  min-height: 1.62rem;
  padding: 0.14rem 0.52rem;
  font-size: 0.69rem;
}

body.admin-page .campaign-workspace-focus-step-list {
  gap: 0.42rem;
}

body.admin-page .campaign-workspace-focus-step {
  min-height: 1.76rem;
  padding: 0.18rem 0.56rem;
  font-size: 0.72rem;
}

body.admin-page .campaign-workspace-side-meta,
body.admin-page .campaign-workspace-stage-meta,
body.admin-page .campaign-workspace-focus-meta-copy {
  font-size: 0.72rem;
  line-height: 1.36;
}

body.admin-page .campaign-workspace-object-stats {
  gap: 0.38rem;
  margin-bottom: 0.62rem;
}

body.admin-page .campaign-workspace-object-stat {
  min-height: 1.68rem;
  padding: 0.18rem 0.56rem;
  font-size: 0.68rem;
}

body.admin-page .campaign-workspace-object-controls {
  grid-template-columns: minmax(0, 1fr) 96px;
  gap: 0.48rem;
  margin-bottom: 0.64rem;
}

body.admin-page .campaign-workspace-object-search,
body.admin-page .campaign-workspace-object-filter {
  min-height: 2.2rem;
  padding: 0.48rem 0.64rem;
  border-radius: 12px;
  font-size: 0.78rem;
}

body.admin-page .campaign-workspace-object-list {
  display: grid;
  gap: 0.48rem;
  max-height: min(45vh, 28rem);
  overflow: auto;
  padding-right: 0.12rem;
}

body.admin-page .campaign-workspace-object-button {
  gap: 0.18rem;
  padding: 0.62rem 0.72rem;
  border-color: rgba(191, 219, 254, 0.72);
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(248, 250, 252, 0.98) 100%);
  color: #0f172a;
}

body.admin-page .campaign-workspace-object-button:hover,
body.admin-page .campaign-workspace-object-button:focus-visible {
  border-color: rgba(96, 165, 250, 0.86);
  box-shadow: 0 10px 18px rgba(37, 99, 235, 0.08);
}

body.admin-page .campaign-workspace-object-button.is-active {
  border-color: rgba(96, 165, 250, 0.88);
  background: linear-gradient(135deg, rgba(219, 234, 254, 0.96), rgba(239, 246, 255, 0.98));
  box-shadow: inset 0 0 0 1px rgba(59, 130, 246, 0.08);
}

body.admin-page .section-domain-link {
  background: transparent;
  border-color: transparent;
  color: #1e293b;
  box-shadow: none;
}

body.admin-page .section-domain-link:hover,
body.admin-page .section-domain-link:focus-visible {
  background: rgba(248, 250, 252, 0.96);
  box-shadow: none;
}

body.admin-page .section-domain-link.is-primary {
  background: linear-gradient(135deg, #2563eb 0%, #1d4ed8 100%);
  border-color: rgba(37, 99, 235, 0.3);
  color: #eff6ff;
}

body.admin-page .section-domain-link.is-current {
  background: rgba(219, 234, 254, 0.82);
  border-color: #93c5fd;
  color: #1d4ed8;
  box-shadow: inset 0 0 0 1px rgba(59, 130, 246, 0.08);
}

body.admin-page .panel-subdomain-grid {
  gap: 1rem;
}

body.admin-page .panel-subdomain-card {
  min-height: 100%;
}

body.admin-page .panel-subdomain-card .reward-label {
  margin-bottom: 0.24rem;
  font-size: 0.79rem;
  line-height: 1.42;
  text-wrap: pretty;
}

body.admin-page .panel-subdomain-card .panel-hint {
  max-width: none;
}

body.admin-page .panel-subdomain-card .admin-form-grid,
body.admin-page .panel-subdomain-card .table-wrap {
  margin-top: 0.72rem;
}

body.admin-page .panel-subdomain-table {
  margin-top: 0.72rem;
}

body.admin-page #merchantEditorForm.is-list-mode > .admin-action-row {
  display: none;
}

body.admin-page #campaignEditorForm.is-list-mode > .admin-action-row {
  display: none;
}

body.admin-page label.field:has(#merchantEditorSelect),
body.admin-page label.field:has(#campaignEditorSelect),
body.admin-page label.field:has(#rewardCampaignSelect) {
  display: none;
}

body.admin-page #merchantEditorSummary,
body.admin-page #campaignEditorSummary,
body.admin-page #rewardConfigSummary {
  display: none;
}

body.admin-page .field {
  color: #1e293b;
}

body.admin-page .field span {
  font-size: 0.84rem;
  line-height: 1.36;
}

body.admin-page .field-label-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

body.admin-page .field-inline-hint {
  flex: 0 0 auto;
  padding: 0.18rem 0.62rem;
  border-radius: 999px;
  background: #eff6ff;
  color: #2563eb;
  font-size: 0.74rem;
  font-weight: 700;
  line-height: 1.3;
  text-align: right;
  white-space: nowrap;
}

body.admin-page .field-inline-hint[data-tone="warning"] {
  background: #fff7ed;
  color: #c2410c;
}

body.admin-page .filter-toolbar {
  padding: 0.58rem;
  margin-bottom: 0.5rem;
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(255, 249, 241, 0.98) 0%, rgba(244, 236, 226, 0.96) 100%);
  border: 1px solid rgba(176, 118, 72, 0.1);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.82);
}

body.admin-page .filter-field {
  padding: 0.48rem 0.52rem 0.52rem;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(191, 219, 254, 0.72);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.88);
}

body.admin-page .filter-field span {
  color: #64748b;
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.03em;
  line-height: 1.34;
}

body.admin-page .filter-field input,
body.admin-page .filter-field select {
  min-height: 2.22rem;
  padding: 0.5rem 0.68rem;
  border-radius: 12px;
  background: #f8fafc;
}

body.admin-page .filter-footer {
  padding: 0.52rem 0.68rem;
  margin-bottom: 0.6rem;
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(248, 250, 252, 0.96) 0%, rgba(241, 245, 249, 0.92) 100%);
  border: 1px solid rgba(191, 219, 254, 0.6);
}

body.admin-page .pagination-controls {
  gap: 0.42rem;
}

body.admin-page .pagination-field {
  padding: 0.28rem 0.42rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(191, 219, 254, 0.68);
}

body.admin-page .field input,
body.admin-page .field select,
body.admin-page .field textarea {
  border-radius: 16px;
  border-color: #cbd5e1;
  background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.82);
}

body.admin-page .field input:focus,
body.admin-page .field select:focus,
body.admin-page .field textarea:focus {
  box-shadow:
    0 0 0 4px rgba(59, 130, 246, 0.14),
    0 10px 24px rgba(37, 99, 235, 0.08);
  border-color: #60a5fa;
}

@media (max-width: 720px) {
  body.admin-page .field-label-row {
    align-items: flex-start;
    flex-direction: column;
    gap: 0.36rem;
  }

  body.admin-page .field-inline-hint {
    white-space: normal;
    text-align: left;
  }

  body.admin-page .panel-subdomain-nav {
    padding: 0.8rem 0.82rem;
  }

  .campaign-workspace-object-controls {
    grid-template-columns: 1fr;
  }

  .campaign-workspace-stage-list {
    grid-template-columns: 1fr;
  }
}

body.admin-page .filter-summary,
body.admin-page .pagination-status,
body.admin-page .download-summary,
body.admin-page .package-import-copy,
body.admin-page .package-import-summary,
body.admin-page .retention-note,
body.admin-page .status-text,
body.admin-page .reward-label {
  color: #64748b;
}

body.admin-page .download-panel,
body.admin-page .reward-box,
body.admin-page .package-import-panel {
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(248, 250, 252, 0.96) 100%);
  border-color: rgba(191, 219, 254, 0.68);
}

body.admin-page .primary-button {
  background: linear-gradient(135deg, #2563eb 0%, #1d4ed8 100%);
  box-shadow: 0 16px 34px rgba(37, 99, 235, 0.18);
}

body.admin-page .primary-button.secondary-tone {
  background: linear-gradient(135deg, #059669 0%, #047857 100%);
  color: #ecfdf5;
}

body.admin-page .ghost-button,
body.admin-page .copy-link-button,
body.admin-page .download-link {
  background: #f8fbff;
  color: #1d4ed8;
  border-color: #cbd5e1;
}

body.admin-page .table-wrap {
  margin-top: 0.25rem;
  border-radius: 22px;
  border: 1px solid rgba(191, 219, 254, 0.56);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.92) 0%, rgba(248, 250, 252, 0.94) 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.84);
  overflow: auto;
}

body.admin-page .data-table {
  min-width: 720px;
}

body.admin-page .data-table th,
body.admin-page .data-table td {
  padding: 0.62rem 0.68rem;
  border-bottom-color: rgba(191, 219, 254, 0.56);
}

body.admin-page .data-table th {
  position: sticky;
  top: 0;
  z-index: 1;
  background: rgba(239, 246, 255, 0.94);
  color: #475569;
  font-size: 0.68rem;
  font-weight: 650;
  letter-spacing: 0.02em;
  text-transform: none;
  line-height: 1.38;
  white-space: nowrap;
}

body.admin-page .data-table td {
  color: #0f172a;
  font-size: 0.88rem;
  line-height: 1.4;
  word-break: keep-all;
  overflow-wrap: normal;
}

body.admin-page .data-table-sticky-actions th:last-child,
body.admin-page .data-table-sticky-actions td:last-child {
  position: sticky;
  right: 0;
}

body.admin-page .data-table-sticky-actions thead th:last-child {
  z-index: 4;
  box-shadow: -1px 0 0 rgba(191, 219, 254, 0.68);
}

body.admin-page .data-table-sticky-actions tbody td:last-child {
  z-index: 1;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(248, 250, 252, 0.98) 100%);
  box-shadow: -1px 0 0 rgba(191, 219, 254, 0.62);
}

body.admin-page .data-table tbody tr {
  transition: background 140ms ease;
}

body.admin-page .data-table tbody tr:hover {
  background: rgba(239, 246, 255, 0.92);
}

body.admin-page .data-table tbody tr:last-child td {
  border-bottom: none;
}

body.admin-page .status-pill {
  min-width: 4.5rem;
  padding: 0.28rem 0.62rem;
  font-size: 0.72rem;
  line-height: 1.2;
  white-space: nowrap;
  word-break: keep-all;
}

body.admin-page .two-line-cell strong,
body.admin-page .two-line-cell span,
body.admin-page .compact-button,
body.admin-page .ghost-button,
body.admin-page .primary-button,
body.admin-page .copy-link-button,
body.admin-page .pagination-status {
  word-break: keep-all;
}

body.admin-page .two-line-cell strong {
  font-size: 0.86rem;
  line-height: 1.28;
}

body.admin-page .two-line-cell span {
  font-size: 0.78rem;
  line-height: 1.26;
}

body.admin-page .admin-action-row {
  gap: 0.6rem;
}

body.admin-page .primary-button,
body.admin-page .ghost-button,
body.admin-page .copy-link-button {
  min-height: 2.48rem;
  padding: 0.62rem 0.92rem;
  font-size: 0.86rem;
}

body.admin-page .compact-button {
  min-height: 2.08rem;
  padding: 0.42rem 0.72rem;
  font-size: 0.8rem;
}

body.admin-page #logoutButton {
  min-height: 2.18rem;
  padding: 0.48rem 0.86rem;
  font-size: 0.82rem;
}

body.admin-page .status-pill.is-active {
  background: rgba(25, 118, 67, 0.08);
  border-color: rgba(25, 118, 67, 0.14);
}

body.admin-page .status-pill.is-paused {
  background: rgba(217, 161, 61, 0.14);
  border-color: rgba(201, 133, 27, 0.16);
}

body.admin-page .campaign-workspace-object-button:hover,
body.admin-page .campaign-workspace-object-button:focus-visible {
  border-color: rgba(59, 130, 246, 0.24);
  box-shadow: 0 12px 24px rgba(37, 99, 235, 0.08);
}

body.admin-page .campaign-workspace-object-button.is-active {
  border-color: rgba(59, 130, 246, 0.28);
  background: linear-gradient(135deg, rgba(219, 234, 254, 0.96), rgba(239, 246, 255, 0.98));
  box-shadow: inset 0 0 0 1px rgba(59, 130, 246, 0.08);
}

body.admin-page .campaign-workspace-object-meta-line,
body.admin-page .campaign-workspace-object-submeta {
  color: #64748b;
}

body.admin-page .campaign-workspace-nav .campaign-workspace-side-card {
  padding: 0.64rem 0.72rem;
  border-radius: 20px;
}

body.admin-page .campaign-workspace-nav .campaign-workspace-side-head {
  margin-bottom: 0.54rem;
}

body.admin-page .campaign-workspace-nav .campaign-workspace-side-title {
  font-size: 0.98rem;
}

body.admin-page .campaign-workspace-nav .campaign-workspace-side-meta {
  font-size: 0.72rem;
  line-height: 1.34;
}

body.admin-page .campaign-workspace-nav .campaign-workspace-object-stats {
  display: none;
}

body.admin-page .campaign-workspace-nav .campaign-workspace-object-controls {
  grid-template-columns: minmax(220px, 1fr) 104px;
  gap: 0.48rem;
  max-width: 520px;
  margin-bottom: 0.52rem;
}

body.admin-page .campaign-workspace-nav .campaign-workspace-object-list {
  display: block;
  max-height: none;
  overflow: visible;
  padding-right: 0;
}

body.admin-page .campaign-workspace-nav .campaign-workspace-object-stack {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(224px, 256px);
  gap: 0.46rem;
  overflow: auto;
  padding-bottom: 0.08rem;
  scroll-snap-type: x proximity;
}

body.admin-page .campaign-workspace-nav .campaign-workspace-object-button {
  gap: 0.14rem;
  min-height: 4.86rem;
  padding: 0.54rem 0.62rem;
  border-radius: 14px;
  scroll-snap-align: start;
}

body.admin-page .campaign-workspace-nav .campaign-workspace-object-button.is-active {
  border-color: rgba(96, 165, 250, 0.92);
  background: linear-gradient(135deg, rgba(239, 246, 255, 0.98), rgba(248, 250, 252, 0.98));
  box-shadow:
    inset 3px 0 0 #2563eb,
    inset 0 0 0 1px rgba(59, 130, 246, 0.08);
}

body.admin-page .campaign-workspace-nav .campaign-workspace-object-title {
  font-size: 0.84rem;
  line-height: 1.32;
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

body.admin-page .campaign-workspace-nav .campaign-workspace-object-meta-line,
body.admin-page .campaign-workspace-nav .campaign-workspace-object-submeta {
  font-size: 0.7rem;
  line-height: 1.26;
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
}

body.admin-page .campaign-workspace-insight-card {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.99) 0%, rgba(248, 250, 252, 0.98) 100%);
  border-color: rgba(191, 219, 254, 0.68);
  padding: 0.72rem 0.76rem;
  border-radius: 18px;
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.04);
}

body.admin-page .campaign-workspace-insight-card.is-compact .campaign-workspace-insight-metric-list {
  gap: 0.4rem;
  margin-top: 0.58rem;
}

body.admin-page .campaign-workspace-insight-card-head strong,
body.admin-page .campaign-workspace-insight-metric strong,
body.admin-page .campaign-workspace-side-title {
  color: #0f172a;
}

body.admin-page .campaign-workspace-insight-card-head span,
body.admin-page .campaign-workspace-insight-metric span,
body.admin-page .campaign-workspace-side-meta {
  color: #64748b;
}

body.admin-page .campaign-workspace-insight-card-head {
  gap: 0.14rem;
}

body.admin-page .campaign-workspace-insight-card-head strong {
  font-size: 0.88rem;
  line-height: 1.2;
}

body.admin-page .campaign-workspace-insight-card-head span,
body.admin-page .campaign-workspace-side-meta {
  font-size: 0.72rem;
  line-height: 1.32;
}

body.admin-page .campaign-workspace-insight-chip {
  background: #eff6ff;
  color: #1d4ed8;
  min-height: 1.56rem;
  padding: 0.12rem 0.5rem;
  font-size: 0.68rem;
}

body.admin-page .campaign-workspace-insight-metric {
  background: rgba(248, 250, 252, 0.96);
  gap: 0.56rem;
  padding: 0.48rem 0.54rem;
  border-radius: 12px;
}

body.admin-page .campaign-workspace-insight-card.is-compact .campaign-workspace-insight-metric {
  padding: 0.44rem 0.5rem;
}

body.admin-page .campaign-workspace-insight-metric span {
  font-size: 0.72rem;
  line-height: 1.28;
}

body.admin-page .campaign-workspace-insight-metric strong {
  font-size: 0.78rem;
  line-height: 1.26;
}

body.admin-page .table-action-cell {
  min-width: 10.75rem;
}

body.admin-page .table-actions {
  justify-content: flex-end;
}

body.admin-page .package-detail-modal {
  border: 1px solid rgba(122, 59, 22, 0.1);
  background:
    radial-gradient(circle at top right, rgba(217, 161, 61, 0.16), transparent 30%),
    linear-gradient(180deg, rgba(255, 252, 247, 0.99) 0%, rgba(246, 239, 231, 0.99) 100%);
  box-shadow: 0 18px 40px rgba(52, 28, 18, 0.1);
}

body.admin-page .package-detail-modal .detail-card {
  background: linear-gradient(180deg, rgba(255, 249, 241, 0.98) 0%, rgba(245, 237, 227, 0.96) 100%);
  border-color: rgba(176, 118, 72, 0.12);
}

body.admin-page .system-status-grid .detail-card {
  margin-top: 0;
}

body.admin-page code {
  background: rgba(122, 17, 22, 0.05);
  color: #6b2514;
}

@keyframes package-row-updated-flash {
  0% {
    background: rgba(255, 220, 154, 0.42);
  }

  100% {
    background: rgba(255, 220, 154, 0.22);
  }
}

@keyframes package-card-updated-flash {
  0% {
    box-shadow: 0 0 0 1px rgba(217, 161, 61, 0.42), 0 24px 48px rgba(158, 100, 20, 0.18);
  }

  100% {
    box-shadow: 0 0 0 1px rgba(217, 161, 61, 0.28), 0 18px 36px rgba(158, 100, 20, 0.12);
  }
}


@media (max-width: 1180px) {
  body.admin-page .admin-layout {
    grid-template-columns: 1fr;
  }

  body.admin-page .admin-sidebar {
    position: static;
  }

  body.admin-page .admin-subnav-shell,
  body.admin-page .admin-main {
    grid-column: auto;
  }

  body.admin-page .admin-sidebar-card {
    min-height: auto;
    padding: 0.9rem;
    align-items: stretch;
  }

  body.admin-page .admin-brand {
    flex-direction: row;
    justify-content: flex-start;
    gap: 0.72rem;
  }

  body.admin-page .admin-brand-copy {
    display: grid;
    text-align: left;
  }

  body.admin-page .admin-brand-copy span {
    display: block;
  }

  body.admin-page .sidebar-copy {
    display: block;
    margin: 0.52rem 0 0;
    color: #94a3b8;
    font-size: 0.82rem;
    line-height: 1.52;
  }

  body.admin-page .admin-nav {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.42rem;
  }

  body.admin-page .admin-nav-link {
    min-height: 4.1rem;
    align-items: center;
  }

  .admin-hero-tools {
    justify-content: flex-start;
  }

  .admin-subnav-head {
    grid-template-columns: 1fr;
    align-items: flex-start;
  }

  body.admin-page .admin-subnav-shell {
    position: static;
    min-height: auto;
    max-height: none;
    overflow: visible;
  }

  .reward-tier-row {
    grid-template-columns: auto repeat(3, minmax(0, 1fr));
  }

  .reward-tier-label-cell {
    grid-column: 2 / -1;
  }

  .reward-tier-remove-button {
    grid-column: 4 / 5;
    justify-self: end;
  }

  .campaign-workspace-layout {
    grid-template-columns: 1fr;
    grid-template-areas:
      "nav"
      "content"
      "insight";
  }

  .campaign-workspace-nav {
    position: static;
  }

  .campaign-workspace-insight {
    position: static;
  }

  .campaign-workspace-layout .section-domain-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .campaign-workspace-stage-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.section-panels-campaigns {
  grid-template-columns: minmax(0, 1.16fr) minmax(420px, 0.84fr);
  align-items: start;
}

.section-panels-campaigns > .panel:last-child {
  grid-column: 1 / -1;
}

.section-panels-campaigns-flow {
  gap: 1rem;
}

.section-panels-campaigns-flow .campaign-preview-panel {
  position: static;
  top: auto;
}

.campaign-preview-panel {
  position: sticky;
  top: 1rem;
  align-self: start;
  overflow: hidden;
}

.campaign-preview-panel .panel-hint {
  max-width: 24rem;
}

.campaign-preview-content {
  display: grid;
  gap: 1rem;
}

.campaign-preview-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

.campaign-preview-toolbar-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2rem;
  padding: 0.45rem 0.8rem;
  border-radius: 999px;
  background: rgba(122, 17, 22, 0.08);
  border: 1px solid rgba(122, 17, 22, 0.12);
  color: #6c2117;
  font-size: 0.82rem;
  font-weight: 700;
}

.campaign-preview-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.campaign-preview-stage {
  --preview-top: #8f1520;
  --preview-bottom: #c73333;
  --preview-accent-soft: rgba(255, 216, 138, 0.28);
  --preview-envelope-top: #d44b34;
  --preview-envelope-bottom: #a2121d;
  position: relative;
  min-height: 24rem;
  padding: 1rem;
  border-radius: 24px;
  border: 1px solid rgba(122, 17, 22, 0.1);
  background:
    radial-gradient(circle at top right, rgba(255, 223, 158, 0.24), transparent 30%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(255, 249, 239, 0.98));
  overflow: hidden;
}

.campaign-preview-stage.is-theme-festive-gold {
  --preview-top: #87521a;
  --preview-bottom: #d89c2f;
  --preview-accent-soft: rgba(255, 218, 127, 0.28);
  --preview-envelope-top: #e3a84a;
  --preview-envelope-bottom: #b36d1b;
}

.campaign-preview-stage.is-theme-lucky-night {
  --preview-top: #31134c;
  --preview-bottom: #5f2c90;
  --preview-accent-soft: rgba(132, 108, 255, 0.28);
  --preview-envelope-top: #6a2ab1;
  --preview-envelope-bottom: #431875;
}

.campaign-preview-stage-flow {
  grid-column: 1 / -1;
  min-height: auto;
  background:
    radial-gradient(circle at top left, rgba(255, 213, 138, 0.18), transparent 26%),
    linear-gradient(180deg, rgba(255, 250, 241, 0.98), rgba(255, 245, 230, 0.96));
}

.campaign-preview-stage-label {
  margin: 0 0 0.85rem;
  color: #7a1116;
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.campaign-preview-phone {
  max-width: 320px;
  margin: 0 auto;
  padding: 0.75rem;
  border-radius: 30px;
  background: linear-gradient(180deg, #250708, #100202);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    0 18px 36px rgba(27, 2, 2, 0.32);
}

.campaign-preview-screen {
  position: relative;
  min-height: 30rem;
  padding: 1.15rem;
  border-radius: 22px;
  background:
    radial-gradient(circle at top, var(--preview-accent-soft), transparent 42%),
    linear-gradient(180deg, var(--preview-top), var(--preview-bottom));
  color: #fff6e9;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.campaign-preview-screen-success {
  align-items: center;
  text-align: center;
  justify-content: flex-start;
}

.campaign-preview-orb,
.campaign-preview-confetti {
  position: absolute;
  inset: auto auto 72% 50%;
  width: 11rem;
  height: 11rem;
  border-radius: 999px;
  transform: translateX(-50%);
  background: radial-gradient(circle, rgba(255, 227, 154, 0.34), transparent 68%);
  filter: blur(4px);
  pointer-events: none;
}

.campaign-preview-confetti {
  inset: 0;
  width: auto;
  height: auto;
  transform: none;
  background:
    radial-gradient(circle at 18% 22%, rgba(255, 214, 126, 0.72) 0, transparent 12px),
    radial-gradient(circle at 82% 16%, rgba(255, 244, 226, 0.68) 0, transparent 10px),
    radial-gradient(circle at 14% 76%, rgba(255, 168, 104, 0.58) 0, transparent 12px),
    radial-gradient(circle at 84% 74%, rgba(255, 214, 126, 0.72) 0, transparent 11px),
    radial-gradient(circle at 52% 12%, rgba(255, 244, 226, 0.58) 0, transparent 8px);
  opacity: 0.9;
}

.campaign-preview-heading {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 0.45rem;
}

.campaign-preview-badge,
.campaign-preview-success-kicker,
.campaign-preview-open-badge,
.campaign-preview-open-mode {
  display: inline-flex;
  align-items: center;
  align-self: flex-start;
  min-height: 1.9rem;
  padding: 0.35rem 0.72rem;
  border-radius: 999px;
  background: rgba(255, 246, 225, 0.14);
  border: 1px solid rgba(255, 241, 219, 0.2);
  color: #fff5db;
  font-size: 0.78rem;
  font-weight: 700;
}

.campaign-preview-heading strong,
.campaign-preview-success-headline {
  font-size: 1.55rem;
  line-height: 1.18;
}

.campaign-preview-heading p,
.campaign-preview-success-description,
.campaign-preview-success-emotion,
.campaign-preview-flow-header p,
.campaign-preview-open-card p,
.campaign-preview-open-footnote,
.campaign-preview-helper,
.campaign-preview-emotion {
  margin: 0;
  line-height: 1.65;
}

.campaign-preview-heading p,
.campaign-preview-helper,
.campaign-preview-emotion,
.campaign-preview-success-description,
.campaign-preview-success-emotion {
  color: rgba(255, 246, 230, 0.84);
}

.campaign-preview-envelope {
  position: relative;
  z-index: 1;
  margin-top: auto;
  padding: 1.35rem 1rem 1rem;
  border-radius: 28px;
  background:
    linear-gradient(180deg, var(--preview-envelope-top), var(--preview-envelope-bottom));
  box-shadow:
    inset 0 1px 0 rgba(255, 242, 206, 0.14),
    0 18px 34px rgba(59, 4, 8, 0.28);
  overflow: hidden;
}

.campaign-preview-envelope::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 48%;
  background: linear-gradient(180deg, rgba(255, 225, 176, 0.14), rgba(255, 225, 176, 0));
  clip-path: polygon(0 0, 100% 0, 50% 100%);
}

.campaign-preview-envelope-seal {
  position: absolute;
  inset: 0 auto auto 50%;
  transform: translate(-50%, -36%);
  width: 4rem;
  height: 4rem;
  border-radius: 999px;
  background: radial-gradient(circle at 30% 28%, #ffe3a1 0, #d8a54a 58%, #b76d1d 100%);
  color: #7a1116;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.55rem;
  font-weight: 800;
  box-shadow: 0 10px 18px rgba(33, 4, 4, 0.22);
}

.campaign-preview-envelope-copy {
  position: relative;
  display: grid;
  gap: 0.3rem;
  text-align: center;
}

.campaign-preview-envelope-copy span {
  color: rgba(255, 236, 193, 0.82);
  font-size: 0.82rem;
  letter-spacing: 0.08em;
}

.campaign-preview-envelope-copy strong {
  font-size: 1.2rem;
  line-height: 1.32;
}

.campaign-preview-password-slots {
  position: relative;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.55rem;
  margin-top: 1rem;
}

.campaign-preview-password-slots span {
  min-height: 2.9rem;
  border-radius: 16px;
  background: rgba(255, 248, 235, 0.14);
  border: 1px solid rgba(255, 233, 192, 0.22);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff7eb;
  font-size: 1rem;
  font-weight: 800;
  letter-spacing: 0.08em;
}

.campaign-preview-amount {
  display: inline-flex;
  align-items: flex-start;
  justify-content: center;
  margin-top: 0.4rem;
  color: #fff0c4;
  text-shadow: 0 10px 26px rgba(92, 7, 9, 0.26);
  animation: campaign-preview-amount-float 1.8s ease-in-out infinite alternate;
}

.campaign-preview-amount-currency {
  margin-top: 0.45rem;
  font-size: 1.4rem;
  font-weight: 800;
}

.campaign-preview-amount-major {
  font-size: 3.2rem;
  font-weight: 900;
  line-height: 0.92;
}

.campaign-preview-amount-minor {
  margin-top: 0.55rem;
  font-size: 1.2rem;
  font-weight: 800;
}

.campaign-preview-amount-label {
  margin: 0.2rem 0 0;
  color: rgba(255, 246, 230, 0.86);
  font-weight: 700;
}

.campaign-preview-tier-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.55rem;
  margin-top: auto;
}

.campaign-preview-tier-chip {
  display: grid;
  gap: 0.1rem;
  min-width: 5.8rem;
  padding: 0.55rem 0.7rem;
  border-radius: 16px;
  background: rgba(255, 250, 239, 0.14);
  border: 1px solid rgba(255, 232, 198, 0.16);
}

.campaign-preview-tier-chip strong,
.campaign-preview-tier-chip em {
  font-style: normal;
}

.campaign-preview-tier-chip strong {
  color: #fff8ec;
  font-size: 0.86rem;
}

.campaign-preview-tier-chip em {
  color: rgba(255, 246, 230, 0.72);
  font-size: 0.74rem;
}

.campaign-preview-tier-chip.is-empty {
  min-width: 7.2rem;
}

.campaign-preview-button {
  width: 100%;
  margin-top: 0.95rem;
  min-height: 3.25rem;
  border: none;
  border-radius: 18px;
  background: linear-gradient(180deg, #ffe4a0, #d9a13d);
  color: #6b1d11;
  font-size: 1rem;
  font-weight: 800;
  box-shadow: 0 12px 20px rgba(73, 10, 7, 0.22);
}

.campaign-preview-flow-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
}

.campaign-preview-flow-header h3,
.campaign-preview-open-card h4 {
  margin: 0.25rem 0 0;
  color: #57150f;
  font-size: 1.2rem;
  line-height: 1.32;
}

.campaign-preview-flow-header p,
.campaign-preview-open-card p,
.campaign-preview-open-footnote {
  color: #7a5632;
}

.campaign-preview-flow-entry {
  display: grid;
  gap: 0.35rem;
  min-width: 15rem;
  padding: 0.85rem 0.95rem;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.62);
  border: 1px solid rgba(122, 17, 22, 0.1);
}

.campaign-preview-flow-entry span,
.campaign-preview-open-meta span {
  color: #8a6440;
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.campaign-preview-flow-entry code {
  white-space: normal;
  word-break: break-all;
  color: #5d1b11;
  font-family: "Consolas", "SFMono-Regular", monospace;
  font-size: 0.8rem;
}

.campaign-preview-flow-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr);
  gap: 1rem;
}

.campaign-preview-flow-steps {
  display: grid;
  gap: 0.75rem;
}

.campaign-preview-flow-step {
  display: grid;
  grid-template-columns: 2.1rem minmax(0, 1fr);
  gap: 0.75rem;
  align-items: center;
  padding: 0.8rem 0.9rem;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.58);
  border: 1px solid rgba(122, 17, 22, 0.08);
}

.campaign-preview-flow-step span {
  width: 2.1rem;
  height: 2.1rem;
  border-radius: 999px;
  background: linear-gradient(180deg, #d9a13d, #b87823);
  color: #fff8ed;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
}

.campaign-preview-flow-step strong {
  color: #55160f;
  font-size: 0.96rem;
  line-height: 1.55;
}

.campaign-preview-open-card {
  display: grid;
  gap: 0.85rem;
  padding: 1rem;
  border-radius: 22px;
  background:
    radial-gradient(circle at top right, rgba(255, 219, 143, 0.18), transparent 28%),
    rgba(255, 255, 255, 0.7);
  border: 1px solid rgba(122, 17, 22, 0.1);
}

.campaign-preview-open-card strong {
  color: #4d0f0f;
  font-size: 1.05rem;
  line-height: 1.45;
}

.campaign-preview-open-card-head {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.campaign-preview-open-meta {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.85rem;
}

.campaign-preview-open-meta div {
  display: grid;
  gap: 0.28rem;
  padding: 0.85rem 0.9rem;
  border-radius: 16px;
  background: rgba(255, 248, 235, 0.72);
}

.campaign-preview-open-meta strong {
  font-size: 0.95rem;
  color: #57150f;
}

.campaign-preview-open-meta em {
  color: #7b5734;
  font-style: normal;
  font-size: 0.8rem;
  line-height: 1.5;
  word-break: break-word;
}

@keyframes campaign-preview-amount-float {
  from {
    transform: translateY(0) scale(1);
  }

  to {
    transform: translateY(-4px) scale(1.02);
  }
}

@media (max-width: 1480px) {
  .section-domain-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .section-panels-campaigns {
    grid-template-columns: 1fr;
  }

  .section-panels-campaigns > .panel:last-child {
    grid-column: auto;
  }

  .campaign-preview-panel {
    position: static;
  }
}

@media (max-width: 880px) {
  .campaign-preview-grid,
  .campaign-preview-flow-grid,
  .campaign-preview-open-meta {
    grid-template-columns: 1fr;
  }

  .campaign-preview-flow-header {
    flex-direction: column;
  }

  .campaign-preview-flow-entry {
    min-width: 0;
    width: 100%;
  }
}

@media (max-width: 900px) {
  body.admin-page .admin-nav {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .content-grid {
    grid-template-columns: 1fr;
  }

  .section-panels-two {
    grid-template-columns: 1fr;
  }

  body.admin-page .section-intro,
  .admin-subnav-head,
  .section-domain-summary,
  body.admin-page .panel-header {
    grid-template-columns: 1fr;
    align-items: flex-start;
  }

  .section-domain-grid {
    grid-template-columns: 1fr;
  }

  .campaign-workspace-layout .section-domain-grid {
    grid-template-columns: 1fr;
  }

  .campaign-workspace-insight-metric {
    flex-direction: column;
  }

  .campaign-workspace-insight-metric strong {
    text-align: left;
  }

  .section-domain-nav {
    padding: 1rem;
  }

  body.admin-page .panel-task-blocks.is-dispatch-grid {
    grid-template-columns: 1fr;
  }

  body.admin-page .workbench-dispatch-head {
    display: none;
  }

  body.admin-page .workbench-dispatch-row {
    grid-template-columns: 1fr;
  }

  body.admin-page .workbench-dispatch-cell.is-actions {
    justify-content: flex-start;
  }

  body.admin-page .panel-task-blocks.is-risk-list .panel-task-block {
    grid-template-columns: 1fr;
  }

  body.admin-page .panel-task-blocks.is-risk-list .panel-task-block-links {
    justify-content: flex-start;
  }

  .section-domain-summary {
    flex-direction: column;
  }

  .admin-hero-side {
    grid-template-columns: 1fr;
  }

  .hero-metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

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

  .reward-tier-card-header {
    flex-direction: column;
    align-items: stretch;
  }

  .reward-tier-card-actions {
    justify-content: flex-start;
  }

  .reward-tier-preset-list {
    grid-template-columns: 1fr;
  }

  .reward-tier-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .reward-tier-index {
    min-height: 2.4rem;
  }

  .reward-tier-label-cell,
  .reward-tier-remove-button {
    grid-column: 1 / -1;
  }

  .reward-tier-remove-button {
    justify-self: stretch;
  }

  .filter-toolbar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .filter-field-search {
    grid-column: 1 / -1;
  }

  .claims-toolbar {
    grid-template-columns: 1fr;
  }

  body.admin-page .panel-header .panel-hint {
    justify-self: stretch;
  }

  .panel-hint {
    max-width: none;
    text-align: left;
  }

  .package-detail-grid {
    grid-template-columns: 1fr;
  }

  .system-status-grid {
    grid-template-columns: 1fr;
  }

  .table-wrap-scroll {
    max-height: none;
  }
}

@media (max-width: 640px) {
  .page-shell {
    width: min(100vw - 1rem, 1120px);
    padding-top: 0.75rem;
    padding-bottom: 1.5rem;
  }

  .admin-brand {
    align-items: flex-start;
  }

  .admin-brand-mark {
    width: 2.75rem;
    height: 2.75rem;
    border-radius: 16px;
  }

  .hero-card,
  .panel {
    border-radius: 22px;
    padding: 1.1rem;
  }

  .reward-command-row {
    flex-direction: column;
    align-items: stretch;
  }

  .modal-card {
    padding: 1.1rem;
    border-radius: 22px;
  }

  .package-detail-shell {
    padding: 0.75rem;
  }

  .package-detail-modal {
    width: 100%;
    max-height: calc(100vh - 1.5rem);
    border-radius: 24px;
  }

  .modal-actions {
    flex-direction: column-reverse;
    align-items: stretch;
  }

  .hero-actions {
    flex-direction: column;
    align-items: flex-start;
  }

  .admin-hero-tools {
    width: 100%;
    justify-content: space-between;
  }

  body.admin-page .admin-nav {
    grid-auto-flow: column;
    grid-auto-columns: max-content;
    grid-template-columns: none;
    overflow-x: auto;
    padding-bottom: 0.2rem;
  }

  body.admin-page .admin-nav-link {
    min-width: 12.75rem;
    min-height: auto;
  }

  .admin-nav-meta {
    white-space: normal;
  }

  .page-focus-card {
    padding: 0.95rem;
    border-radius: 20px;
  }

  .hero-metrics {
    grid-template-columns: 1fr;
  }

  .filter-toolbar {
    grid-template-columns: 1fr;
  }

  .reward-tier-row {
    grid-template-columns: 1fr;
  }

  .reward-tier-index,
  .reward-tier-remove-button {
    justify-self: stretch;
  }

  .filter-field-search {
    grid-column: auto;
  }

  .filter-footer {
    flex-direction: column;
    align-items: stretch;
  }

  .pagination-controls {
    justify-content: flex-start;
  }

  .table-actions {
    flex-wrap: wrap;
  }

  .campaign-preview-phone {
    max-width: 100%;
  }

  .campaign-preview-screen {
    min-height: 27rem;
  }
}

.campaign-preview-live-grid {
  display: grid;
  gap: 1rem;
}

.campaign-preview-live-card,
.campaign-preview-route-card {
  padding: 1rem;
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.52);
  border: 1px solid rgba(122, 17, 22, 0.08);
}

.campaign-preview-live-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 0.85rem;
}

.campaign-preview-live-pill {
  display: inline-flex;
  align-items: center;
  min-height: 1.9rem;
  padding: 0.35rem 0.7rem;
  border-radius: 999px;
  background: rgba(122, 17, 22, 0.08);
  color: #6b1d11;
  font-size: 0.76rem;
  font-weight: 700;
}

.campaign-preview-device {
  max-width: 350px;
  margin: 0 auto;
  padding: 0.72rem;
  border-radius: 30px;
  background: linear-gradient(180deg, #1e1111, #080808);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 16px 32px rgba(26, 2, 2, 0.28);
}

.campaign-preview-device-screen {
  position: relative;
  min-height: 34rem;
  border-radius: 22px;
  overflow: hidden;
  background: #0f0f0f;
  color: #fff;
}

.campaign-preview-bg-photo,
.campaign-preview-bg-shade,
.campaign-preview-bg-glow {
  position: absolute;
}

.campaign-preview-bg-photo {
  inset: -8%;
  background:
    radial-gradient(circle at 50% 30%, rgba(207, 62, 54, 0.28) 0%, rgba(207, 62, 54, 0.12) 18%, rgba(207, 62, 54, 0) 42%),
    radial-gradient(circle at 20% 20%, rgba(255, 138, 80, 0.14) 0%, rgba(255, 138, 80, 0) 26%),
    radial-gradient(circle at 80% 72%, rgba(180, 25, 35, 0.18) 0%, rgba(180, 25, 35, 0) 30%),
    linear-gradient(180deg, #1a0908 0%, #170908 44%, #090909 100%);
  transform: scale(1.12);
  filter: blur(16px);
}

.campaign-preview-bg-shade {
  inset: 0;
  background: linear-gradient(135deg, rgba(0, 0, 0, 0.76) 0%, rgba(42, 0, 0, 0.42) 42%, rgba(0, 0, 0, 0.8) 100%);
}

.campaign-preview-bg-glow {
  border-radius: 999px;
  filter: blur(18px);
}

.campaign-preview-bg-glow-left {
  top: 88px;
  left: -40px;
  width: 150px;
  height: 150px;
  background: rgba(209, 53, 48, 0.2);
}

.campaign-preview-bg-glow-right {
  right: -44px;
  bottom: 106px;
  width: 170px;
  height: 170px;
  background: rgba(255, 138, 80, 0.14);
}

.campaign-preview-device-screen.is-theme-festive-gold .campaign-preview-bg-photo {
  background:
    radial-gradient(circle at 50% 28%, rgba(255, 194, 92, 0.22) 0%, rgba(255, 194, 92, 0.08) 18%, rgba(255, 194, 92, 0) 42%),
    radial-gradient(circle at 18% 20%, rgba(255, 143, 77, 0.16) 0%, rgba(255, 143, 77, 0) 26%),
    radial-gradient(circle at 80% 72%, rgba(198, 52, 31, 0.2) 0%, rgba(198, 52, 31, 0) 30%),
    linear-gradient(180deg, #250d08 0%, #220a08 40%, #120807 100%);
}

.campaign-preview-device-screen.is-theme-festive-gold .campaign-preview-bg-shade {
  background: linear-gradient(135deg, rgba(20, 6, 2, 0.72) 0%, rgba(73, 24, 6, 0.34) 42%, rgba(12, 4, 3, 0.8) 100%);
}

.campaign-preview-device-screen.is-theme-festive-gold .campaign-preview-bg-glow-left {
  background: rgba(255, 198, 96, 0.18);
}

.campaign-preview-device-screen.is-theme-festive-gold .campaign-preview-bg-glow-right {
  background: rgba(255, 143, 77, 0.16);
}

.campaign-preview-device-screen.is-theme-lucky-night .campaign-preview-bg-photo {
  background:
    radial-gradient(circle at 50% 26%, rgba(238, 86, 112, 0.18) 0%, rgba(238, 86, 112, 0.08) 18%, rgba(238, 86, 112, 0) 42%),
    radial-gradient(circle at 18% 20%, rgba(216, 119, 255, 0.12) 0%, rgba(216, 119, 255, 0) 26%),
    radial-gradient(circle at 82% 70%, rgba(112, 43, 159, 0.22) 0%, rgba(112, 43, 159, 0) 30%),
    linear-gradient(180deg, #140816 0%, #100612 42%, #07070b 100%);
}

.campaign-preview-device-screen.is-theme-lucky-night .campaign-preview-bg-shade {
  background: linear-gradient(135deg, rgba(8, 4, 18, 0.78) 0%, rgba(49, 9, 34, 0.42) 42%, rgba(4, 3, 10, 0.82) 100%);
}

.campaign-preview-device-screen.is-theme-lucky-night .campaign-preview-bg-glow-left {
  background: rgba(200, 108, 255, 0.16);
}

.campaign-preview-device-screen.is-theme-lucky-night .campaign-preview-bg-glow-right {
  background: rgba(255, 116, 157, 0.14);
}

.campaign-preview-mini-input-step,
.campaign-preview-mini-opening-step,
.campaign-preview-mini-result-step {
  position: relative;
  z-index: 1;
  min-height: 34rem;
}

.campaign-preview-mini-input-step {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.1rem;
  box-sizing: border-box;
}

.campaign-preview-mini-input-card-shell {
  position: relative;
  width: 100%;
  max-width: 17rem;
}

.campaign-preview-mini-input-card-shadow {
  position: absolute;
  left: 50%;
  bottom: -0.95rem;
  width: 11.4rem;
  height: 2.4rem;
  margin-left: -5.7rem;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(0, 0, 0, 0.42) 0%, rgba(0, 0, 0, 0.16) 60%, rgba(0, 0, 0, 0) 100%);
}

.campaign-preview-mini-input-card,
.campaign-preview-mini-result-card {
  position: relative;
  overflow: hidden;
  border-radius: 24px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  background: rgba(9, 9, 9, 0.42);
  box-shadow:
    0 22px 56px rgba(0, 0, 0, 0.4),
    inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.campaign-preview-mini-input-card {
  padding: 2.8rem 1.4rem 1.4rem;
  text-align: center;
}

.campaign-preview-mini-input-card-blur,
.campaign-preview-mini-result-card-blur {
  position: absolute;
  top: -2.8rem;
  left: -2.4rem;
  width: 7rem;
  height: 7rem;
  border-radius: 999px;
  background: rgba(255, 69, 69, 0.12);
  filter: blur(32px);
}

.campaign-preview-mini-input-card-highlight,
.campaign-preview-mini-result-card-highlight {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 6.2rem;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.06) 0%, rgba(255, 255, 255, 0) 100%);
}

.campaign-preview-mini-input-icon-box,
.campaign-preview-mini-result-coin-core {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #ef5350 0%, #ff7043 100%);
  box-shadow: 0 14px 32px rgba(207, 62, 54, 0.24);
}

.campaign-preview-mini-input-icon-box {
  width: 3.2rem;
  height: 3.2rem;
  margin: 0 auto 1.15rem;
  border-radius: 18px;
}

.campaign-preview-device-screen.is-theme-festive-gold .campaign-preview-mini-input-icon-box,
.campaign-preview-device-screen.is-theme-festive-gold .campaign-preview-mini-result-coin-core {
  background: linear-gradient(135deg, #f7d166 0%, #d58d22 100%);
  box-shadow: 0 14px 32px rgba(213, 141, 34, 0.28);
}

.campaign-preview-device-screen.is-theme-lucky-night .campaign-preview-mini-input-icon-box,
.campaign-preview-device-screen.is-theme-lucky-night .campaign-preview-mini-result-coin-core {
  background: linear-gradient(135deg, #f25f7c 0%, #8b3dff 100%);
  box-shadow: 0 14px 32px rgba(139, 61, 255, 0.26);
}

.campaign-preview-mini-input-icon-core,
.campaign-preview-mini-result-coin-core {
  color: #fff;
  font-weight: 700;
}

.campaign-preview-mini-input-icon-core {
  font-size: 1.2rem;
}

.campaign-preview-mini-input-title,
.campaign-preview-mini-opening-title,
.campaign-preview-mini-result-header-title {
  position: relative;
  z-index: 1;
  color: #fff;
  font-weight: 700;
}

.campaign-preview-mini-input-title {
  font-size: 1.28rem;
  line-height: 1.35;
}

.campaign-preview-mini-input-english {
  position: relative;
  z-index: 1;
  margin-top: 0.35rem;
  color: rgba(255, 255, 255, 0.32);
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.campaign-preview-mini-input-caption {
  position: relative;
  z-index: 1;
  margin-top: 0.7rem;
  color: rgba(255, 255, 255, 0.52);
  font-size: 0.82rem;
  line-height: 1.5;
}

.campaign-preview-mini-slot-panel {
  position: relative;
  z-index: 1;
  margin-top: 1.5rem;
  padding: 0.8rem 0.7rem;
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  background: rgba(255, 255, 255, 0.04);
  box-shadow: 0 0 18px rgba(239, 68, 68, 0.08);
}

.campaign-preview-device-screen.is-theme-festive-gold .campaign-preview-mini-slot-panel {
  box-shadow: 0 0 18px rgba(247, 209, 102, 0.08);
}

.campaign-preview-device-screen.is-theme-lucky-night .campaign-preview-mini-slot-panel {
  box-shadow: 0 0 18px rgba(210, 124, 255, 0.08);
}

.campaign-preview-mini-slot-panel-bg {
  position: absolute;
  inset: 0;
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.04) 0%, rgba(255, 255, 255, 0) 100%);
}

.campaign-preview-mini-slot-list {
  position: relative;
  z-index: 1;
  display: flex;
  justify-content: center;
  gap: 0.45rem;
  flex-wrap: wrap;
}

.campaign-preview-mini-slot {
  position: relative;
  width: 2rem;
  height: 2rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

.campaign-preview-mini-slot-char {
  color: #fff;
  font-size: 0.9rem;
  font-weight: 700;
}

.campaign-preview-mini-slot-dot {
  width: 0.45rem;
  height: 0.45rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.14);
}

.campaign-preview-mini-slot.is-filled .campaign-preview-mini-slot-dot,
.campaign-preview-mini-slot-underline {
  background: #ef4444;
}

.campaign-preview-device-screen.is-theme-festive-gold .campaign-preview-mini-slot.is-filled .campaign-preview-mini-slot-dot,
.campaign-preview-device-screen.is-theme-festive-gold .campaign-preview-mini-slot-underline {
  background: #f7d166;
}

.campaign-preview-device-screen.is-theme-lucky-night .campaign-preview-mini-slot.is-filled .campaign-preview-mini-slot-dot,
.campaign-preview-device-screen.is-theme-lucky-night .campaign-preview-mini-slot-underline {
  background: #f25f7c;
}

.campaign-preview-mini-slot-dot.is-dot-active {
  transform: scale(1.18);
  background: rgba(255, 255, 255, 0.26);
}

.campaign-preview-mini-slot-underline {
  position: absolute;
  left: 0.35rem;
  right: 0.35rem;
  bottom: 0;
  height: 0.18rem;
  border-radius: 999px;
}

.campaign-preview-mini-input-helper {
  position: relative;
  z-index: 1;
  margin-top: 1.05rem;
  color: rgba(255, 255, 255, 0.62);
  font-size: 0.9rem;
  line-height: 1.6;
}

.campaign-preview-mini-input-emotion {
  position: relative;
  z-index: 1;
  margin-top: 0.55rem;
  color: rgba(255, 232, 214, 0.74);
  font-size: 0.84rem;
  line-height: 1.68;
}

.campaign-preview-mini-input-status-row {
  position: relative;
  z-index: 1;
  margin-top: 1.1rem;
}

.campaign-preview-mini-input-security {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.42rem;
  color: rgba(255, 255, 255, 0.24);
  font-size: 0.68rem;
  letter-spacing: 0.12em;
}

.campaign-preview-mini-input-security-dot {
  width: 0.38rem;
  height: 0.38rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.24);
}

.campaign-preview-mini-intro-stage {
  position: relative;
  min-height: 34rem;
  overflow: hidden;
  background:
    radial-gradient(circle at 50% 46%, rgba(255, 255, 255, 0.035), transparent 32%),
    linear-gradient(180deg, #121417 0%, #090909 56%, #040404 100%);
}

.campaign-preview-mini-intro-ambient,
.campaign-preview-mini-intro-frost,
.campaign-preview-mini-intro-video-shell,
.campaign-preview-mini-intro-skip-btn,
.campaign-preview-mini-intro-progress {
  position: absolute;
}

.campaign-preview-mini-intro-ambient {
  inset: -12%;
  pointer-events: none;
}

.campaign-preview-mini-intro-blob {
  position: absolute;
  border-radius: 50%;
  filter: blur(48px);
  opacity: 0.92;
}

.campaign-preview-mini-intro-blob.is-blob-a {
  width: 18rem;
  height: 18rem;
  left: -2rem;
  top: 0.4rem;
  background: radial-gradient(circle at 40% 38%, rgba(243, 247, 255, 0.92), rgba(147, 168, 238, 0.38) 30%, rgba(36, 48, 81, 0.06) 72%, transparent 100%);
  animation: campaign-preview-blob-a 18s ease-in-out infinite alternate;
}

.campaign-preview-mini-intro-blob.is-blob-b {
  width: 20rem;
  height: 20rem;
  right: -4rem;
  top: 6rem;
  background: radial-gradient(circle at 56% 44%, rgba(255, 225, 176, 0.86), rgba(255, 168, 103, 0.32) 32%, rgba(87, 41, 18, 0.08) 70%, transparent 100%);
  animation: campaign-preview-blob-b 22s ease-in-out infinite alternate;
}

.campaign-preview-mini-intro-blob.is-blob-c {
  width: 14rem;
  height: 14rem;
  left: 5rem;
  bottom: -4rem;
  background: radial-gradient(circle at 52% 40%, rgba(225, 235, 255, 0.52), rgba(128, 148, 214, 0.2) 30%, rgba(24, 31, 49, 0.04) 72%, transparent 100%);
  animation: campaign-preview-blob-c 24s ease-in-out infinite alternate;
}

.campaign-preview-mini-intro-frost {
  inset: 0;
  background:
    radial-gradient(circle at 50% 48%, rgba(255, 255, 255, 0.075), rgba(0, 0, 0, 0.18) 58%, rgba(0, 0, 0, 0.34) 100%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.045), rgba(255, 255, 255, 0.018) 24%, rgba(0, 0, 0, 0.16) 100%);
  backdrop-filter: blur(12px) saturate(132%);
}

.campaign-preview-mini-intro-video-shell {
  inset: 0;
  z-index: 3;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.2rem;
  box-sizing: border-box;
}

.campaign-preview-mini-intro-video-frame {
  width: 100%;
  min-height: 15rem;
  border-radius: 22px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background:
    linear-gradient(180deg, rgba(0, 0, 0, 0.18), rgba(0, 0, 0, 0.34)),
    radial-gradient(circle at center, rgba(255, 255, 255, 0.06), transparent 54%);
  box-shadow: 0 18px 42px rgba(0, 0, 0, 0.28);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.7rem;
  padding: 1.4rem;
  text-align: center;
}

.campaign-preview-mini-intro-video-frame span {
  display: inline-flex;
  align-items: center;
  min-height: 1.9rem;
  padding: 0.35rem 0.72rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.82);
  font-size: 0.72rem;
  font-weight: 700;
}

.campaign-preview-mini-intro-video-frame strong {
  color: #fff;
  font-size: 1.18rem;
  line-height: 1.4;
}

.campaign-preview-mini-intro-video-frame p {
  margin: 0;
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.88rem;
  line-height: 1.7;
}

.campaign-preview-mini-intro-skip-btn {
  top: 1rem;
  right: 1rem;
  z-index: 4;
  min-height: 2rem;
  padding: 0.35rem 0.78rem;
  border-radius: 999px;
  background: rgba(8, 8, 8, 0.44);
  color: rgba(255, 255, 255, 0.92);
  font-size: 0.8rem;
  font-weight: 700;
}

.campaign-preview-mini-intro-progress {
  left: 1rem;
  right: 1rem;
  bottom: 1rem;
  z-index: 4;
}

.campaign-preview-mini-intro-progress-meta {
  display: flex;
  justify-content: space-between;
  color: rgba(255, 255, 255, 0.82);
  font-size: 0.72rem;
  margin-bottom: 0.42rem;
}

.campaign-preview-mini-intro-progress-bar {
  height: 0.38rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.2);
  overflow: hidden;
}

.campaign-preview-mini-intro-progress-fill {
  width: 64%;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #fff, rgba(255, 255, 255, 0.7));
}

.campaign-preview-mini-opening-step,
.campaign-preview-mini-result-step {
  position: absolute;
  inset: 0;
}

.campaign-preview-mini-opening-backdrop {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at center, rgba(207, 62, 54, 0.16) 0%, rgba(207, 62, 54, 0.04) 26%, rgba(207, 62, 54, 0) 46%),
    rgba(70, 0, 0, 0.2);
}

.campaign-preview-mini-opening-rain-layer {
  position: absolute;
  inset: 0;
  overflow: hidden;
}

.campaign-preview-mini-opening-rain-track {
  position: absolute;
  top: -3rem;
  width: 2rem;
  height: calc(100% + 6rem);
}

.campaign-preview-mini-opening-rain-envelope {
  position: absolute;
  top: 0;
  left: 0;
  width: 2rem;
  height: 3rem;
  opacity: 0;
  animation-timing-function: linear;
  animation-iteration-count: infinite;
}

.campaign-preview-mini-opening-rain-envelope.is-rain-left {
  animation-name: campaign-preview-rain-left;
}

.campaign-preview-mini-opening-rain-envelope.is-rain-right {
  animation-name: campaign-preview-rain-right;
}

.campaign-preview-mini-opening-rain-envelope.is-rain-soft-left {
  animation-name: campaign-preview-rain-soft-left;
}

.campaign-preview-mini-opening-rain-envelope.is-rain-soft-right {
  animation-name: campaign-preview-rain-soft-right;
}

.campaign-preview-mini-opening-rain-envelope.is-rain-straight {
  animation-name: campaign-preview-rain-straight;
}

.campaign-preview-mini-opening-rain-cap {
  position: absolute;
  top: 0.25rem;
  left: 0.38rem;
  width: 1.24rem;
  height: 1.24rem;
  border-radius: 0.38rem;
  transform: rotate(45deg);
  background: linear-gradient(180deg, #e14a43 0%, #b62d2d 100%);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.campaign-preview-mini-opening-rain-body {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  height: 2.16rem;
  border-radius: 0.78rem;
  background: #cf3e36;
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.22);
  overflow: hidden;
}

.campaign-preview-mini-opening-rain-top {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 0.5rem;
  background: rgba(167, 28, 28, 0.9);
}

.campaign-preview-mini-opening-rain-seal {
  position: absolute;
  left: 50%;
  top: 1.15rem;
  width: 0.72rem;
  height: 0.72rem;
  margin-left: -0.36rem;
  border-radius: 999px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #f3cc67 0%, #d89a28 100%);
}

.campaign-preview-mini-opening-rain-seal-core {
  width: 0.22rem;
  height: 0.22rem;
  border-radius: 999px;
  background: rgba(119, 73, 0, 0.56);
}

.campaign-preview-mini-opening-title-shell {
  position: relative;
  z-index: 1;
  min-height: 34rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 0 1.4rem;
  box-sizing: border-box;
  text-align: center;
}

.campaign-preview-mini-opening-title {
  font-size: 2rem;
  line-height: 1.02;
  font-weight: 900;
  text-shadow: 0 8px 22px rgba(0, 0, 0, 0.34);
}

.campaign-preview-mini-opening-subtitle {
  margin-top: 0.7rem;
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.94rem;
  line-height: 1.6;
}

.campaign-preview-mini-result-step {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.1rem;
  box-sizing: border-box;
}

.campaign-preview-mini-result-confetti-layer {
  position: absolute;
  inset: 0;
  overflow: hidden;
  pointer-events: none;
}

.campaign-preview-mini-result-confetti {
  position: absolute;
  width: 0.7rem;
  height: 0.7rem;
  border-radius: 0.22rem;
  animation: campaign-preview-confetti 2.2s ease-out infinite;
}

.campaign-preview-mini-result-confetti.is-tone-gold {
  top: 12%;
  left: 16%;
  background: linear-gradient(135deg, #f7d56c 0%, #de9d22 100%);
}

.campaign-preview-mini-result-confetti.is-tone-red {
  top: 18%;
  right: 14%;
  background: linear-gradient(135deg, #ef5350 0%, #cf3e36 100%);
  animation-delay: 0.28s;
}

.campaign-preview-mini-result-confetti.is-tone-white {
  top: 66%;
  left: 12%;
  background: linear-gradient(135deg, #fff 0%, #ffe9d9 100%);
  animation-delay: 0.16s;
}

.campaign-preview-mini-result-confetti.is-tone-orange {
  top: 72%;
  right: 12%;
  background: linear-gradient(135deg, #ffb56b 0%, #ff7a45 100%);
  animation-delay: 0.34s;
}

.campaign-preview-mini-result-glow {
  position: absolute;
  top: 50%;
  width: 9.5rem;
  height: 9.5rem;
  margin-top: -4.75rem;
  border-radius: 999px;
  filter: blur(18px);
  background: rgba(209, 53, 48, 0.18);
}

.campaign-preview-mini-result-glow.is-left {
  left: -1.4rem;
}

.campaign-preview-mini-result-glow.is-right {
  right: -1.8rem;
  background: rgba(255, 138, 80, 0.12);
}

.campaign-preview-mini-result-card {
  width: 100%;
  max-width: 17rem;
  max-height: calc(34rem - 2.2rem);
  display: flex;
  flex-direction: column;
}

.campaign-preview-mini-result-card-header {
  position: relative;
  z-index: 1;
  min-height: 7.8rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 2rem 1.2rem 1.9rem;
  text-align: center;
  background: linear-gradient(180deg, rgba(239, 68, 68, 0.18) 0%, rgba(239, 68, 68, 0.04) 72%, rgba(239, 68, 68, 0) 100%);
}

.campaign-preview-device-screen.is-theme-festive-gold .campaign-preview-mini-result-card-header {
  background: linear-gradient(180deg, rgba(247, 209, 102, 0.2) 0%, rgba(247, 209, 102, 0.04) 72%, rgba(247, 209, 102, 0) 100%);
}

.campaign-preview-device-screen.is-theme-lucky-night .campaign-preview-mini-result-card-header {
  background: linear-gradient(180deg, rgba(242, 95, 124, 0.2) 0%, rgba(139, 61, 255, 0.06) 72%, rgba(139, 61, 255, 0) 100%);
}

.campaign-preview-mini-result-card-header-glow {
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 50% 18%, rgba(255, 255, 255, 0.1) 0%, rgba(255, 255, 255, 0) 72%);
}

.campaign-preview-mini-result-header-kicker {
  position: relative;
  z-index: 1;
  color: rgba(255, 255, 255, 0.3);
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.campaign-preview-mini-result-header-title {
  position: relative;
  z-index: 1;
  margin-top: 0.5rem;
  font-size: 1.2rem;
  line-height: 1.38;
  text-align: center;
}

.campaign-preview-mini-result-coin-shell {
  position: absolute;
  left: 50%;
  top: 6rem;
  width: 3.6rem;
  height: 3.6rem;
  margin-left: -1.8rem;
  z-index: 2;
}

.campaign-preview-mini-result-coin-ring {
  position: absolute;
  inset: -0.44rem;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(255, 215, 102, 0.22) 0%, rgba(255, 215, 102, 0.05) 58%, rgba(255, 215, 102, 0) 100%);
}

.campaign-preview-mini-result-coin-core {
  position: relative;
  width: 100%;
  height: 100%;
  border-radius: 20px;
  font-size: 1.22rem;
}

.campaign-preview-mini-result-body {
  position: relative;
  z-index: 1;
  flex: 1;
  min-height: 0;
  padding: 4.6rem 1.35rem 1.35rem;
  box-sizing: border-box;
  text-align: center;
}

.campaign-preview-mini-result-body.is-success {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.campaign-preview-mini-result-amount-stage {
  margin-top: 0.3rem;
  padding: 1.2rem 0.9rem 1rem;
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.06) 0%, rgba(255, 255, 255, 0.03) 100%),
    rgba(255, 255, 255, 0.03);
}

.campaign-preview-mini-result-amount-row {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  gap: 0.12rem;
  color: #fff6eb;
}

.campaign-preview-mini-result-amount-major {
  font-size: 3.3rem;
  line-height: 0.92;
  font-weight: 900;
  letter-spacing: -0.05em;
}

.campaign-preview-mini-result-amount-minor {
  font-size: 1.7rem;
  line-height: 1;
  font-weight: 800;
  margin-bottom: 0.24rem;
}

.campaign-preview-mini-result-amount-unit {
  color: rgba(255, 246, 235, 0.78);
  font-size: 0.98rem;
  line-height: 1;
  font-weight: 700;
  margin-bottom: 0.42rem;
}

.campaign-preview-mini-result-description {
  margin-top: 1rem;
  color: rgba(255, 255, 255, 0.68);
  font-size: 0.92rem;
  line-height: 1.66;
}

.campaign-preview-mini-result-emotion {
  margin-top: 0.52rem;
  color: rgba(255, 255, 255, 0.42);
  font-size: 0.82rem;
  line-height: 1.7;
}

.campaign-preview-mini-result-primary-button {
  width: 100%;
  min-height: 3rem;
  margin-top: 1rem;
  border: none;
  border-radius: 999px;
  color: #fff;
  font-size: 0.96rem;
  font-weight: 700;
  background: linear-gradient(135deg, #ef5350 0%, #ff7043 100%);
  box-shadow: 0 16px 34px rgba(207, 62, 54, 0.24);
}

.campaign-preview-device-screen.is-theme-festive-gold .campaign-preview-mini-result-primary-button {
  background: linear-gradient(135deg, #f7d166 0%, #d58d22 100%);
  box-shadow: 0 16px 34px rgba(213, 141, 34, 0.24);
}

.campaign-preview-device-screen.is-theme-lucky-night .campaign-preview-mini-result-primary-button {
  background: linear-gradient(135deg, #f25f7c 0%, #8b3dff 100%);
  box-shadow: 0 16px 34px rgba(139, 61, 255, 0.22);
}

.campaign-preview-route-grid {
  display: grid;
  gap: 1rem;
}

.campaign-preview-route-block {
  display: grid;
  gap: 0.8rem;
}

.campaign-preview-route-meta {
  display: grid;
  gap: 0.32rem;
  padding: 0.85rem 0.9rem;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.56);
  border: 1px solid rgba(122, 17, 22, 0.08);
}

.campaign-preview-route-meta span {
  color: #8a6440;
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.campaign-preview-route-meta strong {
  color: #57150f;
  font-size: 0.96rem;
  line-height: 1.5;
}

.campaign-preview-route-meta em,
.campaign-preview-route-meta code {
  color: #7b5734;
  font-style: normal;
  font-size: 0.82rem;
  line-height: 1.6;
  word-break: break-all;
}

.campaign-preview-route-tiers {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

.campaign-preview-route-tier {
  display: grid;
  gap: 0.12rem;
  min-width: 5.6rem;
  padding: 0.55rem 0.7rem;
  border-radius: 16px;
  background: rgba(122, 17, 22, 0.05);
  border: 1px solid rgba(122, 17, 22, 0.08);
}

.campaign-preview-route-tier strong,
.campaign-preview-route-tier em {
  font-style: normal;
}

.campaign-preview-route-tier strong {
  color: #5c180f;
  font-size: 0.84rem;
}

.campaign-preview-route-tier em {
  color: #8a6440;
  font-size: 0.74rem;
}

@keyframes campaign-preview-blob-a {
  from {
    transform: translate3d(-2%, -2%, 0) scale(1);
  }

  to {
    transform: translate3d(8%, 5%, 0) scale(1.08);
  }
}

@keyframes campaign-preview-blob-b {
  from {
    transform: translate3d(4%, -4%, 0) scale(1.02);
  }

  to {
    transform: translate3d(-8%, 7%, 0) scale(1.1);
  }
}

@keyframes campaign-preview-blob-c {
  from {
    transform: translate3d(-4%, 0, 0) scale(0.98);
  }

  to {
    transform: translate3d(6%, -8%, 0) scale(1.06);
  }
}

@keyframes campaign-preview-rain-straight {
  0% {
    transform: translate3d(0, 0, 0) rotate(0deg);
    opacity: 0;
  }

  14%,
  82% {
    opacity: 1;
  }

  100% {
    transform: translate3d(0, 31rem, 0) rotate(120deg);
    opacity: 0;
  }
}

@keyframes campaign-preview-rain-left {
  0% {
    transform: translate3d(0, 0, 0) rotate(-8deg);
    opacity: 0;
  }

  14%,
  82% {
    opacity: 1;
  }

  100% {
    transform: translate3d(-0.8rem, 31rem, 0) rotate(168deg);
    opacity: 0;
  }
}

@keyframes campaign-preview-rain-right {
  0% {
    transform: translate3d(0, 0, 0) rotate(8deg);
    opacity: 0;
  }

  14%,
  82% {
    opacity: 1;
  }

  100% {
    transform: translate3d(0.8rem, 31rem, 0) rotate(-168deg);
    opacity: 0;
  }
}

@keyframes campaign-preview-rain-soft-left {
  0% {
    transform: translate3d(0, 0, 0) rotate(-4deg);
    opacity: 0;
  }

  14%,
  82% {
    opacity: 1;
  }

  100% {
    transform: translate3d(-0.46rem, 31rem, 0) rotate(104deg);
    opacity: 0;
  }
}

@keyframes campaign-preview-rain-soft-right {
  0% {
    transform: translate3d(0, 0, 0) rotate(4deg);
    opacity: 0;
  }

  14%,
  82% {
    opacity: 1;
  }

  100% {
    transform: translate3d(0.46rem, 31rem, 0) rotate(-104deg);
    opacity: 0;
  }
}

@keyframes campaign-preview-confetti {
  0% {
    transform: translate3d(0, 0, 0) rotate(0deg);
  }

  50% {
    transform: translate3d(0.18rem, 0.44rem, 0) rotate(18deg);
  }

  100% {
    transform: translate3d(-0.12rem, 0.88rem, 0) rotate(-12deg);
  }
}

@media (max-width: 640px) {
  .campaign-preview-live-head {
    flex-direction: column;
    align-items: flex-start;
  }

  .campaign-preview-device {
    max-width: 100%;
  }

  .campaign-preview-device-screen,
  .campaign-preview-mini-input-step,
  .campaign-preview-mini-opening-step,
  .campaign-preview-mini-result-step {
    min-height: 31rem;
  }
}
