/* ═══════════════════════════════════════════════════════════
   TOKEN ECONOMY UI
   ═══════════════════════════════════════════════════════════ */

/* ── Sidebar Token Button ──────────────────────────────── */
.ws-token-btn {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  padding: 10px 12px;
  margin-bottom: 4px;
  border: 1px solid color-mix(in srgb, var(--accent) 35%, transparent);
  border-radius: var(--radius-sm);
  background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 10%, var(--bg-1)), color-mix(in srgb, var(--accent) 5%, var(--bg-1)));
  color: var(--text-1);
  cursor: pointer;
  transition: all .2s;
  font-size: 13px;
  position: relative;
  overflow: hidden;
}

.ws-token-btn::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, transparent, color-mix(in srgb, var(--accent) 8%, transparent));
  opacity: 0;
  transition: opacity .2s;
}

.ws-token-btn:hover {
  border-color: var(--accent);
  background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 18%, var(--bg-1)), color-mix(in srgb, var(--accent) 10%, var(--bg-1)));
  transform: translateY(-1px);
  box-shadow: 0 2px 8px color-mix(in srgb, var(--accent) 20%, transparent);
}

.ws-token-btn:hover::before {
  opacity: 1;
}

.ws-token-btn i,
.ws-token-btn svg {
  width: 16px;
  height: 16px;
  color: var(--accent);
  flex-shrink: 0;
}

.ws-token-btn .ws-token-count {
  font-weight: 700;
  font-size: 15px;
  color: var(--accent);
}

.ws-token-btn .ws-token-label {
  color: var(--text-3);
  font-size: 12px;
}

.ws-token-btn .ws-token-buy {
  margin-left: auto;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--accent);
  background: color-mix(in srgb, var(--accent) 15%, transparent);
  padding: 2px 8px;
  border-radius: 4px;
}

/* ── Topbar Token Display ──────────────────────────────── */
.ws-topbar-token {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 4px 12px;
  border: 1px solid color-mix(in srgb, var(--accent) 30%, transparent);
  border-radius: 20px;
  background: color-mix(in srgb, var(--accent) 8%, transparent);
  color: var(--accent);
  cursor: pointer;
  font-size: 13px;
  font-weight: 600;
  transition: all .2s;
  margin-right: 8px;
}

.ws-topbar-token:hover {
  background: color-mix(in srgb, var(--accent) 16%, transparent);
  border-color: var(--accent);
  transform: scale(1.02);
}

.ws-topbar-token svg,
.ws-topbar-token i {
  color: var(--accent);
}

/* ── Token Deficit Modal ───────────────────────────────── */
.token-deficit-overlay {
  position: fixed;
  inset: 0;
  z-index: 99999;
  background: rgba(0, 0, 0, .55);
  backdrop-filter: blur(4px);
  display: flex;
  align-items: center;
  justify-content: center;
  animation: fadeIn .2s;
}

.token-deficit-box {
  background: var(--bg-0);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 32px 36px;
  max-width: 400px;
  width: 90%;
  text-align: center;
  box-shadow: 0 20px 60px rgba(0, 0, 0, .3);
  animation: slideUp .3s var(--ease);
}

.token-deficit-icon {
  margin-bottom: 16px;
}

.token-deficit-box h3 {
  font-size: 18px;
  font-weight: 700;
  margin: 0 0 8px;
  color: var(--text-1);
}

.token-deficit-box p {
  font-size: 14px;
  color: var(--text-3);
  margin: 0 0 24px;
  line-height: 1.5;
}

.token-deficit-actions {
  display: flex;
  gap: 10px;
  justify-content: center;
}

.token-deficit-actions .btn-primary {
  padding: 8px 20px;
  font-weight: 600;
}

/* ── Token Shop Modal ──────────────────────────────────── */
.token-shop-overlay {
  position: fixed;
  inset: 0;
  z-index: 99998;
  background: rgba(0, 0, 0, .6);
  backdrop-filter: blur(6px);
  display: flex;
  align-items: center;
  justify-content: center;
  animation: fadeIn .25s;
}

.tshop-modal {
  background: var(--bg-0);
  border: 1px solid var(--border);
  border-radius: 20px;
  max-width: 600px;
  width: 95%;
  max-height: 90vh;
  overflow-y: auto;
  position: relative;
  box-shadow: 0 24px 80px rgba(0, 0, 0, .4);
  animation: slideUp .35s var(--ease);
}

.tshop-close {
  position: absolute;
  top: 16px;
  right: 16px;
  background: none;
  border: none;
  color: var(--text-3);
  cursor: pointer;
  padding: 4px;
  border-radius: 8px;
  transition: all .15s;
  z-index: 2;
}

.tshop-close:hover {
  background: var(--bg-2);
  color: var(--text-1);
}

.tshop-header {
  text-align: center;
  padding: 36px 24px 16px;
}

.tshop-header-icon {
  width: 56px;
  height: 56px;
  margin: 0 auto 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 15%, transparent), color-mix(in srgb, var(--accent) 8%, transparent));
  border-radius: 16px;
  border: 1px solid color-mix(in srgb, var(--accent) 25%, transparent);
}

.tshop-header h2 {
  font-size: 22px;
  font-weight: 700;
  margin: 0 0 4px;
  color: var(--text-1);
}

.tshop-header p {
  font-size: 13px;
  color: var(--text-3);
  margin: 0;
}

.tshop-balance {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 24px;
  font-size: 14px;
  color: var(--text-2);
}

.tshop-balance strong {
  font-size: 20px;
  font-weight: 700;
  color: var(--accent);
}

/* ── Token Packs Grid ──────────────────────────────────── */
.tshop-packs {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  padding: 8px 24px 24px;
}

@media (max-width: 520px) {
  .tshop-packs {
    grid-template-columns: 1fr;
  }
}

.tshop-pack {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 24px 16px 20px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--bg-1);
  transition: all .2s;
  cursor: default;
}

.tshop-pack:hover {
  border-color: color-mix(in srgb, var(--accent) 50%, var(--border));
  transform: translateY(-2px);
  box-shadow: 0 8px 24px color-mix(in srgb, var(--accent) 10%, transparent);
}

.tshop-popular {
  border-color: var(--accent);
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent) 6%, var(--bg-1)), var(--bg-1));
}

.tshop-best {
  border-color: #34d399;
  background: linear-gradient(180deg, color-mix(in srgb, #34d399 6%, var(--bg-1)), var(--bg-1));
}

.tshop-badge {
  position: absolute;
  top: -8px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--accent);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .5px;
  padding: 2px 10px;
  border-radius: 10px;
  white-space: nowrap;
}

.tshop-badge-best {
  background: #34d399;
}

.tshop-pack-coins {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 4px;
  color: var(--accent);
}

.tshop-popular .tshop-pack-coins,
.tshop-best .tshop-pack-coins {
  color: var(--accent);
}

.tshop-best .tshop-pack-coins {
  color: #34d399;
}

.tshop-pack-amount {
  font-size: 28px;
  font-weight: 800;
  line-height: 1;
}

.tshop-pack-name {
  font-size: 12px;
  color: var(--text-3);
  margin-bottom: 2px;
}

.tshop-pack-per {
  font-size: 11px;
  color: var(--text-3);
  margin-bottom: 12px;
}

.tshop-buy-btn {
  width: 100%;
  padding: 8px 16px !important;
  font-weight: 700 !important;
  font-size: 14px !important;
  border-radius: 10px !important;
}

.tshop-best .tshop-buy-btn {
  background: #34d399 !important;
  border-color: #34d399 !important;
}

.tshop-best .tshop-buy-btn:hover {
  background: #2ec48e !important;
}

.tshop-footer {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 16px 24px 24px;
  font-size: 11px;
  color: var(--text-3);
  text-align: center;
}

.tshop-payment-info {
  text-align: center;
  padding: 30px 20px;
}

.tshop-payment-title {
  font-size: 16px;
  font-weight: 600;
  margin-bottom: 12px;
}

.tshop-payment-amount {
  font-size: 14px;
  margin-bottom: 12px;
}

.tshop-payment-address {
  font-family: monospace;
  font-size: 12px;
  word-break: break-all;
  padding: 12px;
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: 10px;
}

/* ── Publish Price Field ───────────────────────────────── */
.mp-pub-price-field {
  border: 1px solid color-mix(in srgb, var(--accent) 30%, var(--border));
  border-radius: 10px;
  padding: 14px 16px;
  background: color-mix(in srgb, var(--accent) 4%, var(--bg-1));
}

.mp-pub-price-field label {
  color: var(--accent) !important;
  font-weight: 600 !important;
}

.mp-pub-price-wrap {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.mp-pub-price-input-group {
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--bg-0);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 4px 12px;
}

.mp-pub-price-input-group .input {
  border: none !important;
  background: none !important;
  padding: 6px 4px !important;
  font-size: 18px !important;
  font-weight: 700 !important;
  width: 120px;
  color: var(--accent);
}

.mp-pub-price-icon {
  flex-shrink: 0;
}

.mp-pub-price-label {
  font-size: 13px;
  color: var(--text-3);
}

.mp-pub-price-hint {
  display: flex;
  gap: 6px;
  font-size: 11px;
  color: var(--text-3);
}

/* ── Slide up animation ────────────────────────────────── */
@keyframes slideUp {
  from {
    opacity: 0;
    transform: translateY(20px) scale(.97);
  }

  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

/* Hide arrows from number inputs globally */
input[type="number"]::-webkit-outer-spin-button,
input[type="number"]::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

input[type="number"] {
  -moz-appearance: textfield;
}

/* Adjust grid for two items instead of 3 */
.mp-pub-type-grid {
  grid-template-columns: repeat(2, 1fr) !important;
}

/* Adjust tag check cards */
.mp-pub-mod-check {
  accent-color: var(--accent);
}



/* ── Races Custom Beautiful Layout ── */

#panel-races .world-grid {
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 20px;
  padding: 8px;
}

.race-card-custom {
  display: flex;
  flex-direction: column;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 12px;
  overflow: hidden;
  transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
  position: relative;
  padding: 0 !important;
  height: auto;
  min-height: 280px;
}

.race-card-custom:hover {
  transform: translateY(-2px);
  border-color: var(--accent);
  box-shadow: 0 8px 16px rgba(0, 0, 0, 0.25);
}

.race-card-header-bg {
  height: 80px;
  background: linear-gradient(135deg, rgba(82, 113, 255, 0.15) 0%, rgba(255, 115, 230, 0.08) 100%);
  border-bottom: 1px solid var(--border);
  position: relative;
}

/* Adjust card actions inside the colored header */
.race-card-header-bg .world-item-actions,
.race-card-custom:hover .world-item-actions {
  position: absolute;
  top: 8px;
  right: 8px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 2px 4px;
}

.race-card-header-bg .race-card-icon {
  position: absolute;
  bottom: -20px;
  left: 16px;
  width: 44px;
  height: 44px;
  background: var(--bg3);
  border: 2px solid var(--border);
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text);
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
  z-index: 2;
  transition: border-color 0.2s ease;
}

.race-card-header-bg .race-card-icon svg {
  width: 22px;
  height: 22px;
  color: var(--accent);
}

.race-card-custom:hover .race-card-icon {
  border-color: var(--accent);
}

.race-card-main {
  padding: 28px 16px 16px 16px;
  display: flex;
  flex-direction: column;
  flex: 1;
}

.rc-title {
  margin: 0;
  font-size: 18px;
  font-weight: 700;
  color: var(--text);
  line-height: 1.2;
}

.rc-badges {
  margin-top: 8px;
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}

.rc-badges .badge {
  background: var(--surface);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: 6px;
  font-size: 11px;
  padding: 2px 8px;
}

.rc-desc {
  margin-top: 12px;
  font-size: 13px;
  color: var(--text2);
  line-height: 1.5;
  flex-grow: 1;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.rc-grid-details {
  margin-top: 16px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px 12px;
  padding-top: 12px;
  border-top: 1px dashed var(--border);
}

.rc-detail-item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--text);
}

.rc-detail-item svg {
  width: 14px;
  height: 14px;
  stroke: var(--text2);
  flex-shrink: 0;
}

.rc-detail-item span {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  /* max-width is omitted as flex layout handles it mostly */
}

/* Fallback for empty spans generated by field placeholders */
.rc-detail-item span:empty::after {
  content: "—";
  color: var(--text3);
  opacity: 0.5;
}

.rc-abilities {
  margin-top: 12px;
  padding: 8px 10px;
  background: var(--surface);
  border-left: 3px solid var(--accent);
  border-radius: 0 6px 6px 0;
  font-size: 12px;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.rc-abilities strong {
  color: var(--text2);
  font-weight: 600;
  margin-right: 4px;
}

/* ── Mind Map Modal ── */
.mm-modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(2px);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  animation: fadeIn 0.15s ease-out;
}

.mm-modal {
  background: var(--bg-1);
  border: 1px solid var(--border);
  border-radius: 12px;
  width: 400px;
  max-width: 90vw;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5);
  display: flex;
  flex-direction: column;
  animation: slideUp 0.2s cubic-bezier(0.16, 1, 0.3, 1);
}

.mm-modal-header {
  padding: 16px 20px;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.mm-modal-header h3 {
  margin: 0;
  font-size: 1.1rem;
  color: var(--text-1);
}

.mm-modal-close {
  background: none;
  border: none;
  color: var(--text-2);
  cursor: pointer;
  padding: 4px;
  border-radius: 4px;
}

.mm-modal-close:hover {
  background: var(--bg-3);
  color: var(--text-1);
}

.mm-modal-body {
  padding: 20px;
}

.mm-modal-footer {
  padding: 16px 20px;
  border-top: 1px solid var(--border);
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  background: var(--bg-2);
  border-radius: 0 0 12px 12px;
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

@keyframes slideUp {
  from {
    transform: translateY(10px);
    opacity: 0;
  }

  to {
    transform: translateY(0);
    opacity: 1;
  }
}

/* ── Mind Map Extended Fixes ───────────────────────────── */
/* Handles: bigger + visible on selected */
.mm-node-handle {
  width: 16px !important;
  height: 16px !important;
  border-color: var(--bg-0) !important;
}

.mm-node:hover .mm-node-handle {
  opacity: 0.75 !important;
}

.mm-node.selected .mm-node-handle {
  opacity: 0.5 !important;
}

.mm-node.selected:hover .mm-node-handle {
  opacity: 1 !important;
}

.mm-handle-top {
  top: -8px !important;
}

.mm-handle-right {
  right: -8px !important;
}

.mm-handle-bottom {
  bottom: -8px !important;
}

.mm-handle-left {
  left: -8px !important;
}

.mm-node-handle:hover {
  opacity: 1 !important;
  transform: translateX(-50%) scale(1.4) !important;
}

.mm-handle-right:hover {
  transform: translateY(-50%) scale(1.4) !important;
}

.mm-handle-left:hover {
  transform: translateY(-50%) scale(1.4) !important;
}

.mm-handle-bottom:hover {
  transform: translateX(-50%) scale(1.4) !important;
}

/* Toolbar animation */
@keyframes mmTbSlide {
  from {
    opacity: 0;
    transform: translateY(-5px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.mm-toolbar-context.mm-tb-anim {
  animation: mmTbSlide .18s ease-out forwards;
}

.mm-toolbar-sep {
  width: 1px;
  align-self: stretch;
  background: var(--border);
  margin: 2px 0;
}

.mm-shape-active {
  background: var(--accent-dim) !important;
  color: var(--accent) !important;
}

.mm-connect-btn {
  gap: 5px;
  color: var(--accent) !important;
}

.mm-connect-btn:hover {
  background: var(--accent-dim) !important;
}

/* Connect mode */
.mm-canvas.mm-connecting {
  cursor: crosshair;
}

.mm-canvas.mm-connecting .mm-node:not(.mm-connect-source) {
  outline: 2px dashed var(--accent);
  outline-offset: 2px;
  cursor: crosshair;
}

.mm-canvas.mm-connecting .mm-node.mm-connect-source {
  opacity: 0.6;
}

.mm-connect-hint {
  position: absolute;
  top: 12px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--bg-1);
  border: 1px solid var(--accent);
  color: var(--text-1);
  border-radius: var(--radius-md);
  padding: 7px 16px;
  font-size: .82rem;
  display: flex;
  align-items: center;
  gap: 8px;
  z-index: 200;
  box-shadow: 0 4px 16px rgba(0, 0, 0, .3);
  pointer-events: auto;
  animation: mmTbSlide .18s ease-out;
}

.mm-connect-hint button {
  background: none;
  border: 1px solid var(--border-light);
  border-radius: var(--radius-sm);
  color: var(--text-2);
  cursor: pointer;
  font-size: .78rem;
  padding: 2px 8px;
}

.mm-connect-hint button:hover {
  color: var(--text-1);
  border-color: var(--text-2);
}

/* ── Mind Map Extended Fixes ───────────────────────────── */
/* Handles: bigger + visible on selected */
.mm-node-handle {
  width: 16px !important;
  height: 16px !important;
  border-color: var(--bg-0) !important;
}

.mm-node:hover .mm-node-handle {
  opacity: 0.75 !important;
}

.mm-node.selected .mm-node-handle {
  opacity: 0.5 !important;
}

.mm-node.selected:hover .mm-node-handle {
  opacity: 1 !important;
}

.mm-handle-top {
  top: -8px !important;
}

.mm-handle-right {
  right: -8px !important;
}

.mm-handle-bottom {
  bottom: -8px !important;
}

.mm-handle-left {
  left: -8px !important;
}

.mm-node-handle:hover {
  opacity: 1 !important;
  transform: translateX(-50%) scale(1.4) !important;
}

.mm-handle-right:hover {
  transform: translateY(-50%) scale(1.4) !important;
}

.mm-handle-left:hover {
  transform: translateY(-50%) scale(1.4) !important;
}

.mm-handle-bottom:hover {
  transform: translateX(-50%) scale(1.4) !important;
}

/* Toolbar animation */
@keyframes mmTbSlide {
  from {
    opacity: 0;
    transform: translateY(-5px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.mm-toolbar-context.mm-tb-anim {
  animation: mmTbSlide .18s ease-out forwards;
}

.mm-toolbar-sep {
  width: 1px;
  align-self: stretch;
  background: var(--border);
  margin: 2px 0;
}

.mm-shape-active {
  background: var(--accent-dim) !important;
  color: var(--accent) !important;
}

.mm-connect-btn {
  gap: 5px;
  color: var(--accent) !important;
}

.mm-connect-btn:hover {
  background: var(--accent-dim) !important;
}

/* Connect mode */
.mm-canvas.mm-connecting {
  cursor: crosshair;
}

.mm-canvas.mm-connecting .mm-node:not(.mm-connect-source) {
  outline: 2px dashed var(--accent);
  outline-offset: 2px;
  cursor: crosshair;
}

.mm-canvas.mm-connecting .mm-node.mm-connect-source {
  opacity: 0.6;
}

.mm-connect-hint {
  position: absolute;
  top: 12px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--bg-1);
  border: 1px solid var(--accent);
  color: var(--text-1);
  border-radius: var(--radius-md);
  padding: 7px 16px;
  font-size: .82rem;
  display: flex;
  align-items: center;
  gap: 8px;
  z-index: 200;
  box-shadow: 0 4px 16px rgba(0, 0, 0, .3);
  pointer-events: auto;
  animation: mmTbSlide .18s ease-out;
}

.mm-connect-hint button {
  background: none;
  border: 1px solid var(--border-light);
  border-radius: var(--radius-sm);
  color: var(--text-2);
  cursor: pointer;
  font-size: .78rem;
  padding: 2px 8px;
}

.mm-connect-hint button:hover {
  color: var(--text-1);
  border-color: var(--text-2);
}

/* ── MindMap: handle visibility during drag-connect ─── */
.mm-canvas.mm-drag-connecting .mm-node-handle {
  opacity: 1 !important;
  box-shadow: 0 0 0 3px var(--accent-dim) !important;
}

.mm-canvas.mm-drag-connecting .mm-node:not(.mm-connect-source) {
  outline: 1px dashed rgba(124, 92, 252, .35);
  transition: outline .1s;
}

/* AI generation spinner */
@keyframes mmSpin {
  to {
    transform: rotate(360deg);
  }
}

/* ═══════════════════════════════════════════════════════════
   MindMap: New shapes (v4)
   ═══════════════════════════════════════════════════════════ */

/* Hexagon */
.mm-node.mm-node-hexagon {
  clip-path: polygon(15% 0%, 85% 0%, 100% 50%, 85% 100%, 15% 100%, 0% 50%);
  border-radius: 0;
}

.mm-node.mm-node-hexagon::before {
  display: none;
}

.mm-node.mm-node-hexagon .mm-node-content {
  text-align: center;
}

/* Triangle */
.mm-node.mm-node-triangle {
  clip-path: polygon(50% 0%, 100% 100%, 0% 100%);
  border-radius: 0;
  min-height: 100px !important;
  width: 140px !important;
}

.mm-node.mm-node-triangle::before {
  display: none;
}

.mm-node.mm-node-triangle .mm-node-content {
  padding-top: 32px;
  text-align: center;
}

.mm-node.mm-node-triangle .mm-node-desc {
  display: none;
}

/* Pill / Stadium */
.mm-node.mm-node-pill {
  border-radius: 999px !important;
  overflow: hidden;
}

.mm-node.mm-node-pill::before {
  display: none;
}

.mm-node.mm-node-pill .mm-node-content {
  text-align: center;
}

/* Parallelogram */
.mm-node.mm-node-parallelogram {
  transform: skewX(-14deg);
  border-radius: 4px;
}

.mm-node.mm-node-parallelogram::before {
  display: none;
}

.mm-node.mm-node-parallelogram .mm-node-content,
.mm-node.mm-node-parallelogram .mm-node-desc {
  transform: skewX(14deg);
  display: block;
}

/* Cloud shape (via clip-path) */
.mm-node.mm-node-cloud {
  clip-path: polygon(10% 60%, 10% 80%, 90% 80%, 90% 60%, 80% 60%, 80% 40%, 70% 30%, 55% 25%, 45% 20%, 30% 25%, 20% 35%, 10% 50%, 10% 60%);
  border-radius: 50%;
  min-height: 80px !important;
}

.mm-node.mm-node-cloud::before {
  display: none;
}

.mm-node.mm-node-cloud .mm-node-content {
  padding-top: 30px;
  text-align: center;
}

.mm-node.mm-node-cloud .mm-node-desc {
  display: none;
}

/* ═══════════════════════════════════════════════════════════
   MindMap: Resize handles (v4)
   ═══════════════════════════════════════════════════════════ */
.mm-resize-handle {
  position: absolute;
  width: 10px;
  height: 10px;
  background: var(--bg-3);
  border: 2px solid var(--node-color, var(--accent));
  border-radius: 2px;
  opacity: 0;
  z-index: 35;
  transition: opacity .15s;
}

.mm-node.selected .mm-resize-handle {
  opacity: 1;
}

.mm-resize-nw {
  top: -5px;
  left: -5px;
  cursor: nwse-resize;
}

.mm-resize-ne {
  top: -5px;
  right: -5px;
  cursor: nesw-resize;
}

.mm-resize-sw {
  bottom: -5px;
  left: -5px;
  cursor: nesw-resize;
}

.mm-resize-se {
  bottom: -5px;
  right: -5px;
  cursor: nwse-resize;
}

.mm-resize-handle:hover {
  background: var(--node-color, var(--accent));
}

/* ═══════════════════════════════════════════════════════════
   MindMap: Minimap (v4)
   ═══════════════════════════════════════════════════════════ */
.mm-minimap {
  position: absolute;
  bottom: 50px;
  right: 12px;
  width: 180px;
  height: 110px;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  overflow: hidden;
  cursor: crosshair;
  z-index: 50;
  opacity: 0.8;
  transition: opacity .2s;
  box-shadow: 0 2px 14px rgba(0, 0, 0, .35);
}

.mm-minimap:hover {
  opacity: 1;
}

/* ═══════════════════════════════════════════════════════════
   MindMap v5: Shape wrapper, undo/redo, minimap panel
   ═══════════════════════════════════════════════════════════ */

/* 1. Strip background/border/shadow from .mm-node container—
      these now live on .mm-node-shape child so clip-path/transform
      on the shape never clips the connection/resize handles.      */
.mm-node {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  overflow: visible !important;
}

.mm-node::before {
  display: none !important;
}

/* 2. Shape wrapper — the visual shape element */
.mm-node-shape {
  width: 100%;
  min-height: inherit;
  position: relative;
  background: var(--bg-2);
  border: 2px solid var(--node-color);
  border-radius: var(--radius-md);
  box-shadow: 0 2px 12px rgba(0, 0, 0, .12);
  transition: box-shadow .15s, border-color .15s;
  overflow: hidden;
  box-sizing: border-box;
}

.mm-node:hover .mm-node-shape {
  box-shadow: 0 4px 20px rgba(0, 0, 0, .2);
}

.mm-node.selected .mm-node-shape {
  box-shadow:
    0 0 0 3px color-mix(in srgb, var(--node-color) 35%, transparent),
    0 4px 24px rgba(0, 0, 0, .22);
}

.mm-node-shape::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: var(--node-color);
  border-radius: var(--radius-md) var(--radius-md) 0 0;
  pointer-events: none;
}

/* ── Shape variants on .mm-node-shape ─────────────────── */

/* Circle */
.mm-node-shape.mm-node-circle {
  border-radius: 50% !important;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

.mm-node-shape.mm-node-circle::before {
  display: none;
}

.mm-node-shape.mm-node-circle .mm-node-content {
  text-align: center;
  padding: 8px;
  width: 100%;
}

.mm-node-shape.mm-node-circle .mm-node-desc {
  display: none;
}

/* Diamond — clip-path so no bounding-box rotation */
.mm-node-shape.mm-node-diamond {
  clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%);
  border-radius: 0;
  border: none;
  overflow: visible;
  background: color-mix(in srgb, var(--node-color) 15%, var(--bg-2));
  filter: drop-shadow(0 0 3px var(--node-color));
}

.mm-node.selected .mm-node-shape.mm-node-diamond {
  filter: drop-shadow(0 0 7px var(--node-color));
}

.mm-node-shape.mm-node-diamond::before {
  display: none;
}

.mm-node-shape.mm-node-diamond .mm-node-content {
  text-align: center;
  padding-top: 28%;
}

.mm-node-shape.mm-node-diamond .mm-node-desc {
  display: none;
}

/* Hexagon — clip-path */
.mm-node-shape.mm-node-hexagon {
  clip-path: polygon(15% 0%, 85% 0%, 100% 50%, 85% 100%, 15% 100%, 0% 50%);
  border-radius: 0;
  border: none;
  filter: drop-shadow(0 0 3px var(--node-color));
}

.mm-node.selected .mm-node-shape.mm-node-hexagon {
  filter: drop-shadow(0 0 7px var(--node-color));
}

.mm-node-shape.mm-node-hexagon::before {
  display: none;
}

.mm-node-shape.mm-node-hexagon .mm-node-content {
  text-align: center;
}

/* Triangle — clip-path */
.mm-node-shape.mm-node-triangle {
  clip-path: polygon(50% 0%, 100% 100%, 0% 100%);
  border-radius: 0;
  border: none;
  min-height: 110px;
  filter: drop-shadow(0 0 3px var(--node-color));
}

.mm-node.selected .mm-node-shape.mm-node-triangle {
  filter: drop-shadow(0 0 7px var(--node-color));
}

.mm-node-shape.mm-node-triangle::before {
  display: none;
}

.mm-node-shape.mm-node-triangle .mm-node-content {
  text-align: center;
  padding-top: 34%;
}

.mm-node-shape.mm-node-triangle .mm-node-desc {
  display: none;
}

/* Pill / stadium */
.mm-node-shape.mm-node-pill {
  border-radius: 999px !important;
  overflow: hidden;
}

.mm-node-shape.mm-node-pill::before {
  display: none;
}

.mm-node-shape.mm-node-pill .mm-node-content {
  text-align: center;
}

/* Parallelogram — skew shape only (not container), so handles stay upright */
.mm-node-shape.mm-node-parallelogram {
  transform: skewX(-14deg);
  border-radius: 4px;
  overflow: hidden;
}

.mm-node-shape.mm-node-parallelogram::before {
  display: none;
}

.mm-node-shape.mm-node-parallelogram .mm-node-content,
.mm-node-shape.mm-node-parallelogram .mm-node-desc {
  transform: skewX(14deg);
  display: block;
}

/* Cloud — organic clip-path */
.mm-node-shape.mm-node-cloud {
  clip-path: polygon(4% 55%, 5% 45%, 10% 35%, 18% 28%, 27% 22%, 36% 20%, 46% 22%, 55% 26%, 63% 22%, 72% 24%, 80% 30%, 87% 38%, 90% 48%, 93% 58%, 91% 68%, 86% 75%, 77% 80%, 65% 82%, 52% 82%, 38% 82%, 25% 80%, 14% 74%, 6% 65%, 4% 55%);
  border-radius: 0;
  border: none;
  min-height: 90px;
  filter: drop-shadow(0 0 3px var(--node-color));
}

.mm-node.selected .mm-node-shape.mm-node-cloud {
  filter: drop-shadow(0 0 7px var(--node-color));
}

.mm-node-shape.mm-node-cloud::before {
  display: none;
}

.mm-node-shape.mm-node-cloud .mm-node-content {
  text-align: center;
  padding: 20% 18% 5%;
}

.mm-node-shape.mm-node-cloud .mm-node-desc {
  display: none;
}

/* ── Cancel old per-node shape rules (now on .mm-node-shape) ──
   JS applies shape classes to .mm-node-shape, NOT .mm-node.
   Old v3/v4 rules used bare selectors that still match. */
.mm-node-shape.mm-node-parallelogram>.mm-node-content,
.mm-node-shape.mm-node-parallelogram>.mm-node-desc {
  /* v5 already handles skew, prevent old rules stacking */
}

/* ── Minimap panel (v5 — replaces standalone canvas) ───── */
.mm-zoom-controls {
  display: none !important;
}

/* now inside minimap panel */
.mm-minimap {
  display: none !important;
}

/* replaced by .mm-minimap-panel */

.mm-minimap-panel {
  position: absolute;
  bottom: 12px;
  right: 12px;
  width: 205px;
  z-index: 50;
  background: rgba(12, 12, 18, 0.93);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  box-shadow: 0 4px 18px rgba(0, 0, 0, .45);
  overflow: hidden;
  user-select: none;
}

.mm-minimap-zoom-row {
  display: flex;
  align-items: center;
  gap: 1px;
  padding: 3px 4px;
  border-bottom: 1px solid var(--border);
}

.mm-mini-btn {
  background: none;
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  color: var(--text-2);
  cursor: pointer;
  font-size: 14px;
  line-height: 1;
  padding: 3px 5px;
  min-width: 24px;
  min-height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .12s, color .12s;
}

.mm-mini-btn:hover:not(:disabled) {
  background: rgba(255, 255, 255, .08);
  color: var(--text-1);
}

.mm-mini-btn:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}

#mm-zoom-label {
  font-size: 11px;
  color: var(--text-3);
  min-width: 34px;
  text-align: center;
  font-variant-numeric: tabular-nums;
}

.mm-mini-sep {
  flex: 1;
}

.mm-minimap-canvas {
  display: block;
  width: 100%;
  cursor: crosshair;
}

.mm-minimap-resize-handle {
  position: absolute;
  top: 0;
  left: 0;
  width: 14px;
  height: 14px;
  cursor: nwse-resize;
  z-index: 10;
  background: linear-gradient(135deg, rgba(124, 92, 252, .45) 0%, transparent 65%);
  border-radius: 0 0 4px 0;
}

.mm-minimap-resize-handle:hover {
  background: linear-gradient(135deg, var(--accent) 0%, transparent 65%);
}
