#view-browse { flex-direction: column; }

/* ── Browse tabs ── */
.browse-tabs { display: flex; gap: 2px; padding: 10px 24px 0; background: var(--ps-surface); border-bottom: 1.5px solid var(--ps-border); flex-shrink: 0; }
.browse-tab { background: none; border: none; border-bottom: 2.5px solid transparent; padding: 8px 16px 10px; font-family: var(--display); font-size: 13px; font-weight: 500; color: var(--ps-text-muted); cursor: pointer; transition: all .15s; margin-bottom: -1.5px; }
.browse-tab:hover { color: var(--ps-text-primary); }
.browse-tab.active { color: var(--ps-azul); border-bottom-color: var(--ps-azul); font-weight: 600; }

/* ── Toolbar ── */
.sub-toolbar { background: var(--ps-surface); border-bottom: 1.5px solid var(--ps-border); padding: 11px 24px; display: flex; align-items: center; gap: 8px; flex-shrink: 0; flex-wrap: wrap; }
#cat-chips { display: contents; }
.browse-filter-btn { display: none; }
.search-box { display: flex; align-items: center; gap: 7px; background: var(--ps-off-white); border: 1.5px solid var(--ps-border); border-radius: var(--ps-radius-pill); padding: 7px 14px; min-width: 200px; transition: border-color .15s; }
.search-box:focus-within { border-color: var(--ps-azul); }
.search-box svg { width: 13px; height: 13px; fill: none; stroke: var(--ps-text-muted); stroke-width: 2; stroke-linecap: round; flex-shrink: 0; }
.search-box input { border: none; outline: none; background: transparent; font-family: var(--display); font-size: 13px; color: var(--ps-text-primary); width: 100%; }
.search-box input::placeholder { color: var(--ps-text-muted); }
.filter-chip { display: inline-flex; align-items: center; gap: 7px; padding: 4px 13px 4px 4px; border-radius: var(--ps-radius-pill); border: 1.5px solid var(--ps-border); background: transparent; font-family: var(--display); font-size: 12px; font-weight: 500; color: var(--ps-text-secondary); cursor: pointer; transition: all .15s; white-space: nowrap; }
.filter-chip:hover { border-color: var(--ps-border-strong); color: var(--ps-text-primary); }
.filter-chip.active { background: var(--ps-text-primary); color: white; border-color: var(--ps-text-primary); }
.chip-count { display: inline-flex; align-items: center; justify-content: center; min-width: 22px; height: 22px; padding: 0 5px; border-radius: var(--ps-radius-pill); background: var(--ps-azul); color: #fff; font-size: 10.5px; font-weight: 700; line-height: 1; flex-shrink: 0; }
.filter-chip.active .chip-count { background: rgba(255,255,255,.22); color: #fff; }
.sort-select { font-family: var(--mono); font-size: 11.5px; color: var(--ps-text-secondary); background: transparent; border: 1.5px solid var(--ps-border); border-radius: var(--ps-radius-pill); padding: 5px 12px; cursor: pointer; margin-left: auto; outline: none; }
.result-count { font-family: var(--mono); font-size: 11px; color: var(--ps-text-muted); }

/* ── Browse body ── */
.browse-body { flex: 1; overflow-y: auto; padding: 24px 28px; }
.browse-body::-webkit-scrollbar { width: 4px; }
.browse-body::-webkit-scrollbar-thumb { background: var(--ps-border); border-radius: 2px; }
.pack-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 10px; margin-bottom: 24px; }
.browse-section-head { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--ps-text-muted); padding: 4px 0 10px; margin-top: 8px; border-bottom: 1.5px solid var(--ps-border); margin-bottom: 14px; }

/* ── Pack cards ── */
.pack-card { background: var(--ps-surface); border: 1.5px solid var(--ps-border); border-radius: var(--ps-radius); display: flex; flex-direction: column; position: relative; overflow: hidden; transition: border-color .18s, box-shadow .18s, transform .18s; cursor: pointer; }
.pack-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; opacity: 0; transition: opacity .18s; }
.pack-card:hover { border-color: transparent; transform: translateY(-2px); }
.pack-card:hover::before { opacity: 1; }
.pack-card.active { border-color: var(--ps-azul); box-shadow: 0 0 0 1.5px var(--ps-azul), var(--ps-shadow-lg); }
.pack-card.active::before { opacity: 1; }
.pack-card.c-terra::before { background: var(--ps-terracotta); }
.pack-card.c-terra:hover { box-shadow: 0 0 0 1.5px var(--ps-terracotta), 0 8px 28px rgba(168,75,42,.14); }
.pack-card.c-blue::before  { background: var(--ps-azul); }
.pack-card.c-blue:hover    { box-shadow: 0 0 0 1.5px var(--ps-azul), 0 8px 28px rgba(120,137,144,.14); }
.pack-card.c-green::before { background: var(--ps-verde); }
.pack-card.c-green:hover   { box-shadow: 0 0 0 1.5px var(--ps-verde), 0 8px 28px rgba(141,149,126,.14); }
.pack-card.c-warm::before  { background: var(--ps-warm); }
.pack-card.c-warm:hover    { box-shadow: 0 0 0 1.5px var(--ps-warm), 0 8px 28px rgba(184,147,106,.14); }

.card-body { padding: 14px 14px 10px; flex: 1; }
.card-top { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 8px; }
.badge-row { display: flex; gap: 5px; flex-wrap: wrap; }
.badge { font-family: var(--mono); font-size: 9.5px; font-weight: 500; letter-spacing: .06em; text-transform: uppercase; border-radius: var(--ps-radius-xs); padding: 3px 8px; }
.b-pack  { background: var(--ps-terracotta-faint); color: var(--ps-terracotta); }
.b-skill { background: var(--ps-azul-faint); color: var(--ps-azul-dark); }
.b-free  { background: var(--ps-verde-faint); color: var(--ps-verde-dark); }
.installed-badge { background: var(--ps-verde-faint); color: var(--ps-verde-dark); border: 1px solid var(--ps-verde-light); }

.card-name { font-size: 13px; font-weight: 700; letter-spacing: -.1px; color: var(--ps-text-primary); margin-bottom: 2px; line-height: 1.35; }
.card-author { font-family: var(--mono); font-size: 10px; color: var(--ps-azul); margin-bottom: 6px; }
.card-counts { font-family: var(--mono); font-size: 10.5px; color: var(--ps-text-muted); }

.content-section { margin-bottom: 10px; }
.cs-label { font-family: var(--mono); font-size: 9px; font-weight: 500; letter-spacing: .1em; text-transform: uppercase; color: var(--ps-text-muted); margin-bottom: 5px; display: flex; align-items: center; gap: 6px; }
.cs-label::after { content: ''; flex: 1; height: 1px; background: var(--ps-border); }
.persona-list { display: flex; flex-direction: column; gap: 4px; }
.persona-row { display: flex; align-items: center; gap: 7px; font-size: 12px; }
.persona-avatar { width: 20px; height: 20px; border-radius: 5px; display: flex; align-items: center; justify-content: center; font-size: 8px; font-weight: 700; flex-shrink: 0; color: #fff; font-family: var(--mono); }
.persona-pname { font-weight: 600; color: var(--ps-text-primary); }
.persona-role  { color: var(--ps-text-muted); font-size: 11px; }
.more-label { font-size: 11px; color: var(--ps-text-muted); padding-left: 27px; }
.tpl-row { font-size: 12px; color: var(--ps-text-secondary); padding: 2px 0; display: flex; align-items: center; gap: 7px; }
.tpl-row::before { content: ''; width: 4px; height: 4px; border-radius: 50%; background: var(--ps-border-strong); flex-shrink: 0; }
.tag-row { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 2px; }
.tag-chip { font-family: var(--mono); font-size: 10px; color: var(--ps-text-secondary); background: var(--ps-bege-rose); border: 1px solid var(--ps-border); border-radius: var(--ps-radius-xs); padding: 2px 7px; }

.card-footer { padding: 8px 14px; border-top: 1.5px solid var(--ps-border); display: flex; align-items: center; justify-content: space-between; gap: 6px; margin-top: auto; }
.footer-counts { font-family: var(--mono); font-size: 10px; color: var(--ps-text-muted); display: flex; gap: 8px; }
.footer-count { display: flex; align-items: center; gap: 4px; }
.footer-count svg { width: 11px; height: 11px; fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.card-actions { display: flex; align-items: center; gap: 6px; }
.btn-details { background: transparent; border: 1.5px solid var(--ps-border); color: var(--ps-text-muted); font-family: var(--display); font-size: 11px; font-weight: 500; padding: 4px 10px; border-radius: var(--ps-radius-pill); cursor: pointer; transition: all .15s; }
.btn-details:hover { border-color: var(--ps-azul-light); color: var(--ps-azul-dark); }
.install-btn { font-family: var(--display); font-size: 11.5px; font-weight: 600; padding: 5px 13px; border-radius: var(--ps-radius-pill); border: none; cursor: pointer; transition: all .15s; white-space: nowrap; }
.install-btn.not-installed { background: var(--ps-azul); color: white; }
.install-btn.not-installed:hover { background: var(--ps-azul-dark); }
.install-btn.is-installed { background: var(--ps-verde-faint); color: var(--ps-verde-dark); border: 1.5px solid var(--ps-verde-light); }
.install-btn.is-installed:hover { background: #FEE2E2; color: #991B1B; border-color: #FECACA; }

/* ── Detail sidebar ── */
.pack-detail-sidebar { position: fixed; top: var(--header-h); right: 0; bottom: 0; width: 460px; max-width: 90vw; background: var(--ps-surface); border-left: 1.5px solid var(--ps-border); display: flex; flex-direction: column; transform: translateX(100%); transition: transform .28s cubic-bezier(.4,0,.2,1); z-index: 20; box-shadow: -6px 0 32px rgba(30,32,34,.12); }
.pack-detail-sidebar.open { transform: translateX(0); }
.pds-bar { display: flex; align-items: center; gap: 10px; padding: 14px 18px; border-bottom: 1.5px solid var(--ps-border); flex-shrink: 0; }
.pds-bar-name { font-size: 14px; font-weight: 700; color: var(--ps-text-primary); flex: 1; min-width: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.pds-close { width: 26px; height: 26px; border-radius: 50%; background: var(--ps-bege-rose); border: none; cursor: pointer; display: flex; align-items: center; justify-content: center; font-size: 15px; color: var(--ps-text-muted); transition: all .12s; flex-shrink: 0; }
.pds-close:hover { background: var(--ps-azul-light); color: var(--ps-azul-dark); }
.pds-body { flex: 1; overflow-y: auto; }
.pds-body::-webkit-scrollbar { width: 4px; }
.pds-body::-webkit-scrollbar-thumb { background: var(--ps-border); border-radius: 2px; }
.pds-loading { display: flex; align-items: center; justify-content: center; height: 120px; color: var(--ps-text-muted); font-size: 13px; }
.pds-hero { padding: 20px 20px 16px; border-bottom: 1.5px solid var(--ps-border); }
.pds-hero-top { display: flex; align-items: flex-start; gap: 14px; margin-bottom: 12px; }
.pds-hero-icon { width: 46px; height: 46px; border-radius: 12px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.pds-hero-icon svg { width: 21px; height: 21px; fill: none; stroke: currentColor; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.pds-hero-name { font-size: 17px; font-weight: 700; color: var(--ps-text-primary); letter-width: -.3px; margin-bottom: 3px; }
.pds-hero-author { font-family: var(--mono); font-size: 11px; color: var(--ps-azul); }
.pds-author-link { color: var(--ps-azul); text-decoration: none; border-bottom: 1px dashed var(--ps-azul-light); transition: color .12s, border-color .12s; cursor: pointer; }
.pds-author-link:hover { color: var(--ps-azul-dark); border-color: var(--ps-azul); }
.pds-desc { font-size: 13px; color: var(--ps-text-secondary); line-height: 1.65; margin-bottom: 14px; }
.pds-stats { display: flex; gap: 14px; margin-bottom: 14px; flex-wrap: wrap; }
.pds-stat { display: flex; align-items: center; gap: 5px; font-family: var(--mono); font-size: 11px; color: var(--ps-text-muted); }
.pds-stat svg { width: 12px; height: 12px; fill: none; stroke: var(--ps-text-muted); stroke-width: 2; stroke-linecap: round; }
.pds-stat strong { color: var(--ps-text-secondary); font-weight: 600; }
.pds-install-btn { width: 100%; padding: 10px; border: none; border-radius: var(--ps-radius-sm); font-family: var(--display); font-size: 13.5px; font-weight: 600; cursor: pointer; transition: all .15s; display: flex; align-items: center; justify-content: center; gap: 8px; }
.pds-install-btn.install { background: var(--ps-azul); color: white; }
.pds-install-btn.install:hover { background: var(--ps-azul-dark); transform: translateY(-1px); }
.pds-install-btn.installed { background: var(--ps-verde-faint); color: var(--ps-verde-dark); border: 1.5px solid var(--ps-verde-light); }
.pds-install-btn.installed:hover { background: #FEE2E2; color: #991B1B; border-color: #FECACA; }
.pds-section { padding: 16px 20px; border-bottom: 1.5px solid var(--ps-border); }
.pds-section:last-child { border-bottom: none; }
.pds-section-title { font-size: 10.5px; font-weight: 600; text-transform: uppercase; letter-spacing: .08em; color: var(--ps-text-muted); margin-bottom: 12px; display: flex; align-items: center; gap: 8px; }
.pds-section-title::after { content: ''; flex: 1; height: 1px; background: var(--ps-border); }
.pds-persona { display: flex; align-items: flex-start; gap: 10px; padding: 10px 12px; background: var(--ps-off-white); border: 1.5px solid var(--ps-border); border-radius: var(--ps-radius-sm); margin-bottom: 7px; }
.pds-persona-icon { width: 30px; height: 30px; border-radius: 8px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; font-family: var(--mono); font-size: 10px; font-weight: 700; color: #fff; }
.pds-persona-name { font-size: 13px; font-weight: 600; color: var(--ps-text-primary); margin-bottom: 2px; }
.pds-persona-role { font-size: 10.5px; color: var(--ps-text-muted); text-transform: uppercase; letter-spacing: .04em; }
.pds-template { background: var(--ps-off-white); border: 1.5px solid var(--ps-border); border-radius: var(--ps-radius-sm); padding: 10px 12px; margin-bottom: 7px; display: flex; align-items: center; gap: 10px; }
.pds-template-with-personas { flex-direction: column; align-items: stretch; gap: 0; }
.pds-template-top { display: flex; align-items: center; gap: 10px; }
.pds-template-info { flex: 1; min-width: 0; }
.pds-template-name { font-size: 13px; font-weight: 600; color: var(--ps-text-primary); margin-bottom: 4px; }
.pds-template-blocks { font-family: var(--mono); font-size: 10.5px; color: var(--ps-text-muted); }
.pds-tpl-use-btn { flex-shrink: 0; padding: 5px 12px; border: 1.5px solid var(--ps-verde-light); border-radius: 999px; background: var(--ps-verde-faint); color: var(--ps-verde-dark); font-size: 11.5px; font-weight: 600; cursor: pointer; transition: all .15s; white-space: nowrap; }
.pds-tpl-use-btn:hover { background: var(--ps-verde); color: #fff; border-color: var(--ps-verde); }

/* Persona chips on template cards */
.pds-persona-chips { display: flex; flex-wrap: wrap; align-items: center; gap: 5px; margin-top: 9px; padding-top: 9px; border-top: 1px solid var(--ps-border); }
.pds-chips-label { font-size: 10.5px; font-weight: 600; color: var(--ps-text-muted); text-transform: uppercase; letter-spacing: .04em; white-space: nowrap; margin-right: 2px; }
.pds-persona-chip { display: inline-flex; align-items: center; gap: 5px; padding: 4px 10px 4px 7px; border: 1.5px solid var(--ps-azul-light); border-radius: 999px; background: var(--ps-azul-faint); color: var(--ps-azul-dark); font-size: 11.5px; font-weight: 600; cursor: pointer; transition: all .15s; }
.pds-persona-chip:hover { background: var(--ps-azul); color: #fff; border-color: var(--ps-azul); }
.pds-chip-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.pds-persona-chip:hover .pds-chip-dot { background: rgba(255,255,255,.6) !important; }

/* Info note */
.pds-combo-note { display: flex; gap: 9px; align-items: flex-start; background: var(--ps-azul-faint); border: 1.5px solid var(--ps-azul-light); border-radius: var(--ps-radius-sm); padding: 10px 12px; margin: 0 14px 14px; font-size: 12px; color: var(--ps-azul-dark); line-height: 1.55; }
.pds-combo-note svg { width: 14px; height: 14px; fill: none; stroke: var(--ps-azul); stroke-width: 2; stroke-linecap: round; flex-shrink: 0; margin-top: 1px; }
.pds-tag-chips { display: flex; flex-wrap: wrap; gap: 5px; }

@media (max-width: 700px) {
  .browse-tabs { padding: 8px 16px 0; }
  .sub-toolbar { padding: 10px 14px; flex-wrap: wrap; gap: 6px; }
  .search-box { flex: 1; min-width: 0; }
  .browse-filter-btn {
    display: flex; align-items: center; justify-content: center;
    width: 36px; height: 36px; border-radius: var(--ps-radius-sm);
    background: var(--ps-off-white); border: 1.5px solid var(--ps-border);
    cursor: pointer; color: var(--ps-text-muted); flex-shrink: 0; transition: all .15s;
  }
  .browse-filter-btn:hover, .browse-filter-btn.active { background: var(--ps-azul-faint); border-color: var(--ps-azul-light); color: var(--ps-azul-dark); }
  #cat-chips { display: none; width: 100%; flex-wrap: wrap; gap: 6px; order: 10; }
  #cat-chips.open { display: flex; }
  .result-count { display: none; }
  .sort-select { font-size: 11px; padding: 5px 10px; }
  .browse-body { padding: 14px; }
  .pack-grid { grid-template-columns: 1fr; }
}

/* Coming soon */
.coming-soon { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 14px; text-align: center; padding: 60px 40px; }
.coming-soon-icon { width: 56px; height: 56px; border-radius: 14px; background: var(--ps-azul-faint); border: 2px solid var(--ps-azul-light); display: flex; align-items: center; justify-content: center; margin-bottom: 4px; }
.coming-soon-icon svg { width: 26px; height: 26px; fill: none; stroke: var(--ps-azul); stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.coming-soon h2 { font-size: 20px; font-weight: 700; color: var(--ps-text-primary); letter-spacing: -.3px; }
.coming-soon h2 em { color: var(--ps-azul); font-style: normal; }
.coming-soon p { font-size: 13.5px; color: var(--ps-text-muted); line-height: 1.65; max-width: 320px; }
