/* =====================================================================
   profilecards · X aesthetic
   - 4 design styles: classic / glass / pastel / editorial
   - Each design has its own color themes
   - Multi template: simple uniform layout w/ swappable bg theme
   ===================================================================== */

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

:root {
  --font-display: "Fraunces", Georgia, serif;
  --font-body: "Plus Jakarta Sans", system-ui, sans-serif;
  --font-soft: "Quicksand", "Plus Jakarta Sans", sans-serif;
  --font-mag: "DM Serif Display", "Fraunces", Georgia, serif;

  --r-sm: 12px;
  --r-md: 18px;
  --r-lg: 28px;
  --r-xl: 36px;

  --shadow-soft: 0 6px 24px -8px rgba(40, 18, 40, 0.18);
  --shadow-card: 0 18px 48px -12px rgba(40, 18, 40, 0.22);
  --shadow-pop:  0 24px 60px -16px rgba(40, 18, 40, 0.28);

  /* Page chrome (UI only — does NOT affect cards) */
  --pg-bg: #fbf6f9;
  --pg-bg2: #f5e6ee;
  --pg-surface: #ffffff;
  --pg-ink: #2a121f;
  --pg-mute: #8a667a;
  --pg-line: #f0d6e0;
  --pg-accent: #c2185b;
  --pg-accent-soft: #fde4ec;
}

html, body { margin: 0; padding: 0; }
body {
  font-family: var(--font-body);
  background:
    radial-gradient(900px 500px at 110% -10%, var(--pg-bg2), transparent 60%),
    radial-gradient(700px 400px at -10% 110%, var(--pg-bg2), transparent 55%),
    var(--pg-bg);
  color: var(--pg-ink);
  min-height: 100vh;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

/* ============ TOPBAR ============ */
.topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 22px;
  max-width: 1180px;
  margin: 0 auto;
}
.brand { display: flex; align-items: center; gap: 12px; }
.brand-dot {
  width: 14px; height: 14px; border-radius: 50%;
  background: var(--pg-accent);
  box-shadow: 0 0 0 4px var(--pg-accent-soft);
}
.brand-text { display: flex; flex-direction: column; line-height: 1; }
.brand-name {
  font-family: "DM Serif Display", "Plus Jakarta Sans", Georgia, serif;
  font-weight: 400;
  font-size: 26px;
  letter-spacing: -0.015em;
  color: var(--pg-ink);
}
.brand-sub {
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--pg-accent);
  margin-top: 4px;
  font-weight: 800;
}

/* ============ TABS ============ */
.tabs {
  display: flex;
  gap: 8px;
  max-width: 1180px;
  margin: 6px auto 18px;
  padding: 0 22px;
}
.tab {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 22px;
  border-radius: 999px;
  border: 1.5px solid var(--pg-line);
  background: var(--pg-surface);
  color: var(--pg-mute);
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 800;
  cursor: pointer;
  transition: all 0.2s;
}
.tab:hover { color: var(--pg-ink); }
.tab.active {
  background: var(--pg-accent);
  color: #fff;
  border-color: var(--pg-accent);
  box-shadow: var(--shadow-soft);
}

/* ============ WRAP & PANELS ============ */
.wrap {
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 22px 60px;
}
.tab-panel { display: none; }
.tab-panel.active { display: block; animation: fadeUp 0.4s ease; }
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}

.hero {
  display: flex;
  align-items: flex-start;
  gap: 18px;
  margin: 14px 0 22px;
}
.hero-emoji { font-size: 44px; line-height: 1; flex-shrink: 0; }
.hero h1 {
  font-family: "DM Serif Display", "Plus Jakarta Sans", Georgia, serif;
  font-weight: 400;
  font-size: clamp(28px, 5.2vw, 42px);
  letter-spacing: -0.02em;
  margin: 0 0 8px;
  line-height: 1.1;
}
.hero h1 .accent {
  color: var(--pg-accent);
  font-style: italic;
  font-weight: 400;
}
.hero p {
  margin: 0;
  color: var(--pg-mute);
  font-size: 15px;
  max-width: 560px;
  font-weight: 500;
}
.hero p b { color: var(--pg-ink); font-weight: 700; }
.hero p i { font-style: italic; color: var(--pg-accent); }

.panel {
  background: var(--pg-surface);
  border-radius: var(--r-lg);
  padding: 22px;
  border: 1px solid var(--pg-line);
  box-shadow: var(--shadow-soft);
}
.panel-label {
  margin: 0 0 12px;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 900;
  color: var(--pg-accent);
}
.panel-hint { font-size: 12px; color: var(--pg-mute); font-weight: 600; }

.input-row {
  display: flex;
  align-items: center;
  background: var(--pg-accent-soft);
  border-radius: var(--r-md);
  padding: 4px 6px 4px 16px;
  border: 1px solid transparent;
  transition: border-color 0.2s;
}
.input-row:focus-within { border-color: var(--pg-accent); }
.input-prefix {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 22px;
  color: var(--pg-accent);
  margin-right: 4px;
}
.input-row input {
  flex: 1;
  background: transparent;
  border: 0;
  outline: 0;
  font-family: var(--font-body);
  font-size: 16px;
  font-weight: 700;
  color: var(--pg-ink);
  padding: 12px 8px;
}
.input-row input::placeholder { color: var(--pg-mute); opacity: 0.5; font-weight: 600; }

textarea#multiUsers {
  width: 100%;
  background: var(--pg-accent-soft);
  border: 1px solid transparent;
  border-radius: var(--r-md);
  padding: 14px 16px;
  font-family: var(--font-body);
  font-size: 15px;
  color: var(--pg-ink);
  resize: vertical;
  outline: 0;
  transition: border-color 0.2s;
}
textarea#multiUsers:focus { border-color: var(--pg-accent); }

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

.btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 13px 26px;
  border-radius: 999px;
  border: 0;
  background: var(--pg-accent);
  color: #fff;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 900;
  letter-spacing: 0.01em;
  cursor: pointer;
  box-shadow: var(--shadow-soft);
  transition: all 0.2s;
}
.btn-primary:hover { transform: translateY(-1px); box-shadow: var(--shadow-pop); }
.btn-primary:disabled { opacity: 0.6; cursor: wait; transform: none; }

.btn-save {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 11px 22px;
  border-radius: 999px;
  border: 0;
  background: var(--pg-accent);
  color: #fff;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 900;
  cursor: pointer;
  box-shadow: var(--shadow-soft);
  transition: all 0.2s;
}
.btn-save:hover { transform: translateY(-1px); box-shadow: var(--shadow-pop); }
.btn-save:disabled { opacity: 0.7; cursor: wait; transform: none; }
.btn-save.saved { background: #1d6b3a; }

.status {
  margin-top: 14px;
  padding: 12px 14px;
  border-radius: var(--r-sm);
  font-size: 13px;
  font-weight: 700;
}
.status.ok  { background: #e8f7ee; color: #1d6b3a; }
.status.err { background: #fde8ea; color: #a3262e; }

/* ============ DESIGN PICKER ============ */
.design-picker {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}
.design-card {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 6px;
  padding: 10px;
  border-radius: var(--r-md);
  border: 2px solid var(--pg-line);
  background: var(--pg-surface);
  cursor: pointer;
  text-align: left;
  font-family: inherit;
  transition: all 0.2s;
}
.design-card:hover { border-color: var(--pg-accent-soft); transform: translateY(-2px); }
.design-card.active {
  border-color: var(--pg-accent);
  box-shadow: 0 6px 16px -8px rgba(194, 24, 91, 0.4);
}
.design-name {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 14px;
  color: var(--pg-ink);
  margin-top: 2px;
  letter-spacing: -0.01em;
}
.design-desc {
  font-size: 10px;
  color: var(--pg-mute);
  letter-spacing: 0.04em;
  font-weight: 600;
}

/* design preview thumbnails */
.design-preview {
  position: relative;
  height: 70px;
  border-radius: var(--r-sm);
  overflow: hidden;
  background: #f6eef2;
}
.design-preview i { display: block; position: absolute; }
/* Classic preview */
.design-preview-classic { background: #fff; }
.design-preview-classic .dp-banner {
  inset: 0 0 60% 0;
  background: linear-gradient(135deg, #ffc4d6, #c2185b);
}
.design-preview-classic .dp-avatar {
  width: 18px; height: 18px; border-radius: 50%;
  background: #fff; border: 2px solid #fff;
  left: 8px; top: 22px;
  box-shadow: 0 2px 4px rgba(0,0,0,0.15);
}
.design-preview-classic .dp-line {
  height: 3px; border-radius: 2px; background: #2a121f;
  left: 8px; right: 30px; bottom: 16px;
}
.design-preview-classic .dp-line.short {
  bottom: 8px; right: 50%; opacity: 0.4;
}

/* Glass preview */
.design-preview-glass {
  background: linear-gradient(135deg, #6a3ec9 0%, #d99cf0 100%);
}
.design-preview-glass .dp-blur {
  inset: 0;
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,0.4), transparent 50%),
              radial-gradient(circle at 70% 70%, rgba(255,200,255,0.5), transparent 60%);
  filter: blur(2px);
}
.design-preview-glass .dp-avatar {
  width: 22px; height: 22px; border-radius: 50%;
  background: rgba(255,255,255,0.4);
  border: 2px solid rgba(255,255,255,0.7);
  left: 50%; top: 8px;
  transform: translateX(-50%);
  backdrop-filter: blur(4px);
}
.design-preview-glass .dp-line {
  height: 3px; border-radius: 2px;
  background: rgba(255,255,255,0.8);
  left: 30%; right: 30%; top: 38px;
}
.design-preview-glass .dp-pills {
  position: absolute;
  bottom: 6px; left: 8px; right: 8px;
  display: flex; gap: 4px; justify-content: center;
}
.design-preview-glass .dp-pills b {
  flex: 1;
  height: 14px;
  background: rgba(255,255,255,0.25);
  border: 1px solid rgba(255,255,255,0.4);
  border-radius: 4px;
  backdrop-filter: blur(4px);
}

/* Pastel preview */
.design-preview-pastel { background: #ffe4ed; }
.design-preview-pastel::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 20% 80%, rgba(255,255,255,0.6), transparent 30%),
    radial-gradient(circle at 80% 20%, rgba(255,200,220,0.6), transparent 40%);
}
.design-preview-pastel .dp-deco {
  font-size: 14px;
  color: #c54971;
  top: 4px; right: 6px;
  font-style: normal;
}
.design-preview-pastel .dp-avatar {
  width: 22px; height: 22px; border-radius: 50%;
  background: #fff;
  border: 2px solid #fff;
  left: 50%; top: 12px;
  transform: translateX(-50%);
  box-shadow: 0 0 0 3px rgba(197,73,113,0.2);
}
.design-preview-pastel .dp-line {
  height: 3px; border-radius: 2px;
  background: #c54971;
  left: 30%; right: 30%; bottom: 18px;
}
.design-preview-pastel .dp-line.short {
  bottom: 10px; right: 45%; left: 35%; opacity: 0.5;
}

/* Editorial preview */
.design-preview-editorial { background: #f4ede0; }
.design-preview-editorial .dp-serif {
  font-family: var(--font-mag);
  font-size: 38px;
  font-style: italic;
  color: #2a1a0a;
  top: -8px; left: 6px;
  line-height: 1;
}
.design-preview-editorial .dp-rule {
  height: 1px; background: #2a1a0a;
  left: 8px; right: 8px; top: 32px;
}
.design-preview-editorial .dp-line {
  height: 2px; border-radius: 1px;
  background: #2a1a0a;
  left: 8px; right: 30px; bottom: 18px;
}
.design-preview-editorial .dp-line.short {
  bottom: 10px; right: 50%; opacity: 0.5;
}

/* ============ THEME PICKER ============ */
.theme-picker {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.theme-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 7px 14px 7px 7px;
  border-radius: 999px;
  border: 2px solid var(--pg-line);
  background: var(--pg-surface);
  color: var(--pg-ink);
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 800;
  cursor: pointer;
  transition: all 0.2s;
}
.theme-pill:hover { border-color: var(--pg-accent-soft); }
.theme-pill.active { border-color: var(--pg-accent); }
.theme-swatch {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--sw1), var(--sw2));
  box-shadow: inset 0 0 0 2px #fff;
}

/* ============ TEMPLATE PICKER ============ */
.template-picker { display: flex; gap: 10px; flex-wrap: wrap; }
.tpl-pill {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px 10px 12px;
  border-radius: 999px;
  border: 2px solid var(--pg-line);
  background: var(--pg-surface);
  color: var(--pg-ink);
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 800;
  cursor: pointer;
  transition: all 0.2s;
}
.tpl-pill:hover { border-color: var(--pg-accent-soft); }
.tpl-pill.active {
  background: var(--pg-accent-soft);
  border-color: var(--pg-accent);
  color: var(--pg-accent);
}
.tpl-grid { display: grid; gap: 2px; width: 22px; height: 22px; }
.tpl-grid i { background: currentColor; border-radius: 2px; opacity: 0.7; }
.tpl-1x2 { grid-template-columns: 1fr 1fr; grid-template-rows: 1fr; }
.tpl-2x2 { grid-template-columns: 1fr 1fr; grid-template-rows: 1fr 1fr; }
.tpl-3x2 { grid-template-columns: 1fr 1fr 1fr; grid-template-rows: 1fr 1fr; }
.tpl-4x2 { grid-template-columns: 1fr 1fr 1fr 1fr; grid-template-rows: 1fr 1fr; }

/* Multi theme picker */
.multi-theme-picker {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.mt-pill {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 2px solid var(--pg-line);
  cursor: pointer;
  transition: all 0.2s;
  padding: 0;
}
.mt-pill[data-bg="lilac"]    { background: linear-gradient(135deg, #ebe2ff, #c4b0ff); }
.mt-pill[data-bg="sakura"]   { background: linear-gradient(135deg, #fde4ec, #f8b1c8); }
.mt-pill[data-bg="mint"]     { background: linear-gradient(135deg, #d8f1e0, #92d3a8); }
.mt-pill[data-bg="cream"]    { background: linear-gradient(135deg, #fff0c6, #f5d976); }
.mt-pill[data-bg="sky"]      { background: linear-gradient(135deg, #d6e8fb, #95bee8); }
.mt-pill[data-bg="peach"]    { background: linear-gradient(135deg, #ffe0cf, #f8b18d); }
.mt-pill[data-bg="paper"]    { background: linear-gradient(135deg, #f4ede0, #d8c8a8); }
.mt-pill[data-bg="midnight"] { background: linear-gradient(135deg, #2c2138, #14101a); }
.mt-pill:hover { transform: scale(1.08); }
.mt-pill.active {
  border-color: var(--pg-accent);
  box-shadow: 0 0 0 3px var(--pg-accent-soft);
  transform: scale(1.05);
}

/* ============ RESULT AREA ============ */
.result-area { margin-top: 26px; }
.result-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
  gap: 12px;
  flex-wrap: wrap;
}
.result-title {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 22px;
  font-style: italic;
  color: var(--pg-accent);
}
.single-card-wrap {
  display: flex;
  justify-content: center;
  padding: 10px 0;
}
.multi-frame-wrap {
  display: flex;
  justify-content: center;
  overflow-x: auto;
  padding: 8px 0;
}

/* ============ FOOTER ============ */
.footer {
  text-align: center;
  padding: 24px 12px 32px;
  font-size: 12px;
  color: var(--pg-mute);
  letter-spacing: 0.1em;
  font-weight: 700;
}

/* ============ RESPONSIVE ============ */
@media (max-width: 600px) {
  .hero { gap: 12px; }
  .hero-emoji { font-size: 36px; }
  .panel { padding: 18px; border-radius: var(--r-md); }
  .tabs { padding: 0 14px; }
  .wrap { padding: 0 14px 60px; }
  .topbar { padding: 14px 16px; }
  .design-picker { grid-template-columns: repeat(2, 1fr); }
}

/* =====================================================================
   ============ THE PROFILE CARD — 4 DESIGNS ===========================
   ===================================================================== */

.pc-card {
  width: 380px;
  position: relative;
  font-family: var(--font-body);
  --c-bg: #fff;
  --c-ink: #2a121f;
  --c-mute: #8a667a;
  --c-line: #f0d6e0;
  --c-accent: #c2185b;
  --c-banner-from: #ffc4d6;
  --c-banner-to: #c2185b;
}

/* avatar fallback letter */
.pc-fallback {
  font-family: var(--font-display);
  font-weight: 800;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}

.pc-verified {
  display: inline-flex;
  width: 18px;
  height: 18px;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.pc-verified svg { width: 18px; height: 18px; }

/* =================== DESIGN 1 · CLASSIC =================== */
/* Theme palettes for classic */
.pc-card[data-design="classic"][data-theme="pink"]     { --c-accent:#c2185b; --c-banner-from:#ffc4d6; --c-banner-to:#c2185b; --c-line:#f3d6e1; --c-mute:#8a667a; --c-ink:#2a121f; }
.pc-card[data-design="classic"][data-theme="sky"]      { --c-accent:#1a6fd9; --c-banner-from:#a8caee; --c-banner-to:#1a6fd9; --c-line:#c6dbf2; --c-mute:#5e7898; --c-ink:#0d1f37; }
.pc-card[data-design="classic"][data-theme="mint"]     { --c-accent:#058c6f; --c-banner-from:#a6e1c1; --c-banner-to:#058c6f; --c-line:#c9e8d3; --c-mute:#5d8071; --c-ink:#0f2a1e; }
.pc-card[data-design="classic"][data-theme="lavender"] { --c-accent:#6a3ec9; --c-banner-from:#cab9fb; --c-banner-to:#6a3ec9; --c-line:#ddd1f5; --c-mute:#786a99; --c-ink:#1f1538; }
.pc-card[data-design="classic"][data-theme="peach"]    { --c-accent:#d8590e; --c-banner-from:#fdc8a3; --c-banner-to:#d8590e; --c-line:#f7d2bb; --c-mute:#966851; --c-ink:#2c160b; }
.pc-card[data-design="classic"][data-theme="rose"]     { --c-accent:#c1252f; --c-banner-from:#f3a8ad; --c-banner-to:#c1252f; --c-line:#f0c5c6; --c-mute:#95636a; --c-ink:#2a0e10; }
.pc-card[data-design="classic"][data-theme="ocean"]    { --c-accent:#00838d; --c-banner-from:#9fd4d3; --c-banner-to:#00838d; --c-line:#b5dedb; --c-mute:#527c79; --c-ink:#082624; }
.pc-card[data-design="classic"][data-theme="butter"]   { --c-accent:#b88500; --c-banner-from:#fbe28a; --c-banner-to:#b88500; --c-line:#f5e2a3; --c-mute:#918143; --c-ink:#2a2208; }
.pc-card[data-design="classic"][data-theme="matcha"]   { --c-accent:#5d8c0a; --c-banner-from:#c5d68f; --c-banner-to:#5d8c0a; --c-line:#cfdaaa; --c-mute:#687853; --c-ink:#1d2807; }
.pc-card[data-design="classic"][data-theme="grape"]    { --c-accent:#8a2bbb; --c-banner-from:#e0b3f5; --c-banner-to:#8a2bbb; --c-line:#e8d5f0; --c-mute:#7a5a8a; --c-ink:#2a1235; }

.pc-card[data-design="classic"] {
  background: var(--c-bg);
  border-radius: var(--r-lg);
  overflow: hidden;
  box-shadow: var(--shadow-card);
  border: 1px solid var(--c-line);
  color: var(--c-ink);
}
.pc-card[data-design="classic"] .pc-banner {
  height: 110px;
  background: linear-gradient(135deg, var(--c-banner-from), var(--c-banner-to));
  background-size: cover; background-position: center;
  position: relative;
  overflow: hidden;
}
.pc-card[data-design="classic"] .pc-banner::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(0,0,0,0.08));
}
.pc-card[data-design="classic"] .pc-avatar {
  width: 84px; height: 84px; border-radius: 50%;
  background: var(--c-line);
  border: 4px solid var(--c-bg);
  position: absolute; left: 22px; top: 68px;
  overflow: hidden;
  box-shadow: var(--shadow-soft);
}
.pc-card[data-design="classic"] .pc-avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }
.pc-card[data-design="classic"] .pc-fallback {
  font-size: 38px; color: var(--c-accent); background: var(--c-line);
}
.pc-card[data-design="classic"] .pc-body { padding: 50px 22px 22px; }
.pc-card[data-design="classic"] .pc-name-row { display: flex; align-items: center; gap: 6px; margin-bottom: 2px; }
.pc-card[data-design="classic"] .pc-name {
  font-family: var(--font-display);
  font-weight: 700; font-size: 22px; letter-spacing: -0.01em; margin: 0; line-height: 1.2;
}
.pc-card[data-design="classic"] .pc-handle { font-size: 13px; color: var(--c-mute); margin-bottom: 10px; font-weight: 500; }
.pc-card[data-design="classic"] .pc-bio {
  font-size: 13px; line-height: 1.5; color: var(--c-ink);
  margin: 8px 0 12px; word-wrap: break-word; overflow-wrap: anywhere;
  white-space: pre-wrap;
}
.pc-card[data-design="classic"] .pc-meta {
  display: flex; flex-wrap: wrap; gap: 6px 14px;
  font-size: 12px; color: var(--c-mute); margin-bottom: 14px;
}
.pc-card[data-design="classic"] .pc-meta span { display: inline-flex; align-items: center; gap: 4px; }
.pc-card[data-design="classic"] .pc-stats {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px;
  padding-top: 12px; border-top: 1px dashed var(--c-line);
}
.pc-card[data-design="classic"] .pc-stat { display: flex; flex-direction: column; align-items: center; text-align: center; }
.pc-card[data-design="classic"] .pc-stat-num {
  font-family: var(--font-display);
  font-weight: 800; font-size: 18px; color: var(--c-ink); line-height: 1.1;
}
.pc-card[data-design="classic"] .pc-stat-label {
  font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--c-mute); margin-top: 4px; font-weight: 700;
}

/* =================== DESIGN 2 · GLASS =================== */
.pc-card[data-design="glass"][data-theme="aurora"]    { --c-grad-1:#6a3ec9; --c-grad-2:#d99cf0; --c-grad-3:#7eb6ff; --c-accent:#fff; --c-text:#fff; --c-text-soft:rgba(255,255,255,0.85); --c-text-mute:rgba(255,255,255,0.7); --c-glass:rgba(255,255,255,0.12); --c-glass-strong:rgba(255,255,255,0.22); }
.pc-card[data-design="glass"][data-theme="midnight"]  { --c-grad-1:#0f0a1e; --c-grad-2:#3a1f5a; --c-grad-3:#1a3a5a; --c-accent:#cfa8ff; --c-text:#fff; --c-text-soft:rgba(220,200,255,0.9); --c-text-mute:rgba(180,160,220,0.75); --c-glass:rgba(180,140,255,0.08); --c-glass-strong:rgba(180,140,255,0.18); }
.pc-card[data-design="glass"][data-theme="sunset"]    { --c-grad-1:#ff5e87; --c-grad-2:#ff9266; --c-grad-3:#ffd070; --c-accent:#fff; --c-text:#fff; --c-text-soft:rgba(255,255,255,0.92); --c-text-mute:rgba(255,255,255,0.75); --c-glass:rgba(255,255,255,0.16); --c-glass-strong:rgba(255,255,255,0.26); }
.pc-card[data-design="glass"][data-theme="ocean"]     { --c-grad-1:#00838d; --c-grad-2:#5ec0c2; --c-grad-3:#a8e1d8; --c-accent:#fff; --c-text:#fff; --c-text-soft:rgba(255,255,255,0.9); --c-text-mute:rgba(255,255,255,0.72); --c-glass:rgba(255,255,255,0.14); --c-glass-strong:rgba(255,255,255,0.24); }
.pc-card[data-design="glass"][data-theme="cottoncandy"]{ --c-grad-1:#f8a7d6; --c-grad-2:#c1a5f0; --c-grad-3:#a5d4f0; --c-accent:#fff; --c-text:#fff; --c-text-soft:rgba(255,255,255,0.92); --c-text-mute:rgba(255,255,255,0.75); --c-glass:rgba(255,255,255,0.18); --c-glass-strong:rgba(255,255,255,0.28); }
.pc-card[data-design="glass"][data-theme="dusk"]      { --c-grad-1:#5a3270; --c-grad-2:#a05080; --c-grad-3:#f0a070; --c-accent:#fff; --c-text:#fff; --c-text-soft:rgba(255,235,225,0.92); --c-text-mute:rgba(255,220,200,0.72); --c-glass:rgba(255,255,255,0.13); --c-glass-strong:rgba(255,255,255,0.22); }
.pc-card[data-design="glass"][data-theme="emerald"]   { --c-grad-1:#0a5040; --c-grad-2:#1a8060; --c-grad-3:#80c898; --c-accent:#fff; --c-text:#fff; --c-text-soft:rgba(240,255,245,0.9); --c-text-mute:rgba(200,230,210,0.72); --c-glass:rgba(255,255,255,0.13); --c-glass-strong:rgba(255,255,255,0.22); }
.pc-card[data-design="glass"][data-theme="cherry"]    { --c-grad-1:#a0143a; --c-grad-2:#e85070; --c-grad-3:#ffa0b0; --c-accent:#fff; --c-text:#fff; --c-text-soft:rgba(255,235,240,0.92); --c-text-mute:rgba(255,210,220,0.75); --c-glass:rgba(255,255,255,0.16); --c-glass-strong:rgba(255,255,255,0.26); }
.pc-card[data-design="glass"][data-theme="frost"]     { --c-grad-1:#7eb6e8; --c-grad-2:#b5d8f0; --c-grad-3:#e0eef8; --c-accent:#1a4060; --c-text:#1a3050; --c-text-soft:rgba(20,40,80,0.85); --c-text-mute:rgba(40,60,100,0.65); --c-glass:rgba(255,255,255,0.32); --c-glass-strong:rgba(255,255,255,0.5); }
.pc-card[data-design="glass"][data-theme="lava"]      { --c-grad-1:#1a0a14; --c-grad-2:#5a1010; --c-grad-3:#e85020; --c-accent:#ffc870; --c-text:#fff; --c-text-soft:rgba(255,235,210,0.9); --c-text-mute:rgba(255,200,170,0.72); --c-glass:rgba(255,180,100,0.1); --c-glass-strong:rgba(255,180,100,0.2); }

.pc-card[data-design="glass"] {
  border-radius: var(--r-xl);
  padding: 32px 22px 26px;
  background:
    radial-gradient(circle at 15% 0%, var(--c-grad-2), transparent 50%),
    radial-gradient(circle at 85% 100%, var(--c-grad-3), transparent 55%),
    linear-gradient(135deg, var(--c-grad-1), var(--c-grad-2));
  box-shadow: var(--shadow-pop);
  overflow: hidden;
  color: var(--c-text);
}
.pc-card[data-design="glass"]::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(circle at 80% 20%, rgba(255,255,255,0.18), transparent 30%),
    radial-gradient(circle at 20% 80%, rgba(255,255,255,0.12), transparent 35%);
  pointer-events: none;
}
.pc-card[data-design="glass"] .pc-banner { display: none; }
.pc-card[data-design="glass"] .pc-avatar {
  width: 96px; height: 96px; border-radius: 50%;
  margin: 0 auto 14px;
  border: 3px solid rgba(255,255,255,0.35);
  background: var(--c-glass);
  overflow: hidden;
  box-shadow: 0 8px 24px -6px rgba(0,0,0,0.35);
  position: relative;
}
.pc-card[data-design="glass"] .pc-avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }
.pc-card[data-design="glass"] .pc-fallback {
  font-size: 42px; color: var(--c-text); background: var(--c-glass-strong);
}
.pc-card[data-design="glass"] .pc-body { text-align: center; position: relative; }
.pc-card[data-design="glass"] .pc-name-row {
  display: flex; align-items: center; justify-content: center; gap: 6px; margin-bottom: 4px;
}
.pc-card[data-design="glass"] .pc-name {
  font-family: var(--font-display);
  font-weight: 700; font-size: 26px;
  margin: 0; line-height: 1.1;
  color: var(--c-text);
  text-shadow: 0 2px 8px rgba(0,0,0,0.2);
}
.pc-card[data-design="glass"] .pc-handle {
  font-size: 14px; color: var(--c-text-mute);
  margin-bottom: 14px; font-weight: 500;
}
.pc-card[data-design="glass"] .pc-bio {
  font-size: 13px; line-height: 1.55; color: var(--c-text-soft);
  margin: 0 0 14px; word-wrap: break-word; overflow-wrap: anywhere;
  padding: 0 6px;
  white-space: pre-wrap;
}
.pc-card[data-design="glass"] .pc-meta {
  display: flex; flex-wrap: wrap; justify-content: center; gap: 6px 12px;
  font-size: 11px; color: var(--c-text-mute); margin-bottom: 18px;
}
.pc-card[data-design="glass"] .pc-meta span { display: inline-flex; align-items: center; gap: 3px; }
.pc-card[data-design="glass"] .pc-stats {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px;
}
.pc-card[data-design="glass"] .pc-stat {
  background: var(--c-glass);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: var(--r-md);
  padding: 10px 4px;
  display: flex; flex-direction: column; align-items: center;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.pc-card[data-design="glass"] .pc-stat-num {
  font-family: var(--font-display);
  font-weight: 800; font-size: 18px; color: var(--c-text); line-height: 1.1;
}
.pc-card[data-design="glass"] .pc-stat-label {
  font-size: 9px; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--c-text-mute); margin-top: 4px; font-weight: 600;
}

/* =================== DESIGN 3 · PASTEL =================== */
.pc-card[data-design="pastel"][data-theme="sakura"]    { --c-bg:#fff5f8; --c-bg2:#ffe4ed; --c-ink:#5a2540; --c-mute:#9c6480; --c-accent:#d65a8a; --c-line:#fad5e1; --c-deco:#e891b1; }
.pc-card[data-design="pastel"][data-theme="mintlatte"] { --c-bg:#f4fbf6; --c-bg2:#dff1e6; --c-ink:#1f4630; --c-mute:#6a8c76; --c-accent:#3b9968; --c-line:#cce6d5; --c-deco:#73b594; }
.pc-card[data-design="pastel"][data-theme="butter"]    { --c-bg:#fffbef; --c-bg2:#fff0c6; --c-ink:#5a4408; --c-mute:#a08945; --c-accent:#d49a16; --c-line:#f5e2a3; --c-deco:#e8c25f; }
.pc-card[data-design="pastel"][data-theme="lilac"]     { --c-bg:#faf6ff; --c-bg2:#ebe2ff; --c-ink:#3a2560; --c-mute:#8276a8; --c-accent:#9265dd; --c-line:#d9c9f5; --c-deco:#b193e4; }
.pc-card[data-design="pastel"][data-theme="peach"]     { --c-bg:#fff7f0; --c-bg2:#ffe0cf; --c-ink:#5a3215; --c-mute:#a87a55; --c-accent:#e07535; --c-line:#fad4ba; --c-deco:#f0a87b; }
.pc-card[data-design="pastel"][data-theme="bluemilk"]  { --c-bg:#f4f9ff; --c-bg2:#dbe8fa; --c-ink:#1f3560; --c-mute:#7888a8; --c-accent:#4575c5; --c-line:#cad7ec; --c-deco:#84a5da; }
.pc-card[data-design="pastel"][data-theme="rosewater"] { --c-bg:#fdf5f3; --c-bg2:#fbdbd3; --c-ink:#5a2820; --c-mute:#a5736a; --c-accent:#c84e3c; --c-line:#f3c5b8; --c-deco:#e08775; }
.pc-card[data-design="pastel"][data-theme="seafoam"]   { --c-bg:#f0fafa; --c-bg2:#cee9e8; --c-ink:#0a3838; --c-mute:#5a8585; --c-accent:#1a8585; --c-line:#b5dad9; --c-deco:#5fb0ae; }
.pc-card[data-design="pastel"][data-theme="vanilla"]   { --c-bg:#fefaf2; --c-bg2:#f4ecd5; --c-ink:#3a2c0e; --c-mute:#8a7752; --c-accent:#a37618; --c-line:#e8d8a8; --c-deco:#c8a85a; }
.pc-card[data-design="pastel"][data-theme="bubblegum"] { --c-bg:#fdf5fb; --c-bg2:#f6d8ee; --c-ink:#5a1850; --c-mute:#985a8e; --c-accent:#c83098; --c-line:#eec3e0; --c-deco:#dd75c0; }

.pc-card[data-design="pastel"] {
  background: var(--c-bg);
  border-radius: 32px;
  padding: 0;
  overflow: hidden;
  border: 2px solid var(--c-line);
  box-shadow: 0 20px 50px -16px rgba(180, 100, 140, 0.25);
  color: var(--c-ink);
}
.pc-card[data-design="pastel"] .pc-banner {
  height: 90px;
  background:
    radial-gradient(circle at 20% 50%, rgba(255,255,255,0.4), transparent 40%),
    radial-gradient(circle at 80% 30%, var(--c-deco), transparent 55%),
    var(--c-bg2);
  position: relative;
  overflow: hidden;
}
.pc-card[data-design="pastel"] .pc-banner::before,
.pc-card[data-design="pastel"] .pc-banner::after {
  position: absolute; font-size: 16px; color: var(--c-accent); opacity: 0.6;
}
/* decoration cuma kalau banner gak ada gambar (fallback gradient) */
.pc-card[data-design="pastel"] .pc-banner:not(.pc-banner-has-image)::before { content: "✿"; top: 10px; left: 14px; }
.pc-card[data-design="pastel"] .pc-banner:not(.pc-banner-has-image)::after  { content: "❀"; top: 14px; right: 18px; font-size: 18px; }

/* banner pakai <img> biar crossorigin work utk html2canvas */
.pc-banner-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.pc-card[data-design="pastel"] .pc-avatar {
  width: 90px; height: 90px; border-radius: 50%;
  background: var(--c-bg);
  border: 4px solid var(--c-bg);
  position: absolute; left: 50%; top: 50px;
  transform: translateX(-50%);
  overflow: hidden;
  box-shadow: 0 0 0 3px var(--c-deco), 0 8px 20px -6px rgba(180,100,140,0.3);
}
.pc-card[data-design="pastel"] .pc-avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }
.pc-card[data-design="pastel"] .pc-fallback {
  font-size: 40px; color: var(--c-accent); background: var(--c-bg2);
}
.pc-card[data-design="pastel"] .pc-body {
  padding: 56px 24px 24px;
  text-align: center;
  position: relative;
}
.pc-card[data-design="pastel"] .pc-body::before {
  content: "✦"; position: absolute; top: 56px; left: 16px; color: var(--c-deco); font-size: 14px; opacity: 0.6;
}
.pc-card[data-design="pastel"] .pc-body::after {
  content: "✦"; position: absolute; top: 56px; right: 16px; color: var(--c-deco); font-size: 14px; opacity: 0.6;
}
.pc-card[data-design="pastel"] .pc-name-row {
  display: flex; align-items: center; justify-content: center; gap: 6px; margin-bottom: 2px;
}
.pc-card[data-design="pastel"] .pc-name {
  font-family: var(--font-soft);
  font-weight: 700; font-size: 22px; margin: 0; line-height: 1.2;
  color: var(--c-ink); letter-spacing: 0.02em;
}
.pc-card[data-design="pastel"] .pc-handle {
  font-size: 13px; color: var(--c-mute); margin-bottom: 12px;
  font-weight: 500;
}
.pc-card[data-design="pastel"] .pc-handle::before { content: "❀ "; color: var(--c-deco); }
.pc-card[data-design="pastel"] .pc-bio {
  font-family: var(--font-soft);
  font-size: 13px; line-height: 1.55; color: var(--c-ink);
  margin: 8px 0 12px; word-wrap: break-word; overflow-wrap: anywhere;
  white-space: pre-wrap;
}
.pc-card[data-design="pastel"] .pc-meta {
  display: flex; flex-wrap: wrap; justify-content: center; gap: 6px 12px;
  font-size: 11px; color: var(--c-mute); margin-bottom: 14px;
}
.pc-card[data-design="pastel"] .pc-meta span { display: inline-flex; align-items: center; gap: 3px; }
.pc-card[data-design="pastel"] .pc-stats {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px;
  padding: 14px 0 4px;
  position: relative;
}
.pc-card[data-design="pastel"] .pc-stats::before {
  content: ""; position: absolute; top: 0; left: 20%; right: 20%;
  height: 1px; background: var(--c-line);
  background-image: repeating-linear-gradient(90deg, var(--c-deco) 0 4px, transparent 4px 8px);
}
.pc-card[data-design="pastel"] .pc-stat {
  display: flex; flex-direction: column; align-items: center;
  background: var(--c-bg2);
  border-radius: 16px;
  padding: 10px 4px;
}
.pc-card[data-design="pastel"] .pc-stat-num {
  font-family: var(--font-soft);
  font-weight: 700; font-size: 17px; color: var(--c-ink); line-height: 1.1;
}
.pc-card[data-design="pastel"] .pc-stat-label {
  font-size: 9px; letter-spacing: 0.16em; text-transform: lowercase;
  color: var(--c-mute); margin-top: 4px; font-weight: 600;
}

/* =================== DESIGN 4 · EDITORIAL =================== */
.pc-card[data-design="editorial"][data-theme="cream"]   { --c-bg:#f7efe1; --c-paper:#fbf6ec; --c-ink:#2a1a0a; --c-mute:#7a604a; --c-accent:#a04020; --c-line:#3a2a1a; }
.pc-card[data-design="editorial"][data-theme="noir"]    { --c-bg:#1a1a1a; --c-paper:#252525; --c-ink:#f5f0e8; --c-mute:#a8a098; --c-accent:#e8c25f; --c-line:#f5f0e8; }
.pc-card[data-design="editorial"][data-theme="sepia"]   { --c-bg:#3a2818; --c-paper:#4a3424; --c-ink:#f0e0c8; --c-mute:#c0a888; --c-accent:#e89e58; --c-line:#f0e0c8; }
.pc-card[data-design="editorial"][data-theme="forest"]  { --c-bg:#1f2e1f; --c-paper:#2a3a2a; --c-ink:#e8efe0; --c-mute:#a8b8a0; --c-accent:#c8e090; --c-line:#e8efe0; }
.pc-card[data-design="editorial"][data-theme="ivory"]   { --c-bg:#fbf8f0; --c-paper:#f5f0e3; --c-ink:#1a1408; --c-mute:#8a7a5a; --c-accent:#8a3a18; --c-line:#3a2a1a; }
.pc-card[data-design="editorial"][data-theme="navy"]    { --c-bg:#0d1a30; --c-paper:#15243f; --c-ink:#e8edf5; --c-mute:#a0b0c8; --c-accent:#f0a838; --c-line:#e8edf5; }
.pc-card[data-design="editorial"][data-theme="burgundy"]{ --c-bg:#3a0e1a; --c-paper:#4a1828; --c-ink:#f5e8ec; --c-mute:#c89aa5; --c-accent:#e8a868; --c-line:#f5e8ec; }
.pc-card[data-design="editorial"][data-theme="kraft"]   { --c-bg:#c4a37a; --c-paper:#cfb084; --c-ink:#2a1808; --c-mute:#6a4828; --c-accent:#8a2a10; --c-line:#3a2808; }
.pc-card[data-design="editorial"][data-theme="oxblood"] { --c-bg:#2a1010; --c-paper:#3a1818; --c-ink:#f0e8d8; --c-mute:#b89a85; --c-accent:#e8a040; --c-line:#f0e8d8; }
.pc-card[data-design="editorial"][data-theme="paper"]   { --c-bg:#ededed; --c-paper:#f5f5f5; --c-ink:#1a1a1a; --c-mute:#7a7a7a; --c-accent:#c0282a; --c-line:#1a1a1a; }

.pc-card[data-design="editorial"] {
  background: var(--c-bg);
  border-radius: 6px;
  padding: 28px 26px 24px;
  border: 1px solid var(--c-line);
  box-shadow: var(--shadow-card);
  color: var(--c-ink);
  position: relative;
}
.pc-card[data-design="editorial"]::after {
  content: "✦";
  position: absolute;
  top: 12px; left: 18px;
  color: var(--c-accent); font-size: 14px;
}
.pc-card[data-design="editorial"] .pc-banner {
  height: 1px; background: var(--c-line); margin: 22px 0 0;
  border: none;
}
.pc-card[data-design="editorial"] .pc-avatar {
  width: 78px; height: 78px;
  border-radius: 50%;
  background: transparent;
  border: 0;
  overflow: hidden;
  margin: 18px 0 12px;
}
.pc-card[data-design="editorial"] .pc-avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }
.pc-card[data-design="editorial"] .pc-fallback {
  font-family: var(--font-mag);
  font-size: 38px; color: var(--c-accent);
  background: transparent;
  font-style: italic;
}
.pc-card[data-design="editorial"] .pc-body { padding: 0; }
.pc-card[data-design="editorial"] .pc-name-row {
  display: flex; align-items: baseline; gap: 6px; margin-bottom: 0;
  flex-wrap: wrap;
}
.pc-card[data-design="editorial"] .pc-name {
  font-family: var(--font-mag);
  font-weight: 400; font-size: 36px; line-height: 1; margin: 0;
  letter-spacing: -0.02em;
  color: var(--c-ink);
  font-style: italic;
}
.pc-card[data-design="editorial"] .pc-handle {
  font-family: var(--font-body);
  font-size: 11px; letter-spacing: 0.18em;
  color: var(--c-mute); margin-top: 6px; margin-bottom: 14px;
  font-weight: 700; text-transform: uppercase;
}
.pc-card[data-design="editorial"] .pc-bio {
  font-family: var(--font-mag);
  font-size: 14px; line-height: 1.55; color: var(--c-ink);
  margin: 12px 0; word-wrap: break-word; overflow-wrap: anywhere;
  font-style: italic;
  padding-left: 12px;
  border-left: 2px solid var(--c-accent);
  white-space: pre-wrap;
}
.pc-card[data-design="editorial"] .pc-meta {
  display: flex; flex-wrap: wrap; gap: 4px 16px;
  font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--c-mute); margin: 12px 0 18px;
  font-weight: 600;
  padding-top: 12px;
  border-top: 1px solid var(--c-line);
}
.pc-card[data-design="editorial"] .pc-meta span { display: inline-flex; align-items: center; gap: 4px; }
.pc-card[data-design="editorial"] .pc-stats {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 0;
  padding-top: 16px;
  border-top: 1px solid var(--c-line);
  position: relative;
}
.pc-card[data-design="editorial"] .pc-stat {
  display: flex; flex-direction: column; text-align: left;
  padding: 0 12px;
  border-right: 1px solid var(--c-line);
}
.pc-card[data-design="editorial"] .pc-stat:first-child { padding-left: 0; }
.pc-card[data-design="editorial"] .pc-stat:last-child { border-right: 0; padding-right: 0; }
.pc-card[data-design="editorial"] .pc-stat-num {
  font-family: var(--font-mag);
  font-weight: 400; font-size: 26px; color: var(--c-ink); line-height: 1;
  font-style: italic;
}
.pc-card[data-design="editorial"] .pc-stat-label {
  font-size: 9px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--c-mute); margin-top: 6px; font-weight: 700;
}

/* =====================================================================
   ============ MULTI TEMPLATE GRID (uniform simple layout) ============
   ===================================================================== */
.multi-frame {
  border-radius: 24px;
  padding: 30px;
  display: grid;
  gap: 22px;
  position: relative;
  font-family: var(--font-body);
}
.multi-frame[data-bg="lilac"]    { background: #ebe2ff; --m-fg:#5a4a8a; }
.multi-frame[data-bg="sakura"]   { background: #fde4ec; --m-fg:#a04062; }
.multi-frame[data-bg="mint"]     { background: #d8f1e0; --m-fg:#3a6a4a; }
.multi-frame[data-bg="cream"]    { background: #fff0c6; --m-fg:#7a5a18; }
.multi-frame[data-bg="sky"]      { background: #d6e8fb; --m-fg:#2a4a78; }
.multi-frame[data-bg="peach"]    { background: #ffe0cf; --m-fg:#7a3a1a; }
.multi-frame[data-bg="paper"]    { background: #f4ede0; --m-fg:#5a4830; }
.multi-frame[data-bg="midnight"] { background: #1f1a2a; --m-fg:#cab9fb; }

.multi-frame::after {
  content: "card star's bot · multi profile";
  position: absolute;
  bottom: 12px; left: 50%;
  transform: translateX(-50%);
  font-size: 11px;
  color: var(--m-fg);
  opacity: 0.6;
  letter-spacing: 0.08em;
}

.multi-frame[data-count="2"] { grid-template-columns: repeat(2, 280px); width: 642px; padding-bottom: 50px; }
.multi-frame[data-count="4"] { grid-template-columns: repeat(2, 280px); width: 642px; padding-bottom: 50px; }
.multi-frame[data-count="6"] { grid-template-columns: repeat(2, 280px); width: 642px; padding-bottom: 50px; }
.multi-frame[data-count="8"] { grid-template-columns: repeat(2, 280px); width: 642px; padding-bottom: 50px; }

/* simple uniform card for grid */
.mt-card {
  background: #fff;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 6px 18px -6px rgba(0,0,0,0.12);
  font-family: var(--font-body);
  color: #2a121f;
  position: relative;
}
.mt-card-banner {
  height: 100px;
  background: linear-gradient(135deg, var(--mt-c1, #ffc4d6), var(--mt-c2, #f8b1c8));
}
.mt-card-avatar-wrap {
  display: flex;
  justify-content: center;
  margin-top: -35px;
  margin-bottom: 8px;
}
.mt-card-avatar {
  width: 70px;
  height: 70px;
  border-radius: 50%;
  background: #fff;
  border: 3px solid #fff;
  overflow: hidden;
  box-shadow: 0 4px 10px rgba(0,0,0,0.15);
  flex-shrink: 0;
}
.mt-card-avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }
.mt-card-avatar .pc-fallback {
  font-size: 28px; color: #c2185b; background: #fde4ec;
}
.mt-card-body {
  padding: 0 14px 14px;
  text-align: center;
}
.mt-card-name {
  font-family: var(--font-display);
  font-weight: 800; font-size: 16px;
  margin: 0; line-height: 1.2;
  color: #1a0a18;
}
.mt-card-handle {
  font-size: 11px;
  color: #b48aa0;
  margin-top: 2px;
  padding-bottom: 8px;
  border-bottom: 1px solid #e8d8e0;
  margin-bottom: 10px;
}
.mt-card-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 4px;
}
.mt-card-stat { display: flex; flex-direction: column; align-items: center; }
.mt-card-stat-num {
  font-family: var(--font-display);
  font-weight: 800; font-size: 14px;
  color: #1a0a18; line-height: 1.1;
}
.mt-card-stat-label {
  font-size: 8px;
  color: #b48aa0;
  letter-spacing: 0.06em;
  margin-top: 2px;
}

/* gradient palette for mt-card banners — assigned via JS in rotation */
.mt-card[data-pal="0"] { --mt-c1:#ffc4d6; --mt-c2:#f8b1c8; }
.mt-card[data-pal="1"] { --mt-c1:#a8caee; --mt-c2:#95bee8; }
.mt-card[data-pal="2"] { --mt-c1:#a6e1c1; --mt-c2:#92d3a8; }
.mt-card[data-pal="3"] { --mt-c1:#fdc8a3; --mt-c2:#f8b18d; }
.mt-card[data-pal="4"] { --mt-c1:#cab9fb; --mt-c2:#b193e4; }
.mt-card[data-pal="5"] { --mt-c1:#fbe28a; --mt-c2:#f5d976; }
.mt-card[data-pal="6"] { --mt-c1:#9fd4d3; --mt-c2:#7ec0bf; }
.mt-card[data-pal="7"] { --mt-c1:#f3a8ad; --mt-c2:#ec7a82; }

@media (max-width: 700px) {
  .multi-frame[data-count="2"],
  .multi-frame[data-count="4"],
  .multi-frame[data-count="6"],
  .multi-frame[data-count="8"] {
    grid-template-columns: repeat(2, 240px); width: 562px;
  }
  .mt-card-name { font-size: 14px; }
}


/* ── Multi-template responsive scaling (fit on mobile without horizontal scroll) ── */
.multi-output-wrap {
  width: 100%;
  overflow-x: auto;
  overflow-y: visible;
  display: flex;
  justify-content: center;
  padding: 4px 0;
  -webkit-overflow-scrolling: touch;
}
.multi-frame-scale {
  transform-origin: top center;
}

/* Smaller per-card width on mobile so the whole grid fits */
@media (max-width: 720px) {
  .multi-frame[data-count="2"],
  .multi-frame[data-count="4"],
  .multi-frame[data-count="6"],
  .multi-frame[data-count="8"] {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    width: min(100%, 560px);
    max-width: calc(100vw - 36px);
    padding-bottom: 44px;
  }
}
@media (max-width: 480px) {
  .multi-frame[data-count="2"],
  .multi-frame[data-count="4"],
  .multi-frame[data-count="6"],
  .multi-frame[data-count="8"] {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    width: 100%;
    max-width: calc(100vw - 36px);
    gap: 14px;
    padding: 18px;
    padding-bottom: 36px;
  }
  .mt-card-banner { height: 72px; }
  .mt-card { border-radius: 14px; }
}

/* ═══════════════════════════════════════════════════════════
   DESIGN PREVIEW THUMBNAILS (mini icons di picker)
   ═══════════════════════════════════════════════════════════ */
.design-preview-minimal{background:#fafafa;border:1px solid #e5e5e5}
.design-preview-minimal .dp-mini-bar{position:absolute;top:14px;left:14px;width:30%;height:2px;background:#1a1a1a}
.design-preview-minimal .dp-mini-num{position:absolute;top:8px;right:14px;font-family:"DM Serif Display",serif;font-size:22px;color:#1a1a1a;line-height:1}
.design-preview-minimal .dp-line{position:absolute;left:14px;right:14px;bottom:30px;height:6px;background:#1a1a1a;border-radius:1px}
.design-preview-minimal .dp-line.short{bottom:18px;width:50%;background:#999}

.design-preview-polaroid{background:linear-gradient(135deg,#fff7e6,#ffe4ec);overflow:visible}
.design-preview-polaroid .dp-tape{position:absolute;top:-6px;left:50%;transform:translateX(-50%) rotate(-3deg);width:40%;height:14px;background:rgba(255,210,140,.7);border:1px dashed rgba(180,120,50,.4)}
.design-preview-polaroid .dp-photo{position:absolute;left:14px;top:18px;right:14px;bottom:18px;background:#fff;border-radius:4px;box-shadow:0 2px 6px rgba(0,0,0,.1);transform:rotate(-2deg)}
.design-preview-polaroid .dp-handwrite{position:absolute;bottom:6px;left:50%;transform:translateX(-50%) rotate(-1.5deg);width:40%;height:6px;background:#c92a5e;border-radius:2px;opacity:.6}

.design-preview-neon{background:#0a0014;border:1px solid #ff00aa44;box-shadow:inset 0 0 24px rgba(255,0,170,.15)}
.design-preview-neon .dp-neon-frame{position:absolute;inset:8px;border:1.5px solid #ff00aa;border-radius:6px;box-shadow:0 0 8px #ff00aa,inset 0 0 8px rgba(255,0,170,.2)}
.design-preview-neon .dp-neon-avatar{position:absolute;top:18px;left:18px;width:18px;height:18px;border-radius:50%;background:#0066ff;box-shadow:0 0 8px #0066ff}
.design-preview-neon .dp-neon-line{position:absolute;left:18px;height:3px;background:#00ffea;box-shadow:0 0 4px #00ffea;border-radius:2px;width:60%;top:42px}
.design-preview-neon .dp-neon-line.short{top:50px;width:30%;background:#ff00aa;box-shadow:0 0 4px #ff00aa}

/* ═══════════════════════════════════════════════════════════
   PROFILE CARD · DESIGN MINIMAL
   Mono palette, oversized typography, ultra clean
   ═══════════════════════════════════════════════════════════ */
.pc-card[data-design="minimal"]{
  background:#fafafa;
  border:1px solid #e5e5e5;
  border-radius:12px;
  box-shadow:0 1px 2px rgba(0,0,0,.04);
  overflow:hidden;
  padding:32px 28px 28px;
}
.pc-card[data-design="minimal"] .pc-banner{display:none}
.pc-card[data-design="minimal"] .pc-avatar{
  position:static;
  width:104px;height:104px;
  margin:0 0 22px;
  border:2px solid #1a1a1a;
  border-radius:50%;
  background:#fff;
  display:grid;place-items:center;
  overflow:hidden;
  flex-shrink:0;
}
.pc-card[data-design="minimal"] .pc-avatar img{width:100%;height:100%;object-fit:cover}
.pc-card[data-design="minimal"] .pc-avatar .pc-fallback{
  font-family:"DM Serif Display",serif;
  font-size:46px;color:#1a1a1a;font-weight:400;
}
.pc-card[data-design="minimal"] .pc-body{padding:0}
.pc-card[data-design="minimal"] .pc-name-row{margin:0 0 4px}
.pc-card[data-design="minimal"] .pc-name{
  font-family:"DM Serif Display",serif;
  font-weight:400;
  font-size:32px;
  line-height:1.05;
  letter-spacing:-.02em;
  color:#0a0a0a;
}
.pc-card[data-design="minimal"] .pc-handle{
  font-family:"Plus Jakarta Sans",sans-serif;
  font-size:13px;color:#666;
  letter-spacing:.04em;text-transform:uppercase;
  margin:0 0 18px;
}
.pc-card[data-design="minimal"] .pc-bio{
  font-size:14px;line-height:1.55;color:#2a2a2a;
  margin:0 0 18px;
  border-left:2px solid #1a1a1a;
  padding-left:14px;
}
.pc-card[data-design="minimal"] .pc-meta{
  display:flex;flex-wrap:wrap;gap:6px 14px;
  font-size:12px;color:#888;margin:0 0 18px
}
.pc-card[data-design="minimal"] .pc-meta span{padding:0}
.pc-card[data-design="minimal"] .pc-stats{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  border-top:1px solid #1a1a1a;
  padding-top:14px;gap:0;
}
.pc-card[data-design="minimal"] .pc-stat{
  display:flex;flex-direction:column;align-items:flex-start;
  border:none;background:transparent;padding:0;
}
.pc-card[data-design="minimal"] .pc-stat-num{
  font-family:"DM Serif Display",serif;
  font-size:26px;font-weight:400;color:#0a0a0a;
  line-height:1;letter-spacing:-.02em;
}
.pc-card[data-design="minimal"] .pc-stat-label{
  font-size:10px;color:#888;
  text-transform:uppercase;letter-spacing:.12em;
  margin-top:4px;
}
/* minimal theme overrides — accent color tints handle / number underline */
.pc-card[data-design="minimal"][data-theme="pink"]   { --m-accent:#c92a5e }
.pc-card[data-design="minimal"][data-theme="sky"]    { --m-accent:#1a6fd9 }
.pc-card[data-design="minimal"][data-theme="mint"]   { --m-accent:#058c6f }
.pc-card[data-design="minimal"][data-theme="lavender"]{ --m-accent:#6a3ec9 }
.pc-card[data-design="minimal"][data-theme="peach"]  { --m-accent:#d8590e }
.pc-card[data-design="minimal"][data-theme="rose"]   { --m-accent:#c1252f }
.pc-card[data-design="minimal"][data-theme="ocean"]  { --m-accent:#00838d }
.pc-card[data-design="minimal"][data-theme="butter"] { --m-accent:#b88500 }
.pc-card[data-design="minimal"][data-theme="matcha"] { --m-accent:#5d8c0a }
.pc-card[data-design="minimal"][data-theme="grape"]  { --m-accent:#8a2bbb }
.pc-card[data-design="minimal"] .pc-handle{color:var(--m-accent,#666)}

/* ═══════════════════════════════════════════════════════════
   PROFILE CARD · DESIGN POLAROID
   Scrapbook vibe — tilted card, washi tape, paper texture
   ═══════════════════════════════════════════════════════════ */
.pc-card[data-design="polaroid"]{
  background:#fff;
  border-radius:6px;
  padding:14px 14px 24px;
  box-shadow:
    0 1px 0 rgba(0,0,0,.04),
    0 14px 28px rgba(0,0,0,.18),
    0 4px 8px rgba(0,0,0,.08);
  position:relative;
  transform:rotate(-1.2deg);
  transform-origin:center;
  overflow:visible;
  margin:24px 0 14px;
  display:flex;
  flex-direction:column;
}
.pc-card[data-design="polaroid"]::before{
  /* washi tape */
  content:"";position:absolute;
  top:-10px;left:50%;
  transform:translateX(-50%) rotate(-2.5deg);
  width:80px;height:22px;
  background:repeating-linear-gradient(45deg,
    rgba(255,200,100,.55) 0 6px,
    rgba(255,170,80,.4) 6px 12px);
  border:1px dashed rgba(180,120,50,.3);
  z-index:5;
}
.pc-card[data-design="polaroid"]::after{
  /* paper texture noise */
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse at 30% 20%,rgba(0,0,0,.02),transparent 60%),
             radial-gradient(ellipse at 70% 80%,rgba(0,0,0,.025),transparent 50%);
  border-radius:inherit;pointer-events:none;
}
.pc-card[data-design="polaroid"] .pc-banner{
  height:140px;
  border-radius:4px;
  overflow:hidden;
  margin:0 0 0;
  filter:saturate(1.1) contrast(1.05);
  background:linear-gradient(135deg,#ffd6e1,#cfe7ff);
  position:relative;
  flex-shrink:0;
}
.pc-card[data-design="polaroid"] .pc-banner-img{width:100%;height:100%;object-fit:cover;display:block}
.pc-card[data-design="polaroid"] .pc-avatar{
  position:relative;
  width:96px;height:96px;
  margin:-48px auto 10px;
  transform:rotate(2deg);
  border:4px solid #fff;
  border-radius:50%;
  box-shadow:0 4px 10px rgba(0,0,0,.18);
  background:#f0f0f0;
  z-index:3;
  overflow:hidden;
  display:grid;place-items:center;
  flex-shrink:0;
}
.pc-card[data-design="polaroid"] .pc-avatar img{width:100%;height:100%;object-fit:cover}
.pc-card[data-design="polaroid"] .pc-avatar .pc-fallback{
  font-family:"DM Serif Display",serif;
  font-size:32px;color:#3a2030;
}
.pc-card[data-design="polaroid"] .pc-body{
  padding:0 6px;
  text-align:center;
  font-family:"Quicksand",sans-serif;
  position:relative;z-index:2;
}
.pc-card[data-design="polaroid"] .pc-name-row{justify-content:center;gap:6px}
.pc-card[data-design="polaroid"] .pc-name{
  font-family:"DM Serif Display",serif;
  font-style:italic;
  font-weight:400;
  font-size:24px;
  color:#3a1024;
  letter-spacing:.005em;
}
.pc-card[data-design="polaroid"] .pc-handle{
  font-family:"Quicksand",cursive,sans-serif;
  font-weight:600;font-size:14px;
  color:var(--m-accent,#c92a5e);
  margin:2px 0 12px;
  position:relative;display:inline-block;
}
.pc-card[data-design="polaroid"] .pc-handle::before,
.pc-card[data-design="polaroid"] .pc-handle::after{
  content:"♡";color:var(--m-accent,#c92a5e);opacity:.7;
  font-size:11px;margin:0 6px;
}
.pc-card[data-design="polaroid"] .pc-bio{
  font-family:"Quicksand",sans-serif;
  font-weight:500;font-size:13.5px;
  color:#5a2c44;line-height:1.55;
  background:repeating-linear-gradient(transparent 0 18px,#f1d9e2 18px 19px);
  background-position:0 2px;
  padding:6px 12px 10px;
  margin:0 0 14px;
  text-align:left;
  border-radius:3px;
}
.pc-card[data-design="polaroid"] .pc-meta{
  font-family:"Quicksand",sans-serif;
  font-size:11.5px;
  display:flex;justify-content:center;flex-wrap:wrap;gap:4px 12px;
  color:#7a4060;margin:0 0 12px
}
.pc-card[data-design="polaroid"] .pc-stats{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:6px;padding:0;border:none;
}
.pc-card[data-design="polaroid"] .pc-stat{
  background:rgba(252,228,238,.6);
  border:1.5px dashed var(--m-accent,#e9a3b8);
  border-radius:10px;
  padding:8px 4px;
  display:flex;flex-direction:column;align-items:center;
  font-family:"Quicksand",sans-serif;
}
.pc-card[data-design="polaroid"] .pc-stat-num{
  font-family:"DM Serif Display",serif;
  font-style:italic;font-size:18px;font-weight:400;
  color:#3a1024;line-height:1;
}
.pc-card[data-design="polaroid"] .pc-stat-label{
  font-size:9.5px;color:#7a4060;
  text-transform:lowercase;letter-spacing:.04em;
  margin-top:3px;font-weight:600;
}
.pc-card[data-design="polaroid"][data-theme="pink"]    { --m-accent:#c92a5e }
.pc-card[data-design="polaroid"][data-theme="sky"]     { --m-accent:#1a6fd9 }
.pc-card[data-design="polaroid"][data-theme="mint"]    { --m-accent:#058c6f }
.pc-card[data-design="polaroid"][data-theme="lavender"]{ --m-accent:#6a3ec9 }
.pc-card[data-design="polaroid"][data-theme="peach"]   { --m-accent:#d8590e }
.pc-card[data-design="polaroid"][data-theme="rose"]    { --m-accent:#c1252f }
.pc-card[data-design="polaroid"][data-theme="ocean"]   { --m-accent:#00838d }
.pc-card[data-design="polaroid"][data-theme="butter"]  { --m-accent:#b88500 }
.pc-card[data-design="polaroid"][data-theme="matcha"]  { --m-accent:#5d8c0a }
.pc-card[data-design="polaroid"][data-theme="grape"]   { --m-accent:#8a2bbb }

/* ═══════════════════════════════════════════════════════════
   PROFILE CARD · DESIGN NEON
   Cyberpunk · dark bg + glow neon · retro futuristic
   ═══════════════════════════════════════════════════════════ */
.pc-card[data-design="neon"]{
  background:#08000f;
  border:1.5px solid var(--n-accent,#ff00aa);
  border-radius:14px;
  box-shadow:
    0 0 24px var(--n-accent,#ff00aa55),
    inset 0 0 24px rgba(255,0,170,.06),
    0 18px 36px rgba(0,0,0,.5);
  padding:0;
  overflow:hidden;
  position:relative;
}
.pc-card[data-design="neon"]::before{
  /* scanline overlay */
  content:"";position:absolute;inset:0;
  background:repeating-linear-gradient(
    to bottom,
    transparent 0 2px,
    rgba(255,255,255,.015) 2px 3px
  );
  pointer-events:none;z-index:1;
}
.pc-card[data-design="neon"]::after{
  /* corner brackets glow */
  content:"";position:absolute;inset:8px;
  border:1px dashed rgba(255,0,170,.25);
  border-radius:8px;pointer-events:none;z-index:1;
}
.pc-card[data-design="neon"] .pc-banner{
  height:120px;
  background:
    linear-gradient(135deg,rgba(255,0,170,.15),rgba(0,180,255,.15)),
    radial-gradient(circle at 30% 50%,rgba(255,0,170,.4),transparent 60%),
    radial-gradient(circle at 70% 50%,rgba(0,200,255,.3),transparent 50%),
    #0a0014;
  position:relative;
  border-bottom:1px solid var(--n-accent,#ff00aa);
}
.pc-card[data-design="neon"] .pc-banner::before{
  /* grid floor */
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(to right,rgba(255,0,170,.2) 1px,transparent 1px),
    linear-gradient(to bottom,rgba(0,200,255,.2) 1px,transparent 1px);
  background-size:24px 24px;
  mask:linear-gradient(to bottom,transparent 30%,#000 100%);
  -webkit-mask:linear-gradient(to bottom,transparent 30%,#000 100%);
}
.pc-card[data-design="neon"] .pc-avatar{
  position:relative;
  width:96px;height:96px;
  margin:-48px 0 0 22px;
  border-radius:50%;
  border:2px solid var(--n-accent,#ff00aa);
  box-shadow:
    0 0 12px var(--n-accent,#ff00aa),
    inset 0 0 8px rgba(255,0,170,.3);
  background:#0a0014;
  z-index:3;
  overflow:hidden;
  display:grid;place-items:center;
  flex-shrink:0;
}
.pc-card[data-design="neon"] .pc-avatar img{width:100%;height:100%;object-fit:cover}
.pc-card[data-design="neon"] .pc-avatar .pc-fallback{
  font-family:"Plus Jakarta Sans",sans-serif;
  font-weight:800;font-size:30px;
  color:var(--n-accent,#ff00aa);
  text-shadow:0 0 8px var(--n-accent,#ff00aa);
}
.pc-card[data-design="neon"] .pc-body{
  padding:14px 22px 22px;
  position:relative;z-index:2;
}
.pc-card[data-design="neon"] .pc-name-row{margin:0 0 4px}
.pc-card[data-design="neon"] .pc-name{
  font-family:"Plus Jakarta Sans",sans-serif;
  font-weight:800;
  font-size:18px;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:#fff;
  text-shadow:0 0 4px rgba(255,255,255,.4),0 0 8px var(--n-accent,#ff00aa);
  word-break:break-word;
  overflow-wrap:anywhere;
  line-height:1.2;
  margin:0;
}
.pc-card[data-design="neon"] .pc-handle{
  font-family:"Plus Jakarta Sans",sans-serif;
  font-weight:500;font-size:13px;
  color:#00e0ff;
  text-shadow:0 0 6px #00e0ff;
  letter-spacing:.05em;
  margin:0 0 14px;
}
.pc-card[data-design="neon"] .pc-bio{
  font-family:"Plus Jakarta Sans",sans-serif;
  font-size:13px;line-height:1.5;
  color:#dccaf0;
  border-left:2px solid var(--n-accent,#ff00aa);
  padding-left:12px;
  margin:0 0 14px;
}
.pc-card[data-design="neon"] .pc-meta{
  display:flex;flex-wrap:wrap;gap:6px 12px;
  font-size:11.5px;color:#9c8aa0;
  margin:0 0 14px;
}
.pc-card[data-design="neon"] .pc-stats{
  display:grid;grid-template-columns:repeat(3,1fr);
  border-top:1px solid var(--n-accent,#ff00aa);
  padding-top:12px;gap:0;
}
.pc-card[data-design="neon"] .pc-stat{
  background:transparent;border:none;padding:0;
  display:flex;flex-direction:column;align-items:center;
}
.pc-card[data-design="neon"] .pc-stat-num{
  font-family:"Plus Jakarta Sans",sans-serif;
  font-weight:800;font-size:20px;
  color:#fff;
  text-shadow:0 0 8px var(--n-accent,#ff00aa);
  letter-spacing:.02em;
}
.pc-card[data-design="neon"] .pc-stat-label{
  font-size:9px;color:#7a6080;
  text-transform:uppercase;letter-spacing:.16em;
  margin-top:3px;font-weight:600;
}
/* neon theme overrides: ganti --n-accent */
.pc-card[data-design="neon"][data-theme="pink"]    { --n-accent:#ff2da8 }
.pc-card[data-design="neon"][data-theme="sky"]     { --n-accent:#00b4ff }
.pc-card[data-design="neon"][data-theme="mint"]    { --n-accent:#00ff9c }
.pc-card[data-design="neon"][data-theme="lavender"]{ --n-accent:#b478ff }
.pc-card[data-design="neon"][data-theme="peach"]   { --n-accent:#ff8c3c }
.pc-card[data-design="neon"][data-theme="rose"]    { --n-accent:#ff4060 }
.pc-card[data-design="neon"][data-theme="ocean"]   { --n-accent:#00d8e0 }
.pc-card[data-design="neon"][data-theme="butter"]  { --n-accent:#ffd040 }
.pc-card[data-design="neon"][data-theme="matcha"]  { --n-accent:#9eff3a }
.pc-card[data-design="neon"][data-theme="grape"]   { --n-accent:#d040ff }

/* verified badge color override per design */
.pc-card[data-design="neon"] .pc-verified svg{filter:drop-shadow(0 0 4px currentColor)}

/* ═══════════════════════════════════════════════════════════
   MULTI-TEMPLATE LAYOUT PICKER
   ═══════════════════════════════════════════════════════════ */
.layout-picker{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:8px;
  margin-bottom:14px;
}
.layout-pill{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  padding:12px 8px 10px;
  border-radius:14px;
  border:1.5px solid var(--pg-line);
  background:var(--pg-surface);
  cursor:pointer;
  transition:all .18s;
  font-family:var(--font-body);
}
.layout-pill:hover{border-color:var(--pg-accent);background:var(--pg-accent-soft)}
.layout-pill.active{
  border-color:var(--pg-accent);
  background:var(--pg-accent-soft);
  color:var(--pg-accent);
  font-weight:700;
}
.lp-icon{
  width:36px;height:24px;
  display:grid;gap:2px;
  grid-template-columns:1fr 1fr;
  grid-template-rows:1fr 1fr;
}
.lp-icon i{background:currentColor;border-radius:2px;opacity:.7}
.layout-pill.active .lp-icon i{opacity:1}
.lp-icon.lp-strip{
  grid-template-columns:repeat(4,1fr);
  grid-template-rows:1fr;
}
.lp-icon.lp-mosaic{
  grid-template-columns:1fr 1fr 1fr;
  grid-template-rows:1fr 1fr;
}
.lp-icon.lp-mosaic i:nth-child(1){grid-column:1/3;grid-row:1/3}
.lp-icon.lp-mosaic i:nth-child(2){grid-column:3/4;grid-row:1/2}
.lp-icon.lp-mosaic i:nth-child(3){grid-column:3/4;grid-row:2/3}
.lp-icon.lp-mosaic i:nth-child(4){display:none}
.lp-icon.lp-polaroid{
  position:relative;
  grid-template-columns:none;grid-template-rows:none;
  display:block;
}
.lp-icon.lp-polaroid i{
  position:absolute;
  width:14px;height:14px;
  border-radius:1px;
}
.lp-icon.lp-polaroid i:nth-child(1){top:2px;left:2px;transform:rotate(-8deg)}
.lp-icon.lp-polaroid i:nth-child(2){top:2px;right:2px;transform:rotate(6deg)}
.lp-icon.lp-polaroid i:nth-child(3){bottom:2px;left:6px;transform:rotate(4deg)}
.lp-icon.lp-polaroid i:nth-child(4){bottom:2px;right:4px;transform:rotate(-5deg)}
.lp-name{font-size:12px;font-weight:600;color:inherit}

@media(max-width:480px){
  .layout-picker{grid-template-columns:repeat(2,1fr)}
}

/* ═══════════════════════════════════════════════════════════
   MULTI-TEMPLATE LAYOUTS · STRIP
   1 baris memanjang seperti photobooth
   ═══════════════════════════════════════════════════════════ */
/* STRIP — 1 kolom vertikal kayak photobooth strip */
.multi-frame[data-layout="strip"]{
  display:flex !important;
  flex-direction:column;
  grid-template-columns:none !important;
  width:min(100%,400px) !important;
  max-width:calc(100vw - 36px) !important;
  gap:14px !important;
  padding:24px !important;
  padding-bottom:42px !important;
  margin:0 auto;
}
.multi-frame[data-layout="strip"] > .mt-card{
  width:100%;
  display:grid !important;
  grid-template-columns:96px 1fr;
  grid-template-rows:auto;
  align-items:center;
  padding:0 !important;
  border-radius:14px !important;
  overflow:hidden;
}
.multi-frame[data-layout="strip"] > .mt-card .mt-card-banner{
  display:none;
}
.multi-frame[data-layout="strip"] > .mt-card .mt-card-avatar-wrap{
  grid-column:1/2;
  grid-row:1/2;
  margin:0;
  padding:14px 0 14px 14px;
}
.multi-frame[data-layout="strip"] > .mt-card .mt-card-avatar{
  width:80px;height:80px;
  border:3px solid var(--mt-c1,#ffc4d6);
  margin:0;
}
.multi-frame[data-layout="strip"] > .mt-card .mt-card-body{
  grid-column:2/3;
  grid-row:1/2;
  padding:14px 16px;
  text-align:left;
}
.multi-frame[data-layout="strip"] > .mt-card .mt-card-name{
  font-size:18px;
  margin:0 0 2px;
}
.multi-frame[data-layout="strip"] > .mt-card .mt-card-handle{
  font-size:12.5px;
  margin:0 0 8px;
}
.multi-frame[data-layout="strip"] > .mt-card .mt-card-stats{
  display:flex !important;
  flex-direction:row;
  gap:14px;
  padding:0;
  border:none !important;
  margin:0;
}
.multi-frame[data-layout="strip"] > .mt-card .mt-card-stat{
  flex-direction:row;
  gap:4px;
  align-items:baseline;
  padding:0;
  border:none;
  background:transparent;
}
.multi-frame[data-layout="strip"] > .mt-card .mt-card-stat-num{
  font-size:14px;
  font-weight:700;
}
.multi-frame[data-layout="strip"] > .mt-card .mt-card-stat-label{
  font-size:10px;
  color:var(--m-fg,#5a4860);
  text-transform:lowercase;
  letter-spacing:.02em;
}
@media(max-width:480px){
  .multi-frame[data-layout="strip"]{padding:18px !important;padding-bottom:32px !important;gap:10px !important}
  .multi-frame[data-layout="strip"] > .mt-card{grid-template-columns:72px 1fr}
  .multi-frame[data-layout="strip"] > .mt-card .mt-card-avatar-wrap{padding:12px 0 12px 12px}
  .multi-frame[data-layout="strip"] > .mt-card .mt-card-avatar{width:62px;height:62px}
  .multi-frame[data-layout="strip"] > .mt-card .mt-card-body{padding:12px}
  .multi-frame[data-layout="strip"] > .mt-card .mt-card-name{font-size:15px}
  .multi-frame[data-layout="strip"] > .mt-card .mt-card-handle{font-size:11.5px;margin-bottom:6px}
  .multi-frame[data-layout="strip"] > .mt-card .mt-card-stats{gap:10px}
  .multi-frame[data-layout="strip"] > .mt-card .mt-card-stat-num{font-size:13px}
  .multi-frame[data-layout="strip"] > .mt-card .mt-card-stat-label{font-size:9px}
}

/* ═══════════════════════════════════════════════════════════
   MULTI-TEMPLATE LAYOUTS · MOSAIC
   1 hero card besar + sisanya kecil
   ═══════════════════════════════════════════════════════════ */
/* MOSAIC — Pinterest style asimetris, support 4/6/8 kartu */
.multi-frame[data-layout="mosaic"]{
  display:grid !important;
  grid-template-columns:repeat(3,1fr) !important;
  gap:14px;
  padding:24px;
  padding-bottom:42px;
  width:min(100%,640px) !important;
  max-width:calc(100vw - 36px) !important;
  margin:0 auto;
}
/* common: card 1 = hero (2x2) */
.multi-frame[data-layout="mosaic"] > .mt-card:nth-child(1){
  grid-column:span 2;
  grid-row:span 2;
}
.multi-frame[data-layout="mosaic"] > .mt-card:nth-child(1) .mt-card-banner{height:160px}
.multi-frame[data-layout="mosaic"] > .mt-card:nth-child(1) .mt-card-name{font-size:22px}
.multi-frame[data-layout="mosaic"] > .mt-card:nth-child(1) .mt-card-avatar{width:90px;height:90px}

/* mosaic 4: hero + 3 small in right column + bottom row */
/* (default behavior; sisanya auto-flow) */

/* mosaic 6: hero + 5 small */
.multi-frame[data-layout="mosaic"][data-count="6"]{
  grid-template-columns:repeat(3,1fr) !important;
  grid-auto-rows:1fr;
}
.multi-frame[data-layout="mosaic"][data-count="6"] > .mt-card:nth-child(1){
  grid-column:span 2;grid-row:span 2;
}

/* mosaic 8: 2 heroes (1 di kiri-atas, 1 di kanan-bawah) + 6 small */
.multi-frame[data-layout="mosaic"][data-count="8"]{
  grid-template-columns:repeat(4,1fr) !important;
  grid-auto-rows:1fr;
}
.multi-frame[data-layout="mosaic"][data-count="8"] > .mt-card:nth-child(1){
  grid-column:1/3;grid-row:1/3;
}
.multi-frame[data-layout="mosaic"][data-count="8"] > .mt-card:nth-child(6){
  grid-column:span 2;grid-row:span 2;
}

@media(max-width:600px){
  .multi-frame[data-layout="mosaic"]{
    grid-template-columns:repeat(2,1fr) !important;
    padding:18px;padding-bottom:36px;
    gap:10px;
  }
  .multi-frame[data-layout="mosaic"] > .mt-card:nth-child(1){
    grid-column:span 2;grid-row:auto;
  }
  .multi-frame[data-layout="mosaic"] > .mt-card:nth-child(1) .mt-card-banner{height:120px}
  .multi-frame[data-layout="mosaic"] > .mt-card:nth-child(1) .mt-card-name{font-size:18px}
  .multi-frame[data-layout="mosaic"] > .mt-card:nth-child(1) .mt-card-avatar{width:70px;height:70px}
  .multi-frame[data-layout="mosaic"][data-count="6"]{grid-template-columns:repeat(2,1fr) !important}
  .multi-frame[data-layout="mosaic"][data-count="6"] > .mt-card:nth-child(1){grid-column:span 2;grid-row:auto}
  .multi-frame[data-layout="mosaic"][data-count="8"]{grid-template-columns:repeat(2,1fr) !important}
  .multi-frame[data-layout="mosaic"][data-count="8"] > .mt-card:nth-child(1){grid-column:span 2;grid-row:auto}
  .multi-frame[data-layout="mosaic"][data-count="8"] > .mt-card:nth-child(6){grid-column:span 2;grid-row:auto}
}

/* ═══════════════════════════════════════════════════════════
   MULTI-TEMPLATE LAYOUTS · POLAROID SCATTERED
   Photo album feel · cards tilted & overlapping
   ═══════════════════════════════════════════════════════════ */
.multi-frame[data-layout="polaroid"]{
  display:grid !important;
  grid-template-columns:repeat(2,1fr) !important;
  width:min(100%,560px) !important;
  max-width:calc(100vw - 36px);
  gap:24px 18px !important;
  padding:32px 24px 44px !important;
  background:var(--m-bg-2,#f5e8d4);
}
.multi-frame[data-layout="polaroid"] > .mt-card{
  background:#fff;
  border-radius:4px !important;
  padding:10px 10px 22px;
  box-shadow:
    0 1px 0 rgba(0,0,0,.04),
    0 12px 22px rgba(0,0,0,.16),
    0 2px 6px rgba(0,0,0,.06);
  position:relative;
  overflow:visible;
  transition:transform .2s;
}
.multi-frame[data-layout="polaroid"] > .mt-card:nth-child(odd){transform:rotate(-2.5deg)}
.multi-frame[data-layout="polaroid"] > .mt-card:nth-child(even){transform:rotate(2deg)}
.multi-frame[data-layout="polaroid"] > .mt-card:nth-child(3n){transform:rotate(-1deg)}
.multi-frame[data-layout="polaroid"] > .mt-card:nth-child(4n){transform:rotate(3deg)}
.multi-frame[data-layout="polaroid"] > .mt-card::before{
  content:"";position:absolute;
  top:-8px;left:50%;
  transform:translateX(-50%) rotate(-3deg);
  width:50px;height:14px;
  background:repeating-linear-gradient(45deg,
    rgba(255,210,140,.55) 0 4px,
    rgba(255,180,100,.4) 4px 8px);
  border:1px dashed rgba(180,120,50,.3);
  z-index:5;
}
.multi-frame[data-layout="polaroid"] > .mt-card .mt-card-banner{
  height:100px;
  border-radius:2px;
  margin-bottom:8px;
  filter:saturate(1.05) contrast(1.05);
}
.multi-frame[data-layout="polaroid"] > .mt-card .mt-card-avatar-wrap{
  margin-top:-32px;position:relative;z-index:2;
}
.multi-frame[data-layout="polaroid"] > .mt-card .mt-card-avatar{
  width:54px;height:54px;
  border:3px solid #fff;
}
.multi-frame[data-layout="polaroid"] > .mt-card .mt-card-body{padding:6px 6px 0;text-align:center}
.multi-frame[data-layout="polaroid"] > .mt-card .mt-card-name{
  font-family:"DM Serif Display",serif;
  font-style:italic;font-size:16px;
  font-weight:400;color:#3a1024;
  letter-spacing:0;
}
.multi-frame[data-layout="polaroid"] > .mt-card .mt-card-handle{
  font-family:"Quicksand",sans-serif;
  font-weight:600;font-size:11.5px;
  color:#a0506e;
}
.multi-frame[data-layout="polaroid"] > .mt-card .mt-card-stats{
  margin-top:8px;font-size:10px;
  display:flex;gap:6px;justify-content:center;flex-wrap:wrap;
  font-family:"Quicksand",sans-serif;
}
.multi-frame[data-layout="polaroid"] > .mt-card .mt-card-stat{
  flex-direction:row;gap:3px;align-items:baseline;
}
.multi-frame[data-layout="polaroid"] > .mt-card .mt-card-stat-num{
  font-family:"DM Serif Display",serif;
  font-style:italic;font-size:13px;color:#3a1024;
}
.multi-frame[data-layout="polaroid"] > .mt-card .mt-card-stat-label{
  font-size:9px;color:#7a4060;text-transform:lowercase;
}
@media(max-width:480px){
  .multi-frame[data-layout="polaroid"]{
    gap:18px 14px !important;padding:24px 18px 36px !important;
  }
  .multi-frame[data-layout="polaroid"] > .mt-card{padding:8px 8px 18px}
}

/* Fix neon card: must be flex column for avatar negative-margin overlap */
.pc-card[data-design="neon"]{
  display:flex;
  flex-direction:column;
}
.pc-card[data-design="neon"] .pc-banner{
  flex-shrink:0;
}

/* Fix polaroid: ensure body name-row centers its content */
.pc-card[data-design="polaroid"] .pc-name-row{
  justify-content:center;
  display:flex;
  align-items:center;
}

/* Fix minimal: ensure pc-card itself flex column biar avatar+body urut vertikal */
.pc-card[data-design="minimal"]{
  display:flex;
  flex-direction:column;
}
