/* ---------- Shape-grid (Design / Frame / Watermark selectors) ---------- */
.shape-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, 62px);
  gap: 4px;
}

.shape-grid.small { grid-template-columns: repeat(auto-fill, 32px); }

.shape-grid.frame-grid { grid-template-columns: repeat(auto-fill, 52px); gap: 6px; }

.shape-grid.wm-grid { grid-template-columns: repeat(auto-fill, 38px); gap: 4px; }

/* ---------- Font picker (Dropdown) ----------
   Trigger zeigt den gewählten Font, Panel mit allen Fonts klappt auf.
   Spart vertikalen Platz im Frame-Panel. */
.font-select {
  position: relative;
  width: 100%;
}

.font-select-trigger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 9px 12px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: #ffffff;
  color: var(--text);
  font-size: 14px;
  cursor: pointer;
  transition: border-color .12s ease, box-shadow .12s ease;
}

.font-select-trigger:hover {
  border-color: var(--purple, #7c3aed);
}

.font-select-trigger:focus-visible {
  outline: none;
  border-color: var(--purple, #7c3aed);
  box-shadow: 0 0 0 3px rgba(124, 58, 237, 0.15);
}

.font-select-current {
  flex: 1;
  text-align: left;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.font-select-caret {
  margin-left: 8px;
  color: #6b7280;
  font-size: 12px;
}

.font-select-panel {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  right: 0;
  max-height: 260px;
  overflow-y: auto;
  background: #ffffff;
  border: 1px solid var(--border);
  border-radius: 6px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
  z-index: 50;
  padding: 4px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.font-select-panel[hidden] { display: none; }

.font-option {
  text-align: left;
  padding: 8px 10px;
  border: none;
  border-radius: 4px;
  background: transparent;
  color: var(--text);
  font-size: 14px;
  cursor: pointer;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  transition: background .1s ease;
}

.font-option:hover {
  background: #f3f4f6;
}

.font-option.active {
  background: #ede9fe;
  color: #5b21b6;
  font-weight: 600;
}

.shape-btn {
  aspect-ratio: 1 / 1;
  border: 1px solid transparent;
  border-radius: 6px;
  background: transparent;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  min-width: 0;
  transition: background .12s ease, border-color .12s ease, transform .08s ease;
}

.shape-btn:hover {
  background: var(--soft);
  border-color: var(--border);
}

.shape-btn:active { transform: scale(0.94); }

.shape-btn.active {
  background: none;
  border-color: #1f2937;
}

.shape-btn svg {
  width: 62%;
  height: 62%;
  color: #1f2937;
}

.shape-btn.active svg { color: #000000; }

/* Watermark gallery: same grid, but with images instead of SVGs */
.wm-btn { padding: 3px; }

.wm-btn img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  pointer-events: none;
}

.wm-btn.active {
  background: #ede7f6;
  border-color: var(--purple);
  box-shadow: 0 0 0 2px var(--purple);
}

.wm-btn.missing {
  opacity: 0.25;
  cursor: not-allowed;
}

/* ---------- Clear-logo button ---------- */
.clear-btn {
  margin-top: 12px;
  padding: 8px 14px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--soft);
  color: var(--text);
  font: inherit;
  font-size: 13px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: background .15s ease, border-color .15s ease;
}

.clear-btn:hover {
  background: #ffffff;
  border-color: #ef4444;
  color: #ef4444;
}

.clear-btn[hidden] { display: none; }