/* ═══════════════════════════════════════════════════════════════════
   Playtix — My Account Bento Grid Dashboard
   Version: 2.0.0
   Author: Playtix Dev

   Architecture:
   - Layer 1: Design Tokens (CSS Custom Properties) — light + dark
   - Layer 2: Base Reset & Typography for My Account
   - Layer 3: Sidebar Navigation (clear white card)
   - Layer 4: Bento Grid Dashboard (summary cards)
   - Layer 5: Orders Page (card-style rows)
   - Layer 6: View Order (progress bar, product cards, info grid)
   - Layer 7: Downloads, Addresses, Account Forms, Support
   - Layer 8: Dark Mode Toggle & Transitions
   - Layer 9: Responsive
   ═══════════════════════════════════════════════════════════════════ */

/* ─── Layer 1: Design Tokens ─────────────────────────────────── */

:root {
  /* — Primitives — */
  --ptx-white: #ffffff;
  --ptx-black: #000000;

  /* Neutral scale */
  --ptx-neutral-25:  #fcfcfd;
  --ptx-neutral-50:  #f8f9fb;
  --ptx-neutral-100: #f1f3f5;
  --ptx-neutral-200: #e4e7eb;
  --ptx-neutral-300: #d1d5db;
  --ptx-neutral-400: #9ca3af;
  --ptx-neutral-500: #6b7280;
  --ptx-neutral-600: #4b5563;
  --ptx-neutral-700: #374151;
  --ptx-neutral-800: #1f2937;
  --ptx-neutral-900: #111827;
  --ptx-neutral-950: #0b0f19;

  /* Brand blue — aligned to playtix.com.br primary #2D6BC6 */
  --ptx-blue-50:  #eef4fb;
  --ptx-blue-100: #d4e3f5;
  --ptx-blue-200: #a9c7eb;
  --ptx-blue-400: #5a94d4;
  --ptx-blue-500: #2D6BC6;
  --ptx-blue-600: #2D6BC6;
  --ptx-blue-700: #245aab;

  /* Status */
  --ptx-green-50:  #f0fdf4;
  --ptx-green-100: #dcfce7;
  --ptx-green-500: #22c55e;
  --ptx-green-600: #16a34a;
  --ptx-orange-50:  #fff7ed;
  --ptx-orange-500: #f97316;
  --ptx-red-50:    #fef2f2;
  --ptx-red-500:   #ef4444;
  --ptx-purple-50:  #faf5ff;
  --ptx-purple-500: #a855f7;

  /* — Semantic Tokens (Light Theme) — */
  --ptx-bg:            #FAFAFA;
  --ptx-bg-card:       var(--ptx-white);
  --ptx-bg-sidebar:    var(--ptx-white);
  --ptx-bg-input:      var(--ptx-white);
  --ptx-bg-hover:      var(--ptx-neutral-50);
  --ptx-bg-active:     var(--ptx-blue-50);

  --ptx-text:          #333333;
  --ptx-text-secondary: #767676;
  --ptx-text-muted:    #9ca3af;
  --ptx-text-invert:   var(--ptx-white);

  --ptx-primary:       var(--ptx-blue-600);
  --ptx-primary-hover: var(--ptx-blue-700);
  --ptx-primary-bg:    var(--ptx-blue-50);
  --ptx-primary-light: var(--ptx-blue-100);

  --ptx-border:        var(--ptx-neutral-200);
  --ptx-border-light:  var(--ptx-neutral-100);

  --ptx-shadow-sm:  0 1px 2px rgba(0,0,0,0.05);
  --ptx-shadow-md:  0 1px 3px rgba(0,0,0,0.07), 0 4px 12px rgba(0,0,0,0.05);
  --ptx-shadow-lg:  0 4px 20px rgba(0,0,0,0.08), 0 2px 6px rgba(0,0,0,0.04);
  --ptx-shadow-card: 0 1px 3px rgba(0,0,0,0.06), 0 1px 2px rgba(0,0,0,0.04);

  --ptx-radius-sm:  8px;
  --ptx-radius-md:  12px;
  --ptx-radius-lg:  16px;
  --ptx-radius-xl:  20px;
  --ptx-radius-2xl: 24px;
  --ptx-radius-full: 9999px;

  /* Spacing (8px base) */
  --ptx-sp-1:  4px;
  --ptx-sp-2:  8px;
  --ptx-sp-3:  12px;
  --ptx-sp-4:  16px;
  --ptx-sp-5:  20px;
  --ptx-sp-6:  24px;
  --ptx-sp-8:  32px;
  --ptx-sp-10: 40px;
  --ptx-sp-12: 48px;

  /* Typography */
  --ptx-font: 'Jost', Arial, Helvetica, sans-serif;
  --ptx-font-mono: 'SF Mono', 'Fira Code', 'JetBrains Mono', monospace;

  --ptx-text-xs:   0.75rem;
  --ptx-text-sm:   0.8125rem;
  --ptx-text-base: 0.875rem;
  --ptx-text-md:   1rem;
  --ptx-text-lg:   1.125rem;
  --ptx-text-xl:   1.25rem;
  --ptx-text-2xl:  1.5rem;
  --ptx-text-3xl:  1.875rem;

  /* Transitions */
  --ptx-transition: 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  --ptx-transition-slow: 0.35s cubic-bezier(0.4, 0, 0.2, 1);

  /* Status badges */
  --ptx-status-processing-bg: var(--ptx-blue-50);
  --ptx-status-processing-text: var(--ptx-blue-600);
  --ptx-status-completed-bg: var(--ptx-green-50);
  --ptx-status-completed-text: var(--ptx-green-600);
  --ptx-status-pending-bg: var(--ptx-orange-50);
  --ptx-status-pending-text: var(--ptx-orange-500);
  --ptx-status-cancelled-bg: var(--ptx-red-50);
  --ptx-status-cancelled-text: var(--ptx-red-500);
  --ptx-status-onhold-bg: var(--ptx-purple-50);
  --ptx-status-onhold-text: var(--ptx-purple-500);
}

/* — Dark Theme Tokens — DISABLED (2026-04-13) — */
/* /* DISABLED dark-mode:
[data-theme="dark"] { ... }
*/ */

/* prefers-color-scheme fallback — DISABLED (2026-04-13) */
/* @media (prefers-color-scheme: dark) { ... } */


/* ─── Layer 2: Base Reset for My Account ──────────────────── */

.woocommerce-account .woocommerce-MyAccount-navigation,
.woocommerce-account .woocommerce-MyAccount-content,
.woocommerce-account .entry-content {
  font-family: var(--ptx-font) !important;
  color: var(--ptx-text);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Full-width background — more visible neutral */
body.woocommerce-account,
.woocommerce-account .site-content,
.woocommerce-account .main-page-wrapper,
.woocommerce-account .wd-page-content {
  background-color: var(--ptx-bg) !important;
  transition: background-color var(--ptx-transition-slow);
}

/* Remove default WoodMart page title in my account */
.woocommerce-account .page-title,
.woocommerce-account .wd-page-title,
.woocommerce-account .wd-page-title-el,
.woocommerce-account .page-title-default,
.woocommerce-account .entry-content > .woocommerce > .page-title,
body.woocommerce-account .wd-page-title,
.woocommerce-account .woocommerce-MyAccount-title.entry-title,
.woocommerce-account h3.woocommerce-MyAccount-title {
  display: none !important;
}

/* Container: flex layout for sidebar + content */
.woocommerce-account .entry-content > .woocommerce {
  display: flex;
  gap: var(--ptx-sp-8);
  max-width: 1280px;
  margin: 0 auto;
  padding: var(--ptx-sp-8) var(--ptx-sp-6);
  align-items: flex-start;
}


/* ─── Layer 3: Sidebar Navigation (CLEAR WHITE CARD) ─────── */

.woocommerce-account .woocommerce-MyAccount-navigation {
  width: 260px;
  min-width: 260px;
  background: var(--ptx-bg-sidebar);
  border-radius: var(--ptx-radius-2xl);
  box-shadow: var(--ptx-shadow-md);
  border: 1px solid var(--ptx-border-light);
  padding: var(--ptx-sp-5) var(--ptx-sp-3);
  padding-top: 0;
  position: sticky;
  top: 130px;
  transition: background-color var(--ptx-transition-slow), box-shadow var(--ptx-transition), border-color var(--ptx-transition);
  overflow: hidden;
}

/* "Minha Conta" title integrated inside the nav card */
.woocommerce-account .woocommerce-MyAccount-navigation::before {
  content: 'Minha Conta';
  display: block;
  font-size: var(--ptx-text-lg);
  font-weight: 700;
  color: var(--ptx-text);
  padding: var(--ptx-sp-5) var(--ptx-sp-4) var(--ptx-sp-3) var(--ptx-sp-4);
  margin-bottom: var(--ptx-sp-2);
  border-bottom: 1px solid var(--ptx-border-light);
  letter-spacing: -0.01em;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li {
  margin: 2px 0 !important;
  padding: 0 !important;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
  display: flex;
  align-items: center;
  gap: var(--ptx-sp-3);
  padding: 10px var(--ptx-sp-4) !important;
  border-radius: var(--ptx-radius-md) !important;
  color: var(--ptx-text-secondary) !important;
  font-size: var(--ptx-text-base) !important;
  font-weight: 500 !important;
  text-decoration: none !important;
  transition: all var(--ptx-transition) !important;
  line-height: 1.4;
  border: none !important;
  border-bottom: none !important;
  background: transparent !important;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover {
  background: var(--ptx-bg-hover) !important;
  color: var(--ptx-text) !important;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation ul li a[aria-current="page"] {
  background: var(--ptx-bg-active) !important;
  color: var(--ptx-primary) !important;
  font-weight: 600 !important;
}

/* Nav icons */
.woocommerce-account .woocommerce-MyAccount-navigation ul li a::before {
  content: '';
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  background-size: 20px 20px;
  background-repeat: no-repeat;
  background-position: center;
  opacity: 0.55;
  transition: opacity var(--ptx-transition);
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover::before,
.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a::before {
  opacity: 1;
}

/* Dark mode icon filter */
/* DISABLED dark-mode:
[data-theme="dark"] .woocommerce-account .woocommerce-MyAccount-navigation ul li a::before {
  filter: invert(0.7);
}
*/
/* DISABLED dark-mode:
[data-theme="dark"] .woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a::before {
  filter: invert(0.5) sepia(1) hue-rotate(190deg) saturate(3);
}
*/

/* Icon per menu item */
.woocommerce-MyAccount-navigation li.woocommerce-MyAccount-navigation-link--dashboard a::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23374151' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='3' width='7' height='7' rx='1'/%3E%3Crect x='14' y='3' width='7' height='7' rx='1'/%3E%3Crect x='3' y='14' width='7' height='7' rx='1'/%3E%3Crect x='14' y='14' width='7' height='7' rx='1'/%3E%3C/svg%3E");
}
.woocommerce-MyAccount-navigation li.woocommerce-MyAccount-navigation-link--orders a::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23374151' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 2 3 6v14a2 2 0 0 0 2 2h14a2 2 0 0 0 2-2V6l-3-4z'/%3E%3Cline x1='3' y1='6' x2='21' y2='6'/%3E%3Cpath d='M16 10a4 4 0 0 1-8 0'/%3E%3C/svg%3E");
}
.woocommerce-MyAccount-navigation li.woocommerce-MyAccount-navigation-link--downloads a::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23374151' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4'/%3E%3Cpolyline points='7 10 12 15 17 10'/%3E%3Cline x1='12' y1='15' x2='12' y2='3'/%3E%3C/svg%3E");
}
.woocommerce-MyAccount-navigation li.woocommerce-MyAccount-navigation-link--edit-address a::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23374151' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 10c0 7-9 13-9 13s-9-6-9-13a9 9 0 0 1 18 0z'/%3E%3Ccircle cx='12' cy='10' r='3'/%3E%3C/svg%3E");
}
.woocommerce-MyAccount-navigation li.woocommerce-MyAccount-navigation-link--edit-account a::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23374151' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 21v-2a4 4 0 0 0-4-4H8a4 4 0 0 0-4 4v2'/%3E%3Ccircle cx='12' cy='7' r='4'/%3E%3C/svg%3E");
}
.woocommerce-MyAccount-navigation li.woocommerce-MyAccount-navigation-link--customer-logout a::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23ef4444' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M9 21H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h4'/%3E%3Cpolyline points='16 17 21 12 16 7'/%3E%3Cline x1='21' y1='12' x2='9' y2='12'/%3E%3C/svg%3E");
}
.woocommerce-MyAccount-navigation li.woocommerce-MyAccount-navigation-link--pgly-pix-receipt a::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 512 512' fill='%23374151'%3E%3Cpath d='M242.47 293.57Q252.49 284.56 263.51 293.57L340.67 370.72Q362.71 391.77 393.77 392.77H408.8L311.61 489.96Q287.56 512 256.5 512Q225.44 512 201.39 489.96L103.2 391.77H113.22Q143.28 391.77 166.32 369.72L242.47 293.57ZM263.51 219.43Q252.49 227.44 242.47 219.43L166.32 142.28Q144.28 120.23 113.22 120.23H103.2L201.39 23.05Q225.44 0 256.5 0Q287.56 0 311.61 23.05L408.8 120.23H393.77Q362.71 120.23 340.67 142.28L263.51 219.43ZM113.22 143.28Q134.26 143.28 150.29 158.31L226.44 235.46Q238.47 245.48 253.5 246.48Q267.52 245.48 279.55 235.46L356.7 158.31Q371.73 143.28 393.77 143.28H430.84L489.96 201.39Q512 225.44 512 256.5Q512 287.56 489.96 311.61L430.84 369.72H393.77Q371.73 369.72 356.7 354.69L279.55 277.54Q267.52 266.52 252.49 266.52Q237.46 266.52 226.44 277.54L150.29 353.69Q134.26 368.72 113.22 369.72H81.16L23.05 311.61Q0 287.56 0 256.5Q0 225.44 23.05 201.39L81.16 143.28H113.22Z'/%3E%3C/svg%3E");
}
.woocommerce-MyAccount-navigation li.woocommerce-MyAccount-navigation-link--support-genix a::before,
.woocommerce-MyAccount-navigation li.woocommerce-MyAccount-navigation-link--genix a::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23374151' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cpath d='M9.09 9a3 3 0 0 1 5.83 1c0 2-3 3-3 3'/%3E%3Cline x1='12' y1='17' x2='12.01' y2='17'/%3E%3C/svg%3E");
}
.woocommerce-MyAccount-navigation li.woocommerce-MyAccount-navigation-link--wishlist a::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23374151' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20.84 4.61a5.5 5.5 0 0 0-7.78 0L12 5.67l-1.06-1.06a5.5 5.5 0 0 0-7.78 7.78l1.06 1.06L12 21.23l7.78-7.78 1.06-1.06a5.5 5.5 0 0 0 0-7.78z'/%3E%3C/svg%3E");
}
.woocommerce-MyAccount-navigation li.woocommerce-MyAccount-navigation-link--payment-methods a::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23374151' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='1' y='4' width='22' height='16' rx='2' ry='2'/%3E%3Cline x1='1' y1='10' x2='23' y2='10'/%3E%3C/svg%3E");
}

/* Logout styling */
.woocommerce-MyAccount-navigation li.woocommerce-MyAccount-navigation-link--customer-logout {
  margin-top: var(--ptx-sp-3) !important;
  border-top: 1px solid var(--ptx-border-light) !important;
  padding-top: var(--ptx-sp-3) !important;
}
.woocommerce-MyAccount-navigation li.woocommerce-MyAccount-navigation-link--customer-logout a {
  color: var(--ptx-red-500) !important;
}
.woocommerce-MyAccount-navigation li.woocommerce-MyAccount-navigation-link--customer-logout a:hover {
  background: var(--ptx-red-50) !important;
}
/* DISABLED dark-mode:
[data-theme="dark"] .woocommerce-MyAccount-navigation li.woocommerce-MyAccount-navigation-link--customer-logout a:hover {
  background: rgba(239, 68, 68, 0.1) !important;
}
*/
/* DISABLED dark-mode:
[data-theme="dark"] .woocommerce-MyAccount-navigation li.woocommerce-MyAccount-navigation-link--customer-logout a::before {
  filter: none !important;
}
*/


/* ─── Layer 4: Content Area ──────────────────────────────── */

.woocommerce-account .woocommerce-MyAccount-content {
  flex: 1;
  min-width: 0;
}


/* ─── BENTO CARD base style ─────────────────────────────── */

.ptx-bento-card {
  background: var(--ptx-bg-card);
  border-radius: var(--ptx-radius-xl);
  box-shadow: var(--ptx-shadow-card);
  border: 1px solid var(--ptx-border-light);
  padding: var(--ptx-sp-6);
  transition: background-color var(--ptx-transition-slow), box-shadow var(--ptx-transition), border-color var(--ptx-transition);
}

.ptx-bento-card:hover {
  box-shadow: var(--ptx-shadow-md);
}

.ptx-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--ptx-sp-4);
  padding-bottom: var(--ptx-sp-3);
  border-bottom: 1px solid var(--ptx-border-light);
}

.ptx-card-header h3 {
  display: flex;
  align-items: center;
  gap: var(--ptx-sp-2);
  font-size: var(--ptx-text-md);
  font-weight: 700;
  color: var(--ptx-text);
  margin: 0;
}

.ptx-card-header h3 svg {
  color: var(--ptx-primary);
  flex-shrink: 0;
}

.ptx-card-link {
  font-size: var(--ptx-text-sm);
  font-weight: 600;
  color: var(--ptx-primary);
  text-decoration: none;
  transition: color var(--ptx-transition);
  white-space: nowrap;
}
.ptx-card-link:hover {
  color: var(--ptx-primary-hover);
}


/* ─── Dashboard Bento Grid ──────────────────────────────── */

.ptx-dashboard-bento {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--ptx-sp-5);
}

.ptx-card-wide {
  grid-column: 1 / -1;
}

/* Welcome Card */
.ptx-card-welcome {
  display: flex;
  align-items: center;
  gap: var(--ptx-sp-5);
  padding: var(--ptx-sp-6) var(--ptx-sp-8);
}

.ptx-welcome-avatar img {
  width: 64px;
  height: 64px;
  border-radius: var(--ptx-radius-full);
  object-fit: cover;
  border: 3px solid var(--ptx-primary-bg);
}

.ptx-welcome-info h2 {
  font-size: var(--ptx-text-xl);
  font-weight: 700;
  color: var(--ptx-text);
  margin: 0 0 4px 0;
}

.ptx-welcome-meta {
  font-size: var(--ptx-text-sm);
  color: var(--ptx-text-muted);
  margin: 0 0 4px 0;
}

.ptx-welcome-sub {
  font-size: var(--ptx-text-sm);
  color: var(--ptx-text-muted);
  margin: 0;
}
.ptx-welcome-sub a {
  color: var(--ptx-primary);
  text-decoration: none;
  font-weight: 500;
}

/* Stats Card */
.ptx-card-stats {
  display: flex;
  gap: var(--ptx-sp-6);
  align-items: center;
  justify-content: center;
  padding: var(--ptx-sp-6);
}

.ptx-stat-item {
  display: flex;
  align-items: center;
  gap: var(--ptx-sp-3);
}

.ptx-stat-icon {
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--ptx-radius-md);
  background: var(--ptx-primary-bg);
  color: var(--ptx-primary);
  flex-shrink: 0;
}
.ptx-stat-icon--green {
  background: var(--ptx-green-50);
  color: var(--ptx-green-600);
}
/* DISABLED dark-mode:
[data-theme="dark"] .ptx-stat-icon--green {
  background: rgba(34, 197, 94, 0.12);
}
*/

.ptx-stat-data {
  display: flex;
  flex-direction: column;
}

.ptx-stat-value {
  font-size: var(--ptx-text-lg);
  font-weight: 700;
  color: var(--ptx-text);
  line-height: 1.2;
}
.ptx-stat-value .woocommerce-Price-amount { font-size: inherit; font-weight: inherit; }

.ptx-stat-label {
  font-size: var(--ptx-text-xs);
  color: var(--ptx-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-weight: 500;
}

/* Orders list in dashboard */
.ptx-orders-list {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.ptx-order-row {
  display: flex;
  align-items: center;
  gap: var(--ptx-sp-4);
  padding: var(--ptx-sp-3) var(--ptx-sp-4);
  border-radius: var(--ptx-radius-md);
  text-decoration: none;
  transition: background var(--ptx-transition);
}
.ptx-order-row:hover {
  background: var(--ptx-bg-hover);
}

.ptx-order-thumb {
  width: 44px;
  height: 44px;
  border-radius: var(--ptx-radius-sm);
  overflow: hidden;
  flex-shrink: 0;
  background: var(--ptx-bg-hover);
}
.ptx-order-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.ptx-order-thumb-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--ptx-text-muted);
}

.ptx-order-info {
  display: flex;
  flex-direction: column;
  min-width: 90px;
}
.ptx-order-number {
  font-weight: 600;
  font-size: var(--ptx-text-sm);
  color: var(--ptx-text);
}
.ptx-order-date {
  font-size: var(--ptx-text-xs);
  color: var(--ptx-text-muted);
}

.ptx-order-details {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.ptx-order-product-name {
  font-size: var(--ptx-text-sm);
  color: var(--ptx-text-secondary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ptx-order-total {
  font-size: var(--ptx-text-sm);
  font-weight: 600;
  color: var(--ptx-text);
}

/* Status badges */
.ptx-status-badge {
  display: inline-flex;
  align-items: center;
  font-size: var(--ptx-text-xs);
  font-weight: 600;
  padding: 4px 12px;
  border-radius: var(--ptx-radius-full);
  white-space: nowrap;
  line-height: 1.4;
}
.ptx-status-badge--lg {
  font-size: var(--ptx-text-sm);
  padding: 6px 16px;
}
.ptx-status-processing {
  background: var(--ptx-status-processing-bg);
  color: var(--ptx-status-processing-text);
}
.ptx-status-completed {
  background: var(--ptx-status-completed-bg);
  color: var(--ptx-status-completed-text);
}
.ptx-status-pending {
  background: var(--ptx-status-pending-bg);
  color: var(--ptx-status-pending-text);
}
.ptx-status-onhold {
  background: var(--ptx-status-onhold-bg);
  color: var(--ptx-status-onhold-text);
}
.ptx-status-cancelled {
  background: var(--ptx-status-cancelled-bg);
  color: var(--ptx-status-cancelled-text);
}

/* Address preview card */
.ptx-address-preview {
  font-style: normal;
  color: var(--ptx-text-secondary);
  font-size: var(--ptx-text-base);
  line-height: 1.7;
}

/* Account info */
.ptx-account-info {
  display: flex;
  flex-direction: column;
  gap: var(--ptx-sp-3);
}
.ptx-account-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--ptx-sp-2) 0;
}
.ptx-account-label {
  font-size: var(--ptx-text-sm);
  color: var(--ptx-text-muted);
  font-weight: 500;
}
.ptx-account-value {
  font-size: var(--ptx-text-base);
  color: var(--ptx-text);
  font-weight: 500;
}

/* Quick actions */
.ptx-quick-actions {
  display: flex;
  gap: var(--ptx-sp-3);
  flex-wrap: wrap;
}
.ptx-quick-action {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--ptx-sp-2);
  padding: var(--ptx-sp-4) var(--ptx-sp-5);
  border-radius: var(--ptx-radius-lg);
  background: var(--ptx-bg-hover);
  border: 1px solid var(--ptx-border-light);
  text-decoration: none;
  transition: all var(--ptx-transition);
  min-width: 80px;
  flex: 1;
}
.ptx-quick-action:hover {
  background: var(--ptx-primary-bg);
  border-color: var(--ptx-primary);
  transform: translateY(-2px);
  box-shadow: var(--ptx-shadow-sm);
}
.ptx-qa-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
}
.ptx-qa-icon svg {
  width: 24px;
  height: 24px;
  stroke: var(--ptx-neutral-400);
  stroke-width: 1.5;
  transition: stroke 0.2s ease;
}
.ptx-quick-action:hover .ptx-qa-icon svg {
  stroke: var(--ptx-primary);
}
.ptx-qa-label {
  font-size: var(--ptx-text-xs);
  font-weight: 600;
  color: var(--ptx-text-secondary);
}
.ptx-quick-action:hover .ptx-qa-label {
  color: var(--ptx-primary);
}

/* Empty state */
.ptx-empty-state {
  text-align: center;
  padding: var(--ptx-sp-10) var(--ptx-sp-6);
  color: var(--ptx-text-muted);
}
.ptx-empty-state svg {
  margin-bottom: var(--ptx-sp-4);
  opacity: 0.3;
}
.ptx-empty-state h3 {
  font-size: var(--ptx-text-lg);
  font-weight: 600;
  color: var(--ptx-text);
  margin: 0 0 var(--ptx-sp-2) 0;
}
.ptx-empty-state p {
  margin: 0 0 var(--ptx-sp-6) 0;
  color: var(--ptx-text-secondary);
}

/* Buttons */
.ptx-btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 24px;
  background: var(--ptx-primary);
  color: var(--ptx-text-invert) !important;
  border: none;
  border-radius: var(--ptx-radius-sm);
  font-size: var(--ptx-text-base);
  font-weight: 600;
  cursor: pointer;
  transition: all var(--ptx-transition);
  text-decoration: none;
  font-family: var(--ptx-font);
}
.ptx-btn-primary:hover {
  background: var(--ptx-primary-hover);
  transform: translateY(-1px);
  box-shadow: var(--ptx-shadow-md);
}

.ptx-btn-secondary {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  border-radius: var(--ptx-radius-sm);
  font-size: var(--ptx-text-sm);
  font-weight: 600;
  border: 1px solid var(--ptx-border);
  background: var(--ptx-bg-card);
  color: var(--ptx-text);
  text-decoration: none;
  transition: all var(--ptx-transition);
}
.ptx-btn-secondary:hover {
  border-color: var(--ptx-primary);
  color: var(--ptx-primary);
}

.ptx-text-muted {
  color: var(--ptx-text-muted);
  font-size: var(--ptx-text-sm);
}


/* ─── Layer 5: Orders Page (Card Layout) ────────────────── */

.ptx-orders-page .ptx-orders-header h2 {
  font-size: var(--ptx-text-2xl);
  font-weight: 700;
  color: var(--ptx-text);
  margin: 0 0 var(--ptx-sp-5) 0;
}

.ptx-orders-cards {
  display: flex;
  flex-direction: column;
  gap: var(--ptx-sp-4);
}

.ptx-order-card {
  padding: 0;
  overflow: hidden;
}

.ptx-order-card-main {
  display: flex;
  align-items: center;
  gap: var(--ptx-sp-5);
  padding: var(--ptx-sp-5) var(--ptx-sp-6);
}

.ptx-order-card-thumb {
  width: 64px;
  height: 64px;
  border-radius: var(--ptx-radius-md);
  overflow: hidden;
  flex-shrink: 0;
  background: var(--ptx-bg-hover);
  position: relative;
}
.ptx-order-card-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.ptx-order-item-badge {
  position: absolute;
  bottom: -2px;
  right: -2px;
  background: var(--ptx-primary);
  color: var(--ptx-text-invert);
  font-size: 10px;
  font-weight: 700;
  padding: 1px 5px;
  border-radius: var(--ptx-radius-full);
  line-height: 1.4;
}

.ptx-order-card-body {
  flex: 1;
  min-width: 0;
}

.ptx-order-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--ptx-sp-3);
  margin-bottom: 4px;
}

.ptx-order-card-number {
  font-size: var(--ptx-text-md);
  font-weight: 700;
  color: var(--ptx-primary);
  text-decoration: none;
}
.ptx-order-card-number:hover {
  color: var(--ptx-primary-hover);
}

.ptx-order-card-product {
  font-size: var(--ptx-text-sm);
  color: var(--ptx-text-secondary);
  margin: 0 0 6px 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.ptx-order-card-meta {
  display: flex;
  align-items: center;
  gap: var(--ptx-sp-4);
}
.ptx-order-card-date {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: var(--ptx-text-xs);
  color: var(--ptx-text-muted);
}
.ptx-order-card-date svg {
  flex-shrink: 0;
}
.ptx-order-card-total {
  font-size: var(--ptx-text-base);
  font-weight: 700;
  color: var(--ptx-text);
}

.ptx-order-card-actions {
  display: flex;
  gap: var(--ptx-sp-2);
  padding: var(--ptx-sp-3) var(--ptx-sp-6);
  background: var(--ptx-bg-hover);
  border-top: 1px solid var(--ptx-border-light);
}
.ptx-order-action {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 6px 14px;
  border-radius: var(--ptx-radius-sm);
  font-size: var(--ptx-text-xs);
  font-weight: 600;
  color: var(--ptx-text-secondary);
  text-decoration: none;
  transition: all var(--ptx-transition);
  background: var(--ptx-bg-card);
  border: 1px solid var(--ptx-border);
}
.ptx-order-action:hover {
  border-color: var(--ptx-primary);
  color: var(--ptx-primary);
}

.ptx-empty-state-card {
  padding: 0;
}

.ptx-pagination {
  display: flex;
  justify-content: center;
  gap: var(--ptx-sp-3);
  margin-top: var(--ptx-sp-6);
}


/* ─── Layer 6: View Order (Progress Bar + Product Cards) ── */

.ptx-view-order {
  display: flex;
  flex-direction: column;
  gap: var(--ptx-sp-5);
}

/* Order Header */
.ptx-order-header {
  padding: var(--ptx-sp-6) var(--ptx-sp-8);
}
.ptx-order-header-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--ptx-sp-4);
}
.ptx-order-header h2 {
  font-size: var(--ptx-text-2xl);
  font-weight: 700;
  color: var(--ptx-text);
  margin: 0 0 4px 0;
}
.ptx-order-date {
  font-size: var(--ptx-text-sm);
  color: var(--ptx-text-muted);
  margin: 0;
}

/* ── Progress Bar ── */
.ptx-order-progress-card {
  padding: var(--ptx-sp-8);
}

.ptx-progress-title {
  font-size: var(--ptx-text-md);
  font-weight: 700;
  color: var(--ptx-text);
  margin: 0 0 var(--ptx-sp-8) 0;
  text-align: center;
}

.ptx-progress-bar {
  position: relative;
  display: flex;
  justify-content: space-between;
  padding: 0 var(--ptx-sp-4);
}

.ptx-progress-track {
  position: absolute;
  top: 17px;
  left: calc(6.25% + 8px);
  right: calc(6.25% + 8px);
  height: 4px;
  background: var(--ptx-border);
  border-radius: 2px;
  z-index: 0;
}

.ptx-progress-fill {
  height: 100%;
  background: var(--ptx-primary);
  border-radius: 2px;
  transition: width 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

.ptx-progress-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--ptx-sp-3);
  position: relative;
  z-index: 1;
  flex: 1;
}

.ptx-step-circle {
  width: 34px;
  height: 34px;
  border-radius: var(--ptx-radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--ptx-text-xs);
  font-weight: 700;
  transition: all 0.4s ease;
  border: 3px solid var(--ptx-border);
  background: var(--ptx-bg-card);
  color: var(--ptx-text-muted);
}

.ptx-step-completed .ptx-step-circle {
  background: var(--ptx-primary);
  border-color: var(--ptx-primary);
  color: var(--ptx-text-invert);
}

.ptx-step-active .ptx-step-circle {
  border-color: var(--ptx-primary);
  color: var(--ptx-primary);
  box-shadow: 0 0 0 4px var(--ptx-primary-bg);
  animation: ptx-pulse 2s infinite;
}

@keyframes ptx-pulse {
  0%, 100% { box-shadow: 0 0 0 4px var(--ptx-primary-bg); }
  50% { box-shadow: 0 0 0 8px transparent; }
}

.ptx-step-number {
  font-size: var(--ptx-text-sm);
}

.ptx-step-label {
  font-size: 0.625rem;
  font-weight: 600;
  color: var(--ptx-text-muted);
  text-align: center;
  max-width: 85px;
  line-height: 1.3;
}
.ptx-step-completed .ptx-step-label,
.ptx-step-active .ptx-step-label {
  color: var(--ptx-text);
}

/* ── Tracking Code Badge ── */
.ptx-tracking-info {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--ptx-sp-3);
  margin-top: var(--ptx-sp-5);
  padding-top: var(--ptx-sp-4);
  border-top: 1px solid var(--ptx-border-light);
}
.ptx-tracking-info svg {
  flex-shrink: 0;
  color: var(--ptx-primary);
}
.ptx-tracking-code {
  font-family: var(--ptx-font-mono);
  font-size: var(--ptx-text-sm);
  font-weight: 600;
  color: var(--ptx-primary);
  background: var(--ptx-primary-bg);
  padding: var(--ptx-sp-1) var(--ptx-sp-3);
  border-radius: var(--ptx-radius-sm);
  letter-spacing: 0.05em;
}
.ptx-tracking-label {
  font-size: var(--ptx-text-sm);
  color: var(--ptx-text-secondary);
  font-weight: 500;
}



/* ── Product Cards ── */
.ptx-product-cards {
  display: flex;
  flex-direction: column;
  gap: var(--ptx-sp-3);
}

.ptx-product-card {
  display: flex;
  align-items: center;
  gap: var(--ptx-sp-4);
  padding: var(--ptx-sp-4);
  border-radius: var(--ptx-radius-md);
  background: var(--ptx-bg-hover);
  border: 1px solid var(--ptx-border-light);
  transition: all var(--ptx-transition);
}
.ptx-product-card:hover {
  border-color: var(--ptx-border);
  box-shadow: var(--ptx-shadow-sm);
}

.ptx-product-image {
  width: 72px;
  height: 72px;
  border-radius: var(--ptx-radius-md);
  overflow: hidden;
  flex-shrink: 0;
  background: var(--ptx-bg-card);
  border: 1px solid var(--ptx-border-light);
}
.ptx-product-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.ptx-product-image-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--ptx-text-muted);
}

.ptx-product-info {
  flex: 1;
  min-width: 0;
}
.ptx-product-name {
  font-size: var(--ptx-text-base);
  font-weight: 600;
  color: var(--ptx-text);
  margin: 0 0 4px 0;
}
.ptx-product-name a {
  color: inherit;
  text-decoration: none;
}
.ptx-product-name a:hover {
  color: var(--ptx-primary);
}
.ptx-product-meta {
  font-size: var(--ptx-text-xs);
  color: var(--ptx-text-muted);
  margin: 0 0 6px 0;
}
.ptx-product-qty-price {
  display: flex;
  align-items: center;
  gap: var(--ptx-sp-4);
}
.ptx-product-qty {
  font-size: var(--ptx-text-sm);
  color: var(--ptx-text-secondary);
  font-weight: 500;
}
.ptx-product-price {
  font-size: var(--ptx-text-base);
  font-weight: 700;
  color: var(--ptx-text);
}

/* Order totals */
.ptx-order-totals {
  margin-top: var(--ptx-sp-4);
  padding-top: var(--ptx-sp-4);
  border-top: 1px solid var(--ptx-border-light);
}
.ptx-total-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--ptx-sp-2) 0;
}
.ptx-total-label {
  font-size: var(--ptx-text-sm);
  color: var(--ptx-text-secondary);
}
.ptx-total-value {
  font-size: var(--ptx-text-base);
  color: var(--ptx-text);
  font-weight: 500;
}
.ptx-total-row--grand {
  padding-top: var(--ptx-sp-3);
  margin-top: var(--ptx-sp-2);
  border-top: 2px solid var(--ptx-border);
}
.ptx-total-row--grand .ptx-total-label {
  font-size: var(--ptx-text-md);
  font-weight: 700;
  color: var(--ptx-text);
}
.ptx-total-row--grand .ptx-total-value {
  font-size: var(--ptx-text-xl);
  font-weight: 700;
  color: var(--ptx-primary);
}

/* Info grid (billing, shipping, payment) */
.ptx-order-info-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--ptx-sp-5);
}

.ptx-card-customer address {
  font-style: normal;
  color: var(--ptx-text-secondary);
  font-size: var(--ptx-text-base);
  line-height: 1.7;
}
.ptx-card-customer address strong {
  color: var(--ptx-text);
}

.ptx-payment-method {
  font-size: var(--ptx-text-base);
  color: var(--ptx-text);
  font-weight: 500;
  margin: 0;
}

/* Order notes timeline */
.ptx-notes-timeline {
  display: flex;
  flex-direction: column;
  gap: 0;
  position: relative;
  padding-left: var(--ptx-sp-6);
}
.ptx-notes-timeline::before {
  content: '';
  position: absolute;
  left: 7px;
  top: 4px;
  bottom: 4px;
  width: 2px;
  background: var(--ptx-border);
  border-radius: 1px;
}
.ptx-note-item {
  position: relative;
  padding-bottom: var(--ptx-sp-5);
}
.ptx-note-dot {
  position: absolute;
  left: calc(-1 * var(--ptx-sp-6) + 3px);
  top: 4px;
  width: 10px;
  height: 10px;
  border-radius: var(--ptx-radius-full);
  background: var(--ptx-primary);
  border: 2px solid var(--ptx-bg-card);
}
.ptx-note-date {
  font-size: var(--ptx-text-xs);
  color: var(--ptx-text-muted);
  font-weight: 500;
  display: block;
  margin-bottom: 4px;
}
.ptx-note-text {
  font-size: var(--ptx-text-sm);
  color: var(--ptx-text-secondary);
  line-height: 1.6;
}
.ptx-note-text p { margin: 0; }


/* ─── Layer 7: Downloads, Addresses, Forms, Support ────── */

/* Downloads table */
.woocommerce-account .woocommerce-table--order-downloads {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  background: var(--ptx-bg-card);
  border-radius: var(--ptx-radius-xl);
  box-shadow: var(--ptx-shadow-card);
  border: 1px solid var(--ptx-border-light);
  overflow: hidden;
  transition: background-color var(--ptx-transition-slow);
}
.woocommerce-account .woocommerce-table--order-downloads thead th {
  background: var(--ptx-bg);
  color: var(--ptx-text-secondary);
  font-size: var(--ptx-text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: var(--ptx-sp-3) var(--ptx-sp-4);
  border-bottom: 1px solid var(--ptx-border);
}
.woocommerce-account .woocommerce-table--order-downloads tbody td {
  padding: var(--ptx-sp-4);
  border-bottom: 1px solid var(--ptx-border-light);
  font-size: var(--ptx-text-base);
  color: var(--ptx-text);
}

/* Addresses (WC default page) */
.woocommerce-account .woocommerce-Addresses {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--ptx-sp-5);
}
.woocommerce-account .woocommerce-Addresses .woocommerce-Address {
  background: var(--ptx-bg-card);
  border-radius: var(--ptx-radius-xl);
  box-shadow: var(--ptx-shadow-card);
  border: 1px solid var(--ptx-border-light);
  padding: var(--ptx-sp-6);
  transition: all var(--ptx-transition);
}
.woocommerce-account .woocommerce-Addresses .woocommerce-Address:hover {
  box-shadow: var(--ptx-shadow-md);
}
.woocommerce-account .woocommerce-Addresses .woocommerce-Address header,
.woocommerce-account .woocommerce-Addresses .woocommerce-Address .woocommerce-Address-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--ptx-sp-4);
  padding-bottom: var(--ptx-sp-3);
  border-bottom: 1px solid var(--ptx-border-light);
}
.woocommerce-account .woocommerce-Addresses .woocommerce-Address h3 {
  font-size: var(--ptx-text-md);
  font-weight: 700;
  color: var(--ptx-text);
  margin: 0;
}
.woocommerce-account .woocommerce-Addresses .woocommerce-Address .edit {
  font-size: var(--ptx-text-xs);
  font-weight: 600;
  color: var(--ptx-primary);
  text-decoration: none;
  padding: 4px 12px;
  border-radius: var(--ptx-radius-full);
  border: 1px solid var(--ptx-primary);
  transition: all var(--ptx-transition);
}
.woocommerce-account .woocommerce-Addresses .woocommerce-Address .edit:hover {
  background: var(--ptx-primary);
  color: var(--ptx-text-invert);
}
.woocommerce-account .woocommerce-Addresses address {
  font-style: normal;
  color: var(--ptx-text-secondary);
  font-size: var(--ptx-text-base);
  line-height: 1.7;
}

/* Edit Account / Edit Address Forms */
.woocommerce-account .woocommerce-EditAccountForm,
.woocommerce-account .woocommerce-address-fields {
  background: var(--ptx-bg-card);
  border-radius: var(--ptx-radius-xl);
  box-shadow: var(--ptx-shadow-card);
  border: 1px solid var(--ptx-border-light);
  padding: var(--ptx-sp-8);
  transition: background-color var(--ptx-transition-slow);
}

.woocommerce-account .woocommerce-MyAccount-content h3,
.woocommerce-account .woocommerce-EditAccountForm > fieldset > legend,
.woocommerce-account .woocommerce-MyAccount-content > h2 {
  font-size: var(--ptx-text-xl);
  font-weight: 700;
  color: var(--ptx-text);
  margin: 0 0 var(--ptx-sp-6) 0;
}

.woocommerce-account .woocommerce-EditAccountForm .form-row,
.woocommerce-account .woocommerce-address-fields .form-row {
  margin-bottom: var(--ptx-sp-4);
}
.woocommerce-account .woocommerce-EditAccountForm label,
.woocommerce-account .woocommerce-address-fields label {
  display: block;
  font-size: var(--ptx-text-sm);
  font-weight: 600;
  color: var(--ptx-text-secondary);
  margin-bottom: var(--ptx-sp-1);
}

.woocommerce-account .woocommerce-EditAccountForm input[type="text"],
.woocommerce-account .woocommerce-EditAccountForm input[type="email"],
.woocommerce-account .woocommerce-EditAccountForm input[type="password"],
.woocommerce-account .woocommerce-EditAccountForm input[type="tel"],
.woocommerce-account .woocommerce-EditAccountForm input[type="number"],
.woocommerce-account .woocommerce-EditAccountForm select,
.woocommerce-account .woocommerce-EditAccountForm textarea,
.woocommerce-account .woocommerce-address-fields input[type="text"],
.woocommerce-account .woocommerce-address-fields input[type="email"],
.woocommerce-account .woocommerce-address-fields input[type="tel"],
.woocommerce-account .woocommerce-address-fields input[type="number"],
.woocommerce-account .woocommerce-address-fields select,
.woocommerce-account .woocommerce-address-fields textarea {
  width: 100%;
  padding: 10px var(--ptx-sp-4);
  border: 1px solid var(--ptx-border);
  border-radius: var(--ptx-radius-sm);
  font-size: var(--ptx-text-base);
  color: var(--ptx-text);
  background: var(--ptx-bg-input);
  transition: all var(--ptx-transition);
  font-family: var(--ptx-font);
  box-sizing: border-box;
}
.woocommerce-account .woocommerce-EditAccountForm input:focus,
.woocommerce-account .woocommerce-EditAccountForm select:focus,
.woocommerce-account .woocommerce-address-fields input:focus,
.woocommerce-account .woocommerce-address-fields select:focus {
  outline: none;
  border-color: var(--ptx-primary);
  box-shadow: 0 0 0 3px var(--ptx-primary-bg);
}

/* Submit buttons */
.woocommerce-account .woocommerce-EditAccountForm .woocommerce-Button,
.woocommerce-account .woocommerce-address-fields .woocommerce-Button,
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Button,
.woocommerce-account .woocommerce-MyAccount-content button[type="submit"],
.woocommerce-account .woocommerce-MyAccount-content input[type="submit"] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px var(--ptx-sp-8);
  background: var(--ptx-primary);
  color: var(--ptx-text-invert) !important;
  border: none;
  border-radius: var(--ptx-radius-sm);
  font-size: var(--ptx-text-base);
  font-weight: 600;
  cursor: pointer;
  transition: all var(--ptx-transition);
  font-family: var(--ptx-font);
  min-height: 44px;
}
.woocommerce-account .woocommerce-EditAccountForm .woocommerce-Button:hover,
.woocommerce-account .woocommerce-address-fields .woocommerce-Button:hover,
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Button:hover,
.woocommerce-account .woocommerce-MyAccount-content button[type="submit"]:hover,
.woocommerce-account .woocommerce-MyAccount-content input[type="submit"]:hover {
  background: var(--ptx-primary-hover);
  transform: translateY(-1px);
  box-shadow: var(--ptx-shadow-md);
}

/* Notices */
.woocommerce-account .woocommerce-message,
.woocommerce-account .woocommerce-info {
  background: var(--ptx-bg-card);
  border-radius: var(--ptx-radius-lg);
  box-shadow: var(--ptx-shadow-sm);
  border: 1px solid var(--ptx-border);
  padding: var(--ptx-sp-5) var(--ptx-sp-6);
  color: var(--ptx-text-secondary);
  font-size: var(--ptx-text-base);
  transition: background-color var(--ptx-transition-slow);
}
.woocommerce-account .woocommerce-message::before,
.woocommerce-account .woocommerce-info::before {
  color: var(--ptx-primary);
}
.woocommerce-account .woocommerce-message a.button,
.woocommerce-account .woocommerce-info a.button {
  background: var(--ptx-primary);
  color: var(--ptx-text-invert) !important;
  border-radius: var(--ptx-radius-sm);
  font-weight: 600;
  font-size: var(--ptx-text-sm);
  padding: 8px 20px;
  text-decoration: none;
  border: none;
  transition: background-color var(--ptx-transition);
}
.woocommerce-account .woocommerce-message a.button:hover,
.woocommerce-account .woocommerce-info a.button:hover {
  background: var(--ptx-primary-hover);
}
.woocommerce-account .woocommerce-error {
  background: var(--ptx-red-50);
  border: 1px solid var(--ptx-red-500);
  border-radius: var(--ptx-radius-md);
  padding: var(--ptx-sp-4);
  color: var(--ptx-red-500);
  list-style: none;
  margin-bottom: var(--ptx-sp-4);
}
/* DISABLED dark-mode:
[data-theme="dark"] .woocommerce-account .woocommerce-error {
  background: rgba(239, 68, 68, 0.1);
}
*/

/* Generic bento wrapper for custom endpoint content (support, pix, etc.) */
.woocommerce-account .woocommerce-MyAccount-content > form:not(.woocommerce-EditAccountForm),
.woocommerce-account .woocommerce-MyAccount-content > table,
.woocommerce-account .woocommerce-MyAccount-content > .genix-content,
.woocommerce-account .woocommerce-MyAccount-content > .pgly-wps-fields,
.woocommerce-account .woocommerce-MyAccount-content > div:not(.woocommerce-notices-wrapper):not(.woocommerce-Addresses):not(.woocommerce-order-details):not(.woocommerce-customer-details):not(.ptx-dashboard-bento):not(.ptx-orders-page):not(.ptx-view-order) {
  background: var(--ptx-bg-card);
  border-radius: var(--ptx-radius-xl);
  box-shadow: var(--ptx-shadow-card);
  border: 1px solid var(--ptx-border-light);
  padding: var(--ptx-sp-6);
  transition: background-color var(--ptx-transition-slow);
}

/* Override the default WC order-details/customer-details (used by woocommerce_view_order hook) */
.woocommerce-account .woocommerce-order-details,
.woocommerce-account .woocommerce-customer-details {
  background: var(--ptx-bg-card);
  border-radius: var(--ptx-radius-xl);
  box-shadow: var(--ptx-shadow-card);
  border: 1px solid var(--ptx-border-light);
  padding: var(--ptx-sp-6);
  margin-bottom: var(--ptx-sp-5);
  transition: background-color var(--ptx-transition-slow);
}
.woocommerce-account .woocommerce-order-details h2,
.woocommerce-account .woocommerce-customer-details h2 {
  font-size: var(--ptx-text-lg);
  font-weight: 700;
  color: var(--ptx-text);
  margin: 0 0 var(--ptx-sp-4) 0;
  padding: 0 0 var(--ptx-sp-3) 0;
  border-bottom: 1px solid var(--ptx-border-light);
}

/* Style tables inside order details */
.woocommerce-account .woocommerce-order-details .shop_table,
.woocommerce-account .woocommerce-table--order-details {
  width: 100%;
  border: none !important;
  border-collapse: collapse;
}
.woocommerce-account .woocommerce-table--order-details thead th {
  background: transparent;
  color: var(--ptx-text-secondary);
  font-size: var(--ptx-text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: var(--ptx-sp-3) var(--ptx-sp-2);
  border-bottom: 1px solid var(--ptx-border);
  border-left: none !important;
  border-right: none !important;
}
.woocommerce-account .woocommerce-table--order-details td {
  padding: var(--ptx-sp-3) var(--ptx-sp-2);
  border-bottom: 1px solid var(--ptx-border-light);
  border-left: none !important;
  border-right: none !important;
  color: var(--ptx-text);
  font-size: var(--ptx-text-base);
}
.woocommerce-account .woocommerce-table--order-details tfoot th {
  color: var(--ptx-text-secondary);
  border-left: none !important;
  border-right: none !important;
}
.woocommerce-account .woocommerce-table--order-details tfoot td {
  color: var(--ptx-text);
  font-weight: 600;
  border-left: none !important;
  border-right: none !important;
}


/* ─── Layer 8: Dark Mode Toggle Button ───────────────────── */

.ptx-theme-toggle {
  display: flex;
  align-items: center;
  gap: var(--ptx-sp-2);
  padding: 10px var(--ptx-sp-4);
  margin: var(--ptx-sp-3) var(--ptx-sp-3) 0;
  border-radius: var(--ptx-radius-md);
  border: 1px solid var(--ptx-border-light);
  background: var(--ptx-bg-hover);
  cursor: pointer;
  font-size: var(--ptx-text-sm);
  font-weight: 500;
  color: var(--ptx-text-secondary);
  font-family: var(--ptx-font);
  transition: all var(--ptx-transition);
  width: calc(100% - var(--ptx-sp-6));
  box-sizing: border-box;
}
.ptx-theme-toggle:hover {
  background: var(--ptx-bg-active);
  color: var(--ptx-primary);
  border-color: var(--ptx-primary);
}
.ptx-theme-toggle-icon {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
}
.ptx-theme-toggle .ptx-icon-sun,
/* DISABLED dark-mode:
[data-theme="dark"] .ptx-theme-toggle .ptx-icon-moon {
  display: none;
}
*/
/* DISABLED dark-mode:
[data-theme="dark"] .ptx-theme-toggle .ptx-icon-sun,
.ptx-theme-toggle .ptx-icon-moon {
  display: block;
}
*/
.ptx-theme-toggle .ptx-label-light,
/* DISABLED dark-mode:
[data-theme="dark"] .ptx-theme-toggle .ptx-label-dark {
  display: none;
}
*/
/* DISABLED dark-mode:
[data-theme="dark"] .ptx-theme-toggle .ptx-label-light,
.ptx-theme-toggle .ptx-label-dark {
  display: inline;
}
*/

/* Theme Transition */
.woocommerce-account.ptx-theme-transitioning,
.woocommerce-account.ptx-theme-transitioning * {
  transition: background-color 0.4s ease, color 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease !important;
}


/* ─── WoodMart Overrides (specificity bump) ──────────────── */

.woocommerce-account .woocommerce-MyAccount-navigation {
  border: 1px solid var(--ptx-border-light) !important;
}
body.woocommerce-account .website-wrapper .woocommerce-MyAccount-navigation ul li {
  border-bottom: none !important;
}
body.woocommerce-account .website-wrapper .woocommerce-MyAccount-navigation ul li a {
  border-bottom: none !important;
  padding-left: var(--ptx-sp-4) !important;
}
body.woocommerce-account .shop_table {
  border: none !important;
}
body.woocommerce-account .shop_table th,
body.woocommerce-account .shop_table td {
  border-left: none !important;
  border-right: none !important;
}

/* Select2 */
.woocommerce-account .select2-container--default .select2-selection--single {
  height: 44px;
  border: 1px solid var(--ptx-border);
  border-radius: var(--ptx-radius-sm);
  background: var(--ptx-bg-input);
  padding: var(--ptx-sp-2) var(--ptx-sp-3);
}
.woocommerce-account .select2-container--default .select2-selection--single .select2-selection__rendered {
  color: var(--ptx-text);
  line-height: 28px;
}
.woocommerce-account .select2-container--default .select2-selection--single .select2-selection__arrow {
  height: 42px;
}

/* Pagination */
.woocommerce-account .woocommerce-pagination {
  margin-top: var(--ptx-sp-6);
  text-align: center;
}
.woocommerce-account .woocommerce-pagination a,
.woocommerce-account .woocommerce-pagination span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: var(--ptx-radius-sm);
  font-size: var(--ptx-text-sm);
  font-weight: 500;
  color: var(--ptx-text-secondary);
  text-decoration: none;
  transition: all var(--ptx-transition);
  margin: 0 2px;
}
.woocommerce-account .woocommerce-pagination a:hover {
  background: var(--ptx-bg-hover);
  color: var(--ptx-text);
}
.woocommerce-account .woocommerce-pagination span.current {
  background: var(--ptx-primary);
  color: var(--ptx-text-invert);
}

/* Hide old dashboard paragraphs (template override replaces them) */
.ptx-dashboard-bento + p { display: none; }


/* ─── Layer 9: Responsive ────────────────────────────────── */

/* Tablet */
@media (max-width: 991px) {
  .woocommerce-account .entry-content > .woocommerce {
    flex-direction: column;
    padding: var(--ptx-sp-4);
    gap: var(--ptx-sp-4);
  }

  .woocommerce-account .woocommerce-MyAccount-navigation {
    width: 100% !important;
    min-width: 100% !important;
    position: static;
    border-radius: var(--ptx-radius-xl);
    padding: var(--ptx-sp-3);
  }

  .woocommerce-account .woocommerce-MyAccount-navigation ul {
    display: flex !important;
    flex-wrap: wrap;
    gap: var(--ptx-sp-1);
  }
  .woocommerce-account .woocommerce-MyAccount-navigation ul li {
    flex: 0 0 auto;
  }
  .woocommerce-account .woocommerce-MyAccount-navigation ul li a {
    padding: var(--ptx-sp-2) var(--ptx-sp-3) !important;
    font-size: var(--ptx-text-sm) !important;
    white-space: nowrap;
  }

  .woocommerce-MyAccount-navigation li.woocommerce-MyAccount-navigation-link--customer-logout {
    margin-top: 0 !important;
    border-top: none !important;
    padding-top: 0 !important;
  }

  .ptx-theme-toggle {
    width: auto;
    margin: 0;
  }

  .ptx-dashboard-bento {
    grid-template-columns: 1fr;
  }

  .woocommerce-account .woocommerce-Addresses {
    grid-template-columns: 1fr;
  }

  .ptx-order-info-grid {
    grid-template-columns: 1fr;
  }

  .ptx-progress-step .ptx-step-label {
    font-size: 8px;
    max-width: 58px;
  }
  .ptx-step-circle {
    width: 30px;
    height: 30px;
  }
  .ptx-progress-track {
    top: 15px;
  }
}

/* Mobile */
@media (max-width: 575px) {
  .woocommerce-account .entry-content > .woocommerce {
    padding: var(--ptx-sp-3);
    gap: var(--ptx-sp-3);
  }

  .woocommerce-account .woocommerce-MyAccount-navigation ul {
    overflow-x: auto;
    flex-wrap: nowrap !important;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding-bottom: var(--ptx-sp-1);
  }
  .woocommerce-account .woocommerce-MyAccount-navigation ul::-webkit-scrollbar {
    display: none;
  }
  .woocommerce-account .woocommerce-MyAccount-navigation ul li a::before {
    display: none;
  }
  .woocommerce-account .woocommerce-MyAccount-navigation::before {
    display: none;
  }

  .ptx-bento-card {
    padding: var(--ptx-sp-4);
    border-radius: var(--ptx-radius-lg);
  }

  .ptx-card-welcome {
    flex-direction: column;
    text-align: center;
    padding: var(--ptx-sp-5);
  }

  .ptx-card-stats {
    flex-direction: column;
    gap: var(--ptx-sp-4);
  }

  .ptx-order-row {
    flex-wrap: wrap;
    gap: var(--ptx-sp-2);
  }

  .ptx-order-card-main {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--ptx-sp-3);
    padding: var(--ptx-sp-4);
  }
  .ptx-order-card-thumb {
    width: 56px;
    height: 56px;
  }
  .ptx-order-card-top {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--ptx-sp-2);
  }

  .ptx-order-header {
    padding: var(--ptx-sp-4);
  }
  .ptx-order-header-top {
    flex-direction: column;
    gap: var(--ptx-sp-3);
  }

  .ptx-progress-bar {
    padding: 0;
  }
  .ptx-step-circle {
    width: 26px;
    height: 26px;
  }
  .ptx-step-circle svg {
    width: 11px;
    height: 11px;
  }
  .ptx-step-label {
    font-size: 7px;
    max-width: 42px;
  }
  .ptx-progress-track {
    top: 13px;
  }

  .ptx-product-card {
    flex-direction: column;
    align-items: flex-start;
  }
  .ptx-product-image {
    width: 100%;
    height: 120px;
  }

  .ptx-quick-actions {
    gap: var(--ptx-sp-2);
  }
  .ptx-quick-action {
    padding: var(--ptx-sp-3);
    min-width: 60px;
  }

  .woocommerce-account .woocommerce-EditAccountForm,
  .woocommerce-account .woocommerce-address-fields {
    padding: var(--ptx-sp-4);
  }
  .woocommerce-account .woocommerce-Addresses .woocommerce-Address {
    padding: var(--ptx-sp-4);
  }
  .woocommerce-account .woocommerce-order-details,
  .woocommerce-account .woocommerce-customer-details {
    padding: var(--ptx-sp-4);
  }
}


/* ─── Dark Mode Toggle — HIDDEN (2026-04-13) ─── */
.ptx-theme-toggle { display: none !important; }


/* ─── WoodMart Nav Grid — harmonize with Bento design (2026-04-13) ─── */
.woocommerce-account .wd-my-account-links.wd-nav-my-acc {
  margin-top: var(--ptx-sp-4);
}
.woocommerce-account .wd-my-account-links.wd-nav-my-acc > li {
  background: var(--ptx-bg-card);
  border: 1px solid var(--ptx-border-light);
  border-radius: var(--ptx-radius-lg);
  transition: all var(--ptx-transition);
}
.woocommerce-account .wd-my-account-links.wd-nav-my-acc > li:hover {
  border-color: var(--ptx-primary);
  box-shadow: var(--ptx-shadow-sm);
  transform: translateY(-2px);
}
.woocommerce-account .wd-my-account-links.wd-nav-my-acc > li:hover .wd-nav-icon::before {
  color: var(--ptx-primary);
}
.woocommerce-account .wd-my-account-links.wd-nav-my-acc > li:hover a {
  color: var(--ptx-primary) !important;
}


/* ─── Acesso Rápido — Full Grid Layout (2026-04-13) ─── */
.ptx-quick-actions--grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--ptx-sp-4);
}
.ptx-quick-actions--grid .ptx-quick-action {
  padding: var(--ptx-sp-6) var(--ptx-sp-4);
  min-width: unset;
  flex: unset;
  border-radius: var(--ptx-radius-xl);
  background: var(--ptx-bg-card);
  border: 1px solid var(--ptx-border);
  box-shadow: var(--ptx-shadow-card);
}
.ptx-quick-actions--grid .ptx-qa-icon {
  width: 48px;
  height: 48px;
  margin-bottom: var(--ptx-sp-1);
}
.ptx-quick-actions--grid .ptx-qa-icon svg {
  width: 32px;
  height: 32px;
  stroke-width: 1.25;
}
.ptx-quick-actions--grid .ptx-qa-label {
  font-size: var(--ptx-text-sm);
  font-weight: 500;
  color: var(--ptx-text);
}
.ptx-quick-actions--grid .ptx-quick-action:hover .ptx-qa-label {
  color: var(--ptx-primary);
}

/* Logout action — subtle red on hover */
.ptx-quick-action--logout:hover {
  border-color: var(--ptx-red-500, #ef4444) !important;
  background: var(--ptx-red-50, #fef2f2) !important;
}
.ptx-quick-action--logout:hover .ptx-qa-icon svg {
  stroke: var(--ptx-red-500, #ef4444) !important;
}
.ptx-quick-action--logout:hover .ptx-qa-label {
  color: var(--ptx-red-500, #ef4444) !important;
}

/* Hide WoodMart nav grid — replaced by Acesso Rápido */
.woocommerce-account .woocommerce-MyAccount-content > .wd-my-account-links.wd-nav-my-acc {
  display: none !important;
}

/* Responsive: 2 columns on tablet, full width on mobile */
@media (max-width: 768px) {
  .ptx-quick-actions--grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--ptx-sp-3);
  }
  .ptx-quick-actions--grid .ptx-quick-action {
    padding: var(--ptx-sp-4) var(--ptx-sp-3);
  }
  .ptx-quick-actions--grid .ptx-qa-icon svg {
    width: 28px;
    height: 28px;
  }
}


/* ─── PIX icon — fill-based instead of stroke (2026-04-13) ─── */
.ptx-qa-icon--pix svg {
  fill: var(--ptx-neutral-400);
  stroke: none !important;
  width: 32px;
  height: 32px;
}
.ptx-quick-action:hover .ptx-qa-icon--pix svg {
  fill: var(--ptx-primary);
}
