
  /* Toast: position at the bottom-center of the canvas area so it
     doesn't overlap the design cards in the left panel. Approximates
     the canvas column by accounting for the typical desktop side-panel
     widths; the bundle's toast div is position:fixed at viewport
     coords, so we offset from the left edge by half the design-panel
     width then center within the remaining canvas+right-panel space.
     Falls back to viewport-center via the second declaration if the
     CSS variables aren't set (older themes). Mobile override on
     line ~165 keeps its own `bottom:120px` rule. */
  .toast {
    left: 50vw !important;
    right: auto !important;
    transform: translateX(-50%) translateY(20px) !important;
  }
  .toast.show {
    transform: translateX(-50%) translateY(0) !important;
  }

  html, body { overflow-x: hidden !important; max-width: 100vw !important; }
  #elemRecolorPicker, #elemRecolorBtn { display: none !important; visibility: hidden !important; pointer-events: none !important; }

  /* Legacy SaaS dashboard overlay — RETIRED. The working subscriber
     dashboard lives in #adminPanel (with the full sidebar). Any stray
     code path that tried to reveal #saasDashboard would double up on
     the visible dashboards — force-hide here as a safety net. */
  #saasDashboard { display: none !important; visibility: hidden !important; pointer-events: none !important; }

  /* Hide every canvas-selection overlay while any full-screen app modal
     is open (customer orders panel, cart, Quick Order). Otherwise the
     white rotation handle, its degree badge, and the dashed stem (all
     position:fixed, z-index:9999+) leak through the modal background
     and sit on top of the content. JS tries to hide them on modal-open
     but any later canvas render re-shows them — CSS with :has() +
     !important is the only way to pin them down. */
  body:has(#customerPanel[style*="display: flex"]) #rotateHandleGlobal,
  body:has(#customerPanel[style*="display: flex"]) #rotateHandleStem,
  body:has(#customerPanel[style*="display: flex"]) #rotateDegreeBadge,
  body:has(#cartOverlay.open) #rotateHandleGlobal,
  body:has(#cartOverlay.open) #rotateHandleStem,
  body:has(#cartOverlay.open) #rotateDegreeBadge,
  body:has(#qoOverlay.open) #rotateHandleGlobal,
  body:has(#qoOverlay.open) #rotateHandleStem,
  body:has(#qoOverlay.open) #rotateDegreeBadge {
    display: none !important;
    visibility: hidden !important;
    pointer-events: none !important;
  }

  /* Font selector: dark themed dropdown */
  #dlTextFont option {
    padding: 8px 12px;
    font-size: 15px;
    line-height: 1.8;
    background: #222;
    color: #e0e0e0;
  }
  #dlTextFont option:hover,
  #dlTextFont option:focus {
    background: #333;
  }
  #dlTextFont option:checked {
    background: #383838;
    color: #e0e0e0;
  }
  #dlTextFont optgroup {
    font-size: 12px;
    font-weight: 800;
    color: var(--accent, #7c5cbf);
    padding-top: 10px;
    font-style: normal;
    background: #1a1a1a;
  }

  /* Remove left separator before Total Price in stats bar */
  .stats-bar > #footerPriceCredits::before,
  .stats-bar > #creditsBadgeWrap + span { display: none !important; }
  #footerPriceCredits { border-left: none !important; padding-left: 0 !important; }

  /* Desktop: hide mobile-only elements */
  .mob-status-strip { display: none; }
  .qo-mob-cta { display: none; }

  @media (min-width: 769px) {
    .mbb-design { display: none !important; }

    /* Prevent right panel scrollbar from shifting canvas layout */
    .right-panel {
      scrollbar-gutter: stable !important;
      overflow-y: auto !important;
    }

    /* Quick Order tab contents: stack toolbar above body on desktop */
    #qoTabContentDesigns, #qoTabContentPremade {
      flex-direction: column !important;
      flex: 1 !important;
      min-height: 0 !important;
    }
    /* Center empty state icons in full available area */
    #qoTabContentDesigns > .qo-body,
    #qoTabContentPremade > .qo-body {
      flex: 1 !important;
      display: flex !important;
      flex-direction: column !important;
    }
    #qoTabContentDesigns .qo-grid-area,
    #qoTabContentPremade .qo-grid-area {
      flex: 1 !important;
      display: flex !important;
      flex-direction: column !important;
    }
    #qoTabContentDesigns .qo-designs-grid,
    #qoTabContentPremade .qo-designs-grid {
      flex: 1 !important;
    }
    .qo-empty {
      flex: 1 !important;
      display: flex !important;
      align-items: center !important;
      justify-content: center !important;
    }
  }

  /* Admin sidebar: align labels with nav item text */
  .adm-nav-label { padding-left: 36px !important; }
  .adm-nav-item { padding-left: 12px !important; }
  .adm-nav-icon { display:inline-block; width:22px; text-align:left; margin-right:4px; flex-shrink:0; }

  /* Quick Order responsive: show compact mobile fields on small screens */
  .qo-mobile-fields { display: none; }
  @media (max-width: 768px) {
    .qo-mobile-fields {
      display: flex !important;
      gap: 6px;
      align-items: center;
      padding: 8px 10px 4px;
      border-top: 1px solid var(--border);
    }
    .qo-mobile-fields .qo-mf {
      flex: 1;
      display: flex;
      flex-direction: column;
      gap: 2px;
    }
    .qo-mobile-fields .qo-mf label {
      font-size: 8px;
      font-weight: 700;
      color: var(--text3);
      text-transform: uppercase;
      letter-spacing: 0.05em;
    }
    .qo-mobile-fields .qo-mf input {
      width: 100%;
      padding: 7px 4px;
      font-size: 13px;
      font-weight: 600;
      text-align: center;
      background: var(--bg2);
      border: 1px solid var(--border2);
      border-radius: 6px;
      color: var(--text);
      font-family: 'Inter', sans-serif;
      box-sizing: border-box;
    }
    .qo-mobile-fields .qo-remove {
      width: 32px;
      height: 32px;
      border-radius: 6px;
      border: 1px solid rgba(239,68,68,0.3);
      background: rgba(239,68,68,0.1);
      color: #ef4444;
      font-size: 14px;
      cursor: pointer;
      flex-shrink: 0;
      align-self: flex-end;
      margin-bottom: 2px;
    }
    .qo-card-mid,
    .qo-card-right { display: none !important; }

    /* Fix: Toast pushed above mobile bottom bar so it's always visible */
    .toast {
      bottom: 120px !important;
    }

    /* Fix: Hide cloud import icons on mobile — they clutter the small canvas */
    #canvasImportBar {
      display: none !important;
    }

    /* Fix: Size modal better fit on mobile — prevent overflow */
    .sm-box {
      max-width: calc(100vw - 24px) !important;
      max-height: calc(100vh - 40px) !important;
      overflow-y: auto !important;
      margin: 12px !important;
    }

    /* Fix: Cart overlay scrollable on small screens */
    .cart-box {
      max-height: calc(100vh - 24px) !important;
      max-width: calc(100vw - 16px) !important;
      margin: 8px !important;
    }
    .cart-body {
      max-height: calc(100vh - 160px) !important;
      overflow-y: auto !important;
      -webkit-overflow-scrolling: touch;
    }

    /* Fix: Sheet tab bar buttons — larger touch targets */
    .mob-sheet-add,
    .mob-sheet-manage {
      min-width: 40px !important;
      min-height: 40px !important;
      font-size: 18px !important;
    }

    /* Fix: Canvas undo/redo buttons — larger touch targets */
    .canvas-undo-redo .cur-btn {
      min-width: 36px !important;
      min-height: 36px !important;
    }

    /* Fix: Quick Edit header wraps properly on mobile */
    .qe-header {
      flex-wrap: wrap !important;
      gap: 6px !important;
      padding: 8px 12px !important;
    }
    .qe-header h3 {
      font-size: 13px !important;
      width: 100% !important;
    }
    .qe-header-btns {
      flex-wrap: wrap !important;
      gap: 4px !important;
      width: 100% !important;
    }
    .qe-header-btns .qe-btn {
      font-size: 9px !important;
      padding: 6px 8px !important;
    }
    /* Quick Edit panel — full screen on mobile */
    .qe-overlay {
      z-index: 400 !important;
    }
    .qe-panel {
      width: 100% !important;
      height: 100% !important;
      max-width: 100% !important;
      max-height: 100% !important;
      border-radius: 0 !important;
      display: flex !important;
      flex-direction: column !important;
    }
    .qe-info-bar {
      font-size: 10px !important;
      padding: 4px 12px !important;
      gap: 8px !important;
      flex-wrap: wrap !important;
    }
    .qe-body {
      flex: 1 !important;
      display: flex !important;
      flex-direction: column !important;
      overflow: hidden !important;
      min-height: 0 !important;
    }
    /* Tool strip — single row, no scroll on mobile */
    .qe-tool-strip {
      flex-direction: row !important;
      overflow: hidden !important;
      width: 100% !important;
      min-height: auto !important;
      height: auto !important;
      padding: 4px 4px !important;
      gap: 0 !important;
      flex-shrink: 0 !important;
      border-right: none !important;
      border-bottom: 1px solid var(--border2) !important;
      justify-content: space-evenly !important;
    }
    .qe-strip-btn {
      flex: 1 1 0% !important;
      width: auto !important;
      min-width: 0 !important;
      padding: 4px 1px !important;
      font-size: 6px !important;
      gap: 1px !important;
      letter-spacing: -0.03em !important;
      text-transform: none !important;
    }
    .qe-strip-btn svg {
      width: 15px !important;
      height: 15px !important;
    }
    .qe-strip-btn span {
      display: block !important;
      overflow: hidden !important;
      text-overflow: ellipsis !important;
      white-space: nowrap !important;
      text-transform: capitalize !important;
    }
    .qe-strip-sep {
      display: none !important;
    }
    /* Canvas area — takes remaining space */
    .qe-canvas-area {
      flex: 1 !important;
      min-height: 180px !important;
      max-height: 40vh !important;
      width: 100% !important;
    }
    /* Tool options panel — scrollable below canvas */
    .qe-tools {
      width: 100% !important;
      min-width: 0 !important;
      max-width: 100% !important;
      flex: 1 !important;
      overflow-y: auto !important;
      -webkit-overflow-scrolling: touch !important;
      border-left: none !important;
      border-top: 1px solid var(--border2) !important;
      min-height: 0 !important;
    }
    .qe-tool-panel {
      padding: 10px 14px !important;
    }
    .qe-action-btn {
      font-size: 10px !important;
      padding: 8px !important;
    }
    .qe-zoom-bar {
      bottom: 4px !important;
    }

    /* ═══════════════════════════════════════════════════════ */
    /* MOBILE UX OVERHAUL — Canva-quality experience         */
    /* ═══════════════════════════════════════════════════════ */

    /* ── Bottom Bar Redesign ── */
    /* ── Sheet switching arrows ── */
    .mob-topbar-cart,
    #mobTopCart {
      display: none !important;
    }
    #mobAdminOrder {
      display: none !important;
    }
    #mobAdminOrder.visible {
      display: flex !important;
      background: rgba(124,92,191,0.15) !important;
      border: 1px solid rgba(124,92,191,0.3) !important;
      border-radius: 8px !important;
      color: #b794f6 !important;
      padding: 5px 6px !important;
      -webkit-tap-highlight-color: transparent !important;
    }
    .mob-sheet-arrow {
      display: flex !important;
      align-items: center !important;
      justify-content: center !important;
      width: 24px !important;
      height: 24px !important;
      border-radius: 6px !important;
      border: none !important;
      background: rgba(255,255,255,0.06) !important;
      color: rgba(200,200,220,0.5) !important;
      cursor: pointer !important;
      flex-shrink: 0 !important;
      padding: 0 !important;
      -webkit-tap-highlight-color: transparent !important;
      transition: background 0.15s, color 0.15s !important;
      outline: none !important;
    }
    .mob-sheet-arrow:active {
      background: rgba(255,255,255,0.12) !important;
      color: #fff !important;
    }
    .mob-sheet-arrow:focus {
      outline: none !important;
    }
    .mob-topbar-sheet {
      display: flex !important;
      align-items: center !important;
      gap: 4px !important;
      -webkit-tap-highlight-color: transparent !important;
    }
    .mob-topbar-sheet-inner {
      cursor: pointer !important;
      -webkit-tap-highlight-color: transparent !important;
    }
    .mob-topbar-sheet,
    .mob-topbar-sheet * {
      -webkit-tap-highlight-color: transparent !important;
      outline: none !important;
    }

    /* ═══ ELEMENTS PANEL — Mobile Layout ═══ */
    /* DL Panel base */
    .dl-panel {
      padding: 0 !important;
    }
    .dl-search-wrap {
      margin: 6px 8px !important;
    }
    .dl-search {
      font-size: 13px !important;
      padding: 8px 10px 8px 30px !important;
    }
    /* Category buttons */
    .dl-cat-btn {
      padding: 10px 12px !important;
      min-height: 42px !important;
    }
    .dl-cat-label {
      font-size: 13px !important;
    }
    .dl-cat-icon {
      font-size: 16px !important;
      width: 32px !important;
      height: 32px !important;
    }
    /* Sub-panels */
    .dl-subpanel {
      padding: 8px !important;
    }
    .dl-sub-title {
      font-size: 14px !important;
      margin-bottom: 8px !important;
    }
    .dl-back-btn {
      font-size: 11px !important;
      padding: 6px 10px !important;
      margin-bottom: 6px !important;
    }
    /* AI Generator */
    .dl-ai-prompt {
      font-size: 13px !important;
      padding: 10px !important;
      min-height: 60px !important;
    }
    .dl-ai-pipeline {
      font-size: 9px !important;
      gap: 4px !important;
      flex-wrap: wrap !important;
    }
    .dl-ai-config {
      font-size: 10px !important;
    }
    .dl-ai-result-item {
      min-width: 0 !important;
    }
    /* Text sub-panel */
    .dl-text-input {
      font-size: 14px !important;
      padding: 10px !important;
    }
    .dl-text-opts {
      gap: 6px !important;
    }
    .dl-text-opt-row {
      gap: 4px !important;
      flex-wrap: wrap !important;
    }
    .dl-text-opt-label {
      font-size: 9px !important;
      min-width: 30px !important;
    }
    .dl-text-opt-row select {
      font-size: 12px !important;
      max-width: 100% !important;
    }
    .dl-text-opt-row input[type="number"] {
      font-size: 12px !important;
    }
    .dl-text-opt-row input[type="color"] {
      width: 28px !important;
      height: 24px !important;
    }
    /* Shapes grid */
    .dl-shape-grid {
      grid-template-columns: repeat(4, 1fr) !important;
      gap: 6px !important;
    }
    .dl-shape-grid button {
      padding: 8px !important;
    }
    .dl-shape-grid svg {
      width: 28px !important;
      height: 28px !important;
    }
    /* Icons/Graphics grid */
    .dl-grid {
      grid-template-columns: repeat(3, 1fr) !important;
      gap: 6px !important;
    }
    /* Gallery pack grid */
    #galleryPackGrid {
      grid-template-columns: repeat(3, 1fr) !important;
      gap: 6px !important;
    }
    /* Recent strip */
    .dl-recent-strip {
      gap: 6px !important;
    }
    /* Color swatches in shapes */
    #dlShapeSwatches {
      gap: 3px !important;
    }
    /* Names & Numbers Panel — full mobile rework */
    #jrsPanel {
      flex-direction: column !important;
    }
    #jrsPanel > div:first-child {
      /* Header */
      flex-wrap: wrap !important;
      padding: 8px 12px !important;
      gap: 6px !important;
    }
    #jrsPanel > div:first-child > div:last-child {
      width: 100% !important;
      display: flex !important;
      gap: 6px !important;
    }
    #jrsPanel > div:first-child > div:last-child button {
      flex: 1 !important;
      font-size: 11px !important;
      padding: 8px 10px !important;
    }
    /* Body: stack columns vertically */
    #jrsPanel > div:nth-child(2) {
      flex-direction: column !important;
    }
    /* Names list — full width */
    #jrsPanel > div:nth-child(2) > div:first-child {
      width: 100% !important;
      max-height: 180px !important;
      border-right: none !important;
      border-bottom: 1px solid #2a2a2e !important;
    }
    /* Preview canvas — compact */
    #jrsPanel > div:nth-child(2) > div:nth-child(2) {
      height: 200px !important;
      padding: 10px !important;
    }
    #jrsPreviewCanvas {
      max-height: 180px !important;
    }
    /* Controls — full width */
    #jrsPanel > div:nth-child(2) > div:last-child {
      width: 100% !important;
      border-left: none !important;
      border-top: 1px solid #2a2a2e !important;
      max-height: 250px !important;
      overflow-y: auto !important;
    }

    /* ═══ CART — Mobile Layout ═══ */
    .cart-overlay {
      align-items: flex-end !important;
      padding: 0 !important;
    }
    .cart-box {
      width: 100% !important;
      max-width: 100% !important;
      max-height: 95vh !important;
      border-radius: 16px 16px 0 0 !important;
      margin: 0 !important;
    }
    .cart-header {
      padding: 12px 14px !important;
    }
    .cart-header h2 {
      font-size: 16px !important;
    }
    .cart-body {
      padding: 10px 12px !important;
      max-height: 55vh !important;
      overflow-y: auto !important;
      -webkit-overflow-scrolling: touch !important;
    }
    .cart-footer {
      padding: 10px 12px !important;
    }
    .cart-item {
      padding: 8px !important;
      gap: 8px !important;
    }
    .cart-item-thumb {
      width: 50px !important;
      height: 50px !important;
      flex-shrink: 0 !important;
    }
    .cart-item-info {
      font-size: 11px !important;
      min-width: 0 !important;
    }
    .cart-place-btn {
      font-size: 13px !important;
      padding: 12px !important;
    }

    /* ═══ ADMIN PANEL — Mobile Layout ═══ */
    #adminPanel {
      flex-direction: column !important;
    }
    #adminPanel > div:first-child {
      /* Top bar */
      flex-wrap: wrap !important;
      padding: 8px 12px !important;
      gap: 6px !important;
    }
    #adminPanel > div:first-child > div:first-child {
      width: 100% !important;
      gap: 8px !important;
    }
    #adminPanel > div:first-child > div:last-child {
      width: 100% !important;
      justify-content: flex-end !important;
      gap: 6px !important;
    }
    #adminPanelTitle {
      font-size: 14px !important;
    }
    #adminRoleBadge {
      font-size: 8px !important;
    }
    #adminUserLabel {
      font-size: 10px !important;
    }
    /* Sidebar + Content wrapper */
    #adminPanel > div:nth-child(2) {
      flex-direction: column !important;
      overflow: hidden !important;
    }
    /* Sidebar — horizontal scrollable tabs on mobile */
    #adminSidebar {
      width: 100% !important;
      height: auto !important;
      flex-shrink: 0 !important;
      overflow-x: auto !important;
      overflow-y: hidden !important;
      -webkit-overflow-scrolling: touch !important;
      display: flex !important;
      flex-direction: row !important;
      flex-wrap: nowrap !important;
      padding: 0 4px !important;
      border-right: none !important;
      border-bottom: 1px solid var(--border) !important;
      gap: 0 !important;
      background: var(--panel) !important;
    }
    #adminSidebar .adm-nav-item {
      flex-shrink: 0 !important;
      white-space: nowrap !important;
      font-size: 10px !important;
      padding: 10px 10px !important;
      border-radius: 0 !important;
      border-bottom: 2px solid transparent !important;
      margin: 0 !important;
      background: none !important;
      cursor: pointer !important;
    }
    #adminSidebar .adm-nav-item.active,
    #adminSidebar .adm-nav-item[style*="accent"],
    #adminSidebar .adm-nav-item[style*="border-left"] {
      border-bottom-color: var(--accent) !important;
      border-left: none !important;
    }
    #adminSidebar .adm-nav-label,
    #adminSidebar .adm-nav-divider,
    #adminSidebar .adm-nav-section {
      display: none !important;
    }
    /* ═══ ADMIN CONTENT — Mobile Responsive ═══ */
    #adminContent {
      flex: 1 !important;
      overflow-y: auto !important;
      -webkit-overflow-scrolling: touch !important;
      padding: 12px 10px !important;
    }
    #adminContent h2 { font-size: 16px !important; }
    #adminContent h3 { font-size: 13px !important; }
    /* Inputs touch-friendly */
    #adminContent input[type="text"],
    #adminContent input[type="number"],
    #adminContent input[type="email"],
    #adminContent input[type="password"],
    #adminContent input[type="url"],
    #adminContent select,
    #adminContent textarea {
      font-size: 14px !important;
      max-width: 100% !important;
      box-sizing: border-box !important;
    }
    /* Stat cards grid — 2 columns on mobile */
    .adm-stat-grid {
      display: grid !important;
      grid-template-columns: 1fr 1fr !important;
      gap: 8px !important;
    }
    .adm-stat-card {
      padding: 10px !important;
      border-radius: 8px !important;
    }
    .asc-label { font-size: 9px !important; }
    .asc-value { font-size: 18px !important; }
    .asc-sub { font-size: 9px !important; }
    /* Tables — horizontal scroll, compact */
    .adm-table {
      font-size: 10px !important;
      display: block !important;
      overflow-x: auto !important;
      -webkit-overflow-scrolling: touch !important;
      white-space: nowrap !important;
      border-radius: 8px !important;
    }
    .adm-table th,
    .adm-table td {
      padding: 6px 6px !important;
      font-size: 10px !important;
    }
    .adm-table th {
      font-size: 9px !important;
      white-space: nowrap !important;
    }
    /* Buttons in admin content */
    .adm-btn {
      font-size: 11px !important;
      padding: 8px 12px !important;
    }
    /* Form sections */
    .adm-form-section {
      padding: 10px !important;
    }
    .adm-form-row {
      flex-direction: column !important;
      gap: 6px !important;
    }
    .adm-form-row label {
      font-size: 11px !important;
      min-width: auto !important;
    }
    .adm-form-row input,
    .adm-form-row select {
      width: 100% !important;
    }
    /* Flex containers — wrap on mobile */
    #adminContent > div[style*="display:flex"],
    #adminContent > div[style*="display: flex"] {
      flex-wrap: wrap !important;
    }
    /* Order detail views */
    .odv-card { padding: 10px !important; border-radius: 8px !important; }
    .odv-grid { 
      grid-template-columns: 1fr !important;
      gap: 8px !important;
    }
    .odv-ghost-btn {
      font-size: 10px !important;
      padding: 6px 10px !important;
    }
    /* Credits banner — stack on mobile */
    #adminContent div[style*="flex:1;min-width:160px"],
    #adminContent div[style*="flex:1; min-width:160px"] {
      min-width: 100% !important;
    }
    #adminContent div[style*="align-items:flex-end"] {
      align-items: stretch !important;
      width: 100% !important;
    }
    #adminContent div[style*="align-items:flex-end"] button {
      width: 100% !important;
    }
    /* Plan cards — stack vertically */
    #adminContent div[style*="grid-template-columns: repeat(5"],
    #adminContent div[style*="grid-template-columns:repeat(5"],
    #adminContent div[style*="grid-template-columns: repeat(4"],
    #adminContent div[style*="grid-template-columns:repeat(4"],
    #adminContent div[style*="grid-template-columns: repeat(3"],
    #adminContent div[style*="grid-template-columns:repeat(3"],
    #adminContent div[style*="grid-template-columns: repeat(7"],
    #adminContent div[style*="grid-template-columns:repeat(7"],
    #adminContent div[style*="grid-template-columns:1fr 1fr 1fr"],
    #adminContent div[style*="grid-template-columns: 1fr 1fr 1fr"],
    #adminContent div[style*="grid-template-columns:140px"],
    #saasDashContent div[style*="grid-template-columns:repeat(3"],
    #saasDashContent div[style*="grid-template-columns:repeat(4"],
    #saasDashContent div[style*="grid-template-columns:1fr 1fr 1fr"] {
      grid-template-columns: 1fr 1fr !important;
      gap: 6px !important;
    }
    /* Credit packs & all grids */
    #adminContent div[style*="display:grid"][style*="grid-template-columns"],
    #saasDashContent div[style*="display:grid"][style*="grid-template-columns"] {
      grid-template-columns: 1fr 1fr !important;
      gap: 6px !important;
    }
    /* Bento cards span fix — no multi-column spans on mobile */
    #adminContent div[style*="grid-column:span 2"],
    #adminContent div[style*="grid-column:span 3"],
    #adminContent div[style*="grid-column: span 2"],
    #adminContent div[style*="grid-column: span 3"] {
      grid-column: span 1 !important;
    }
    /* Max-width limits should be removed on mobile */
    #adminContent div[style*="max-width:600px"],
    #adminContent div[style*="max-width: 600px"],
    #adminContent div[style*="max-width:500px"],
    #adminContent div[style*="max-width:800px"] {
      max-width: 100% !important;
    }
    /* Fixed-width inline elements */
    #adminContent div[style*="width:160px"] button,
    #adminContent button[style*="width:160px"] {
      width: 100% !important;
    }
    #adminContent div[style*="min-width:160px"] {
      min-width: 100% !important;
    }
    /* Buttons row wrapping */
    #adminContent div[style*="display:flex;gap:8px"],
    #adminContent div[style*="display:flex; gap:8px"],
    #adminContent div[style*="display:flex;gap:10px"],
    #adminContent div[style*="display:flex;gap:6px"] {
      flex-wrap: wrap !important;
    }
    /* Platform selector buttons */
    #adminContent div[style*="display:flex;gap:10px"] > button[style*="flex:1"] {
      flex: 1 1 80px !important;
      padding: 10px 8px !important;
      font-size: 11px !important;
    }
    /* Comparison table responsive */
    #adminContent table[style*="table-layout:fixed"] {
      table-layout: auto !important;
      min-width: 500px !important;
    }
    /* Order tabs — scrollable */
    #adminContent div[style*="display:flex;border-bottom"] {
      overflow-x: auto !important;
      -webkit-overflow-scrolling: touch !important;
      flex-wrap: nowrap !important;
    }
    #adminContent div[style*="display:flex;border-bottom"] button {
      flex-shrink: 0 !important;
      padding: 8px 8px !important;
      font-size: 9px !important;
    }
    /* Header rows — stack title and controls */
    #adminContent > div[style*="justify-content:space-between"] {
      flex-direction: column !important;
      gap: 6px !important;
      align-items: flex-start !important;
    }
    #adminContent > div[style*="justify-content:space-between"] > div {
      width: 100% !important;
      flex-wrap: wrap !important;
      gap: 4px !important;
    }
    /* Search input wider */
    #adminContent input[id*="Search"],
    #adminContent input[id*="search"],
    #adminContent #ordSearchInput {
      width: 100% !important;
      max-width: none !important;
    }
    /* Pagination compact */
    #adminContent div[style*="justify-content:center"] button {
      padding: 5px 8px !important;
      font-size: 9px !important;
    }
    /* Feature pills */
    #adminContent div[style*="gap:4px;padding:4px 10px"] {
      padding: 3px 5px !important;
      font-size: 8px !important;
    }
    /* Tier bars compact */
    #adminContent div[style*="display:flex;align-items:center;gap:8px;opacity"] span:first-child {
      font-size: 7px !important;
      width: 22px !important;
    }
    #adminContent div[style*="display:flex;align-items:center;gap:8px;opacity"] span:last-child {
      font-size: 9px !important;
      width: 55px !important;
    }
    /* Store setup sections */
    #adminContent .sss-row,
    #adminContent div[style*="display:flex;gap:12px;align-items:center"] {
      flex-direction: column !important;
      align-items: stretch !important;
      gap: 6px !important;
    }
    #adminContent .sss-row input,
    #adminContent .sss-row select {
      width: 100% !important;
    }
    /* Code blocks */
    #adminContent pre,
    #adminContent code {
      font-size: 9px !important;
      overflow-x: auto !important;
      word-break: break-all !important;
      white-space: pre-wrap !important;
      max-width: 100% !important;
    }
    /* Section headings & descriptions */
    #adminContent h3 { margin-bottom: 6px !important; }
    #adminContent p[style*="font-size:11px"],
    #adminContent p[style*="font-size:12px"],
    #adminContent p[style*="font-size:10px"] {
      font-size: 10px !important;
    }
    /* Form sections compact */
    .adm-form-section {
      padding: 12px 10px !important;
      border-radius: 8px !important;
    }
    /* Inline flex row inputs stack on mobile */
    .adm-form-row {
      flex-direction: column !important;
      gap: 8px !important;
    }
    .adm-form-row > div[style*="flex:1"],
    .adm-form-row > div[style*="flex:2"] {
      width: 100% !important;
      flex: none !important;
    }
    .adm-form-row input,
    .adm-form-row select {
      width: 100% !important;
    }
    /* Banner cards compact */
    #adminContent div[style*="padding:16px;margin-bottom:16px;display:flex"] {
      flex-direction: column !important;
      gap: 10px !important;
      padding: 12px !important;
    }
    #adminContent div[style*="padding:16px;margin-bottom:16px;display:flex"] > div[style*="flex:1"] {
      width: 100% !important;
    }
    #adminContent div[style*="padding:16px;margin-bottom:16px;display:flex"] > div[style*="flex-direction:column"] {
      flex-direction: row !important;
      gap: 6px !important;
      width: 100% !important;
    }
    #adminContent div[style*="padding:16px;margin-bottom:16px;display:flex"] > div[style*="flex-direction:column"] button {
      flex: 1 !important;
      width: auto !important;
    }
    /* Bento card padding */
    #adminContent div[style*="padding:16px 18px;position:relative"] {
      padding: 12px !important;
    }
    #adminContent div[style*="width:28px;height:28px"] {
      width: 22px !important;
      height: 22px !important;
      font-size: 11px !important;
    }
    /* Product cards */
    #adminContent .adm-product-card {
      flex-direction: column !important;
    }
    #adminContent .adm-product-thumb {
      width: 100% !important;
      height: 120px !important;
    }
    /* Order detail view */
    .order-detail-back {
      font-size: 12px !important;
    }
    .odv-stepper {
      overflow-x: auto !important;
      -webkit-overflow-scrolling: touch !important;
      padding-bottom: 4px !important;
    }
    .odv-stepper > div {
      min-width: max-content !important;
    }
    /* Order detail cards grid */
    #adminContent div[style*="display:grid"][style*="1fr 1fr 1fr"] {
      grid-template-columns: 1fr !important;
    }
    #adminContent div[style*="grid-template-columns:1fr 1fr 1fr"] {
      grid-template-columns: 1fr !important;
    }
    /* Order header */
    #adminContent h2[style*="font-size:22px"] {
      font-size: 17px !important;
    }
    #adminContent span[style*="font-size:22px"] {
      font-size: 17px !important;
    }
    /* Sheet thumbnails in order detail */
    #adminContent div[style*="width:200px"][style*="height:200px"],
    #adminContent div[style*="width:180px"] {
      width: 100% !important;
      max-width: 200px !important;
      height: auto !important;
      aspect-ratio: 1 !important;
    }
    #adminContent div[style*="display:flex;gap:16px;flex-wrap"] {
      gap: 10px !important;
    }
    /* Action buttons row in order detail */
    #adminContent div[style*="display:flex;gap:6px;flex-wrap:wrap;margin-top"] {
      gap: 4px !important;
    }
    #adminContent div[style*="display:flex;gap:6px;flex-wrap:wrap;margin-top"] button {
      font-size: 9px !important;
      padding: 5px 8px !important;
    }
    /* Usage log table */
    #adminContent div[style*="max-height:300px"] {
      max-height: 200px !important;
    }
    /* Credit log entries */
    #adminContent div[style*="font-size:11px"][style*="border-bottom:1px solid"] {
      font-size: 10px !important;
      padding: 6px 0 !important;
    }
    /* ═══ SAAS DASHBOARD — Mobile ═══ */
    #saasDashboard {
      overflow-y: auto !important;
      -webkit-overflow-scrolling: touch !important;
    }
    #saasDashContent {
      padding: 14px 12px !important;
      max-width: 100% !important;
    }
    #saasDashContent h2 { font-size: 16px !important; }
    #saasDashContent h3 { font-size: 13px !important; }
    #saasDashContent input,
    #saasDashContent select {
      font-size: 14px !important;
      max-width: 100% !important;
      box-sizing: border-box !important;
    }
    #saasDashContent table {
      display: block !important;
      overflow-x: auto !important;
      -webkit-overflow-scrolling: touch !important;
      white-space: nowrap !important;
      font-size: 10px !important;
    }
    #saasDashContent div[style*="display:flex"] {
      flex-wrap: wrap !important;
    }
    #saasDashContent div[style*="display:grid"] {
      grid-template-columns: 1fr 1fr !important;
    }
    /* Admin login modal — mobile */
    #adminLoginOverlay > div {
      width: 92% !important;
      max-width: 380px !important;
      padding: 20px 16px !important;
      max-height: 90vh !important;
      overflow-y: auto !important;
      box-sizing: border-box !important;
    }
    #adminLoginOverlay h2 {
      font-size: 16px !important;
    }
    #adminLoginOverlay input {
      font-size: 14px !important;
    }
    /* Save & Apply button */
    #admTopbarSaveApply {
      font-size: 10px !important;
      padding: 5px 12px !important;
    }
    /* Log out button */
    #adminPanel button[onclick="adminLogout()"] {
      font-size: 9px !important;
      padding: 4px 8px !important;
    }
    /* Close button */
    #adminPanel button[onclick="closeAdminPanel()"] {
      font-size: 18px !important;
    }

    /* ═══ BOTTOM BAR — COMPLETE REBUILD ═══ */
    .mob-bottom-bar {
      padding-bottom: env(safe-area-inset-bottom, 0px) !important;
      height: auto !important;
      min-height: auto !important;
      border-top: none !important;
      background: #0c0c14 !important;
      display: block !important;
      position: fixed !important;
      bottom: 0 !important;
      left: 0 !important;
      right: 0 !important;
      z-index: 90 !important;
    }
    .mob-bottom-bar::before {
      content: '';
      position: absolute;
      top: 0;
      left: 0;
      right: 0;
      height: 1px;
      background: linear-gradient(90deg, transparent, var(--accent), rgba(124,92,191,0.6), var(--accent), transparent);
    }
    .mob-bottom-bar .mbb-mode.mbb-default {
      display: flex !important;
      width: 100% !important;
      justify-content: space-evenly !important;
      align-items: stretch !important;
      padding: 0 !important;
      gap: 0 !important;
      margin: 0 !important;
    }
    .mob-bottom-bar .mbb-default > button {
      display: flex !important;
      flex-direction: column !important;
      align-items: center !important;
      justify-content: center !important;
      gap: 5px !important;
      flex: 1 1 0% !important;
      width: 20% !important;
      min-width: 0 !important;
      padding: 10px 4px 10px !important;
      margin: 0 !important;
      background: none !important;
      border: none !important;
      border-right: 1px solid rgba(255,255,255,0.04) !important;
      color: rgba(200,200,220,0.6) !important;
      font-size: 10px !important;
      font-weight: 600 !important;
      font-family: 'Inter', sans-serif !important;
      cursor: pointer !important;
      letter-spacing: 0.01em !important;
      -webkit-tap-highlight-color: transparent !important;
      position: relative !important;
      text-transform: none !important;
      line-height: 1 !important;
      box-sizing: border-box !important;
    }
    .mob-bottom-bar .mbb-default > button:last-child {
      border-right: none !important;
    }
    .mob-bottom-bar .mbb-default > button:active {
      color: #fff !important;
      background: rgba(255,255,255,0.04) !important;
    }
    .mob-bottom-bar .mbb-default > button.active {
      color: var(--accent) !important;
    }
    .mob-bottom-bar .mbb-default > button.active::after {
      content: '' !important;
      position: absolute !important;
      top: 3px !important;
      left: 50% !important;
      transform: translateX(-50%) !important;
      width: 4px !important;
      height: 4px !important;
      border-radius: 50% !important;
      background: var(--accent) !important;
    }
    .mob-bottom-bar .mbb-default > button > .mbb-svg {
      opacity: 0.6 !important;
      transition: opacity 0.15s !important;
      display: block !important;
    }
    .mob-bottom-bar .mbb-default > button.active > .mbb-svg {
      opacity: 1 !important;
    }
    .mob-bottom-bar .mbb-default > button > span {
      display: block !important;
      font-size: 10px !important;
      line-height: 1 !important;
      white-space: nowrap !important;
      text-transform: none !important;
    }
    /* ── Design Action Bar (logo selected) ── */
    .mob-bottom-bar .mbb-design {
      display: none;
      flex-direction: column !important;
      width: 100% !important;
      padding: 0 !important;
    }
    .mob-bottom-bar .mbb-design-actions {
      display: flex !important;
      width: 100% !important;
    }
    .mob-bottom-bar .mbb-design-actions > button {
      display: flex !important;
      flex-direction: column !important;
      align-items: center !important;
      justify-content: center !important;
      gap: 5px !important;
      flex: 1 1 0% !important;
      width: 20% !important;
      padding: 10px 4px !important;
      margin: 0 !important;
      background: none !important;
      border: none !important;
      border-right: 1px solid rgba(255,255,255,0.04) !important;
      color: rgba(200,200,220,0.6) !important;
      font-size: 10px !important;
      font-weight: 600 !important;
      font-family: 'Inter', sans-serif !important;
      cursor: pointer !important;
      -webkit-tap-highlight-color: transparent !important;
      box-sizing: border-box !important;
      line-height: 1 !important;
    }
    .mob-bottom-bar .mbb-design-actions > button:last-child {
      border-right: none !important;
    }
    .mob-bottom-bar .mbb-design-actions > button:active {
      color: #fff !important;
      background: rgba(255,255,255,0.04) !important;
    }
    .mob-bottom-bar .mbb-design-actions > button > .mbb-svg {
      opacity: 0.6 !important;
    }
    .mob-bottom-bar .mbb-design-actions > button > span {
      display: block !important;
      font-size: 10px !important;
      line-height: 1 !important;
      white-space: nowrap !important;
      text-transform: none !important;
    }
    .mob-bottom-bar .mbb-design-actions > button.mbb-delete-btn {
      color: rgba(239,68,68,0.6) !important;
    }
    .mob-bottom-bar .mbb-design-actions > button.mbb-delete-btn:active {
      color: #ef4444 !important;
      background: rgba(239,68,68,0.08) !important;
    }

    /* Hide old emoji icons */
    .mbb-icon { display: none !important; }

    /* ── Design Action Bar ── */
    .mbb-d-row {
      display: flex;
      align-items: center;
      justify-content: center;
      width: 100%;
      padding: 10px 10px;
      gap: 5px;
    }
    .mbb-d-btn {
      width: 32px;
      height: 32px;
      border-radius: 7px;
      border: 1px solid var(--border2);
      background: var(--panel2);
      color: var(--text2);
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      -webkit-tap-highlight-color: transparent;
      transition: transform 0.1s;
      flex-shrink: 0;
      padding: 0;
    }
    .mbb-d-btn:active { transform: scale(0.9); }
    .mbb-d-minus {
      border-color: rgba(255,255,255,0.12) !important;
      color: #fff !important;
      opacity: 1;
    }
    .mbb-d-add {
      background: rgba(124,92,191,0.15) !important;
      border-color: rgba(124,92,191,0.4) !important;
      color: #7c5cbf !important;
    }
    .mbb-d-del {
      background: rgba(239,68,68,0.08) !important;
      border-color: rgba(239,68,68,0.25) !important;
      color: #ef4444 !important;
    }
    .mbb-d-count {
      font-size: 14px;
      font-weight: 800;
      color: var(--text);
      font-family: 'Inter', sans-serif;
      min-width: 16px;
      text-align: center;
      flex-shrink: 0;
      -webkit-user-select: none;
      user-select: none;
    }
    .mbb-d-sep {
      width: 1px;
      height: 20px;
      background: var(--border2);
      flex-shrink: 0;
    }
    .mbb-d-lbl {
      font-size: 8px;
      font-weight: 700;
      color: var(--text3);
      flex-shrink: 0;
      font-family: 'Inter', sans-serif;
      text-transform: uppercase;
      letter-spacing: 0.04em;
      -webkit-user-select: none;
      user-select: none;
      pointer-events: none;
    }
    .mbb-d-input {
      width: 42px;
      flex-shrink: 0;
      padding: 6px 2px;
      font-size: 12px;
      font-weight: 700;
      text-align: center;
      background: var(--bg2);
      border: 1px solid var(--border2);
      border-radius: 6px;
      color: var(--text);
      font-family: 'Inter', sans-serif;
      box-sizing: border-box;
      -webkit-appearance: none;
    }
    .mbb-d-input:focus {
      border-color: var(--accent);
      outline: none;
    }

    /* ── Status Strip ── */
    .mob-status-strip {
      position: fixed;
      bottom: calc(52px + env(safe-area-inset-bottom, 0px));
      left: 0; right: 0;
      z-index: 89;
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 7px 14px 17px;
      background: #0f0f18;
      border-top: 1px solid rgba(255,255,255,0.06);
      border-bottom: 1px solid rgba(255,255,255,0.04);
      gap: 10px;
      min-height: 46px;
      box-sizing: border-box;
    }
    .mss-left {
      display: flex;
      align-items: center;
      gap: 8px;
      flex: 1;
      min-width: 0;
    }
    .mss-efficiency {
      position: relative;
      width: 28px;
      height: 28px;
      flex-shrink: 0;
    }
    .mss-ring {
      display: block;
    }
    .mss-ring-fill {
      transition: stroke-dasharray 0.6s ease, stroke 0.3s;
    }
    .mss-pct {
      position: absolute;
      inset: 0;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 7px;
      font-weight: 800;
      color: var(--text2);
      font-family: 'Inter', sans-serif;
      line-height: 1;
      text-align: center;
      padding: 0;
      margin: 0;
    }
    .mss-info {
      display: flex;
      flex-direction: column;
      justify-content: center;
      gap: 1px;
      min-width: 0;
    }
    .mss-artworks {
      font-size: 12px;
      font-weight: 700;
      color: var(--text);
      font-family: 'Inter', sans-serif;
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
      line-height: 1.2;
    }
    .mss-sheets {
      font-size: 9px;
      font-weight: 500;
      color: var(--text3);
      font-family: 'Inter', sans-serif;
      line-height: 1.2;
    }
    .mss-right {
      display: flex;
      align-items: center;
      gap: 8px;
      flex-shrink: 0;
    }
    .mss-info-btn {
      display: flex;
      align-items: center;
      justify-content: center;
      width: 30px;
      height: 30px;
      border-radius: 7px;
      border: 1px solid rgba(255,255,255,0.08);
      background: rgba(255,255,255,0.04);
      color: rgba(200,200,220,0.5);
      cursor: pointer;
      padding: 0;
      flex-shrink: 0;
      -webkit-tap-highlight-color: transparent;
      transition: background 0.15s, color 0.15s;
    }
    .mss-info-btn:active {
      background: rgba(255,255,255,0.1);
      color: #fff;
    }
    .mss-price {
      font-size: 13px;
      font-weight: 800;
      color: var(--text);
      font-family: 'Inter', sans-serif;
      font-variant-numeric: tabular-nums;
      letter-spacing: -0.02em;
      line-height: 1;
      display: flex;
      align-items: center;
    }
    .mss-cart-btn {
      display: flex !important;
      align-items: center !important;
      justify-content: center !important;
      width: 34px !important;
      height: 34px !important;
      padding: 0 !important;
      border-radius: 8px !important;
      border: none !important;
      background: linear-gradient(135deg, #7c5cbf, #6d4bb5) !important;
      color: #fff !important;
      font-family: 'Inter', sans-serif !important;
      cursor: pointer !important;
      -webkit-tap-highlight-color: transparent !important;
      white-space: nowrap !important;
      flex-shrink: 0 !important;
    }
    .mss-cart-btn:active {
      transform: scale(0.95);
    }
    .mss-cart-btn svg {
      flex-shrink: 0;
    }

    /* ── Sheet Bar Visual Thumbnails ── */
    .mob-sheet-tab {
      position: relative;
      min-width: 56px !important;
      padding: 4px 6px 4px !important;
      flex-direction: column !important;
      gap: 2px !important;
      border-radius: 8px !important;
    }
    .mob-sheet-tab .mst-thumb {
      width: 40px;
      height: 48px;
      border-radius: 4px;
      border: 1px solid var(--border2);
      background: var(--bg2);
      overflow: hidden;
      display: flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
    }
    .mob-sheet-tab .mst-thumb canvas {
      width: 100%;
      height: 100%;
      object-fit: contain;
    }
    .mob-sheet-tab.active .mst-thumb {
      border-color: var(--accent);
      box-shadow: 0 0 0 1px var(--accent);
    }
    .mob-sheet-tab .mst-name {
      font-size: 8px !important;
      max-width: 52px;
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap;
    }
    .mob-sheet-tab .mst-count {
      position: absolute;
      top: 2px;
      right: 2px;
      min-width: 14px;
      height: 14px;
      border-radius: 7px;
      background: var(--accent);
      color: #000;
      font-size: 8px;
      font-weight: 800;
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 0 3px;
    }

    /* ── Adjust canvas area for new bottom layout ── */
    /* Status strip (38px) + bottom bar (56px) + safe area */
    .canvas-area {
      padding-bottom: calc(94px + env(safe-area-inset-bottom, 0px)) !important;
    }

    /* ── Hide stats bar on mobile (replaced by status strip) ── */
    .stats-bar {
      display: none !important;
    }

    /* ── Hide status strip when panels/modals are open ── */
    body.mob-panel-fullscreen .mob-status-strip {
      display: none !important;
    }

    /* ── Hide desktop undo/redo on mobile — merged into unified toolbar ── */
    .canvas-undo-redo {
      display: none !important;
    }

    /* ── Unified Canvas Toolbar ── */
    .mob-canvas-ctrl {
      position: fixed !important;
      right: 4px !important;
      top: 50% !important;
      bottom: auto !important;
      transform: translateY(-60%) !important;
      z-index: 80 !important;
      display: flex !important;
      flex-direction: column !important;
      align-items: center !important;
      gap: 2px !important;
      padding: 5px 3px !important;
      border-radius: 12px !important;
      background: rgba(12,12,20,0.7) !important;
      border: 1px solid rgba(255,255,255,0.06) !important;
      backdrop-filter: blur(8px) !important;
      -webkit-backdrop-filter: blur(8px) !important;
      max-height: none !important;
      overflow: visible !important;
    }
    .mob-canvas-ctrl .mcc-btn {
      width: 30px !important;
      height: 30px !important;
      border-radius: 7px !important;
      background: transparent !important;
      border: none !important;
      color: rgba(200,200,220,0.6) !important;
      display: flex !important;
      align-items: center !important;
      justify-content: center !important;
      padding: 0 !important;
      cursor: pointer;
      -webkit-tap-highlight-color: transparent;
      transition: color 0.15s, transform 0.1s;
    }
    .mob-canvas-ctrl .mcc-btn:active {
      transform: scale(0.9);
      color: #fff !important;
    }
    .mob-canvas-ctrl .mcc-btn.active {
      color: #7c5cbf !important;
    }
    .mob-canvas-ctrl .mcc-btn:disabled {
      opacity: 0.2 !important;
      cursor: default;
    }
    .mob-canvas-ctrl .mcc-sep {
      width: 18px !important;
      height: 1px !important;
      margin: 0 !important;
      background: rgba(255,255,255,0.06) !important;
    }
    .mob-canvas-ctrl .mcc-zoom-label {
      font-size: 7px !important;
      color: rgba(200,200,220,0.35) !important;
      text-align: center;
      padding: 0 !important;
      line-height: 1;
      font-weight: 700;
      font-family: 'Inter', sans-serif;
      letter-spacing: 0.03em;
    }
    /* Remove old colored add/remove styling */
    .mob-canvas-ctrl .mcc-add,
    .mob-canvas-ctrl .mcc-remove {
      background: transparent !important;
      border: none !important;
      color: rgba(200,200,220,0.6) !important;
    }
    .mob-canvas-ctrl .mcc-trash {
      color: rgba(239,68,68,0.5) !important;
    }
    .mob-canvas-ctrl .mcc-trash:active {
      color: #ef4444 !important;
    }

    /* ── FAB Long-Press Menu ── */
    .mob-fab-option {
      display: flex;
      align-items: center;
      gap: 8px;
      padding: 10px 16px;
      border-radius: 10px;
      border: 1px solid var(--border);
      background: var(--panel);
      color: var(--text);
      font-size: 12px;
      font-weight: 600;
      font-family: 'Inter', sans-serif;
      cursor: pointer;
      white-space: nowrap;
      box-shadow: 0 2px 12px rgba(0,0,0,0.3);
      -webkit-tap-highlight-color: transparent;
      transition: transform 0.1s;
    }
    .mob-fab-option:active {
      transform: scale(0.95);
    }
    .mob-fab-option svg {
      flex-shrink: 0;
      opacity: 0.7;
    }

    /* ── Nest Prompt Animation ── */
    @keyframes mobNestIn {
      from { opacity: 0; transform: translateY(12px); }
      to { opacity: 1; transform: translateY(0); }
    }

    /* ── Hide Quick Order + Auto-Fill on mobile (moved to More menu) ── */
    #quickOrderBtn,
    .nest-all-btn {
      display: none !important;
    }
    /* Hide the flex container too */
    #tab-designs > div:first-child {
      display: none !important;
    }

    /* ═══ QUICK ORDER MOBILE REDESIGN ═══ */
    .qo-panel {
      width: 100% !important; max-width: 100% !important;
      height: 100% !important; max-height: 100% !important;
      border-radius: 0 !important;
      display: flex !important; flex-direction: column !important;
    }
    .qo-header { padding: 10px 14px !important; min-height: auto !important; }
    .qo-header h2 { font-size: 15px !important; }
    .qo-header h2 span { display: none !important; }
    #qoGenerateBtn { display: none !important; }
    #qoUploadTrigger { display: none !important; }
    #qoTabs { padding: 0 !important; }
    #qoTabs button { flex: 1 !important; text-align: center !important; padding: 11px 0 !important; font-size: 12px !important; }
    .qo-toolbar {
      padding: 6px 12px !important; gap: 6px !important;
      flex-wrap: wrap !important; min-height: auto !important;
      border-bottom: 1px solid var(--border) !important;
    }
    .qo-toolbar label { font-size: 9px !important; }
    .qo-toolbar input[type="number"] { width: 44px !important; padding: 3px 4px !important; font-size: 10px !important; }
    .qo-toolbar select { padding: 3px 4px !important; font-size: 10px !important; }
    .qo-stat { font-size: 9px !important; }
    .qo-body {
      flex: 1 !important; overflow-y: auto !important;
      -webkit-overflow-scrolling: touch !important;
      padding-bottom: 10px !important;
    }
    /* Tab content must be flex to allow body to scroll above sticky CTA */
    #qoTabContentDesigns {
      flex: 1;
      flex-direction: column;
      min-height: 0;
      overflow: hidden;
    }
    #qoTabContentDesigns[style*="display: none"],
    #qoTabContentDesigns[style*="display:none"] {
      display: none !important;
    }
    #qoTabContentPremade {
      flex: 1;
      flex-direction: column;
      min-height: 0;
      overflow: hidden;
    }
    /* Hide spacing/nesting toolbar inside premade tab on mobile */
    #qoTabContentPremade > .qo-toolbar:first-child {
      padding: 4px 12px !important;
      min-height: auto !important;
    }
    /* Hide toast notifications on mobile */
    #toast {
      display: none !important;
    }
    .qo-empty { padding: 24px 16px !important; min-height: auto !important; }
    .qo-empty-icon { font-size: 28px !important; margin-bottom: 6px !important; }
    .qo-empty p { font-size: 11px !important; margin: 0 !important; }
    .qo-design-card {
      padding: 0 !important; margin: 0 10px 6px !important;
      border-radius: 10px !important; overflow: hidden !important;
    }
    /* Hide desktop card sections on mobile */
    .qo-design-name { display: none !important; }
    .qo-card-body { display: none !important; }
    .qo-card-mid, .qo-card-right { display: none !important; }

    /* ── New compact mobile card ── */
    .qo-mobile-fields {
      display: block !important;
      padding: 0 !important; border-top: none !important;
    }
    .qo-mob-card-top {
      display: flex !important;
      align-items: flex-start !important;
      gap: 8px !important;
      padding: 8px !important;
    }
    .qo-mob-thumb {
      width: 48px !important; height: 48px !important;
      flex-shrink: 0 !important; border-radius: 6px !important;
      overflow: hidden !important; background: var(--bg2) !important;
    }
    .qo-mob-thumb img {
      width: 48px !important; height: 48px !important;
      object-fit: contain !important;
    }
    .qo-mob-card-info {
      flex: 1 !important; min-width: 0 !important;
      display: flex !important; flex-direction: column !important;
      gap: 6px !important;
    }
    .qo-mob-card-name {
      font-size: 11px !important; font-weight: 600 !important;
      color: var(--text) !important; font-family: 'Inter', sans-serif !important;
      white-space: nowrap !important; overflow: hidden !important;
      text-overflow: ellipsis !important; line-height: 1.2 !important;
      padding-right: 4px !important;
    }
    .qo-mob-card-inputs {
      display: flex !important; gap: 4px !important;
    }
    .qo-mob-card-inputs .qo-mf {
      flex: 1 !important;
    }
    .qo-mob-card-inputs .qo-mf label {
      font-size: 7px !important; font-weight: 700 !important;
      color: var(--text3) !important; text-transform: uppercase !important;
      display: block !important; margin-bottom: 2px !important;
      letter-spacing: 0.05em !important;
    }
    .qo-mob-card-inputs .qo-mf input {
      width: 100% !important; padding: 5px 2px !important;
      font-size: 11px !important; font-weight: 700 !important;
      text-align: center !important; background: var(--bg2) !important;
      border: 1px solid var(--border2) !important;
      border-radius: 5px !important; color: var(--text) !important;
      -webkit-appearance: none !important; box-sizing: border-box !important;
    }
    .qo-mob-card-inputs .qo-mf input:focus {
      border-color: var(--accent) !important; outline: none !important;
    }
    .qo-mob-del {
      width: 24px !important; height: 24px !important;
      border-radius: 5px !important; flex-shrink: 0 !important;
      border: 1px solid rgba(239,68,68,0.2) !important;
      background: rgba(239,68,68,0.06) !important;
      color: #ef4444 !important; font-size: 12px !important;
      display: flex !important; align-items: center !important;
      justify-content: center !important; cursor: pointer !important;
      -webkit-tap-highlight-color: transparent !important;
      padding: 0 !important; margin-top: 0 !important;
    }
    /* Hide old mobile remove button */
    .qo-mobile-fields > .qo-remove { display: none !important; }
    .qo-mob-cta {
      display: flex !important; flex-direction: column !important;
      gap: 4px !important; padding: 8px 14px !important;
      padding-bottom: calc(8px + env(safe-area-inset-bottom, 0px)) !important;
      border-top: 1px solid var(--border) !important;
      background: var(--panel) !important; flex-shrink: 0 !important;
    }
    .qo-mob-cta-stat {
      font-size: 10px; font-weight: 600; color: var(--text3);
      text-align: center; font-family: 'Inter', sans-serif;
    }
    .qo-mob-cta-btn {
      width: 100%; padding: 13px; border-radius: 10px; border: none;
      background: linear-gradient(135deg, #7c5cbf, #6d4bb5);
      color: #fff; font-size: 14px; font-weight: 800;
      font-family: 'Inter', sans-serif; cursor: pointer;
      -webkit-tap-highlight-color: transparent;
    }
    .qo-mob-cta-btn:active { transform: scale(0.98); }
    .qo-mob-cta-btn:disabled { opacity: 0.3; }

    /* ── Panel tabs: bigger on mobile ── */
    .panel-tabs {
      gap: 0 !important;
      padding: 0 !important;
      flex-shrink: 0 !important;
    }
    .panel-tab {
      font-size: 13px !important;
      padding: 14px 0 !important;
      font-weight: 700 !important;
      letter-spacing: 0.03em !important;
    }

    /* ── Left panel: full screen, proper layout ── */
    .left-panel.mob-open {
      display: flex !important;
      flex-direction: column !important;
      overflow: hidden !important;
    }
    /* ═══ EMPTY STATE — full dark takeover ═══ */
    body.mob-empty-state .mob-status-strip,
    body.mob-empty-state .mob-bottom-bar,
    body.mob-empty-state .mob-canvas-ctrl,
    body.mob-empty-state .topbar {
      display: none !important;
    }
    body.mob-empty-state #mobCanvasHint {
      z-index: 300 !important;
      background: rgba(0,0,0,1) !important;
    }

    /* ═══ CLOSE BUTTON — floating above panel ═══ */
    .mob-panel-close {
      display: none;
      position: fixed !important;
      left: 50% !important;
      top: 22% !important;
      transform: translateX(-50%) !important;
      z-index: 200 !important;
      width: 34px !important;
      height: 34px !important;
      border-radius: 8px !important;
      border: 1px solid var(--border2) !important;
      background: var(--panel2) !important;
      color: var(--text2) !important;
      font-size: 15px !important;
      align-items: center !important;
      justify-content: center !important;
      cursor: pointer !important;
      -webkit-tap-highlight-color: transparent;
      box-shadow: 0 4px 16px rgba(0,0,0,0.5) !important;
      padding: 0 !important;
      line-height: 1 !important;
      backdrop-filter: blur(12px) !important;
      -webkit-backdrop-filter: blur(12px) !important;
    }
    .mob-panel-close:active {
      transform: translateX(-50%) scale(0.9) !important;
      background: var(--border2) !important;
    }
    .mob-panel-close.visible {
      display: flex !important;
    }
    .left-panel .panel-content {
      flex: 1 !important;
      overflow-y: auto !important;
      -webkit-overflow-scrolling: touch !important;
      padding: 8px 3px 8px 21px !important;
      min-height: 0 !important;
    }
    .left-panel .panel-content::-webkit-scrollbar {
      width: 3px !important;
    }
    .left-panel .panel-content::-webkit-scrollbar-track {
      background: transparent !important;
    }
    .left-panel .panel-content::-webkit-scrollbar-thumb {
      background: rgba(255,255,255,0.15) !important;
      border-radius: 2px !important;
    }

    /* ── Upload zone: minimal on mobile ── */
    .upload-zone {
      padding: 10px 12px !important;
      min-height: auto !important;
      margin-bottom: 6px !important;
      margin-right: 14px !important;
    }
    .upload-zone h4 {
      font-size: 12px !important;
      margin: 0 !important;
    }
    .upload-zone p {
      font-size: 8px !important;
      margin: 2px 0 0 !important;
    }

    /* ── Design grid: FORCE 2 columns on mobile ── */
    .design-grid {
      gap: 20px !important;
      padding: 0 14px 0 0 !important;
    }
    .design-grid > div {
      gap: 14px !important;
    }
    /* Force hide 3rd column if JS created 3 */
    .design-grid > div:nth-child(n+3) {
      display: none !important;
    }

    /* ══════════════════════════════════════════════
       MOBILE CARD REDESIGN — 2 cols, clean controls
       ══════════════════════════════════════════════ */

    .design-thumb {
      border-radius: 10px !important;
      padding: 8px !important;
      overflow: visible !important;
      position: relative !important;
    }
    .design-thumb-number {
      font-size: 8px !important;
      width: 16px !important;
      height: 16px !important;
      line-height: 16px !important;
    }

    /* +/- controls — inside card, away from scroll edge */
    .thumb-badge-pill {
      top: 4px !important;
      right: 4px !important;
      gap: 3px !important;
      transform: none !important;
      flex-direction: column !important;
    }
    .thumb-add-badge,
    .thumb-minus-badge {
      width: 26px !important;
      height: 26px !important;
      min-width: 26px !important;
      min-height: 26px !important;
    }
    .thumb-add-badge svg,
    .thumb-minus-badge svg {
      width: 12px !important;
      height: 12px !important;
    }

    /* Thumbnail */
    .design-thumb > img {
      height: 64px !important;
      max-height: 64px !important;
    }

    /* Info */
    .design-thumb-info {
      padding: 4px 2px 2px !important;
    }
    .design-thumb-name {
      font-size: 10px !important;
      line-height: 1.2 !important;
      white-space: nowrap !important;
      overflow: hidden !important;
      text-overflow: ellipsis !important;
    }
    .design-thumb-meta { margin-top: 2px !important; }
    .design-thumb-dpi { font-size: 8px !important; }
    .design-thumb-onsheet { font-size: 8px !important; }

    /* Buttons — uniform, full width */
    .ds-size-wrap { width: 100% !important; padding: 0 !important; margin-top: 4px !important; }
    .ds-size-btn {
      font-size: 10px !important; padding: 7px 4px !important;
      width: 100% !important; box-sizing: border-box !important;
      text-align: center !important; border-radius: 6px !important;
    }
    .ds-size-edit { padding: 4px !important; }
    .ds-size-row { gap: 4px !important; }
    .ds-size-field label { font-size: 8px !important; }
    .ds-input { font-size: 11px !important; padding: 5px 3px !important; }
    .qa-wrap { width: 100% !important; padding: 0 !important; margin-top: 3px !important; }
    .qa-toggle {
      font-size: 10px !important; padding: 7px 4px !important;
      width: 100% !important; box-sizing: border-box !important;
      text-align: center !important; border-radius: 6px !important;
    }
    .qa-form { padding: 4px !important; }
    .thumb-remove-lib {
      font-size: 9px !important; padding: 6px 4px !important;
      margin: 3px 0 0 !important; text-align: center !important;
      width: 100% !important; box-sizing: border-box !important;
      border-radius: 6px !important;
    }

    /* ═══ end card redesign ═══ */
  }

/* ═══ Inline Style Block Separator ═══ */

/* Checkerboard background for design library thumbnails — makes black/dark logos visible */
.design-thumb > img {
  background-image:
    linear-gradient(45deg, #2a2a2a 25%, transparent 25%),
    linear-gradient(-45deg, #2a2a2a 25%, transparent 25%),
    linear-gradient(45deg, transparent 75%, #2a2a2a 75%),
    linear-gradient(-45deg, transparent 75%, #2a2a2a 75%);
  background-size: 10px 10px;
  background-position: 0 0, 0 5px, 5px -5px, -5px 0px;
  background-color: #1e1e1e;
}

/* ═══ Inline Style Block Separator ═══ */

/* ── Quick Edit — Prevent accidental text selection ── */
.qe-overlay, .qe-overlay * {
  -webkit-user-select: none !important;
  user-select: none !important;
}
.qe-overlay input, .qe-overlay textarea, .qe-overlay [contenteditable="true"] {
  -webkit-user-select: text !important;
  user-select: text !important;
}
/* ── Quick Edit — Global Panel Normalization ── */
.qe-tool-panel {
  padding:12px 14px !important;
  font-family:'Inter',sans-serif !important;
  overflow-x:hidden !important;
  box-sizing:border-box !important;
}
.qe-recolor-controls, .qe-recolor-hex-row, .qe-recolor-mode-row,
.qe-recolor-swatches, .qe-recolor-spectrum, .qe-recolor-hue-bar {
  max-width:100% !important; overflow:hidden !important; box-sizing:border-box !important;
}
/* Section headings — all panels */
.qe-tool-panel > div[style*="font-size:12px"],
.qe-tool-panel > div[style*="font-size:10px"][style*="font-weight:6"],
.qe-tool-panel-title {
  font-size:13px !important; font-weight:700 !important; color:var(--text) !important;
  letter-spacing:0.04em !important; margin-bottom:10px !important; margin-top:4px !important;
  font-family:'Inter',sans-serif !important;
}
/* Description text */
.qe-tool-panel > div[style*="font-size:7px"],
.qe-tool-panel div[style*="font-size:7px"][style*="color:var(--text3)"],
.qe-tool-panel div[style*="font-size:8px"][style*="color:var(--text3)"] {
  font-size:10px !important; line-height:1.5 !important; margin-bottom:6px !important;
}
/* All action buttons — unified */
.qe-action-btn {
  padding:10px 14px !important; border-radius:6px !important;
  font-size:11px !important; font-weight:600 !important;
  font-family:'Inter',sans-serif !important;
  background:var(--panel2) !important; border:1px solid var(--border2) !important;
  color:var(--text) !important; cursor:pointer !important;
  display:flex !important; align-items:center !important; justify-content:center !important;
  gap:5px !important; transition:border-color 0.15s, background 0.15s !important;
  box-shadow:none !important; position:relative !important; overflow:hidden !important;
  letter-spacing:0.01em !important;
}
.qe-action-btn:hover { border-color:var(--accent) !important; background:rgba(124,92,191,0.06) !important; }
.qe-action-btn.active { border-color:var(--accent) !important; color:var(--accent) !important; background:rgba(124,92,191,0.08) !important; }
/* Apply buttons — purple with white text */
.qe-action-btn[onclick*="Apply"], .qe-action-btn[onclick*="apply"],
.qerp-btn[onclick*="Apply"], .qerp-btn[onclick*="apply"] {
  background:#7c3aed !important; border-color:#7c3aed !important; color:#fff !important;
}
.qe-action-btn[onclick*="Apply"]:hover, .qe-action-btn[onclick*="apply"]:hover,
.qerp-btn[onclick*="Apply"]:hover, .qerp-btn[onclick*="apply"]:hover {
  background:#6d28d9 !important; border-color:#6d28d9 !important;
}
/* Kill all colored left-bar decorations inside buttons */
.qe-action-btn > span[style*="position:absolute"][style*="width:4px"] { display:none !important; }
/* Dividers between sections */
.qe-tool-panel > div[style*="border-top:2px"] {
  border-top:1px solid var(--border2) !important; margin:14px 0 !important; opacity:1 !important;
}
/* Hide trailing divider when it's the last visible element */
.qe-tool-panel > div[style*="border-top:2px"]:last-child,
.qe-tool-panel > div[style*="border-top:1px"]:last-child {
  display:none !important;
}
/* Slider rows */
.qe-tool-row { display:flex; align-items:center; gap:8px; margin-bottom:8px; }
.qe-tool-label { font-size:11px !important; font-weight:500 !important; color:var(--text2) !important; min-width:64px !important; flex-shrink:0 !important; font-family:'Inter',sans-serif !important; }
.qe-slider { height:4px !important; flex:1 !important; min-width:0 !important; }
.qe-slider-val { font-size:11px !important; font-weight:700 !important; color:var(--text) !important; min-width:30px !important; width:30px !important; flex-shrink:0 !important; text-align:right !important; font-family:'Inter',sans-serif !important; font-variant-numeric:tabular-nums; }
.qe-tool-row { overflow:hidden; }
/* Recolor mode buttons */
.qe-recolor-mode-btn {
  padding:9px 12px !important; border-radius:6px !important;
  font-size:11px !important; font-weight:600 !important;
  font-family:'Inter',sans-serif !important;
  background:var(--panel2) !important; border:1px solid var(--border2) !important;
  color:var(--text3) !important; cursor:pointer !important; flex:1 !important;
  transition:all 0.15s !important;
}
.qe-recolor-mode-btn:hover { border-color:var(--accent) !important; }
.qe-recolor-mode-btn.active { border-color:var(--accent) !important; color:var(--accent) !important; background:rgba(124,92,191,0.08) !important; }
/* Color swatches */
.qe-color-preview { width:32px !important; height:32px !important; border-radius:6px !important; border:2px solid var(--border2) !important; flex-shrink:0 !important; }
/* HEX input in recolor */
.qe-recolor-hex { font-family:'Inter',monospace !important; font-size:12px !important; padding:8px 10px !important; border-radius:6px !important; border:1px solid var(--border2) !important; background:var(--panel2) !important; color:var(--text) !important; }

/* ── Quick Edit — Light Mode Overrides ── */
[data-theme="light"] .qe-canvas-area { background:#e8e8ec !important; }
[data-theme="light"] #qeUndoRedoBar { background:rgba(255,255,255,0.92) !important; }
[data-theme="light"] #qeUndoRedoBar button:hover { background:rgba(0,0,0,0.06) !important; }
[data-theme="light"] .qe-info-bar { background:rgba(255,255,255,0.95) !important; }
[data-theme="light"] .qe-info-bar button:hover { background:rgba(0,0,0,0.06) !important; }
[data-theme="light"] #qePanel_text #qeTextPreviewSpan { color:var(--text) !important; }
[data-theme="light"] #qePanel_text #qeOptBold span[style*="color:#fff"],
[data-theme="light"] #qePanel_text #qeOptItalic span[style*="color:#fff"],
[data-theme="light"] #qePanel_text #qeOptUpper span[style*="color:#fff"],
[data-theme="light"] #qePanel_text #qeOptShadow span[style*="color:#fff"] { color:var(--text) !important; }
[data-theme="light"] #qeFontDropdown { background:var(--panel) !important; border-color:var(--border2) !important; box-shadow:0 8px 24px rgba(0,0,0,0.12) !important; }
[data-theme="light"] #qeFontDropdown #qeFontSearch { background:var(--panel2) !important; color:var(--text) !important; border-bottom-color:var(--border2) !important; }
[data-theme="light"] #qeFontDropdown > div[style*="color:#7c5cbf"] { color:var(--accent) !important; }
[data-theme="light"] #qeFontDropdown > div[style*="color:#e0e0e0"] { color:var(--text) !important; }
[data-theme="light"] #qeFontDropdown > div[style*="color:#666"] { color:var(--text3) !important; }
[data-theme="light"] #qeFontDropdown > div[style*="cursor:pointer"]:hover { background:var(--panel2) !important; }
[data-theme="light"] #qeFontDropdown > div[style*="background:#383838"],
[data-theme="light"] #qeFontDropdown > div[style*="background: #383838"] { background:var(--accent-dim) !important; }
[data-theme="light"] .qe-strip-btn { color:var(--text3); }
[data-theme="light"] .qe-strip-btn:hover { color:var(--text); background:rgba(0,0,0,0.04); }
[data-theme="light"] .qe-strip-btn.active { color:var(--accent) !important; background:var(--accent-dim) !important; }
[data-theme="light"] .qerp-heading::after { background:var(--border2) !important; }
[data-theme="light"] .qe-color-preview { border-color:var(--border2) !important; }
[data-theme="light"] .qe-tool-panel div[style*="border:1px solid rgba(255,255,255"],
[data-theme="light"] .qe-tool-panel div[style*="border:2px solid transparent"] { border-color:var(--border2) !important; }
[data-theme="light"] .qe-tool-panel div[style*="background:#FFFFFF"][style*="cursor:pointer"],
[data-theme="light"] .qe-tool-panel div[style*="background:#ffffff"][style*="cursor:pointer"] { border-color:var(--border2) !important; }
[data-theme="light"] #qePanel_border div[style*="border:1px solid rgba(255,255,255"] { border-color:var(--border2) !important; }

/* ── Global Light Mode Overrides ── */

/* Scrollbars */
[data-theme="light"] ::-webkit-scrollbar-track { background:rgba(0,0,0,0.03) !important; }
[data-theme="light"] ::-webkit-scrollbar-thumb { background:rgba(0,0,0,0.15) !important; }
[data-theme="light"] ::-webkit-scrollbar-thumb:hover { background:rgba(0,0,0,0.25) !important; }

/* Names & Numbers Panel */
[data-theme="light"] #jrsOverlay { background:var(--bg) !important; }
[data-theme="light"] #jrsOverlay > div:first-child { background:var(--panel) !important; border-bottom-color:var(--border2) !important; }
[data-theme="light"] #jrsOverlay > div:first-child h3 { color:var(--text) !important; }
[data-theme="light"] #jrsOverlay > div:first-child button[onclick*="jrsClose"] { background:var(--panel2) !important; border-color:var(--border2) !important; color:var(--text3) !important; }
[data-theme="light"] #jrsOverlay > div:first-child button[onclick*="jrsClose"]:hover { border-color:var(--text3) !important; color:var(--text) !important; }
[data-theme="light"] #jrsOverlay > div:last-child > div:first-child { background:var(--panel) !important; border-right-color:var(--border2) !important; }
[data-theme="light"] #jrsOverlay > div:last-child > div:nth-child(2) { background:var(--bg2) !important; }
[data-theme="light"] #jrsOverlay > div:last-child > div:last-child { background:var(--panel) !important; border-left-color:var(--border2) !important; }
[data-theme="light"] #jrsOverlay div[style*="color:#888"] { color:var(--text3) !important; }
[data-theme="light"] #jrsOverlay div[style*="color:#999"] { color:var(--text3) !important; }
[data-theme="light"] #jrsOverlay div[style*="border-bottom:1px solid #2a2a2e"],
[data-theme="light"] #jrsOverlay div[style*="border-right:1px solid #2a2a2e"] { border-color:var(--border2) !important; }
[data-theme="light"] #jrsOverlay button[onclick*="jrsAdd"] { border-color:var(--border2) !important; color:var(--text3) !important; }
[data-theme="light"] #jrsOverlay button[onclick*="jrsAdd"]:hover { border-color:var(--accent) !important; color:var(--accent) !important; }
[data-theme="light"] #jrsFontList { background:var(--panel2) !important; border-color:var(--border2) !important; }
[data-theme="light"] #jrsOverlay input[type="color"] { border-color:var(--border2) !important; }
[data-theme="light"] #jrsOverlay .jrs-jc[style*="border:2px solid transparent"] { border-color:var(--border2) !important; }
[data-theme="light"] #jrsOverlay div[style*="border:1px solid #555"] { border-color:var(--border2) !important; }

/* Background Remover Modal */
[data-theme="light"] #bgRemovalModal { background:rgba(0,0,0,0.4) !important; }
[data-theme="light"] #bgRemovalModal > div:first-child { background:var(--panel) !important; border-color:var(--border2) !important; box-shadow:0 40px 100px rgba(0,0,0,0.15) !important; }
[data-theme="light"] #bgRemovalModal div[style*="border-bottom:1px solid #1c1c1c"],
[data-theme="light"] #bgRemovalModal div[style*="border-top:1px solid #1c1c1c"] { border-color:var(--border2) !important; }
[data-theme="light"] #bgRemovalModal div[style*="color:#fff"][style*="font-size:13px"] { color:var(--text) !important; }
[data-theme="light"] #bgRemovalModal #bgrModeRow { background:var(--panel2) !important; }
[data-theme="light"] #bgRemovalModal .bgrModeBtn { color:var(--text3) !important; }
[data-theme="light"] #bgRemovalModal .bgrModeBtn[style*="background:#1e1e22"] { background:var(--accent-dim) !important; color:var(--accent) !important; }
[data-theme="light"] #bgRemovalModal button[onclick*="bgrClose"] { color:var(--text3) !important; }
[data-theme="light"] #bgRemovalModal button[onclick*="bgrClose"]:hover { color:var(--text) !important; }
[data-theme="light"] #bgRemovalModal #bgrPickedRow2 { background:var(--panel2) !important; border-bottom-color:var(--border2) !important; }
[data-theme="light"] #bgRemovalModal #bgrPickedRow2 span { color:var(--text3) !important; }
[data-theme="light"] #bgRemovalModal div[style*="background:#111"] { background:var(--border2) !important; }
[data-theme="light"] #bgRemovalModal #bgrLoading { background:rgba(255,255,255,0.95) !important; }
[data-theme="light"] #bgRemovalModal #bgrLoadingText { color:var(--text2) !important; }
[data-theme="light"] #bgRemovalModal #bgrLoadingPct { color:var(--text) !important; }

/* Overflow Modal */
[data-theme="light"] #overflowModal { background:rgba(0,0,0,0.35) !important; }
[data-theme="light"] #overflowModal > div:first-child { background:var(--panel) !important; border-color:var(--border2) !important; box-shadow:0 24px 80px rgba(0,0,0,0.12) !important; }
[data-theme="light"] #overflowModal div[style*="color:#fff"][style*="font-size:15px"] { color:var(--text) !important; }
[data-theme="light"] #overflowModal div[style*="color:#555"] { color:var(--text3) !important; }
[data-theme="light"] #overflowModal div[style*="background:#1e1e1e"] { background:var(--border) !important; }
[data-theme="light"] #overflowModal div[style*="background:#0e0e0e"] { background:var(--panel2) !important; border-color:var(--border2) !important; }
[data-theme="light"] #overflowModal div[style*="color:#444"] { color:var(--text3) !important; }
[data-theme="light"] #overflowModal div[style*="color:#aaa"] { color:var(--text2) !important; }
[data-theme="light"] #overflowModal input[style*="background:#0a0a0a"] { background:var(--bg2) !important; color:var(--text3) !important; border-color:var(--border2) !important; }
[data-theme="light"] #overflowModal input[style*="background:#111"] { background:var(--panel) !important; color:var(--text) !important; border-color:var(--border2) !important; }
[data-theme="light"] #overflowModal div[style*="color:rgba(255,255,255,0.5)"] { color:var(--text3) !important; }

/* Sheet Full Modal */
[data-theme="light"] #sheetFullModal { background:rgba(0,0,0,0.3) !important; }
[data-theme="light"] #sheetFullModal > div:first-child { background:var(--panel) !important; border-color:var(--border2) !important; box-shadow:0 16px 48px rgba(0,0,0,0.12) !important; }
[data-theme="light"] #sheetFullModal div[style*="color:#fff"][style*="font-size:15px"] { color:var(--text) !important; }
[data-theme="light"] #sheetFullModal div[style*="color:#888"] { color:var(--text2) !important; }
[data-theme="light"] #sheetFullModal button[onclick*="hideSheetFull"] { background:var(--panel2) !important; border-color:var(--border2) !important; color:var(--text2) !important; }

/* Quantity Modal */
[data-theme="light"] #qtyModal { background:rgba(0,0,0,0.25) !important; }
[data-theme="light"] #qtyModal > div:first-child { background:var(--panel) !important; border-color:var(--border2) !important; box-shadow:0 16px 48px rgba(0,0,0,0.12) !important; }
[data-theme="light"] #qtyModal div[style*="color:#fff"][style*="font-size:14px"] { color:var(--text) !important; }
[data-theme="light"] #qtyModal #qtyModalName { color:var(--text3) !important; }
[data-theme="light"] #qtyModal button[style*="background:#2a2a2a"] { background:var(--panel2) !important; border-color:var(--border2) !important; color:var(--text) !important; }
[data-theme="light"] #qtyModal input[style*="background:#111"] { background:var(--panel2) !important; border-color:var(--border2) !important; color:var(--text) !important; }
[data-theme="light"] #qtyModal button[style*="color:#aaa"] { color:var(--text2) !important; }

/* Design Library Font Dropdown */
[data-theme="light"] #dlFontDropdown { background:var(--panel) !important; border-color:var(--border2) !important; box-shadow:0 8px 24px rgba(0,0,0,0.12) !important; }
[data-theme="light"] #dlFontDropdown input[type="text"] { background:var(--panel2) !important; color:var(--text) !important; border-bottom-color:var(--border2) !important; }
[data-theme="light"] #dlFontDropdown > div[style*="color:#7c5cbf"] { color:var(--accent) !important; }
[data-theme="light"] #dlFontDropdown > div[style*="color:#e0e0e0"] { color:var(--text) !important; }
[data-theme="light"] #dlFontDropdown > div[style*="color:#666"] { color:var(--text3) !important; }
[data-theme="light"] #dlFontDropdown > div[style*="cursor:pointer"]:hover { background:var(--panel2) !important; }

/* Footer Price Label */
[data-theme="light"] #footerPCLabel { color:var(--text) !important; }

/* Auto-Fill, Sheet Manager, Clear Sheets overlays */
[data-theme="light"] #afOverlay,
[data-theme="light"] #sfmOverlay,
[data-theme="light"] #clearSheetsOverlay { background:rgba(0,0,0,0.3) !important; }
[data-theme="light"] #afOverlay > div,
[data-theme="light"] #sfmOverlay > div,
[data-theme="light"] #clearSheetsOverlay > div { background:var(--panel) !important; border-color:var(--border2) !important; box-shadow:0 16px 48px rgba(0,0,0,0.12) !important; }

/* Too Wide Modal */
[data-theme="light"] #tooWideModal { background:rgba(0,0,0,0.3) !important; }
[data-theme="light"] #tooWideModal > div:first-child { background:var(--panel) !important; border-color:var(--border2) !important; box-shadow:0 16px 48px rgba(0,0,0,0.12) !important; }
[data-theme="light"] #tooWideModal div[style*="color:#fff"] { color:var(--text) !important; }
[data-theme="light"] #tooWideModal div[style*="color:#888"],
[data-theme="light"] #tooWideModal div[style*="color:#aaa"] { color:var(--text2) !important; }
[data-theme="light"] #tooWideModal div[style*="background:#1e1e1e"],
[data-theme="light"] #tooWideModal div[style*="background:#1a1a1a"] { background:var(--panel2) !important; }
[data-theme="light"] #tooWideModal input[style*="background:#111"] { background:var(--panel2) !important; color:var(--text) !important; border-color:var(--border2) !important; }

/* ── Quick Edit Canvas Layout — Centered ── */
.qe-canvas-area {
  display:flex !important; align-items:center !important; justify-content:center !important;
  position:relative !important; overflow:hidden !important;
  background:#1a1a1e !important;
}
#qeCanvasWrap {
  position:relative; display:flex; align-items:center; justify-content:center;
}
#qeCanvas {
  display:block;
  background-image:
    linear-gradient(45deg, #d0d0d0 25%, transparent 25%),
    linear-gradient(-45deg, #d0d0d0 25%, transparent 25%),
    linear-gradient(45deg, transparent 75%, #d0d0d0 75%),
    linear-gradient(-45deg, transparent 75%, #d0d0d0 75%) !important;
  background-size: 10px 10px !important;
  background-position: 0 0, 0 5px, 5px -5px, -5px 0px !important;
  background-color: #e8e8e8 !important;
}
#qeSelCanvas {
  background:transparent !important;
}
/* zoom bar is now part of the vertical undo/redo toolbar */

/* ── Quick Edit Left Toolbar — Clean Minimal ── */
.qe-tool-strip {
  display:flex; flex-direction:column; gap:0; padding:4px 3px 32px;
  background:var(--panel); border-right:1px solid var(--border2);
  width:58px; min-width:58px; overflow-y:auto; overflow-x:hidden;
  scrollbar-width:none;
}
.qe-tool-strip::-webkit-scrollbar { display:none; }
.qe-strip-btn {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:2px; padding:5px 2px; border:none; background:transparent;
  color:var(--text3); cursor:pointer; border-radius:5px;
  font-family:'Inter',sans-serif; font-size:7px; font-weight:600;
  letter-spacing:0.02em; text-transform:uppercase; transition:all 0.15s;
  min-height:0; flex-shrink:0;
}
.qe-strip-btn svg { width:16px; height:16px; flex-shrink:0; }
.qe-strip-btn span { line-height:1; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:52px; text-align:center; }
.qe-strip-btn:hover { color:var(--text); background:var(--panel2); }
.qe-strip-btn.active {
  color:var(--accent); background:rgba(124,92,191,0.08);
  border:1px solid rgba(124,92,191,0.2);
}
.qe-strip-sep {
  height:1px; background:var(--border2); margin:1px 6px; flex-shrink:0;
}
.qe-tools { overflow-x:hidden; overflow-y:auto; }

/* ═══ Inline Style Block Separator ═══ */

            .qerp-section { margin-bottom:18px; }
            .qerp-heading { font-size:11px; font-weight:700; color:var(--text3); text-transform:uppercase; letter-spacing:0.08em; margin-bottom:10px; display:flex; align-items:center; gap:6px; }
            .qerp-heading::after { content:''; flex:1; height:1px; background:var(--border2); }
            .qerp-btn { width:100%; padding:10px 14px; background:var(--panel2); border:1px solid var(--border2); border-radius:6px; color:var(--text); font-size:11px; font-weight:600; font-family:'Inter',sans-serif; cursor:pointer; display:flex; align-items:center; justify-content:center; gap:6px; transition:border-color 0.15s, background 0.15s; }
            .qerp-btn:hover { border-color:var(--accent); background:rgba(124,92,191,0.06); }
            .qerp-btn-row { display:flex; gap:6px; }
            .qerp-btn-row .qerp-btn { flex:1; padding:10px 8px; font-size:11px; }
            .qerp-gap { height:6px; }
            .qerp-toggle-group { display:flex; gap:0; background:var(--panel2); border-radius:6px; padding:3px; border:1px solid var(--border2); }
            .qerp-toggle-group .qerp-btn { border:none; border-radius:5px; padding:8px 10px; font-size:11px; background:transparent; color:var(--text3); }
            .qerp-toggle-group .qerp-btn.active { background:var(--accent-dim); color:var(--accent); font-weight:700; }
            .qerp-toggle-group .qerp-btn:hover:not(.active) { color:var(--text); }
          
/* ═══ Inline Style Block Separator ═══ */

      @keyframes bgrSpin { to { transform: rotate(360deg); } }
      @keyframes _dtlSpin { to { transform: rotate(360deg); } }
      ._dtl-spinner {
        width: 28px; height: 28px;
        border: 3px solid rgba(124,92,191,0.15);
        border-top-color: #7c5cbf;
        border-radius: 50%;
        animation: _dtlSpin 0.7s linear infinite;
        will-change: transform;
      }
    
/* ═══ Inline Style Block Separator ═══ */

.sctx-menu {
  background:#1a1a1a; border:1px solid #2e2e2e;
  border-radius:9px; padding:5px; min-width:190px;
  box-shadow:0 12px 40px rgba(0,0,0,0.85);
  font-family:'Inter',sans-serif;
}
.sctx-item { display:flex;align-items:center;gap:9px;padding:7px 12px;border-radius:6px;font-size:12px;color:#fff;cursor:pointer;transition:background 0.1s; }
.sctx-item:hover { background:#2e2e2e; color:#fff; }
.sctx-item span { width:16px;text-align:center;font-size:13px; }
.sctx-sep { height:1px;background:#252525;margin:4px 0; }

/* ═══ Inline Style Block Separator ═══ */

/* Undo / Redo floating buttons */
.canvas-undo-redo {
  position: absolute;
  top: 10px;
  right: 166px;
  z-index: 100;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.canvas-undo-redo .cur-btn {
  position: relative;
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--panel);
  opacity: 0.85;
  border: 1px solid transparent;
  border-radius: 7px;
  cursor: pointer;
  color: #fff;
  transition: border-color 0.15s;
  padding: 0;
}
.canvas-undo-redo .cur-btn:hover:not(:disabled) {
  border-color: #00e5ff;
}
.canvas-undo-redo .cur-btn:disabled {
  cursor: default;
  color: #333340;
}
.canvas-undo-redo .cur-btn:active:not(:disabled) {
  transform: scale(0.93);
}
/* Light theme */
[data-theme="light"] .canvas-undo-redo .cur-btn {
  background: #ffffff;
  color: #666;
  box-shadow: none;
}
[data-theme="light"] .canvas-undo-redo {
  box-shadow: 0 2px 10px rgba(0,0,0,0.12), 0 0 0 1px rgba(0,0,0,0.08);
}
[data-theme="light"] .canvas-undo-redo .cur-btn:hover:not(:disabled) {
  background: #f0f2f5;
  color: var(--text);
}

/* Marquee selection rectangle */
.marquee-rect {
  position:fixed;
  border:1px dashed #000000;
  background:rgba(59,130,246,0.05);
  pointer-events:none;
  z-index:50;
  border-radius:0px;
  outline:1px dashed #ffffff;
  outline-offset:0px;
}
/* Multi-select group bounding box */
.multi-select-bbox {
  position:absolute;
  border:1px dashed #6a4dab;
  background:transparent;
  pointer-events:none;
  z-index:14;
  border-radius:0px;
  outline:1px dashed #ffffff;
  outline-offset:0px;
}

.ctx-menu {
  background:#1c1c1c; border:1px solid #333;
  box-shadow:0 8px 32px rgba(0,0,0,0.8);
}

.ctx-item {
  display:flex; align-items:center; gap:8px;
  padding:7px 14px; cursor:pointer; color:#cccccc;
  transition:all 0.1s; position:relative;
}
.ctx-item:hover { background:#2a2a2a; color:#ffffff; }
.ctx-danger { color:#ff5555 !important; }
.ctx-danger:hover { background:rgba(255,68,68,0.12) !important; }
.ctx-icon { font-size:14px; width:18px; text-align:center; flex-shrink:0; }
.ctx-kb {
  margin-left:auto; font-size:10px; color:#777777;
  font-family:'Montserrat',sans-serif; letter-spacing:0.05em;
}
.ctx-sep { height:1px; background:#2a2a2a; margin:3px 0; }

/* Light theme context menus */
[data-theme="light"] .ctx-menu { background:#ffffff; border-color:var(--border); box-shadow:0 8px 30px rgba(0,0,0,0.15); }
[data-theme="light"] .ctx-item { color:#555; }
[data-theme="light"] .ctx-item:hover { background:#f0f2f5; color:var(--text); }
[data-theme="light"] .ctx-kb { color:#999; }
[data-theme="light"] .ctx-sep { background:#ddd; }
[data-theme="light"] .ctx-danger { color:#dc2626 !important; }
[data-theme="light"] .ctx-danger:hover { background:rgba(220,38,38,0.08) !important; }
[data-theme="light"] .sctx-menu { background:#ffffff; border-color:var(--border); box-shadow:0 8px 30px rgba(0,0,0,0.15); }
[data-theme="light"] .sctx-item { color:var(--text); }
[data-theme="light"] .sctx-item:hover { background:#f0f2f5; color:var(--text); }
[data-theme="light"] .sctx-sep { background:#e5e7eb; }
/* Floating name tooltip */
#designNameTip {
  position:fixed; z-index:99999; pointer-events:none;
  background:#111; color:#eee; font-size:11px; font-weight:600;
  padding:6px 12px; border-radius:6px; white-space:normal; word-break:break-all;
  box-shadow:0 4px 16px rgba(0,0,0,0.5); border:1px solid rgba(255,255,255,0.12);
  max-width:260px; width:max-content; text-align:center; line-height:1.4;
  font-family:'Inter',sans-serif; letter-spacing:0.01em;
  opacity:0; transition:opacity 0.12s;
}
#designNameTip.visible { opacity:1; }
[data-theme="light"] #designNameTip { background:#fff; color:#222; border-color:#ddd; box-shadow:0 4px 16px rgba(0,0,0,0.15); }

/* ═══ Inline Style Block Separator ═══ */
' +
        '*{margin:0;padding:0;box-sizing:border-box}' +
        'body{background:#0a0a0a;color:#e0e0e0;font-family:Inter,system-ui,sans-serif;line-height:1.6;padding:32px 24px 80px}' +
        '.wrap{max-width:720px;margin:0 auto}' +
        'h1{font-size:22px;font-weight:700;margin-bottom:6px;color:#fff}' +
        '.subtitle{font-size:13px;color:#888;margin-bottom:32px}' +
        '.section{margin-bottom:28px}' +
        '.sec-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:#7c5cbf;margin-bottom:12px;padding-bottom:6px;border-bottom:1px solid #1c1c1c}' +
        '.card{background:#141414;border:1px solid #242424;border-radius:10px;padding:16px 18px;margin-bottom:10px}' +
        '.card-name{font-size:14px;font-weight:700;color:#fff;margin-bottom:4px;display:flex;align-items:center;gap:8px}' +
        '.card-name .icon{font-size:16px}' +
        '.badge{font-size:8px;padding:2px 6px;border-radius:3px;font-weight:700;text-transform:uppercase}' +
        '.badge.danger{background:rgba(239,68,68,0.12);color:#ef4444}' +
        '.badge.warn{background:rgba(245,158,11,0.12);color:#f59e0b}' +
        '.badge.safe{background:rgba(34,197,94,0.12);color:#7c5cbf}' +
        '.badge.info{background:rgba(124,92,191,0.12);color:#7c5cbf}' +
        '.card-desc{font-size:12px;color:#b8b8b8;margin-bottom:8px}' +
        '.card-detail{font-size:11px;color:#888;line-height:1.7}' +
        '.card-detail b{color:#ccc;font-weight:600}' +
        '.tag{display:inline-block;font-size:9px;padding:1px 5px;border-radius:3px;background:#1c1c1c;color:#888;margin-right:4px}' +
      '
/* ═══ Inline Style Block Separator ═══ */

      @keyframes rpFillBar { from { width: 0%; } }
      @keyframes rpPriceIn {
        from { opacity:0; transform:scale(0.95) translateY(4px); }
        to   { opacity:1; transform:scale(1) translateY(0); }
      }

      /* ── Price Hero ── */
      .rp-price-card {
        position:relative;
        padding:12px 14px 4px;
        border-radius:10px;
        background:var(--panel2);
        border:1px solid var(--border);
        text-align:center;
        overflow:hidden;
        display:flex; flex-direction:column;
      }
      .rp-price-card::before {
        content:'';
        position:absolute; top:0; left:0; right:0; height:2px;
        background:linear-gradient(90deg, var(--accent) 0%, rgba(124,92,191,0.8) 50%, var(--accent) 100%);
        opacity:0.7;
      }
      .rp-price-eyebrow {
        font-size:9px; font-weight:700; color:var(--text3);
        text-transform:uppercase; letter-spacing:0.12em;
        margin-bottom:2px;
      }
      .rp-price-amount {
        font-size:26px; font-weight:700; color:var(--text);
        letter-spacing:-0.02em; line-height:1;
        font-variant-numeric:tabular-nums;
        font-family:'Inter',sans-serif;
      }
      .rp-price-context {
        font-size:10px; color:var(--text3); margin-top:6px;
        line-height:1.3;
      }
      .rp-price-context strong {
        font-weight:600; color:var(--text2);
      }

      /* ── Section Labels ── */
      .rp-section-label {
        font-size:10px; font-weight:800; color:var(--text);
        text-transform:uppercase; letter-spacing:0.14em;
        padding:0 0 4px; margin:0;
      }

      /* ── Stat Rows ── */
      .rp-stat-row {
        display:flex; justify-content:space-between; align-items:center;
        padding:2px 0;
      }
      .rp-stat-label { font-size:11px; font-weight:400; color:#888888; }
      .rp-stat-value { font-size:11px; font-weight:700; color:var(--text); font-variant-numeric:tabular-nums; }

      /* ── Dividers ── */
      .rp-divider { height:1px; background:var(--border); margin:6px 0; }

      /* ── Order Efficiency ── */
      .rp-bar-track {
        width:100%; height:4px; background:var(--bg2);
        border-radius:99px; overflow:hidden;
      }
      .rp-bar-fill {
        height:100%; border-radius:99px;
        transition: width 0.6s cubic-bezier(0.4,0,0.2,1);
        animation: rpFillBar 0.8s cubic-bezier(0.4,0,0.2,1);
      }
      .rp-fill-header {
        display:flex; align-items:center; gap:8px;
      }
      .rp-fill-pct {
        font-size:16px; font-weight:800; letter-spacing:-0.02em; line-height:1;
        font-variant-numeric:tabular-nums;
      }
      .rp-fill-badge {
        font-size:9px; font-weight:600; padding:2px 6px;
        border-radius:4px; letter-spacing:0.02em;
      }
      .rp-micro {
        font-size:10px; color:var(--text3); margin-top:4px;
        line-height:1.3; opacity:0.6;
      }

/* ═══ Quick Order — Product Tabs (multi-product support) ═══ */
#qoProductTabs {
  display: flex; align-items: center; gap: 6px;
  padding: 8px 16px; background: var(--panel);
  border-bottom: 1px solid var(--border);
  overflow-x: auto; -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
}
#qoProductTabs .qopt-pill {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 5px 11px; border-radius: 999px;
  background: transparent; border: 1px solid var(--border2);
  color: var(--text3); font-family: 'Inter', sans-serif;
  font-size: 11px; font-weight: 600; cursor: pointer;
  white-space: nowrap; transition: all 0.12s;
  flex-shrink: 0;
}
#qoProductTabs .qopt-pill:hover {
  border-color: var(--text3); color: var(--text);
}
#qoProductTabs .qopt-pill.qopt-active {
  background: rgba(139, 92, 246, 0.10);
  border-color: #7c3aed; color: #fff;
}
#qoProductTabs .qopt-dot { width: 9px; height: 9px; flex-shrink: 0; }
#qoProductTabs .qopt-dot svg { display: block; width: 100%; height: 100%; }
#qoProductTabs .qopt-count {
  display: inline-block;
  background: rgba(124, 58, 237, 0.22); color: #c9b3ea;
  font-size: 9px; font-weight: 700; padding: 1px 6px;
  border-radius: 8px; line-height: 1.4;
}
#qoProductTabs .qopt-pill.qopt-active .qopt-count {
  background: #7c3aed; color: #fff;
}
#qoCrossProductStat {
  font-size: 10px; color: var(--text3);
  padding: 3px 16px 0; font-family: 'Inter', sans-serif;
}
@media (max-width: 768px) {
  #qoProductTabs { padding: 6px 10px !important; gap: 4px !important; }
  #qoProductTabs .qopt-pill { font-size: 10px !important; padding: 4px 9px !important; }
}

/* ═══ Inline Style Block Separator ═══ */
@keyframes mobFabMenuIn{from{opacity:0;transform:translateY(10px) scale(0.9);}to{opacity:1;transform:translateY(0) scale(1);}}


/* ════════════════════════════════════════════════════════════════════
   Mobile + Tablet visual polish (CSS-only, no behaviour change)
   ════════════════════════════════════════════════════════════════════
   Layered over `gangsheet-builder.css` to:
     • Tighten topbar at ≤480 px so iPhone SE / Galaxy S22 fit cleanly.
     • Collapse Try-it-free + Add-to-Cart to icons at small phones.
     • Internal-scroll the cart overlay on landscape phones.
     • Pin sidebars on tablet portrait (700–1100) so subscribers can
       preview their store; HIDE the bottom bar there (it's smartphone-only).
     • Bump bottom-bar gap on mid/large phones (380–768) for thumb spacing.
     • Restore desktop layout above 1100 (covers iPad landscape too).
   No JS, no new layout. Rules are last-cascade, so they win without
   needing !important except where the frozen bundle uses an inline style.
   ════════════════════════════════════════════════════════════════════ */

/* ── Smartphone (≤480 px): topbar density + readable badges ─────── */
@media (max-width: 480px) {
  .topbar { padding: 6px 10px; gap: 6px; }
  .topbar-action-btn,
  .topbar button {
    padding: 6px 10px;
    font-size: 11px;
    min-width: 0;
  }
  /* Try it for free → ⚡ icon only */
  #subUpgradeBtn {
    font-size: 0 !important;
    padding: 7px 9px !important;
    min-width: 0 !important;
  }
  #subUpgradeBtn::before {
    content: "⚡";
    font-size: 14px;
    line-height: 1;
  }
  /* Add to Cart text → 🛒 icon only at smallest sizes */
  .topbar-action-btn[data-ac="8d6cc3"] {
    font-size: 0 !important;
    padding: 7px 10px !important;
  }
  .topbar-action-btn[data-ac="8d6cc3"]::before {
    content: "🛒";
    font-size: 15px;
    line-height: 1;
  }
  /* Sheet 1 banner — keep on a single line */
  #sheetNameBanner,
  .sheet-name-banner {
    font-size: 11px;
    padding: 4px 10px;
  }
  /* Right-panel "TOTAL ORDER SIZE" headline shrink */
  .right-panel h2,
  .total-order-size {
    font-size: 18px;
  }
  /* Customer panel header — wrap email under name */
  #customerPanelContent > div > div:first-of-type {
    flex-wrap: wrap;
    gap: 8px;
  }
  /* Sign-in modal padding */
  #saasAuthBox {
    padding: 18px !important;
  }
  /* Library card DPI badge readability — earlier @media (max-width:768px)
     block (line ~1963) sets `font-size:8px !important` on the same selector;
     we need !important here to win at the ≤480 breakpoint and bump it up. */
  .design-thumb-dpi {
    font-size: 9px !important;
    padding: 2px 5px !important;
  }
}

/* ── Smallest phones (≤380 = Galaxy S22 / iPhone SE) ─────────────── */
@media (max-width: 380px) {
  .qo-mobile-fields { gap: 4px; }
  .qo-design-card { padding: 8px; }
  .qo-design-name { font-size: 11px; }
  .topbar { gap: 4px; padding: 5px 8px; }
}

/* ── Mid-large phones (380–700 px) — generous bottom-bar spacing ── */
@media (min-width: 380px) and (max-width: 700px) {
  .mob-bottom-bar {
    gap: 8px !important;
    padding: 8px 10px !important;
  }
}

/* ── Large phones (412+ Pro Max / S23 Ultra) — full text in topbar */
@media (min-width: 412px) and (max-width: 700px) {
  .topbar-action-btn { padding: 7px 14px; font-size: 12px; }
}

/* ── Tablet portrait (700–1100 px) — pin sidebars, hide mobile UI ─ */
@media (min-width: 700px) and (max-width: 1100px) {
  /* Hide smartphone-only bottom bar even though the frozen 768 px
     rule sets it to grid. This rule lives later in the cascade so it
     wins without needing weird specificity tricks. */
  .mob-bottom-bar { display: none !important; }
  /* Hamburger + mobile topbar widgets off — desktop-style sidebars
     are the primary nav on tablet portrait. */
  .mob-toggle,
  .mob-hmenu-trigger,
  .mob-topbar-icon,
  .mob-topbar-sheet,
  #mobLeftToggle,
  #mobMenuToggle,
  #mobTopbarSheet { display: none !important; }
  /* Pin sidebars; the frozen mobile rule fixes them off-canvas. */
  .left-panel,
  .left-sidebar {
    position: relative !important;
    transform: none !important;
    width: 240px !important;
    min-width: 240px !important;
    max-width: 240px !important;
    height: auto !important;
    inset: auto !important;
  }
  .right-panel,
  .sheets-sidebar {
    position: relative !important;
    transform: none !important;
    width: 280px !important;
    min-width: 280px !important;
    max-width: 280px !important;
    height: auto !important;
    inset: auto !important;
  }
  /* Heavy desktop-only affordances hidden on tablet */
  .qo-multi-product-grid,
  .ai-generation-panel { display: none !important; }
  /* Topbar — keep text labels but tighten padding */
  .topbar { padding: 0 12px; }
  .topbar-action-btn { padding: 7px 14px; font-size: 12px; }
}

/* ── Cart overlay internal scroll on short viewports ────────────── */
@media (max-height: 700px) {
  #cartBody {
    max-height: calc(100vh - 80px);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
  #cartFooter {
    flex-shrink: 0;
  }
}



/* ════════════════════════════════════════════════════════════════════
   Button sizing + interaction polish (CSS-only)
   ════════════════════════════════════════════════════════════════════
   Findings from a live audit on a 1440×900 viewport:
     • Topbar action buttons render at 24–25 px tall (way under the
       desktop click-target sweet spot of 32–36 px).
     • Sheet-card action icons (rename / delete / ×) at 18–20 px.
     • Right-sidebar tool rows (Size, Crop Sheet, Products) at 22–28 px.
     • Inline +/− quantity controls at 20 px.
     • Hover/focus states inconsistent (some hairline, some none).
   None of those break functionality — they're just cramped/imprecise.
   This block normalises sizes so:
     • Every primary topbar button ≥ 32 px (≥ 36 px on touch devices).
     • Tool rows + tabs ≥ 30 px.
     • Icon-only buttons ≥ 26 px.
     • Hover state: subtle background lift + 1 px border tint.
     • Focus state: 2 px accent ring (keyboard a11y).
     • Active state: micro-press scale 0.97.
   ════════════════════════════════════════════════════════════════════ */

/* ── Topbar primary actions ──────────────────────────────────────── */
.topbar .topbar-action-btn,
.topbar .btn.btn-sm {
  min-height: 32px;
  height: 32px;
  padding: 0 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 700;
  border-radius: 8px;
  cursor: pointer;
  transition: background 0.12s ease, border-color 0.12s ease,
              transform 0.08s ease, box-shadow 0.12s ease;
}
.topbar .topbar-action-btn:hover,
.topbar .btn.btn-sm:hover {
  filter: brightness(1.08);
}
.topbar .topbar-action-btn:active,
.topbar .btn.btn-sm:active {
  transform: scale(0.97);
}
.topbar .topbar-action-btn:focus-visible,
.topbar .btn.btn-sm:focus-visible {
  outline: 2px solid var(--accent, #7c5cbf);
  outline-offset: 2px;
}

/* ── Right sidebar tool rows + product tabs ─────────────────────── */
.cs-tool-row,
.cs-size-btn {
  min-height: 30px !important;
  padding: 6px 10px !important;
  font-size: 11px !important;
  display: flex;
  align-items: center;
  gap: 6px;
  border-radius: 6px;
  transition: background 0.12s ease, color 0.12s ease;
}
.cs-tool-row:hover,
.cs-size-btn:hover {
  background: rgba(255, 255, 255, 0.06) !important;
  color: var(--text) !important;
}

/* Nesting type pills (Box / Shape / AI) */
.nest-type-btn {
  min-height: 32px !important;
  font-size: 11px !important;
  padding: 6px 10px !important;
  transition: background 0.12s ease, border-color 0.12s ease, transform 0.08s ease;
}
.nest-type-btn:active { transform: scale(0.97); }
.nest-type-btn:focus-visible {
  outline: 2px solid var(--accent, #7c5cbf);
  outline-offset: 1px;
}

/* ── Sheet card mini-action buttons (rename / duplicate / delete) ── */
.sheet-card-top-btn,
.sheet-card-action-btn {
  min-width: 24px !important;
  min-height: 24px !important;
  width: 24px !important;
  height: 24px !important;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  border-radius: 5px;
  transition: background 0.12s ease, color 0.12s ease;
}
.sheet-card-top-btn:hover,
.sheet-card-action-btn:hover {
  background: rgba(255, 255, 255, 0.08) !important;
}

/* New Sheet (+) tile icon */
.sheets-sb-card-add {
  min-width: 28px !important;
  min-height: 28px !important;
  width: 28px !important;
  height: 28px !important;
}

/* ── Inline quantity / numeric +/- controls ─────────────────────── */
.qa-qty-btn,
.qo-qty-btn,
.spin-btn,
button.minus-btn,
button.plus-btn {
  min-width: 26px !important;
  min-height: 26px !important;
  font-size: 14px !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 5px;
  transition: background 0.12s ease, transform 0.08s ease;
}
.qa-qty-btn:active,
.qo-qty-btn:active,
.spin-btn:active {
  transform: scale(0.92);
}

/* ── Canvas Undo/Redo + tool icons ──────────────────────────────── */
.cur-btn {
  min-width: 32px !important;
  min-height: 32px !important;
  width: 32px !important;
  height: 32px !important;
  border-radius: 6px;
  transition: background 0.12s ease, color 0.12s ease, transform 0.08s ease;
}
.cur-btn:hover { background: rgba(255, 255, 255, 0.06); }
.cur-btn:active { transform: scale(0.94); }

/* ── Auto Nest / Auto Fill big buttons — leave at 34 px but add polish */
.quick-order-btn,
.nest-all-btn {
  transition: filter 0.12s ease, transform 0.08s ease, box-shadow 0.12s ease;
}
.quick-order-btn:hover,
.nest-all-btn:hover { filter: brightness(1.06); }
.quick-order-btn:active,
.nest-all-btn:active { transform: translateY(1px); }

/* ── Panel tabs (Designs / Elements) — keep height, add focus ──── */
.panel-tab {
  transition: color 0.12s ease, border-color 0.12s ease;
}
.panel-tab:focus-visible {
  outline: 2px solid var(--accent, #7c5cbf);
  outline-offset: -2px;
}

/* ── Touch devices: bump everything ≥ 36 px (iOS HIG) ──────────── */
@media (hover: none) and (pointer: coarse) {
  .topbar .topbar-action-btn,
  .topbar .btn.btn-sm {
    min-height: 36px;
    height: 36px;
    padding: 0 16px;
  }
  .cs-tool-row,
  .cs-size-btn,
  .nest-type-btn {
    min-height: 36px !important;
    padding: 8px 12px !important;
  }
  .sheet-card-top-btn,
  .sheet-card-action-btn {
    min-width: 30px !important;
    min-height: 30px !important;
    width: 30px !important;
    height: 30px !important;
  }
  .qa-qty-btn,
  .qo-qty-btn,
  .spin-btn {
    min-width: 32px !important;
    min-height: 32px !important;
  }
  .cur-btn {
    min-width: 36px !important;
    min-height: 36px !important;
    width: 36px !important;
    height: 36px !important;
  }
}

/* ── Disabled state — uniform across every button ───────────────── */
button[disabled],
.topbar-action-btn[disabled],
.btn[disabled],
.btn[aria-disabled="true"] {
  opacity: 0.45 !important;
  cursor: not-allowed !important;
  filter: saturate(0.6);
  pointer-events: none;
}

/* ── Loading state helper class — auto-spinner for buttons ──────── */
button.is-loading {
  position: relative;
  color: transparent !important;
  pointer-events: none;
}
button.is-loading::after {
  content: "";
  position: absolute;
  top: 50%; left: 50%;
  width: 14px; height: 14px;
  margin: -7px 0 0 -7px;
  border: 2px solid currentColor;
  border-right-color: transparent;
  border-radius: 50%;
  animation: v2BtnSpin 0.7s linear infinite;
  color: rgba(255, 255, 255, 0.85);
}
@keyframes v2BtnSpin {
  to { tra