/* PFS_SHOP_PRODUCT_TYPE_TAXONOMY_V1 */
/* PFS_SHOP_PRODUCT_TYPE_TAXONOMY_V1B_DEPTH3_DUPLICATE_LAYOUT_FIX */
/* PFS_SHOP_PRODUCT_TYPE_TAXONOMY_V1C_MOBILE_FULLWIDTH_PWA_BOHO_ICON */
.pfs-taxonomy-trigger-row {
  display: flex;
  gap: 8px;
  align-items: stretch;
}
.pfs-taxonomy-trigger-row input {
  flex: 1;
}
.pfs-taxonomy-btn {
  border: 1px solid var(--color-border, #eadfcc);
  background: var(--color-bg-secondary, #fbf7ee);
  color: var(--color-accent, #1D9E75);
  border-radius: 12px;
  padding: 8px 10px;
  font-weight: 800;
  font-size: 13px;
  white-space: nowrap;
  cursor: pointer;
}
.pfs-taxonomy-btn:active { transform: translateY(1px); }
.pfs-taxonomy-backdrop {
  position: fixed;
  inset: 0;
  z-index: 10000;
  background: rgba(17, 24, 39, .45);
  display: flex;
  justify-content: flex-end;
  align-items: stretch;
}
.pfs-taxonomy-shell {
  width: min(100vw, 720px);
  height: 100%;
  background: var(--color-bg-primary, #fffdf8);
  color: var(--color-text-primary, #1f2937);
  box-shadow: -16px 0 34px rgba(0,0,0,.24);
  display: flex;
  flex-direction: column;
  animation: pfsTaxSlideIn .18s ease-out;
}
@keyframes pfsTaxSlideIn { from { transform: translateX(26px); opacity: .75; } to { transform: translateX(0); opacity: 1; } }
.pfs-taxonomy-header {
  padding: 12px 14px;
  border-bottom: 1px solid var(--color-border, #eadfcc);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.pfs-taxonomy-title { font-weight: 900; font-size: 16px; line-height: 1.2; }
.pfs-taxonomy-subtitle { font-size: 12px; color: var(--color-text-muted, #8d98aa); margin-top: 2px; }
.pfs-taxonomy-close {
  border: 1px solid var(--color-border, #eadfcc);
  background: var(--color-bg-secondary, #fbf7ee);
  color: var(--color-text-primary, #1f2937);
  width: 34px;
  height: 34px;
  border-radius: 12px;
  font-size: 20px;
  line-height: 1;
}
.pfs-taxonomy-panels {
  flex: 1;
  overflow-x: auto;
  overflow-y: hidden;
  display: flex;
  scroll-snap-type: x mandatory;
  background: linear-gradient(90deg, rgba(0,0,0,.03), transparent 18px), var(--color-bg-primary, #fffdf8);
}
.pfs-taxonomy-panel {
  width: min(92vw, 240px);
  min-width: min(92vw, 240px);
  border-right: 1px solid var(--color-border, #eadfcc);
  display: flex;
  flex-direction: column;
  scroll-snap-align: end;
  background: var(--color-bg-primary, #fffdf8);
}
.pfs-taxonomy-panel-head {
  position: sticky;
  top: 0;
  z-index: 1;
  padding: 10px 10px 8px;
  background: var(--color-bg-primary, #fffdf8);
  border-bottom: 1px solid var(--color-border, #eadfcc);
}
.pfs-taxonomy-panel-title { font-size: 13px; font-weight: 900; }
.pfs-taxonomy-path { margin-top: 4px; font-size: 11px; color: var(--color-text-muted, #8d98aa); line-height: 1.3; }
.pfs-taxonomy-list { padding: 8px; overflow-y: auto; }
.pfs-taxonomy-row {
  border: 1px solid var(--color-border, #eadfcc);
  border-radius: 14px;
  background: var(--color-bg-secondary, #fbf7ee);
  margin-bottom: 8px;
  overflow: hidden;
}
.pfs-taxonomy-row-main {
  width: 100%;
  border: 0;
  background: transparent;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  padding: 10px 11px;
  color: var(--color-text-primary, #1f2937);
  font-weight: 800;
  text-align: left;
}
.pfs-taxonomy-row-main.is-selected {
  background: var(--color-success-bg, #ecfaf4);
  color: var(--color-income, #1D9E75);
}
.pfs-taxonomy-row-arrow { color: var(--color-text-muted, #8d98aa); font-weight: 900; }
.pfs-taxonomy-actions {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 4px;
  padding: 0 7px 7px;
}
.pfs-taxonomy-actions button,
.pfs-taxonomy-footer button {
  border: 1px solid var(--color-border, #eadfcc);
  background: var(--color-bg-primary, #fffdf8);
  color: var(--color-text-secondary, #5f6b7a);
  border-radius: 10px;
  padding: 6px 5px;
  font-size: 11px;
  font-weight: 800;
}
.pfs-taxonomy-actions button[data-act="choose"] { color: var(--color-income, #1D9E75); }
.pfs-taxonomy-actions button[data-act="edit"] { color: #b7791f; }
.pfs-taxonomy-actions button[data-act="copy"] { color: #2563eb; }
.pfs-taxonomy-actions button[data-act="delete"] { color: var(--color-expense, #d98778); }
.pfs-taxonomy-footer {
  padding: 9px 8px 12px;
  border-top: 1px solid var(--color-border, #eadfcc);
  background: var(--color-bg-primary, #fffdf8);
}
.pfs-taxonomy-footer button {
  width: 100%;
  color: var(--color-income, #1D9E75);
  background: var(--color-accent-light, #ecfaf4);
}
.pfs-taxonomy-empty {
  color: var(--color-text-muted, #8d98aa);
  padding: 18px 10px;
  font-size: 13px;
  line-height: 1.35;
}
.pfs-taxonomy-toast {
  position: fixed;
  left: 50%;
  bottom: 18px;
  z-index: 10002;
  transform: translateX(-50%);
  background: var(--color-bg-secondary, #fbf7ee);
  color: var(--color-text-primary, #1f2937);
  border: 1px solid var(--color-border, #eadfcc);
  border-radius: 14px;
  box-shadow: 0 10px 28px rgba(0,0,0,.18);
  padding: 10px 12px;
  font-size: 13px;
  font-weight: 700;
}
@media (max-width: 680px) {
  .pfs-taxonomy-backdrop {
    justify-content: flex-start;
    overflow: hidden;
  }
  .pfs-taxonomy-shell {
    width: 100vw;
    max-width: 100vw;
    overflow: hidden;
    box-shadow: none;
  }
  .pfs-taxonomy-panels {
    width: 100vw;
    max-width: 100vw;
    overflow: hidden;
    scroll-snap-type: none;
    overscroll-behavior-x: contain;
    touch-action: pan-y;
    background: var(--color-bg-primary, #fffdf8);
  }
  .pfs-taxonomy-panel {
    flex: 0 0 100vw;
    width: 100vw;
    min-width: 100vw;
    max-width: 100vw;
    border-right: 0;
    scroll-snap-align: start;
    transform: translateX(calc(var(--pfs-taxonomy-active-panel, 0) * -100vw));
    transition: transform .18s ease-out;
    box-sizing: border-box;
  }
  .pfs-taxonomy-panel-head,
  .pfs-taxonomy-list,
  .pfs-taxonomy-footer {
    box-sizing: border-box;
    width: 100%;
  }
}


/* PFS_SHOP_PRODUCT_TYPE_TAXONOMY_V1D_FORCE_FULLWIDTH_PANELS_CACHEBUST */
/* Force selector screens to be full viewport width. This is intentionally
   not media-gated: Android WebView/PWA viewport can report wider CSS px than
   the physical phone view, so the earlier max-width media rule was not enough. */
.pfs-taxonomy-backdrop {
  justify-content: flex-start !important;
  overflow: hidden !important;
}
.pfs-taxonomy-shell {
  width: 100vw !important;
  min-width: 100vw !important;
  max-width: 100vw !important;
  height: 100vh !important;
  overflow: hidden !important;
  box-shadow: none !important;
}
.pfs-taxonomy-panels {
  width: 100vw !important;
  min-width: 100vw !important;
  max-width: 100vw !important;
  overflow: hidden !important;
  scroll-snap-type: none !important;
  overscroll-behavior-x: contain !important;
  touch-action: pan-y !important;
  background: var(--color-bg-primary, #fffdf8) !important;
}
.pfs-taxonomy-panel {
  flex: 0 0 100vw !important;
  width: 100vw !important;
  min-width: 100vw !important;
  max-width: 100vw !important;
  border-right: 0 !important;
  scroll-snap-align: start !important;
  transform: translate3d(calc(var(--pfs-taxonomy-active-panel, 0) * -100vw), 0, 0) !important;
  transition: transform .18s ease-out !important;
  box-sizing: border-box !important;
}
.pfs-taxonomy-panel-head,
.pfs-taxonomy-list,
.pfs-taxonomy-footer {
  box-sizing: border-box !important;
  width: 100% !important;
}
