/* ═══════════════════════════════════════════════════════════════════
   Bear SVG Catalog — UI Pro v1.2.0
   bearstudio.space
   ═══════════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Syne:wght@600;700;800&family=Figtree:wght@400;500;600&display=swap');

/* ─── Design tokens ────────────────────────────────────────────────── */
:root {
  --bsc-bg:        #07071a;
  --bsc-s1:        #0e0e22;
  --bsc-s2:        #13132b;
  --bsc-s3:        #1a1a38;
  --bsc-border:    rgba(120,120,255,.14);
  --bsc-border-h:  rgba(120,120,255,.35);
  --bsc-primary:   #818cf8;
  --bsc-primary-d: #6366f1;
  --bsc-accent:    #f441a5;
  --bsc-accent-d:  #c0006e;
  --bsc-text:      #dde0ff;
  --bsc-sub:       #8b8fb5;
  --bsc-hint:      #454870;
  --bsc-free:      #34d399;
  --bsc-free-bg:   rgba(52,211,153,.1);
  --bsc-prem:      #c084fc;
  --bsc-prem-bg:   rgba(192,132,252,.1);
  --bsc-r:         14px;
  --bsc-r-lg:      20px;
  --bsc-font:      'Figtree', sans-serif;
  --bsc-head:      'Syne', sans-serif;
  --shadow-glow:   0 0 0 1px var(--bsc-border-h), 0 8px 40px rgba(99,102,241,.2);
}

/* ─── Base ─────────────────────────────────────────────────────────── */
#bsc-catalog-app,
#bsc-modal {
  font-family: var(--bsc-font);
  color: var(--bsc-text);
  -webkit-font-smoothing: antialiased;
}

/* ─── Skeleton ─────────────────────────────────────────────────────── */
.bsc-skeleton {
  background: linear-gradient(90deg,
    rgba(255,255,255,.04) 25%,
    rgba(255,255,255,.08) 50%,
    rgba(255,255,255,.04) 75%);
  background-size: 200% 100%;
  animation: bsc-shimmer 1.6s ease infinite;
  border-radius: 10px;
}
@keyframes bsc-shimmer {
  0%   { background-position: 200% 0 }
  100% { background-position:-200% 0 }
}
.bsc-skeleton-header {
  display: flex;
  gap: 12px;
  margin-bottom: 28px;
  align-items: center;
}
.bsc-sk-tabs  { width: 200px; height: 40px; border-radius: 40px; }
.bsc-sk-search{ flex: 1; max-width: 280px; height: 40px; border-radius: 40px; }
.bsc-skeleton-grid {
  display: grid;
  grid-template-columns: repeat(var(--bsc-cols, 4), 1fr);
  gap: 14px;
}
.bsc-sk-card { height: 240px; }

/* ─── Catalog app ──────────────────────────────────────────────────── */
#bsc-catalog-app {
  max-width: 1200px;
  margin: 0 auto;
  padding: 32px 0;
}

/* ─── Header ───────────────────────────────────────────────────────── */
.bsc-catalog-header {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 28px;
  flex-wrap: wrap;
}

/* ─── Tabs ─────────────────────────────────────────────────────────── */
.bsc-tabs {
  display: flex;
  gap: 2px;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--bsc-border);
  border-radius: 40px;
  padding: 4px;
}
.bsc-tab {
  font-family: var(--bsc-font);
  font-size: 13px;
  font-weight: 600;
  padding: 7px 18px;
  border: none;
  border-radius: 40px;
  cursor: pointer;
  background: transparent;
  color: var(--bsc-sub);
  letter-spacing: .02em;
  transition: all .2s;
}
.bsc-tab.active {
  background: var(--bsc-primary);
  color: #fff;
  box-shadow: 0 2px 12px rgba(129,140,248,.4);
}
.bsc-tab:hover:not(.active) { color: var(--bsc-text); }

/* ─── Search ───────────────────────────────────────────────────────── */
.bsc-search-wrap {
  flex: 1;
  max-width: 300px;
  position: relative;
}
.bsc-search-wrap svg {
  position: absolute;
  left: 13px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--bsc-hint);
}
.bsc-search-input {
  font-family: var(--bsc-font);
  font-size: 13px;
  width: 100%;
  padding: 9px 14px 9px 38px;
  border: 1px solid var(--bsc-border);
  border-radius: 40px;
  background: rgba(255,255,255,.04);
  color: var(--bsc-text);
  outline: none;
  transition: all .2s;
  box-sizing: border-box;
}
.bsc-search-input::placeholder { color: var(--bsc-hint); }
.bsc-search-input:focus {
  border-color: var(--bsc-primary);
  background: rgba(129,140,248,.07);
}

/* Count */
.bsc-section-info {
  font-size: 12px;
  color: var(--bsc-hint);
  letter-spacing: .03em;
  margin-left: auto;
  font-family: var(--bsc-font);
}

/* ─── Grid ─────────────────────────────────────────────────────────── */
.bsc-grid {
  display: grid;
  grid-template-columns: repeat(var(--bsc-cols, 4), 1fr);
  gap: 14px;
}
.bsc-empty, .bsc-error {
  grid-column: 1 / -1;
  text-align: center;
  padding: 60px 20px;
  color: var(--bsc-hint);
  font-size: 14px;
}
.bsc-error { color: #f87171; }

/* ─── Card ─────────────────────────────────────────────────────────── */
@keyframes bsc-card-in {
  from { opacity: 0; transform: translateY(18px); }
  to   { opacity: 1; transform: translateY(0); }
}
.bsc-card {
  background: rgba(255,255,255,.03);
  border: 1px solid var(--bsc-border);
  border-radius: var(--bsc-r);
  overflow: hidden;
  transition: border-color .25s, box-shadow .25s, transform .25s;
  cursor: pointer;
  animation: bsc-card-in .4s ease both;
  position: relative;
}
.bsc-card:hover {
  border-color: var(--bsc-border-h);
  box-shadow: var(--shadow-glow);
  transform: translateY(-3px);
}

/* Card thumb */
.bsc-card-thumb {
  position: relative;
  height: 160px;
  background: var(--bsc-s1);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
/* Checker pattern SVG background */
.bsc-card-thumb::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(45deg, rgba(255,255,255,.015) 25%, transparent 25%),
    linear-gradient(-45deg, rgba(255,255,255,.015) 25%, transparent 25%),
    linear-gradient(45deg, transparent 75%, rgba(255,255,255,.015) 75%),
    linear-gradient(-45deg, transparent 75%, rgba(255,255,255,.015) 75%);
  background-size: 16px 16px;
  background-position: 0 0, 0 8px, 8px -8px, -8px 0px;
}
.bsc-card-thumb img {
  position: relative;
  max-width: 75%;
  max-height: 120px;
  object-fit: contain;
  filter: drop-shadow(0 4px 16px rgba(0,0,0,.5));
  transition: transform .3s ease;
}
.bsc-card:hover .bsc-card-thumb img { transform: scale(1.06); }

.bsc-card-thumb-svg {
  position: relative;
  width: 70%;
  height: 70%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.bsc-card-thumb-svg svg {
  max-width: 100%;
  max-height: 100%;
  filter: drop-shadow(0 4px 12px rgba(0,0,0,.4));
  transition: transform .3s ease;
}
.bsc-card:hover .bsc-card-thumb-svg svg { transform: scale(1.06); }

.bsc-thumb-placeholder {
  position: relative;
  font-family: var(--bsc-head);
  font-size: 28px;
  font-weight: 800;
  color: var(--bsc-primary);
  opacity: .2;
  letter-spacing: -.02em;
}

/* Glow edge top on hover */
.bsc-card::before {
  content: '';
  position: absolute;
  top: 0; left: 20%; right: 20%;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--bsc-primary), transparent);
  opacity: 0;
  transition: opacity .3s;
  z-index: 1;
}
.bsc-card:hover::before { opacity: .7; }

/* Badge */
.bsc-badge {
  position: absolute;
  top: 10px;
  left: 10px;
  font-family: var(--bsc-font);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: 3px 9px 3px 7px;
  border-radius: 20px;
  display: flex;
  align-items: center;
  gap: 4px;
  backdrop-filter: blur(8px);
  border: 1px solid;
  z-index: 2;
}
.bsc-badge.free {
  background: var(--bsc-free-bg);
  color: var(--bsc-free);
  border-color: rgba(52,211,153,.25);
}
.bsc-badge.premium {
  background: var(--bsc-prem-bg);
  color: var(--bsc-prem);
  border-color: rgba(192,132,252,.25);
}

/* Card info */
.bsc-card-info {
  padding: 13px 14px;
  border-top: 1px solid var(--bsc-border);
  background: rgba(255,255,255,.015);
}
.bsc-card-info h3 {
  font-family: var(--bsc-font);
  font-size: 13px;
  font-weight: 600;
  margin: 0 0 10px;
  color: var(--bsc-text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Buttons */
.bsc-btn {
  font-family: var(--bsc-font);
  font-size: 12px;
  font-weight: 600;
  padding: 8px 14px;
  border: none;
  border-radius: 8px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  transition: all .2s;
  width: 100%;
  justify-content: center;
  box-sizing: border-box;
  letter-spacing: .02em;
}
.bsc-btn-edit {
  background: linear-gradient(135deg, var(--bsc-primary), var(--bsc-primary-d));
  color: #fff;
  box-shadow: 0 2px 10px rgba(99,102,241,.25);
}
.bsc-btn-edit:hover {
  box-shadow: 0 4px 20px rgba(99,102,241,.45);
  transform: translateY(-1px);
}
.bsc-btn-lock {
  background: var(--bsc-prem-bg);
  color: var(--bsc-prem);
  border: 1px solid rgba(192,132,252,.2);
}
.bsc-btn-lock:hover {
  background: rgba(192,132,252,.18);
  border-color: var(--bsc-prem);
}

/* Premium overlay */
.bsc-card.premium-locked .bsc-card-thumb::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(7,7,26,.35);
  backdrop-filter: blur(1px);
}

/* ─── Modal ────────────────────────────────────────────────────────── */
.bsc-modal {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  box-sizing: border-box;
  opacity: 0;
  pointer-events: none;
  transition: opacity .25s ease;
}
.bsc-modal.open {
  opacity: 1;
  pointer-events: all;
}
.bsc-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(4,4,16,.85);
  backdrop-filter: blur(12px);
}
.bsc-modal-content {
  position: relative;
  background: var(--bsc-s1);
  border: 1px solid var(--bsc-border);
  border-radius: var(--bsc-r-lg);
  width: 100%;
  max-width: 980px;
  max-height: 92vh;
  overflow: hidden;
  box-shadow: 0 0 0 1px rgba(255,255,255,.05), 0 32px 80px rgba(0,0,15,.7);
  display: flex;
  flex-direction: column;
  transform: scale(.97) translateY(8px);
  transition: transform .25s ease;
}
.bsc-modal.open .bsc-modal-content {
  transform: scale(1) translateY(0);
}

.bsc-modal-close {
  position: absolute;
  top: 14px;
  right: 14px;
  z-index: 20;
  width: 30px;
  height: 30px;
  border-radius: 8px;
  border: 1px solid var(--bsc-border);
  background: rgba(255,255,255,.05);
  color: var(--bsc-sub);
  cursor: pointer;
  font-size: 13px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all .2s;
}
.bsc-modal-close:hover { background: rgba(244,65,165,.15); color: var(--bsc-accent); border-color: rgba(244,65,165,.3); }

/* ─── Editor layout ────────────────────────────────────────────────── */
.bsc-editor-layout {
  display: flex;
  height: 90vh;
  max-height: 660px;
  overflow: hidden;
}

/* Preview left */
.bsc-editor-left {
  flex: 1;
  display: flex;
  flex-direction: column;
  background: #050510;
  overflow: hidden;
  min-width: 0;
  position: relative;
}

/* Barra superior del preview */
.bsc-editor-topbar {
  padding: 14px 18px 12px;
  border-bottom: 1px solid rgba(255,255,255,.05);
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
}
.bsc-editor-title {
  font-family: var(--bsc-font);
  font-size: 13px;
  font-weight: 600;
  color: rgba(255,255,255,.6);
  flex: 1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.bsc-editor-type-badge {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: 2px 8px;
  border-radius: 20px;
  flex-shrink: 0;
}

/* Canvas del preview */
.bsc-svg-preview {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  box-sizing: border-box;
  overflow: hidden;
  position: relative;
  /* Figma-style checker */
  background-image:
    linear-gradient(45deg, #0c0c20 25%, transparent 25%),
    linear-gradient(-45deg, #0c0c20 25%, transparent 25%),
    linear-gradient(45deg, transparent 75%, #0c0c20 75%),
    linear-gradient(-45deg, transparent 75%, #0c0c20 75%);
  background-size: 20px 20px;
  background-position: 0 0, 0 10px, 10px -10px, -10px 0;
  background-color: #080818;
}
.bsc-svg-preview svg {
  max-width: 100%;
  max-height: 100%;
  filter: drop-shadow(0 8px 32px rgba(0,0,0,.6));
  transition: filter .2s;
}

.bsc-editor-hint {
  padding: 8px 18px 12px;
  font-size: 11px;
  color: rgba(255,255,255,.2);
  text-align: center;
  flex-shrink: 0;
  border-top: 1px solid rgba(255,255,255,.04);
  font-family: var(--bsc-font);
}
.bsc-editor-hint strong { color: rgba(255,255,255,.35); }

/* Panel right */
.bsc-editor-right {
  width: 296px;
  flex-shrink: 0;
  overflow-y: auto;
  overflow-x: hidden;
  border-left: 1px solid rgba(255,255,255,.06);
  background: var(--bsc-s1);
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,.08) transparent;
}
.bsc-editor-right::-webkit-scrollbar { width: 4px; }
.bsc-editor-right::-webkit-scrollbar-thumb { background: rgba(255,255,255,.1); border-radius: 2px; }

/* ─── Panel de control ─────────────────────────────────────────────── */
.bsc-panel-loading {
  color: var(--bsc-hint);
  font-size: 13px;
  text-align: center;
  padding: 40px 20px;
  font-family: var(--bsc-font);
}

.bsc-panel-section {
  padding: 16px 16px;
  border-bottom: 1px solid rgba(255,255,255,.05);
}
.bsc-panel-section:last-child { border-bottom: none; }

.bsc-panel-section h4 {
  font-family: var(--bsc-font);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--bsc-hint);
  margin: 0 0 12px;
}

/* Toggle group modo */
.bsc-toggle-group {
  display: flex;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 8px;
  padding: 3px;
  gap: 2px;
}
.bsc-mode-btn {
  flex: 1;
  font-family: var(--bsc-font);
  font-size: 12px;
  font-weight: 600;
  padding: 6px;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  background: transparent;
  color: var(--bsc-hint);
  transition: all .15s;
}
.bsc-mode-btn.active {
  background: rgba(129,140,248,.15);
  color: var(--bsc-primary);
  box-shadow: 0 1px 4px rgba(0,0,0,.2);
}

/* Lista de paths */
.bsc-paths-list {
  margin-top: 10px;
  max-height: 130px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 3px;
  scrollbar-width: thin;
}
.bsc-paths-list.hidden { display: none; }
.bsc-path-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 8px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 12px;
  font-family: var(--bsc-font);
  color: var(--bsc-sub);
  border: 1px solid transparent;
  transition: all .15s;
}
.bsc-path-item:hover { background: rgba(255,255,255,.04); color: var(--bsc-text); }
.bsc-path-item.selected {
  border-color: rgba(244,65,165,.35);
  background: rgba(244,65,165,.06);
  color: var(--bsc-text);
}
.bsc-path-color {
  width: 14px;
  height: 14px;
  border-radius: 4px;
  border: 1px solid rgba(255,255,255,.15);
  flex-shrink: 0;
}

/* Fill tabs */
.bsc-fill-tabs {
  display: flex;
  gap: 3px;
  margin-bottom: 12px;
  flex-wrap: wrap;
}
.bsc-fill-tab {
  font-family: var(--bsc-font);
  font-size: 11px;
  font-weight: 600;
  padding: 4px 10px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 20px;
  cursor: pointer;
  background: transparent;
  color: var(--bsc-hint);
  transition: all .15s;
  letter-spacing: .03em;
}
.bsc-fill-tab.active {
  border-color: var(--bsc-primary);
  background: rgba(129,140,248,.12);
  color: var(--bsc-primary);
}
.bsc-fill-tab:hover:not(.active) { color: var(--bsc-sub); border-color: rgba(255,255,255,.15); }

/* Fill panels */
.bsc-fill-panel { display: flex; flex-direction: column; gap: 8px; }
.bsc-fill-panel.hidden { display: none; }
.bsc-fill-panel label {
  font-size: 10px;
  font-weight: 700;
  color: var(--bsc-hint);
  text-transform: uppercase;
  letter-spacing: .07em;
  font-family: var(--bsc-font);
  margin-top: 2px;
}

/* Color row */
.bsc-color-row {
  display: flex;
  align-items: center;
  gap: 6px;
}
.bsc-color-row input[type="color"] {
  width: 34px;
  height: 34px;
  padding: 2px;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 7px;
  cursor: pointer;
  background: var(--bsc-s2);
  flex-shrink: 0;
  transition: border-color .15s;
}
.bsc-color-row input[type="color"]:hover { border-color: var(--bsc-primary); }
.bsc-color-row input[type="text"] {
  font-family: 'Courier New', monospace;
  font-size: 12px;
  font-weight: 600;
  flex: 1;
  padding: 7px 10px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 7px;
  background: var(--bsc-s2);
  color: var(--bsc-text);
  outline: none;
  transition: border-color .15s;
  letter-spacing: .04em;
}
.bsc-color-row input[type="text"]:focus { border-color: var(--bsc-primary); }

/* Gradient preview strip */
.bsc-gradient-preview {
  height: 22px;
  border-radius: 6px;
  border: 1px solid rgba(255,255,255,.06);
  margin-top: 2px;
}

/* Sliders */
.bsc-slider-row { display: flex; flex-direction: column; gap: 6px; }
.bsc-slider-label {
  display: flex;
  justify-content: space-between;
  font-size: 10px;
  font-weight: 700;
  color: var(--bsc-hint);
  text-transform: uppercase;
  letter-spacing: .07em;
  font-family: var(--bsc-font);
}
.bsc-slider-val { color: var(--bsc-primary); font-weight: 800; }

input[type="range"].bsc-range {
  -webkit-appearance: none;
  width: 100%;
  height: 3px;
  background: rgba(255,255,255,.08);
  border-radius: 2px;
  outline: none;
  cursor: pointer;
}
input[type="range"].bsc-range::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 14px;
  height: 14px;
  background: var(--bsc-primary);
  border-radius: 50%;
  border: 2px solid var(--bsc-s1);
  box-shadow: 0 0 0 2px rgba(129,140,248,.3);
  cursor: pointer;
  transition: box-shadow .15s;
}
input[type="range"].bsc-range::-webkit-slider-thumb:hover {
  box-shadow: 0 0 0 4px rgba(129,140,248,.25);
}

/* Switch toggle */
.bsc-switch-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
  cursor: pointer;
}
.bsc-switch-label {
  font-size: 13px;
  font-weight: 500;
  color: var(--bsc-text);
  cursor: pointer;
  font-family: var(--bsc-font);
}
.bsc-switch {
  position: relative;
  width: 34px;
  height: 19px;
  flex-shrink: 0;
}
.bsc-switch input { opacity: 0; width: 0; height: 0; position: absolute; }
.bsc-switch-track {
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 19px;
  transition: all .2s;
  cursor: pointer;
}
.bsc-switch input:checked + .bsc-switch-track {
  background: var(--bsc-primary);
  border-color: var(--bsc-primary);
  box-shadow: 0 0 10px rgba(129,140,248,.4);
}
.bsc-switch-track::after {
  content: '';
  position: absolute;
  top: 2px; left: 2px;
  width: 13px; height: 13px;
  background: #fff;
  border-radius: 50%;
  transition: left .2s;
  box-shadow: 0 1px 3px rgba(0,0,0,.3);
}
.bsc-switch input:checked + .bsc-switch-track::after { left: 17px; }

.bsc-stroke-controls { display: flex; flex-direction: column; gap: 8px; }
.bsc-stroke-controls.hidden { display: none; }

/* Botones del panel */
.bsc-btn-apply, .bsc-btn-download, .bsc-btn-reset {
  font-family: var(--bsc-font);
  width: 100%;
  border: none;
  border-radius: 9px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  transition: all .2s;
  margin-bottom: 7px;
}
.bsc-btn-apply {
  font-size: 12px;
  font-weight: 700;
  padding: 9px;
  background: rgba(129,140,248,.12);
  color: var(--bsc-primary);
  border: 1px solid rgba(129,140,248,.25);
  letter-spacing: .03em;
}
.bsc-btn-apply:hover { background: rgba(129,140,248,.2); border-color: var(--bsc-primary); }

.bsc-btn-download {
  font-size: 13px;
  font-weight: 700;
  padding: 11px;
  background: linear-gradient(135deg, var(--bsc-accent), var(--bsc-primary-d));
  color: #fff;
  box-shadow: 0 4px 20px rgba(244,65,165,.3);
  letter-spacing: .03em;
}
.bsc-btn-download:hover {
  box-shadow: 0 6px 28px rgba(244,65,165,.5);
  transform: translateY(-1px);
}
.bsc-btn-reset {
  font-size: 11px;
  font-weight: 600;
  padding: 7px;
  background: transparent;
  color: var(--bsc-hint);
  border: 1px solid rgba(255,255,255,.07);
  letter-spacing: .02em;
}
.bsc-btn-reset:hover { color: var(--bsc-sub); border-color: rgba(255,255,255,.14); }

/* ─── SVG interactivo (modo path) ──────────────────────────────────── */
.bsc-svg-interactive { outline: none; }
.bsc-path-mode .bsc-svg-interactive path,
.bsc-path-mode .bsc-svg-interactive circle,
.bsc-path-mode .bsc-svg-interactive rect,
.bsc-path-mode .bsc-svg-interactive ellipse,
.bsc-path-mode .bsc-svg-interactive polygon,
.bsc-path-mode .bsc-svg-interactive polyline {
  cursor: crosshair;
  transition: filter .12s;
}
.bsc-path-mode .bsc-svg-interactive *:hover {
  filter: brightness(1.3) drop-shadow(0 0 6px rgba(244,65,165,.5));
}
.bsc-element-selected {
  filter: drop-shadow(0 0 8px rgba(244,65,165,.9)) brightness(1.2) !important;
}

/* ─── Responsive ───────────────────────────────────────────────────── */
@media (max-width: 960px) {
  .bsc-grid { grid-template-columns: repeat(3, 1fr) !important; }
  .bsc-editor-layout { flex-direction: column; max-height: 92vh; }
  .bsc-editor-left { min-height: 260px; flex: none; }
  .bsc-editor-right { width: 100%; border-left: none; border-top: 1px solid rgba(255,255,255,.06); max-height: 320px; }
}
@media (max-width: 640px) {
  .bsc-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .bsc-catalog-header { gap: 10px; }
}
@media (max-width: 420px) {
  .bsc-grid { grid-template-columns: 1fr !important; }
  .bsc-modal { padding: 8px; }
  .bsc-modal-content { border-radius: 14px; }
}

/* ─── Paginación ───────────────────────────────────────────────────────────── */
.bsc-pagination {
  margin-top: 32px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}
.bsc-pager {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  justify-content: center;
}
.bsc-page-btn {
  font-family: var(--bsc-font);
  font-size: 12px;
  font-weight: 600;
  padding: 7px 14px;
  border: 1px solid var(--bsc-border);
  border-radius: 8px;
  background: rgba(255,255,255,.04);
  color: var(--bsc-sub);
  cursor: pointer;
  transition: all .18s;
  letter-spacing: .02em;
}
.bsc-page-btn:hover:not([disabled]) {
  border-color: var(--bsc-primary);
  color: var(--bsc-primary);
  background: rgba(129,140,248,.08);
}
.bsc-page-btn[disabled] {
  opacity: .3;
  cursor: default;
}
.bsc-page-nums {
  display: flex;
  align-items: center;
  gap: 3px;
  flex-wrap: wrap;
  justify-content: center;
}
.bsc-page-num {
  font-family: var(--bsc-font);
  font-size: 13px;
  font-weight: 600;
  width: 34px;
  height: 34px;
  border: 1px solid var(--bsc-border);
  border-radius: 8px;
  background: rgba(255,255,255,.03);
  color: var(--bsc-sub);
  cursor: pointer;
  transition: all .18s;
  display: flex;
  align-items: center;
  justify-content: center;
}
.bsc-page-num:hover { border-color: var(--bsc-primary); color: var(--bsc-primary); background: rgba(129,140,248,.08); }
.bsc-page-num.active {
  background: var(--bsc-primary);
  border-color: var(--bsc-primary);
  color: #fff;
  box-shadow: 0 2px 10px rgba(129,140,248,.4);
}
.bsc-page-ellipsis {
  color: var(--bsc-hint);
  font-size: 13px;
  padding: 0 3px;
  user-select: none;
}
.bsc-pager-info {
  font-size: 11px;
  color: var(--bsc-hint);
  margin: 0;
  font-family: var(--bsc-font);
}
