/*
 Theme Name:   The Only Phone You Need
 Theme URI:    https://theonlyphoneyouneed.com.au
 Description:  Premium refurbished phone store â€” Rehub child theme
 Author:       The Only Phone You Need
 Author URI:   https://theonlyphoneyouneed.com.au
 Template:     rehub-theme
 Version:      1.1.0
 Text Domain:  topyn-child
*/

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');

:root {
  --topyn-primary:   #2563eb;
  --topyn-primary-h: #1d4ed8;
  --topyn-text:      #111827;
  --topyn-muted:     #6b7280;
  --topyn-border:    #e5e7eb;
  --topyn-bg:        #f9fafb;
  --topyn-red:       #dc2626;
  --topyn-green:     #16a34a;
  --topyn-font:      'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

*, *::before, *::after { box-sizing: border-box; }
body { font-family: var(--topyn-font) !important; }
a { transition: color .15s; }
img { max-width: 100%; }
/* ============================================================
   NAVBAR + FOOTER â€” exact React match  (append to style.css)
   ============================================================ */

/* â”€â”€ Reset everything Rehub forces â”€â”€ */
html, body {
  margin: 0 !important; padding: 0 !important;
  max-width: 100% !important; width: 100% !important;
  border: none !important; box-shadow: none !important;
  background: #fff !important; overflow-x: hidden !important;
}
#page, .site, #content, .hfeed,
.rh_wrap, #topyn-page {
  max-width: 100% !important; width: 100% !important;
  margin: 0 !important; padding: 0 !important;
  border: none !important; box-shadow: none !important;
}
#topyn-content { padding: 0 !important; margin: 0 !important; }

/* â”€â”€ Hide Rehub header/footer/panels â”€â”€ */
#site-header, .rh-header-wrap, .rh-topbar, .rehub-header,
#colophon, .rh-footer, .rehub-footer, .rh_footer_wrap,
#rh_search_panel, .rh_search_panel, .rehub-side-panel,
#rehub-side-panel, .side-panel, .off-canvas { display: none !important; }

/* ============================================================
   NAVBAR
   ============================================================ */
.topyn-navbar {
  position: sticky;
  top: 0;
  z-index: 9999;
  background: rgba(255,255,255,0.85);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid #f3f4f6;
  width: 100%;
  box-sizing: border-box;
}

.topyn-nav-container {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 16px;
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

@media (min-width: 640px)  { .topyn-nav-container { padding: 0 24px; } }
@media (min-width: 1024px) { .topyn-nav-container { padding: 0 32px; } }

/* â”€â”€ Logo â”€â”€ */
.topyn-logo {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  text-decoration: none !important;
  flex-shrink: 0 !important;
  color: #111827 !important;
}
.topyn-logo svg { flex-shrink: 0; }
.topyn-logo span {
  font-weight: 700 !important;
  font-size: 1.125rem !important;
  letter-spacing: -.02em !important;
  color: #111827 !important;
  white-space: nowrap !important;
  font-family: var(--topyn-font, 'Inter', sans-serif) !important;
}
/* Custom logo image */
.topyn-logo .custom-logo-link { display: flex; align-items: center;  }
.topyn-logo .custom-logo { height: 36px !important; width: auto !important; display: block; }
.custom-logo-link img { width: 150px; }

/* â”€â”€ Desktop nav links â”€â”€ */
.topyn-nav-links { display: flex; align-items: center; }

ul.topyn-nav-ul {
  display: flex !important;
  align-items: center !important;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  gap: 4px !important;
}
ul.topyn-nav-ul > li { margin: 0 !important; padding: 0 !important; }
ul.topyn-nav-ul > li > a {
  display: block !important;
  padding: 8px 12px !important;
  font-size: 0.9375rem !important;
  font-weight: 500 !important;
  color: #4b5563 !important;
  text-decoration: none !important;
  border-radius: 6px !important;
  transition: color .15s, background .15s !important;
  white-space: nowrap !important;
  font-family: var(--topyn-font, 'Inter', sans-serif) !important;
  background: none !important;
}
ul.topyn-nav-ul > li > a:hover,
ul.topyn-nav-ul > li.current-menu-item > a {
  color: #111827 !important;
  background: none !important;
}
/* Deals â€” red */
ul.topyn-nav-ul > li.topyn-deals-item > a,
ul.topyn-nav-ul > li > a.topyn-deals {
  color: #dc2626 !important;
  font-weight: 600 !important;
}
ul.topyn-nav-ul > li.topyn-deals-item > a:hover { color: #b91c1c !important; }

/* â”€â”€ Right side â”€â”€ */
.topyn-nav-right {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

/* Cart button */
.topyn-cart-link {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 8px;
  color: #4b5563 !important;
  text-decoration: none !important;
  border-radius: 6px;
  transition: color .15s;
}
.topyn-cart-link:hover { color: #111827 !important; }
.topyn-cart-link svg { stroke: currentColor; flex-shrink: 0; }

/* Cart count badge */
.topyn-cart-count {
  position: absolute;
  top: 0; right: 0;
  background: #2563eb;
  color: #fff;
  font-size: 0.625rem;
  font-weight: 700;
  min-width: 16px; height: 16px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 2px;
  line-height: 1;
  border: 2px solid #fff;
  font-family: var(--topyn-font, 'Inter', sans-serif);
}

/* Hamburger */
.topyn-hamburger {
  display: none;
  align-items: center;
  justify-content: center;
  background: none;
  border: none;
  cursor: pointer;
  padding: 8px;
  color: #4b5563;
  border-radius: 6px;
  transition: color .15s;
}
.topyn-hamburger:hover { color: #111827; }
.topyn-hamburger svg { stroke: currentColor; display: block; }

/* â”€â”€ Mobile menu dropdown â”€â”€ */
.topyn-mobile-menu {
  display: none;
  flex-direction: column;
  background: #fff;
  border-top: 1px solid #f3f4f6;
  padding: 8px 16px 16px;
  box-shadow: 0 8px 24px rgba(0,0,0,.08);
}
.topyn-mobile-menu.is-open { display: flex; }

ul.topyn-mobile-ul {
  list-style: none !important;
  margin: 0 !important; padding: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 2px !important;
}
ul.topyn-mobile-ul > li > a {
  display: block !important;
  padding: 10px 12px !important;
  border-radius: 6px !important;
  font-size: 1rem !important;
  font-weight: 500 !important;
  color: #374151 !important;
  text-decoration: none !important;
  transition: background .15s !important;
  font-family: var(--topyn-font, 'Inter', sans-serif) !important;
}
ul.topyn-mobile-ul > li:first-child > a { color: #111827 !important; font-weight: 600 !important; }
ul.topyn-mobile-ul > li > a:hover { background: #f9fafb !important; }
ul.topyn-mobile-ul > li.topyn-deals-item > a { color: #dc2626 !important; }
ul.topyn-mobile-ul > li.topyn-deals-item > a:hover { background: #fef2f2 !important; }

/* â”€â”€ Admin bar offset â”€â”€ */
.admin-bar .topyn-navbar { top: 32px !important; }
@media screen and (max-width: 782px) {
  .admin-bar .topyn-navbar { top: 46px !important; }
}

/* â”€â”€ Responsive nav â”€â”€ */
@media (max-width: 768px) {
  .topyn-nav-links { display: none !important; }
  .topyn-hamburger { display: flex !important; }
}

/* ============================================================
   FOOTER
   ============================================================ */
.topyn-footer {
  background: #f9fafb;
  border-top: 1px solid #e5e7eb;
  padding: 64px 0 32px;
  width: 100%;
  box-sizing: border-box;
}

.topyn-footer-wrap {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 16px;
  box-sizing: border-box;
}
@media (min-width: 640px)  { .topyn-footer-wrap { padding: 0 24px; } }
@media (min-width: 1024px) { .topyn-footer-wrap { padding: 0 32px; } }

/* Grid */
.topyn-footer-grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1fr;
  gap: 32px;
  margin-bottom: 48px;
}

/* Brand col */
.topyn-footer-logo {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  text-decoration: none !important;
  color: #111827 !important;
  margin-bottom: 16px !important;
}
.topyn-footer-logo svg { flex-shrink: 0; }
.topyn-footer-logo span {
  font-weight: 700 !important;
  font-size: 1.125rem !important;
  letter-spacing: -.02em !important;
  color: #111827 !important;
  font-family: var(--topyn-font, 'Inter', sans-serif) !important;
}
.topyn-footer-logo .custom-logo { height: 36px !important; width: auto !important; }

.topyn-footer-brand p {
  font-size: 0.875rem !important;
  color: #4b5563 !important;
  line-height: 1.7 !important;
  margin: 0 0 16px !important;
  margin-top: 16px !important;
}

.topyn-footer-social{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top: 14px;
}
.topyn-footer-social-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 8px 14px;
  border-radius: 999px;
  border: 1px solid #e5e7eb;
  background: #fff;
  color: #111827 !important;
  font-size: 0.875rem;
  font-weight: 600;
  text-decoration: none !important;
  transition: background .15s, border-color .15s, transform .15s;
  font-family: var(--topyn-font, 'Inter', sans-serif) !important;
}
.topyn-footer-social-link:hover{
  background:#f9fafb;
  border-color:#d1d5db;
  transform: translateY(-1px);
}

.topyn-footer-trust {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  padding-top: 8px;
}
.topyn-footer-trust-item {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 0.875rem;
  font-weight: 500;
  color: #111827;
}
.topyn-footer-trust-item svg {
  fill: none;
  flex-shrink: 0;
}
.topyn-footer-trust-item:nth-child(1) > svg {
  stroke: oklch(62.7% .194 149.214);
}
.topyn-footer-trust-item:nth-child(2) > svg {
  stroke: oklch(54.6% .245 262.881);
}

/* Link columns */
.topyn-footer-col h3 {
  font-size: 0.9375rem !important;
  font-weight: 600 !important;
  color: #111827 !important;
  margin: 0 0 16px !important;
  padding: 0 !important;
  font-family: var(--topyn-font, 'Inter', sans-serif) !important;
}
.topyn-footer-col ul {
  list-style: none !important;
  margin: 0 !important; padding: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
}
.topyn-footer-col ul li a {
  font-size: 0.875rem !important;
  color: #4b5563 !important;
  text-decoration: none !important;
  transition: color .15s !important;
  font-family: var(--topyn-font, 'Inter', sans-serif) !important;
}
.topyn-footer-col ul li a:hover { color: #2563eb !important; }

/* Bottom bar */
.topyn-footer-bottom {
  border-top: 1px solid #e5e7eb;
  padding-top: 32px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}
.topyn-footer-bottom p {
  font-size: 0.875rem !important;
  color: #6b7280 !important;
  margin: 0 !important;
}

/* Payment icon placeholders */
.topyn-payment-icons { display: flex; align-items: center; gap: 16px; }
.topyn-pay-icon {
  width: 48px; height: 32px;
  background: #e5e7eb;
  border-radius: 4px;
}

/* â”€â”€ Responsive footer â”€â”€ */
@media (max-width: 1024px) {
  .topyn-footer-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
}
@media (max-width: 640px) {
  .topyn-footer-grid { grid-template-columns: 1fr; }
  .topyn-footer-bottom { flex-direction: column; align-items: flex-start; }
  .topyn-footer { margin-top: 48px; }
}

/* ============================================================
   HOMEPAGE â€” front-page.php
   ============================================================ */

/* â”€â”€ Shared section styles â”€â”€ */
.topyn-section { padding: 70px 0; }
.topyn-section-gray  { background: #f9fafb; }
.topyn-section-white { background: #ffffff; }
.topyn-section-dark  { background: #1e3a8a; }

.topyn-container-narrow { max-width: 896px; }

/* Section headings */
.topyn-section-head {
  display: flex; align-items: flex-end;
  justify-content: space-between; gap: 16px;
  margin-bottom: 48px; flex-wrap: wrap;
}
.topyn-section-head h2 {
  font-size: 1.875rem !important; font-weight: 800 !important;
  color: #111827 !important; margin: 0 !important;
}
.topyn-section-head a {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 0.9375rem; font-weight: 600;
  color: #2563eb !important; text-decoration: none !important;
  transition: color .2s;
}
.topyn-section-head a:hover { color: #1d4ed8 !important; }
.topyn-section-head a svg { width: 16px; height: 16px; stroke: currentColor; fill: none; stroke-width: 2.5; }

.topyn-section-head-center { text-align: center; margin-bottom: 64px; }
.topyn-section-head-center h2,
.topyn-section-head-center-h2 {
  font-size: 1.875rem !important; font-weight: 800 !important;
  color: #111827 !important; margin: 0 0 64px !important;
  text-align: center;
}

/* Grids */
.topyn-grid-3 {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 32px;
}
.topyn-grid-3.topyn-grid-3--single {
  grid-template-columns: minmax(0, 1fr);
  justify-items: center;
}
.topyn-grid-3.topyn-grid-3--single > * {
  width: 100%;
  max-width: 520px;
}
.topyn-grid-3.topyn-grid-3--two {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.topyn-grid-2 {
  display: grid; grid-template-columns: 1fr 1fr; gap: 32px;
}
.topyn-grid-2.topyn-grid-2--single {
  grid-template-columns: minmax(0, 1fr);
  justify-items: center;
}
.topyn-grid-2.topyn-grid-2--single .topyn-promise-card {
  width: 100%;
  max-width: 520px;
}

/* â”€â”€ Buttons â”€â”€ */
.topyn-btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: 8px; padding: 14px 32px;
  border-radius: 50px; font-size: 1.0625rem; font-weight: 700;
  cursor: pointer; transition: all .2s ease;
  text-decoration: none !important; border: 2px solid transparent;
  font-family: var(--topyn-font); white-space: nowrap;
  line-height: 1;
}
.topyn-btn-primary {
  background: #2563eb; color: #fff !important;
  box-shadow: 0 4px 20px rgba(37,99,235,.35);
}
.topyn-btn-primary:hover {
  background: #1d4ed8; color: #fff !important;
  transform: translateY(-2px);
  box-shadow: 0 8px 30px rgba(37,99,235,.45);
}
.topyn-btn-outline {
  background: #fff; color: #374151 !important;
  border-color: #d1d5db;
}
.topyn-btn-outline:hover {
  background: #f9fafb; color: #111827 !important;
}
.topyn-btn-lg { padding: 18px 48px; font-size: 1.125rem; }

/* â”€â”€ 1. HERO â”€â”€ */
.topyn-hero {
  background: #f9fafb;
  padding: 80px 0 120px;
  position: relative; overflow: hidden;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.topyn-hero::before {
  content: '';
  position: absolute; top: -200px; right: -200px;
  width: 500px; height: 500px;
  background: radial-gradient(circle, rgba(37,99,235,.07) 0%, transparent 70%);
  pointer-events: none;
}
.topyn-hero-inner {
  text-align: center; max-width: 720px; margin: 0 auto;
}
.topyn-hero-inner h1 {
  font-size: clamp(2.5rem, 6vw, 3.75rem) !important;
  font-weight: 900 !important; color: #111827 !important;
  line-height: 1.1 !important; letter-spacing: -.03em !important;
  margin: 0 0 24px !important;
}
.topyn-hero-inner h1 span { color: #2563eb; }
.topyn-hero-inner > p {
  font-size: 1.25rem; color: #6b7280;
  line-height: 1.7; margin: 0 0 40px; max-width: 560px;
  margin-left: auto; margin-right: auto;
}
.topyn-hero-btns {
  display: flex; justify-content: center;
  gap: 16px; flex-wrap: wrap; margin-bottom: 48px;
}
.topyn-hero-trust {
  display: flex; justify-content: center;
  gap: 32px; flex-wrap: wrap;
}
.topyn-trust-item {
  display: flex; align-items: center; gap: 8px;
  font-size: 0.9375rem; font-weight: 500; color: #4b5563;
}
.topyn-trust-item svg {
  width: 20px; height: 20px; fill: none;
  stroke-width: 2; stroke-linecap: round; stroke-linejoin: round;
  flex-shrink: 0;
}
.topyn-trust-item:nth-child(1) > svg {
  stroke: oklch(62.7% .194 149.214);
}
.topyn-trust-item:nth-child(2) > svg {
  stroke: oklch(54.6% .245 262.881);
}
.topyn-trust-item:nth-child(3) > svg {
  stroke: oklch(21% .034 264.665);
}

/* â”€â”€ 2. SOCIAL PROOF â”€â”€ */
.topyn-social-proof {
  padding: 48px 0;
  background: #fff;
  border-top: 1px solid #f3f4f6;
  border-bottom: 1px solid #f3f4f6;
}
.topyn-social-inner { text-align: center; }
.topyn-stars {
  display: flex; justify-content: center; gap: 4px; margin-bottom: 12px;
}
.topyn-stars svg { width: 24px; height: 24px; }
.topyn-rating-text {
  font-size: 1.0625rem; font-weight: 600; color: #111827; margin: 0 0 6px;
}
.topyn-rating-sub {
  font-size: 0.875rem; color: #9ca3af; margin: 0;
}

/* â”€â”€ 3. VALUE CARDS â”€â”€ */
.topyn-value-card { text-align: center; }
.topyn-value-icon {
  width: 64px; height: 64px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 24px;
}
.topyn-icon-blue  { background: #dbeafe; }
.topyn-icon-green { background: #dcfce7; }
.topyn-icon-gray  { background: #e5e7eb; }
.topyn-value-icon svg {
  width: 32px; height: 32px; fill: none;
  stroke-width: 2; stroke-linecap: round; stroke-linejoin: round;
}
.topyn-value-card:nth-child(1) .topyn-value-icon > svg {
    stroke: oklch(54.6% .245 262.881);
}
.topyn-value-card:nth-child(2) .topyn-value-icon > svg {
    stroke: oklch(62.7% .194 149.214);
}
.topyn-value-card:nth-child(3) .topyn-value-icon > svg {
    stroke: oklch(21% .034 264.665);
}
.topyn-value-card h3 {
  font-size: 1.1875rem !important; font-weight: 700 !important;
  color: #111827 !important; margin: 0 0 12px !important;
}
.topyn-value-card p { font-size: 0.9375rem; color: #6b7280; line-height: 1.7; margin: 0; }

/* â”€â”€ 4. CATEGORY CARDS â”€â”€ */
.topyn-cat-card {
  display: block; border-radius: 16px; overflow: hidden;
  background: #f9fafb;
  text-decoration: none !important;
  transition: box-shadow .25s ease, transform .25s ease;
  border: 1px solid #f3f4f6;
}
.topyn-cat-card:hover {
  box-shadow: 0 16px 48px rgba(0,0,0,.12);
  transform: translateY(-4px);
}
.topyn-cat-img {
  width: 100%; aspect-ratio: 4/3;
  overflow: hidden; background: #e5e7eb;
}
.topyn-cat-img img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .5s ease; display: block;
}
.topyn-cat-card:hover .topyn-cat-img img { transform: scale(1.06); }
.topyn-cat-body { padding: 24px; }
.topyn-cat-body h3 {
  font-size: 1.1875rem !important; font-weight: 800 !important;
  color: #111827 !important; margin: 0 0 8px !important;
}
.topyn-cat-body p { font-size: 0.9375rem; color: #6b7280; margin: 0; }

/* â”€â”€ 5. WHY REFURBISHED (dark) â”€â”€ */
.topyn-refurb-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 64px; align-items: center;
}
.topyn-refurb-grid.is-no-image {
  grid-template-columns: 1fr;
}
.topyn-refurb-grid.is-no-image .topyn-refurb-content {
  max-width: 920px;
  margin-left: auto;
  margin-right: auto;
}
.topyn-refurb-content h2 {
  font-size: clamp(1.75rem, 3vw, 2.25rem) !important;
  font-weight: 800 !important; color: #fff !important;
  margin: 0 0 32px !important;
}
.topyn-refurb-list { display: flex; flex-direction: column; gap: 32px; }
.topyn-refurb-item { display: flex; gap: 16px; }
.topyn-refurb-icon {
  flex-shrink: 0; margin-top: 2px;
  width: 24px; height: 24px;
}
.topyn-refurb-icon svg {
  width: 24px; height: 24px;
  stroke: oklch(70.7% .165 254.624); fill: none;
  stroke-width: 2; stroke-linecap: round; stroke-linejoin: round;
}
.topyn-refurb-item h4 {
  font-size: 1.125rem !important; font-weight: 700 !important;
  color: #fff !important; margin: 0 0 8px !important;
}
.topyn-refurb-item p { font-size: 0.9375rem; color: #bfdbfe; line-height: 1.7; margin: 0; }
.topyn-refurb-image {
  border-radius: 16px; overflow: hidden;
  box-shadow: 0 24px 64px rgba(0,0,0,.4);
}
.topyn-refurb-image img {
  width: 100%; height: auto; display: block; object-fit: cover;
}

/* â”€â”€ 6. PROMISE CARDS â”€â”€ */
.topyn-promise-card {
  padding: 32px; background: #f9fafb;
  border-radius: 16px; border: 1px solid #f3f4f6;
}
.topyn-promise-card > svg {
  width: 40px; height: 40px; fill: none;
  stroke-width: 2; stroke-linecap: round; stroke-linejoin: round;
  margin-bottom: 16px; display: block;
}
.topyn-promise-card:nth-child(1) > svg {
  stroke: oklch(62.7% .194 149.214);
}

.topyn-promise-card:nth-child(2) > svg {
  stroke: oklch(54.6% .245 262.881);
}
.topyn-promise-card h3 {
  font-size: 1.125rem !important; font-weight: 800 !important;
  color: #111827 !important; margin: 0 0 12px !important;
}
.topyn-promise-card p { font-size: 0.9375rem; color: #6b7280; line-height: 1.7; margin: 0; }

/* â”€â”€ 7. FINAL CTA â”€â”€ */
.topyn-cta-section { border-top: 1px solid #e5e7eb; }
.topyn-cta-inner { text-align: center; }
.topyn-cta-inner h2 {
  font-size: clamp(1.875rem, 4vw, 2.5rem) !important;
  font-weight: 900 !important; color: #111827 !important;
  margin: 0 0 20px !important;
}
.topyn-cta-inner > p {
  font-size: 1.25rem; color: #6b7280;
  margin: 0 0 40px; line-height: 1.6;
}

/* â”€â”€ Responsive homepage â”€â”€ */
@media (max-width: 1024px) {
  .topyn-refurb-grid { gap: 40px; }
}
@media (max-width: 768px) {
  .topyn-section { padding: 64px 0; }
  .topyn-grid-3 { grid-template-columns: 1fr; gap: 24px; }
  .topyn-grid-2 { grid-template-columns: 1fr; }
  .topyn-refurb-grid { grid-template-columns: 1fr; }
  .topyn-refurb-image { order: -1; }
  .topyn-hero { padding: 60px 0 80px; }
  .topyn-hero-trust { gap: 20px; }
}
@media (max-width: 480px) {
  .topyn-hero-btns { flex-direction: column; align-items: center; }
  .topyn-btn { width: 100%; max-width: 320px; justify-content: center; }
}
/* ============================================================
   SHOP PAGE
   ============================================================ */
.topyn-shop-wrap { padding: 60px 0 96px; }

.topyn-shop-archive-desc {
  max-width: 1280px;
  margin: 0 auto 22px;
  padding: 0 16px;
}
@media (min-width: 640px)  { .topyn-shop-archive-desc { padding: 0 24px; } }
@media (min-width: 1024px) { .topyn-shop-archive-desc { padding: 0 32px; } }

.topyn-shop-archive-desc > * {
  background: #f9fafb;
  border: 1px solid #e5e7eb;
  border-radius: 16px;
  padding: 16px 18px;
  color: #4b5563;
  line-height: 1.8;
  font-size: 0.9375rem;
  margin: 0;
}
.topyn-shop-archive-desc p + p { margin-top: 10px; }

.topyn-shop-archive-desc--after{
  margin-top: 18px;
  margin-bottom: 0;
}

.topyn-shop-header {
  display: flex; align-items: baseline;
  justify-content: space-between;
  flex-wrap: wrap; gap: 16px;
  margin-bottom: 32px;
}
.topyn-shop-header h1 {
  font-size: 1.875rem !important; font-weight: 800 !important;
  color: #111827 !important; margin: 0 !important;
  text-transform: capitalize;
}
.topyn-shop-controls {
  display: flex; align-items: center; gap: 16px; flex-wrap: wrap;
}
.topyn-shop-controls .woocommerce-result-count {
  font-size: 0.875rem; color: #6b7280; margin: 0;
}
.topyn-shop-controls .woocommerce-ordering select {
  appearance: none; background: #fff;
  border: 1px solid #d1d5db;
  padding: 8px 36px 8px 14px;
  border-radius: 8px; font-size: 0.9rem;
  font-family: var(--topyn-font); color: #374151;
  outline: none; cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 12px center;
}
.topyn-shop-controls .woocommerce-ordering select:focus { border-color: #2563eb; box-shadow: 0 0 0 2px rgba(37,99,235,.15); }

/* Layout: sidebar + grid */
.topyn-shop-layout { display: grid; grid-template-columns: 240px 1fr; gap: 40px; align-items: start; }

/* Sidebar */
.topyn-shop-sidebar .widget { margin-bottom: 32px; }
.topyn-shop-sidebar .widget-title {
  font-size: 0.9375rem !important; font-weight: 700 !important;
  color: #111827 !important; margin: 0 0 14px !important;
  padding-bottom: 10px !important;
  border-bottom: 2px solid #e5e7eb !important;
}
.topyn-shop-sidebar ul { list-style: none !important; margin: 0 !important; padding: 0 !important; }
.topyn-shop-sidebar ul li { padding: 5px 0 !important; }
.topyn-shop-sidebar ul li a { font-size: 0.875rem !important; color: #4b5563 !important; text-decoration: none !important; transition: color .15s; }
.topyn-shop-sidebar ul li a:hover { color: #2563eb !important; }
.topyn-shop-sidebar .price_slider_wrapper { padding-top: 8px; }

/* Product grid */
.topyn-shop-main ul.products {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 32px !important;
  list-style: none !important;
  margin: 0 !important; padding: 0 !important;
}

/* Product card */
.topyn-product-card {
  display: block; text-decoration: none !important;
  border-radius: 0 !important; /* override WC */
}
.topyn-product-img-wrap {
  display: block; position: relative;
  background: #f3f4f6; border-radius: 16px;
  overflow: hidden; aspect-ratio: 1/1;
  margin-bottom: 16px;
}
.topyn-product-img-wrap img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .5s ease; display: block;
}
.topyn-product-card:hover .topyn-product-img-wrap img { transform: scale(1.05); }

.topyn-condition-badge {
  position: absolute; top: 12px; left: 12px;
  background: rgba(255,255,255,.9);
  backdrop-filter: blur(4px);
  padding: 3px 10px; border-radius: 6px;
  font-size: 0.75rem; font-weight: 600;
  color: #111827; box-shadow: 0 1px 4px rgba(0,0,0,.1);
}
.topyn-sale-badge {
  position: absolute; top: 12px; right: 12px;
  background: #ef4444; color: #fff;
  padding: 3px 10px; border-radius: 6px;
  font-size: 0.75rem; font-weight: 700;
}

.topyn-product-info { padding: 0; }
.topyn-product-top {
  display: flex; align-items: flex-start;
  justify-content: space-between; gap: 8px; margin-bottom: 4px;
}
.topyn-product-name {
  font-size: 1rem !important; font-weight: 700 !important;
  color: #111827 !important; text-decoration: none !important;
  line-height: 1.3 !important; transition: color .15s !important;
  font-family: var(--topyn-font) !important;
}
.topyn-product-card:hover .topyn-product-name { color: #2563eb !important; }
.topyn-product-rating {
  display: flex; align-items: center; gap: 3px;
  font-size: 0.8125rem; color: #6b7280;
  flex-shrink: 0; white-space: nowrap;
}
.topyn-product-brand { font-size: 0.875rem; color: #6b7280; margin: 0 0 10px; }
.topyn-product-footer { display: flex; align-items: center; justify-content: space-between; }
.topyn-product-price { font-size: 1.25rem !important; font-weight: 800 !important; color: #111827 !important; }
.topyn-product-price .woocommerce-Price-amount { font-size: inherit !important; font-weight: inherit !important; color: inherit !important; }
.topyn-product-price del { font-size: 0.875rem !important; color: #9ca3af !important; font-weight: 400 !important; }
.topyn-view-link {
  font-size: 0.875rem; font-weight: 500;
  color: #2563eb !important; text-decoration: none !important;
  transition: text-decoration .15s;
}
.topyn-product-card:hover .topyn-view-link { text-decoration: underline !important; }

/* Pagination */
.topyn-pagination { margin-top: 48px; }
.topyn-pagination .woocommerce-pagination ul {
  display: flex; list-style: none !important;
  margin: 0 !important; padding: 0 !important;
  gap: 8px; justify-content: center;
}
.topyn-pagination .woocommerce-pagination ul li a,
.topyn-pagination .woocommerce-pagination ul li span {
  display: flex; align-items: center; justify-content: center;
  width: 40px; height: 40px; border-radius: 8px;
  font-size: 0.9rem; font-weight: 500;
  border: 1px solid #e5e7eb; color: #374151 !important;
  text-decoration: none !important; transition: all .15s;
}
.topyn-pagination .woocommerce-pagination ul li a:hover { border-color: #2563eb; color: #2563eb !important; }
.topyn-pagination .woocommerce-pagination ul li span.current { background: #2563eb; color: #fff !important; border-color: #2563eb; }

/* Empty state (shop/category no products) */
.topyn-empty-state{
  max-width: 640px;
  margin: 24px auto 0;
  text-align: center;
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 18px;
  padding: 28px 22px;
  box-shadow: 0 10px 30px rgba(17,24,39,.06);
}
.topyn-empty-icon{
  width: 56px;
  height: 56px;
  border-radius: 999px;
  margin: 0 auto 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #eff6ff;
  color: #2563eb;
}
.topyn-empty-title{
  margin: 0 0 8px !important;
  font-size: 1.375rem !important;
  font-weight: 900 !important;
  color: #111827 !important;
}
.topyn-empty-text{
  margin: 0 auto 18px !important;
  max-width: 520px;
  font-size: 0.95rem !important;
  line-height: 1.75 !important;
  color: #6b7280 !important;
}
.topyn-empty-actions{
  display: flex;
  justify-content: center;
}

/* ============================================================
   SINGLE PRODUCT PAGE
   ============================================================ */
.topyn-product-page { padding: 32px 0 96px; }

.topyn-breadcrumb {
  display: flex; align-items: center; gap: 8px;
  font-size: 0.875rem; color: #6b7280; margin-bottom: 32px; margin-top: 32px;
  flex-wrap: wrap;
}
.topyn-breadcrumb a { color: #6b7280 !important; text-decoration: none !important; transition: color .15s; }
.topyn-breadcrumb a:hover { color: #111827 !important; }
.topyn-breadcrumb span:not(:last-child) { color: #d1d5db; }
.topyn-breadcrumb span:last-child { color: #111827; font-weight: 500; }

/* Add to cart success (product page, when redirect to cart is off) */
.topyn-addcart-alert {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 28px;
  padding: 16px 52px 16px 18px;
  border-radius: 14px;
  border: 1px solid #a7f3d0;
  background: linear-gradient(135deg, #ecfdf5 0%, #d1fae5 100%);
  color: #064e3b;
  font-size: 0.9375rem;
  line-height: 1.55;
  font-family: var(--topyn-font);
  position: relative;
  box-sizing: border-box;
  box-shadow: 0 4px 18px rgba(16, 185, 129, 0.12);
}
.topyn-addcart-alert__icon {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  background: #10b981;
  color: #fff;
}
.topyn-addcart-alert__text { flex: 1; min-width: 0; }
.topyn-addcart-alert__text p { margin: 0 0 6px; }
.topyn-addcart-alert__text p:last-child { margin-bottom: 0; }
.topyn-addcart-alert__text a.button,
.topyn-addcart-alert__text a.wc-forward {
  display: inline-flex;
  align-items: center;
  margin-top: unset;
  padding: 8px 16px;
  border-radius: 999px;
  background: #059669 !important;
  color: #fff !important;
  font-weight: 600;
  font-size: 0.875rem;
  text-decoration: none !important;
  border: none;
  transition: background .15s, transform .15s;
}
.topyn-addcart-alert__text a.button:hover,
.topyn-addcart-alert__text a.wc-forward:hover {
  background: #047857 !important;
  transform: translateY(-1px);
}
.topyn-addcart-alert__text a:not(.button):not(.wc-forward) {
  color: #047857 !important;
  font-weight: 600;
  text-decoration: underline;
}
.topyn-addcart-alert__close {
  position: absolute;
  top: 18px;
  right: 10px;
  width: 36px;
  height: 36px;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  border: none;
  background: rgba(255,255,255,.65);
  cursor: pointer;
  color: #064e3b;
  opacity: 0.85;
  border-radius: 10px;
  transition: background .15s, opacity .15s;
}
.topyn-addcart-alert__close:hover { opacity: 1; background: rgba(255,255,255,.95); }

.topyn-product-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 48px; margin-bottom: 80px;
}

/* Images */
.topyn-main-image {
  background: #f3f4f6; border-radius: 16px;
  overflow: hidden; aspect-ratio: 1/1; margin-bottom: 16px;
}
.topyn-main-image img { width: 100%; height: 100%; object-fit: cover; display: block; transition: opacity .2s; }

/* Thumbnail strip: same width as main image; max 4 thumbs visible; scroll if more */
.topyn-product-images .topyn-thumb-slider-wrap {
  width: 100%;
  max-width: 100%;
  --topyn-thumb-gap: 10px;
  --topyn-thumb-visible: 4;
  display: flex; align-items: center; gap: 8px; position: relative;
}
.topyn-thumb-slider {
  flex: 1; min-width: 0; width: 100%; max-width: 100%;
  container-type: inline-size;
  container-name: topyn-thumbs;
  overflow-x: auto; overflow-y: hidden;
  scroll-behavior: smooth; -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  scroll-snap-type: x proximity;
}
.topyn-thumb-slider::-webkit-scrollbar { display: none; }
.topyn-thumb-track {
  display: flex; gap: var(--topyn-thumb-gap);
  width: max-content;
  flex-shrink: 0;
}
.topyn-thumb {
  flex: 0 0 calc((100cqi - (var(--topyn-thumb-visible) - 1) * var(--topyn-thumb-gap)) / var(--topyn-thumb-visible));
  width: calc((100cqi - (var(--topyn-thumb-visible) - 1) * var(--topyn-thumb-gap)) / var(--topyn-thumb-visible));
  aspect-ratio: 1 / 1;
  max-height: none;
  scroll-snap-align: start;
  background: #f3f4f6; border-radius: 10px;
  overflow: hidden; cursor: pointer;
  border: 2px solid transparent; transition: border-color .15s;
}
/* Fallback when container queries unsupported */
@supports not (width: 1cqi) {
  .topyn-thumb {
    flex: 0 0 76px; width: 76px; height: 76px;
  }
}
.topyn-thumb:hover, .topyn-thumb.active { border-color: #2563eb; }
.topyn-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.topyn-thumb-arrow {
  width: 32px; height: 32px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  background: #fff; border: 1px solid #e5e7eb; border-radius: 50%;
  font-size: 1.25rem; color: #374151; cursor: pointer;
  transition: background .15s, color .15s, opacity .15s; line-height: 1;
  box-shadow: 0 1px 3px rgba(0,0,0,.08);
}
.topyn-thumb-arrow:hover { background: #f3f4f6; color: #111827; }
.topyn-thumb-slider-wrap.topyn-thumbs-fit .topyn-thumb-arrow {
  display: none !important;
}

/* Duplicate backorder: hide WC stock line when our notice exists */
.topyn-product-details:has(.topyn-stock-status.topyn-backorder) .topyn-atc-wrap p.stock.available-on-backorder {
  display: none !important;
}

/* Flash Sale countdown (ReHub) — do not override .digit inner layout (breaks JS animation) */
.topyn-atc-wrap .clearbox:has(.countdown_dashboard) {
  margin-bottom: 16px !important;
  width: 100% !important;
  padding: 16px !important;
  background: linear-gradient(135deg, #fff7ed 0%, #ffedd5 100%) !important;
  border: 1px solid #fed7aa !important;
  border-radius: 14px !important;
  box-sizing: border-box !important;
  text-align: center !important;
}
/* Only one countdown (ReHub sometimes duplicates) */
.topyn-atc-wrap .clearbox:has(.countdown_dashboard) .countdown_dashboard ~ .countdown_dashboard {
  display: none !important;
}
.topyn-atc-wrap .clearbox .rehub-main-color {
  font-family: var(--topyn-font) !important;
  font-size: 0.9375rem !important; font-weight: 800 !important;
  color: #111827 !important; margin-bottom: 12px !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
  gap: 8px !important;
}
.topyn-atc-wrap .clearbox .rehub-main-color .orangecolor,
.topyn-atc-wrap .clearbox .rehub-main-color .fastShake {
  color: #ea580c !important;
}
/* One row: flex only on the outer strip — .dash inner .digit layout stays ReHub (float + flip halves) */
.topyn-atc-wrap .clearbox:has(.countdown_dashboard) .countdown_dashboard {
  float: none !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  justify-content: center !important;
  align-items: flex-start !important;
  margin-left: auto !important;
  margin-right: auto !important;
  width: 100% !important;
  max-width: 100% !important;
  font-family: var(--topyn-font) !important;
  overflow-x: auto !important;
  overflow-y: hidden !important;
  -webkit-overflow-scrolling: touch;
  gap: 0;
}
.topyn-atc-wrap .countdown_dashboard .dash {
  float: none !important;
  flex: 0 0 auto !important;
  display: block !important;
  margin-right: 14px !important;
  height: 39px !important;
  position: relative !important;
}
.dash:after{
    margin-left: 0% !important;
}
.topyn-atc-wrap .countdown_dashboard .dash:last-child {
  margin-right: 0 !important;
}
.topyn-atc-wrap .countdown_dashboard .dash .digit {
  overflow: hidden !important;
  height: 39px !important;
  line-height: 39px !important;
}
/* Qty inside Flash Sale block — centered */
.topyn-atc-wrap .clearbox:has(.countdown_dashboard) .quantity {
  display: flex !important; align-items: center !important; justify-content: center !important;
  margin: 16px auto 0 !important; width: fit-content !important; max-width: 100% !important;
}
.topyn-atc-wrap .clearbox:has(.countdown_dashboard) .quantity.topyn-qty-styled {
  margin-left: auto !important; margin-right: auto !important;
}

/* Product info */
.topyn-product-details h1 {
  font-size: 1.875rem !important; font-weight: 800 !important;
  color: #111827 !important; margin: 0 0 16px !important; line-height: 1.2 !important;
}
.topyn-product-stars {
  display: flex; align-items: center; gap: 4px;
  margin-bottom: 24px; font-size: 0.875rem; color: #6b7280;
}
.topyn-product-stars svg { flex-shrink: 0; }
.topyn-product-pricing { margin-bottom: 24px; }
.topyn-price-row {
  display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap; margin-bottom: 6px;
}
/* WooCommerce default price_html — current price first, cut price after */
.topyn-price-row ins,
.topyn-price-row ins .woocommerce-Price-amount {
  font-size: 2.25rem !important; font-weight: 900 !important;
  color: #111827 !important; text-decoration: none !important;
  order: 1 !important;
}
.topyn-price-row del,
.topyn-price-row del .woocommerce-Price-amount {
  font-size: 1.125rem !important; font-weight: 500 !important;
  color: #9ca3af !important; text-decoration: line-through !important;
  order: 2 !important;
}
.topyn-price-row .woocommerce-Price-amount {
  font-size: 2.25rem !important; font-weight: 900 !important; color: #111827 !important;
}
.topyn-price-row > span#topyn-price-html {
  display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap;
}
/* Our clean price elements (set by JS after variation found) */
.topyn-cur-price {
  font-size: 2.25rem; font-weight: 900; color: #111827;
  font-family: var(--topyn-font);
}
.topyn-was-price {
  font-size: 1.125rem; font-weight: 500; color: #9ca3af;
  text-decoration: line-through; font-family: var(--topyn-font);
}
.topyn-price-new { font-size: 1rem; color: #9ca3af; text-decoration: line-through; padding-bottom: 4px; }
.topyn-savings {
  font-size: 0.875rem; font-weight: 500; color: #16a34a; margin: 0;
  font-family: var(--topyn-font);
  display: flex; align-items: center; gap: 6px;
}
.topyn-savings strong { font-weight: 700; }

/* Stock status badges */
.topyn-stock-status {
  display: flex; align-items: center; gap: 8px;
  font-size: 0.875rem; font-weight: 600; padding: 10px 16px;
  border-radius: 10px; margin-bottom: 20px;
  font-family: var(--topyn-font);
}
.topyn-out-of-stock {
  background: #fef2f2; color: #dc2626; border: 1px solid #fecaca;
}
.topyn-low-stock {
  background: #fffbeb; color: #d97706; border: 1px solid #fde68a;
}
.topyn-backorder {
  background: #eff6ff; color: #2563eb; border: 1px solid #bfdbfe;
}

/* OOS image badge */
.topyn-product-images { position: relative; }
.topyn-oos-badge {
  position: absolute; top: 16px; left: 16px; z-index: 3;
  padding: 6px 14px; border-radius: 8px;
  font-size: 0.75rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .04em; font-family: var(--topyn-font);
  background: #6b7280; color: #fff;
}

/* Condition selector */
.topyn-condition-wrap { margin-bottom: 32px; }
.topyn-condition-head {
  display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px;
}
.topyn-condition-head span { font-size: 0.9375rem; font-weight: 600; color: #111827; }
.topyn-condition-info {
  display: flex; align-items: center; gap: 4px;
  font-size: 0.875rem; color: #2563eb; background: none;
  border: none; cursor: pointer; font-family: var(--topyn-font); padding: 0;
}
.topyn-condition-options { display: grid; grid-template-columns: repeat(3,1fr); gap: 10px; }
.topyn-condition-btn {
  display: block; padding: 12px;
  border: 1.5px solid #e5e7eb; border-radius: 12px;
  text-align: center; cursor: pointer; transition: all .15s;
  position: relative; background: #fff;
}
.topyn-condition-btn input[type=radio] { position: absolute; opacity: 0; width: 0; height: 0; }
.topyn-condition-btn:hover { border-color: #9ca3af; background: #f9fafb; }
.topyn-condition-btn.is-selected {
  border-color: #2563eb !important;
  background: #eff6ff !important;
  box-shadow: 0 0 0 1px #2563eb;
}
.topyn-condition-btn:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px rgba(37,99,235,.18);
}
.topyn-condition-label { display: flex; flex-direction: column; gap: 2px; pointer-events: none; }
.topyn-condition-label strong { font-size: 0.9rem; color: #111827; }
.topyn-condition-label small { font-size: 0.8125rem; color: #6b7280; }
.topyn-condition-btn.is-selected .topyn-condition-label strong { color: #1d4ed8; }

/* Variation step states */
.topyn-var-wrap { transition: opacity .25s ease; }
.topyn-var-wrap.is-locked { opacity: .45; pointer-events: none; }
.topyn-var-wrap.is-locked .topyn-condition-head span { color: #9ca3af; }
.topyn-var-hint {
  font-size: 0.8125rem; color: #9ca3af; font-style: italic;
  padding: 10px 0 4px; font-family: var(--topyn-font);
}

/* Loading overlay on variations container */
.topyn-variations-ui { position: relative; min-height: 120px; }
.topyn-variations-ui.is-loading .topyn-var-wrap { opacity: 0; visibility: hidden; pointer-events: none; }
.topyn-variations-ui .topyn-var-loader {
  display: none; position: absolute; inset: 0;
  z-index: 5; border-radius: 12px;
  background: #f9fafb;
  flex-direction: column; align-items: center; justify-content: center; gap: 14px;
}
.topyn-variations-ui.is-loading .topyn-var-loader { display: flex; }
.topyn-var-loader-spinner {
  width: 28px; height: 28px; border: 3px solid #e5e7eb;
  border-top-color: #2563eb; border-radius: 50%;
  animation: topynSpin .7s linear infinite;
}
@keyframes topynSpin { to { transform: rotate(360deg); } }
.topyn-var-loader-text {
  font-size: 0.8125rem; color: #6b7280;
  font-family: var(--topyn-font); font-weight: 500;
}
/* Smooth reveal after loading */
.topyn-variations-ui.is-ready .topyn-var-wrap {
  animation: topynFadeUp .3s ease both;
}
.topyn-variations-ui.is-ready .topyn-var-wrap:nth-child(2) { animation-delay: .06s; }
.topyn-variations-ui.is-ready .topyn-var-wrap:nth-child(3) { animation-delay: .12s; }
@keyframes topynFadeUp {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Variations (Storage/Color) reuse same UI */
.topyn-variations-ui .topyn-condition-head { margin-bottom: 12px; }
.topyn-variations-ui .topyn-condition-options { grid-template-columns: repeat(3,1fr); }
.topyn-condition-btn.is-disabled,
.topyn-var-btn.is-disabled {
  opacity: .45 !important;
  cursor: not-allowed !important;
  pointer-events: none !important;
}
.topyn-hidden { display: none !important; }
.topyn-atc-wrap table.variations { display: none !important; }
.topyn-atc-wrap .reset_variations { display: none !important; }
.topyn-atc-wrap .woocommerce-variation-price,
.topyn-atc-wrap .single_variation .woocommerce-variation-price,
.topyn-atc-wrap .woocommerce-variation.single_variation { display: none !important; }

/* Trust badges */
.topyn-product-trust {
  background: #f9fafb; border-radius: 12px;
  padding: 16px; margin-bottom: 28px;
  display: flex; flex-direction: column; gap: 12px;
}
.topyn-trust-row {
  display: flex; align-items: center; gap: 12px;
  font-size: 0.9rem; color: #374151;
}
.topyn-trust-row svg { flex-shrink: 0; stroke: currentColor; fill: none; }

/* WooCommerce ATC button override */
.topyn-atc-wrap .single_add_to_cart_button,
.topyn-atc-wrap button[type=submit].button {
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  background: #2563eb !important;
  color: #fff !important;
  font-size: 1.0625rem !important;
  font-weight: 700 !important;
  padding: 16px 32px !important;
  border-radius: 50px !important;
  border: none !important;
  cursor: pointer !important;
  box-shadow: 0 4px 20px rgba(37,99,235,.35) !important;
  transition: all .2s !important;
  font-family: var(--topyn-font) !important;
  margin-bottom: 32px !important;
}
.topyn-atc-wrap .single_add_to_cart_button:hover { background: #1d4ed8 !important; transform: translateY(-2px) !important; }
.topyn-atc-wrap .single_add_to_cart_button {
  position: sticky !important;
  bottom: 16px !important;
  z-index: 40 !important;
}
@media (min-width: 1024px) {
  .topyn-atc-wrap .single_add_to_cart_button { position: static !important; }
}

/* Force wrapper full width too */
.topyn-atc-wrap .woocommerce-variation-add-to-cart,
.topyn-atc-wrap .woocommerce-variation-add-to-cart-disabled,
.topyn-atc-wrap .variations_button,
.topyn-atc-wrap .single_variation_wrap {
  width: 100% !important;
  max-width: none !important;
  display: block !important;
}
.topyn-atc-wrap form.variations_form {
  width: 100% !important;
  max-width: none !important;
}
.topyn-atc-wrap .single_add_to_cart_button:disabled,
.topyn-atc-wrap .single_add_to_cart_button[disabled],
.topyn-atc-wrap .single_add_to_cart_button.disabled,
.topyn-atc-wrap .single_add_to_cart_button.wc-variation-selection-needed {
  background: #2563eb !important;
  color: #fff !important;
  width: 100% !important;
  display: block !important;
  opacity: .65 !important;
  cursor: not-allowed !important;
  transform: none !important;
}
/* Qty stepper */
.topyn-atc-wrap .quantity {
  display: flex; align-items: center; gap: 0; margin-bottom: 16px;
}
.topyn-atc-wrap .quantity.topyn-qty-styled {
  display: inline-flex; border: 1.5px solid #d1d5db; border-radius: 12px;
  overflow: hidden; background: #fff;
}
.topyn-atc-wrap .quantity .qty {
  width: 56px !important; padding: 10px 4px !important;
  border: none !important; border-radius: 0 !important;
  font-size: 1rem !important; text-align: center !important;
  font-family: var(--topyn-font) !important; font-weight: 700 !important;
  background: transparent !important; color: #111827 !important;
  -moz-appearance: textfield !important; appearance: textfield !important;
}
.topyn-atc-wrap .quantity .qty::-webkit-inner-spin-button,
.topyn-atc-wrap .quantity .qty::-webkit-outer-spin-button {
  -webkit-appearance: none !important; margin: 0 !important;
}
.topyn-qty-btn {
  width: 44px; height: 44px; display: flex; align-items: center; justify-content: center;
  background: transparent; border: none; cursor: pointer;
  font-size: 1.25rem; color: #374151; font-family: var(--topyn-font);
  transition: background .15s, color .15s; flex-shrink: 0;
}
.topyn-qty-btn:hover { background: #f3f4f6; color: #111827; }
.topyn-qty-btn:active { background: #e5e7eb; }
.topyn-qty-minus { border-right: 1px solid #e5e7eb; }
.topyn-qty-plus { border-left: 1px solid #e5e7eb; }

/* Specs */
.topyn-product-specs {
  border-top: 1px solid #e5e7eb;
  padding-top: 28px; margin-top: 8px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 24px;
}
.topyn-spec-col h4 {
  font-size: 0.9375rem !important; font-weight: 700 !important;
  color: #111827 !important; margin: 0 0 10px !important;
}
.topyn-spec-col ul { padding-left: 20px; margin: 0; }
.topyn-spec-col ul li { font-size: 0.875rem; color: #4b5563; margin-bottom: 6px; line-height: 1.5; }

/* Product tabs */
.topyn-product-tabs {
  margin-bottom: 64px;
}
.topyn-tabs-nav {
  display: flex; gap: 0; border-bottom: 2px solid #e5e7eb;
  overflow: visible;
}
.topyn-tab-btn {
  padding: 16px 32px; font-size: 0.9375rem; font-weight: 600;
  color: #6b7280; background: none; border: none; border-bottom: 2px solid transparent;
  margin-bottom: -2px; cursor: pointer; white-space: nowrap;
  font-family: var(--topyn-font); transition: color .15s, border-color .15s;
}
.topyn-tab-btn:hover { color: #111827; }
.topyn-tab-btn.is-active {
  color: #2563eb; border-bottom-color: #2563eb;
}
.topyn-tab-panel {
  display: none; padding: 30px 0 0;
}
.topyn-tab-panel.is-active { display: block; }

/* Description content — full typography */
.topyn-desc-content { font-family: var(--topyn-font); color: #4b5563; line-height: 1.8; font-size: 0.9375rem; }
.topyn-desc-content p { margin: 0 0 16px; }
.topyn-desc-content h1 { font-size: 1.75rem !important; font-weight: 800 !important; color: #111827 !important; margin: 32px 0 14px !important; line-height: 1.3 !important; }
.topyn-desc-content h2 { font-size: 1.375rem !important; font-weight: 800 !important; color: #111827 !important; margin: 28px 0 12px !important; line-height: 1.3 !important; }
.topyn-desc-content h3 { font-size: 1.125rem !important; font-weight: 700 !important; color: #111827 !important; margin: 24px 0 10px !important; }
.topyn-desc-content h4 { font-size: 1rem !important; font-weight: 700 !important; color: #111827 !important; margin: 20px 0 8px !important; }
.topyn-desc-content h5 { font-size: 0.9375rem !important; font-weight: 700 !important; color: #374151 !important; margin: 16px 0 6px !important; }
.topyn-desc-content h6 { font-size: 0.875rem !important; font-weight: 700 !important; color: #374151 !important; margin: 16px 0 6px !important; text-transform: uppercase !important; letter-spacing: .03em !important; }
.topyn-desc-content span { color: inherit; }
.topyn-desc-content strong, .topyn-desc-content b { font-weight: 700; color: #111827; }
.topyn-desc-content em, .topyn-desc-content i { font-style: italic; }
.topyn-desc-content a { color: #2563eb; text-decoration: underline; transition: color .15s; }
.topyn-desc-content a:hover { color: #1d4ed8; }
.topyn-desc-content ul,
.topyn-desc-content ol { padding-left: 24px; margin: 0 0 16px; }
.topyn-desc-content ul { list-style-type: disc; }
.topyn-desc-content ol { list-style-type: decimal; }
.topyn-desc-content ul li,
.topyn-desc-content ol li { font-size: 0.9375rem; color: #4b5563; line-height: 1.8; margin-bottom: 6px; }
.topyn-desc-content img { border-radius: 12px; margin: 16px 0; max-width: 100%; height: auto; }
.topyn-desc-content blockquote {
  border-left: 4px solid #2563eb; padding: 16px 20px; margin: 20px 0;
  background: #f9fafb; border-radius: 0 8px 8px 0; font-style: italic; color: #374151;
}
.topyn-desc-content table { width: 100%; border-collapse: collapse; margin: 16px 0; }
.topyn-desc-content table th,
.topyn-desc-content table td { padding: 10px 14px; border: 1px solid #e5e7eb; font-size: 0.875rem; }
.topyn-desc-content table th { background: #f9fafb; font-weight: 600; color: #374151; text-align: left; }
.topyn-desc-content table td { color: #4b5563; }
.topyn-desc-content pre, .topyn-desc-content code {
  background: #f3f4f6; border-radius: 6px; font-size: 0.8125rem; font-family: monospace;
}
.topyn-desc-content pre { padding: 16px; overflow-x: auto; margin: 16px 0; }
.topyn-desc-content code { padding: 2px 6px; }
.topyn-desc-content hr { border: none; border-top: 1px solid #e5e7eb; margin: 24px 0; }

/* Additional info attributes table */
.topyn-attr-table {
  width: 100%; border-collapse: collapse;
  font-family: var(--topyn-font); font-size: 0.9375rem;
}
.topyn-attr-table tr:nth-child(even) { background: #f9fafb; }
.topyn-attr-table th {
  text-align: left; padding: 12px 16px; font-weight: 600;
  color: #374151; width: 200px; border-bottom: 1px solid #e5e7eb;
}
.topyn-attr-table td {
  padding: 12px 16px; color: #4b5563; border-bottom: 1px solid #e5e7eb;
}

/* Product meta (SKU) */
.topyn-product-meta {
  display: flex; flex-direction: column; gap: 8px;
  padding: 16px 0; margin-bottom: 8px;
  border-top: 1px solid #f3f4f6;
  font-size: 0.8125rem; color: #6b7280;
  font-family: var(--topyn-font);
}
.topyn-meta-row { display: flex; gap: 6px; flex-wrap: wrap; }
.topyn-meta-label { font-weight: 600; color: #374151; }
.topyn-meta-row a { color: #2563eb; text-decoration: none; }
.topyn-meta-row a:hover { text-decoration: underline; }

/* ── Reviews — ReHub theme structure ── */
.topyn-tab-panel[data-panel="reviews"] #reviews,
.topyn-tab-panel[data-panel="reviews"] .woocommerce-Reviews {
  font-family: var(--topyn-font) !important;
}

/* Main review title */
.topyn-tab-panel[data-panel="reviews"] .woocommerce-Reviews-title,
.topyn-tab-panel[data-panel="reviews"] .rh-heading-icon {
  font-size: 1.25rem !important; font-weight: 800 !important;
  color: #111827 !important; font-family: var(--topyn-font) !important;
  margin: 0 0 16px !important;
}
.topyn-tab-panel[data-panel="reviews"] .rh-line {
  border: none !important; border-top: 1px solid #e5e7eb !important;
  margin: 16px 0 !important;
}

/* Rating summary row */
.topyn-tab-panel[data-panel="reviews"] .mobileblockdisplay {
  display: flex !important; align-items: center !important;
  gap: 0 !important; flex-wrap: wrap !important;
  border: 1px solid #e5e7eb !important; border-radius: 14px !important;
  overflow: hidden !important; background: #fff !important;
}

/* Average rating part */
.topyn-tab-panel[data-panel="reviews"] .woo-rev-part:first-child {
  padding: 24px 28px !important; text-align: center !important;
  min-width: 140px !important;
}
.topyn-tab-panel[data-panel="reviews"] .woo-avg-rating .font200 {
  font-size: 2.5rem !important; font-weight: 900 !important;
  color: #111827 !important; font-family: var(--topyn-font) !important;
  display: block !important; line-height: 1.1 !important;
}
.topyn-tab-panel[data-panel="reviews"] .woo-avg-rating .font90 {
  font-size: 0.8125rem !important; color: #9ca3af !important;
  font-weight: 500 !important;
}

/* Rating bars section */
.topyn-tab-panel[data-panel="reviews"] .rh-line-left {
  border-left: 1px solid #e5e7eb !important;
}
.topyn-tab-panel[data-panel="reviews"] .rh-line-right {
  border-right: 1px solid #e5e7eb !important;
}
.topyn-tab-panel[data-panel="reviews"] .woo-rating-bars {
  padding: 0 !important;
}
.topyn-tab-panel[data-panel="reviews"] .rating-bar {
  display: flex !important; align-items: center !important;
  gap: 10px !important; padding: 5px 0 !important;
}
.topyn-tab-panel[data-panel="reviews"] .star-rating-wrap {
  flex-shrink: 0 !important; width: auto !important;
}
.topyn-tab-panel[data-panel="reviews"] .rh_woo_star {
  display: inline-flex !important; gap: 1px !important;
}
.topyn-tab-panel[data-panel="reviews"] .rhwoostar {
  font-size: 1.4rem !important; line-height: 1 !important;
  color: #d1d5db !important;
}
.topyn-tab-panel[data-panel="reviews"] .rhwoostar.active {
  color: #f59e0b !important;
}

/* Progress bar */
.topyn-tab-panel[data-panel="reviews"] .rating-percentage-bar-wrap {
  flex: 1 !important; min-width: 0 !important;
}
.topyn-tab-panel[data-panel="reviews"] .rating-percentage-bar {
  background: #f3f4f6 !important; border-radius: 999px !important;
  height: 8px !important; overflow: hidden !important; position: relative !important;
}
.topyn-tab-panel[data-panel="reviews"] .rating-percentage {
  display: block !important; height: 100% !important;
  background: #f59e0b !important; border-radius: 999px !important;
  transition: width .3s !important;
}
.topyn-tab-panel[data-panel="reviews"] .rating-count {
  font-size: 0.8125rem !important; color: #6b7280 !important;
  font-weight: 600 !important; min-width: 20px !important; text-align: right !important;
}
.topyn-tab-panel[data-panel="reviews"] .rating-count.zero {
  color: #d1d5db !important;
}

/* Write a review button */
.topyn-tab-panel[data-panel="reviews"] .rehub_main_btn,
.topyn-tab-panel[data-panel="reviews"] .wpsm-button {
  background: #2563eb !important; color: #fff !important;
  border: none !important; border-radius: 10px !important;
  padding: 12px 24px !important; font-size: 0.9375rem !important;
  font-weight: 700 !important; font-family: var(--topyn-font) !important;
  cursor: pointer !important; text-decoration: none !important;
  display: inline-block !important; transition: background .15s !important;
}
.topyn-tab-panel[data-panel="reviews"] .rehub_main_btn:hover,
.topyn-tab-panel[data-panel="reviews"] .wpsm-button:hover {
  background: #1d4ed8 !important;
}

/* No reviews message */
.topyn-tab-panel[data-panel="reviews"] .woocommerce-noreviews {
  font-size: 0.9375rem !important; color: #6b7280 !important;
  padding: 24px 0 !important; font-family: var(--topyn-font) !important;
}

/* Review form */
.topyn-tab-panel[data-panel="reviews"] #woo_comm_form {
  margin-top: 28px !important;
  padding: 28px 24px 32px !important;
  background: #fafbfc !important;
  border: 1px solid #e5e7eb !important;
  border-radius: 16px !important;
  box-sizing: border-box !important;
}
.topyn-tab-panel[data-panel="reviews"] #review_form_wrapper {
  margin-top: 0 !important;
}
.topyn-tab-panel[data-panel="reviews"] .comment-reply-title {
  font-size: 1.125rem !important; font-weight: 700 !important;
  color: #111827 !important; font-family: var(--topyn-font) !important;
  margin: 0 0 20px !important;
}
.topyn-tab-panel[data-panel="reviews"] .comment-reply-title small a {
  font-size: 0.8125rem !important; color: #2563eb !important;
  font-weight: 500 !important;
}

/* Star rating selector */
.topyn-tab-panel[data-panel="reviews"] .comment-form-rating label {
  font-weight: 600 !important; font-size: 0.9375rem !important;
  color: #111827 !important; font-family: var(--topyn-font) !important;
  display: block !important; margin-bottom: 8px !important;
}
.topyn-tab-panel[data-panel="reviews"] p.stars {
  margin: 0 0 16px !important;
}
.topyn-tab-panel[data-panel="reviews"] p.stars a {
  color: #d1d5db !important; text-decoration: none !important;
  font-size: 1.5rem !important; line-height: 1 !important;
}
.topyn-tab-panel[data-panel="reviews"] p.stars a:hover,
.topyn-tab-panel[data-panel="reviews"] p.stars a.active {
  color: #f59e0b !important;
}

/* Form fields */
.topyn-tab-panel[data-panel="reviews"] .comment-form label {
  display: block !important; font-size: 0.875rem !important;
  font-weight: 600 !important; color: #374151 !important;
  margin-bottom: 6px !important; font-family: var(--topyn-font) !important;
}
.topyn-tab-panel[data-panel="reviews"] .comment-form textarea,
.topyn-tab-panel[data-panel="reviews"] .comment-form input[type="text"],
.topyn-tab-panel[data-panel="reviews"] .comment-form input[type="email"] {
  width: 100% !important; padding: 12px 16px !important;
  border: 1.5px solid #d1d5db !important; border-radius: 10px !important;
  font-size: 0.9375rem !important; font-family: var(--topyn-font) !important;
  transition: border-color .15s !important; background: #fff !important;
  color: #111827 !important; box-sizing: border-box !important;
}
.topyn-tab-panel[data-panel="reviews"] .comment-form textarea:focus,
.topyn-tab-panel[data-panel="reviews"] .comment-form input:focus {
  border-color: #2563eb !important; outline: none !important;
  box-shadow: 0 0 0 3px rgba(37,99,235,.1) !important;
}
.topyn-tab-panel[data-panel="reviews"] .comment-form p {
  margin: 0 0 16px !important;
}

/* Pros/cons textareas */
.topyn-tab-panel[data-panel="reviews"] .woo_pros_cons_form {
  display: grid !important; grid-template-columns: 1fr 1fr !important;
  gap: 16px !important; margin-bottom: 16px !important;
}
.topyn-tab-panel[data-panel="reviews"] .woo_pros_cons_form .comment-form-comment {
  width: 100% !important; float: none !important; margin: 0 !important; padding: 0 !important;
}
.topyn-tab-panel[data-panel="reviews"] .woo_pros_cons_form textarea {
  width: 100% !important; padding: 12px 16px !important;
  border: 1.5px solid #d1d5db !important; border-radius: 10px !important;
  font-size: 0.875rem !important; font-family: var(--topyn-font) !important;
  resize: vertical !important; min-height: 80px !important;
  box-sizing: border-box !important; color: #111827 !important; background: #fff !important;
}
.topyn-tab-panel[data-panel="reviews"] .woo_pros_cons_form textarea:focus {
  border-color: #2563eb !important; outline: none !important;
  box-shadow: 0 0 0 3px rgba(37,99,235,.1) !important;
}

/* Submit button */
.topyn-tab-panel[data-panel="reviews"] .form-submit .submit,
.topyn-tab-panel[data-panel="reviews"] .form-submit input[type="submit"] {
  background: #2563eb !important; color: #fff !important;
  border: none !important; border-radius: 10px !important;
  padding: 14px 32px !important; font-size: 0.9375rem !important;
  font-weight: 700 !important; font-family: var(--topyn-font) !important;
  cursor: pointer !important; transition: background .15s !important;
}
.topyn-tab-panel[data-panel="reviews"] .form-submit .submit:hover,
.topyn-tab-panel[data-panel="reviews"] .form-submit input[type="submit"]:hover {
  background: #1d4ed8 !important;
}

/* Review comments list */
.topyn-tab-panel[data-panel="reviews"] .commentlist {
  list-style: none !important; padding: 0 !important; margin: 0 !important;
}
.topyn-tab-panel[data-panel="reviews"] .commentlist li {
  border-bottom: 1px solid #f3f4f6 !important;
}
.topyn-tab-panel[data-panel="reviews"] .commentlist li:last-child { border-bottom: none !important; }
.topyn-tab-panel[data-panel="reviews"] .comment_container {
  display: flex !important; gap: 16px !important;
}
.topyn-tab-panel[data-panel="reviews"] .comment_container img.avatar {
  width: 48px !important; height: 48px !important; border-radius: 50% !important; flex-shrink: 0 !important;
}
.topyn-tab-panel[data-panel="reviews"] .comment-text {
  flex: 1 !important;
}
.woocommerce #reviews #comments ol.commentlist li .comment-text {
    margin: 0px 0 0 5px !important;
}

.topyn-tab-panel[data-panel="reviews"] .comment-text .meta {
  margin-bottom: 8px !important; font-size: 0.875rem !important; color: #6b7280 !important;
}
.topyn-tab-panel[data-panel="reviews"] .comment-text .meta strong {
  color: #111827 !important; font-weight: 600 !important;
}
.topyn-tab-panel[data-panel="reviews"] .description p {
  font-size: 0.9375rem !important; color: #4b5563 !important; line-height: 1.7 !important; margin: 0 !important;
}

/* Review link in stars area */
.topyn-review-link {
  color: #2563eb; text-decoration: none; font-weight: 500;
  margin-left: 4px; transition: color .15s;
}
.topyn-review-link:hover { text-decoration: underline; }
.topyn-no-reviews { color: #6b7280; font-style: italic; margin-left: 0; }
.topyn-no-reviews:hover { color: #2563eb; }

/* Review sort tabs (ReHub: #rehub-comments-tabs) */
.topyn-tab-panel[data-panel="reviews"] #rehub-comments-tabs,
.topyn-tab-panel[data-panel="reviews"] .rh_grey_tabs_span {
  display: flex !important; gap: 0 !important;
  border: 1px solid #e5e7eb !important; border-radius: 10px !important;
  overflow: hidden !important; margin-bottom: 20px !important;
  background: #fff !important;
}
.topyn-tab-panel[data-panel="reviews"] #rehub-comments-tabs span,
.topyn-tab-panel[data-panel="reviews"] .rh_grey_tabs_span span {
  padding: 10px 18px !important; font-size: 0.8125rem !important;
  font-weight: 600 !important; color: #6b7280 !important;
  cursor: pointer !important; white-space: nowrap !important;
  transition: background .15s, color .15s !important;
  border-right: 1px solid #e5e7eb !important;
  font-family: var(--topyn-font) !important;
  background: transparent !important;
}
.topyn-tab-panel[data-panel="reviews"] #rehub-comments-tabs span:last-child,
.topyn-tab-panel[data-panel="reviews"] .rh_grey_tabs_span span:last-child {
  border-right: none !important;
}
.topyn-tab-panel[data-panel="reviews"] #rehub-comments-tabs span:hover,
.topyn-tab-panel[data-panel="reviews"] .rh_grey_tabs_span span:hover {
  background: #f9fafb !important; color: #111827 !important;
}
.topyn-tab-panel[data-panel="reviews"] #rehub-comments-tabs span.active,
.topyn-tab-panel[data-panel="reviews"] .rh_grey_tabs_span span.active {
  background: #2563eb !important; color: #fff !important;
}

/* Individual review comment */
.topyn-tab-panel[data-panel="reviews"] .commentlist li.review {
  border-bottom: 1px solid #f3f4f6 !important;
  list-style: none !important;
}
.topyn-tab-panel[data-panel="reviews"] .commentlist li.review:last-child { border-bottom: none !important; }
.topyn-tab-panel[data-panel="reviews"] .comment_container {
  display: flex !important; gap: 16px !important;
}
.topyn-tab-panel[data-panel="reviews"] .wc-comment-author {
  flex-shrink: 0 !important;
}
.topyn-tab-panel[data-panel="reviews"] .wc-comment-author img.avatar {
  width: 52px !important; height: 52px !important;
  border-radius: 50% !important; object-fit: cover !important;
}
.topyn-tab-panel[data-panel="reviews"] .comment-text {
  flex: 1 !important; min-width: 0 !important;
}
.topyn-tab-panel[data-panel="reviews"] .comment-text .rh_woo_star {
  margin-bottom: 6px !important;
}
.topyn-tab-panel[data-panel="reviews"] .comment-text .meta {
  margin-bottom: 8px !important; font-size: 0.875rem !important; color: #6b7280 !important;
  font-family: var(--topyn-font) !important;
}
.topyn-tab-panel[data-panel="reviews"] .comment-text .meta strong {
  color: #111827 !important; font-weight: 700 !important;
}
.topyn-tab-panel[data-panel="reviews"] .comment-text .description {
  font-size: 0.9375rem !important; color: #4b5563 !important;
  line-height: 1.7 !important; font-family: var(--topyn-font) !important;
}
.topyn-tab-panel[data-panel="reviews"] .comment-text .description p {
  margin: 0 !important;
}

/* Vote buttons (Helpful / Unhelpful) */
.topyn-tab-panel[data-panel="reviews"] .user-review-vote {
  display: flex !important; align-items: center !important;
  gap: 16px !important; margin-top: 12px !important;
  padding-top: 12px !important; border-top: 1px solid #f3f4f6 !important;
  float: none !important; overflow: visible !important;
}
.topyn-tab-panel[data-panel="reviews"] .us-rev-vote-up,
.topyn-tab-panel[data-panel="reviews"] .us-rev-vote-down {
  display: inline-flex !important; align-items: center !important;
  gap: 4px !important; font-size: 0.8125rem !important;
  font-weight: 600 !important; color: #6b7280 !important;
  cursor: pointer !important; padding: 6px 12px !important;
  border-radius: 8px !important; transition: background .15s, color .15s !important;
  float: none !important; font-family: var(--topyn-font) !important;
  line-height: 1.3 !important;
}
.topyn-tab-panel[data-panel="reviews"] .us-rev-vote-up:hover {
  background: #f0fdf4 !important; color: #16a34a !important;
}
.topyn-tab-panel[data-panel="reviews"] .us-rev-vote-down:hover {
  background: #fef2f2 !important; color: #dc2626 !important;
}
.topyn-tab-panel[data-panel="reviews"] .us-rev-vote-up i,
.topyn-tab-panel[data-panel="reviews"] .us-rev-vote-down i {
  float: none !important; margin: 0 !important;
}
.topyn-tab-panel[data-panel="reviews"] .already_commhelp {
  font-size: 0.75rem !important; color: #9ca3af !important;
  display: none !important;
}

/* Average rating big stars */
.topyn-tab-panel[data-panel="reviews"] .rh_woo_star_big {
  margin-top: 6px !important;
}
.topyn-tab-panel[data-panel="reviews"] .rh_woo_star_big .rhwoostar {
  font-size: 1.25rem !important;
}

/* Related */
.topyn-related { margin-top: 64px; }
.topyn-related h2 { font-size: 1.5rem !important; font-weight: 800 !important; color: #111827 !important; margin: 0 0 32px !important; }
ul.topyn-related-grid {
  display: grid !important; grid-template-columns: repeat(4,1fr) !important;
  gap: 24px !important; list-style: none !important;
  padding: 0 !important; margin: 0 !important;
}

/* Cart toast notification */
.topyn-cart-toast {
  position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%) translateY(20px);
  background: #fff; color: #111827; padding: 16px 28px;
  border-radius: 14px; font-size: 0.9375rem; font-weight: 600;
  font-family: var(--topyn-font); z-index: 99999;
  display: flex; align-items: center; gap: 12px;
  box-shadow: 0 12px 40px rgba(0,0,0,.15), 0 0 0 1px rgba(0,0,0,.05);
  opacity: 0; transition: opacity .3s, transform .3s;
  pointer-events: none; white-space: nowrap;
  border-left: 4px solid #2563eb;
}
.topyn-cart-toast.is-visible {
  opacity: 1; transform: translateX(-50%) translateY(0);
  pointer-events: auto;
}
.topyn-cart-toast .topyn-toast-icon {
  width: 32px; height: 32px; border-radius: 50%;
  background: #2563eb; display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.topyn-cart-toast .topyn-toast-icon svg { flex-shrink: 0; }
.topyn-cart-toast a {
  color: #fff; font-weight: 700; font-size: 0.8125rem; text-decoration: none;
  background: #2563eb; padding: 6px 16px; border-radius: 50px;
  margin-left: 8px; transition: background .2s;
}
.topyn-cart-toast a:hover { background: #1d4ed8; }
/* Error toast variant */
.topyn-cart-toast.topyn-toast-error { border-left-color: #dc2626; }
.topyn-cart-toast.topyn-toast-error .topyn-toast-icon { background: #dc2626; }

/* ============================================================
   ABOUT PAGE
   ============================================================ */
.topyn-about-hero {
  background: #f9fafb; padding: 80px 0;
}
.topyn-text-center { text-align: center; }
.topyn-about-hero h1 {
  font-size: clamp(1.875rem, 4vw, 3rem) !important; font-weight: 900 !important;
  color: #111827 !important; margin: 0 0 24px !important; line-height: 1.15 !important;
}
.topyn-about-hero p { font-size: 1.25rem; color: #6b7280; line-height: 1.7; margin: 0; }

.topyn-about-hero .topyn-container { max-width: 896px !important; }
.topyn-about-story {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 64px; align-items: center;
}
.topyn-about-story-text h2 {
  font-size: 1.875rem !important; font-weight: 800 !important;
  color: #111827 !important; margin: 0 0 24px !important;
}
.topyn-about-story-text p { font-size: 1rem; color: #4b5563; line-height: 1.8; margin-bottom: 16px; }
.topyn-about-story-img { border-radius: 16px; overflow: hidden; box-shadow: 0 20px 60px rgba(0,0,0,.12); }
.topyn-about-story-img img { width: 100%; height: auto; display: block; object-fit: cover; }

.topyn-grid-4 { display: grid; grid-template-columns: repeat(4,1fr); gap: 24px; }

.topyn-value-box {
  background: #fff; padding: 32px;
  border-radius: 16px; box-shadow: 0 1px 4px rgba(0,0,0,.06);
  border: 1px solid #f3f4f6;
}
.topyn-value-box svg {
  width: 30px;
  height: 30px;
  /* Do NOT set stroke here (keeps inline stroke colors) */
  fill: none;
  stroke-width: 2.25;
  stroke-linecap: round;
  stroke-linejoin: round;
  margin-bottom: 14px;
  display: block;
}
/* If SVG has no explicit stroke attr, use theme color */
.topyn-value-box svg:not([stroke]) { stroke: currentColor; }
/* Make icon look consistent even when inline SVG uses stroke attr */
.topyn-value-box svg * { vector-effect: non-scaling-stroke; }
.topyn-value-box h3 { font-size: 1.125rem !important; font-weight: 700 !important; color: #111827 !important; margin: 0 0 10px !important; }
.topyn-value-box p { font-size: 0.9rem; color: #6b7280; line-height: 1.7; margin: 0; }

.topyn-process-list { display: flex; flex-direction: column; gap: 48px; }
.topyn-process-item { display: flex; gap: 24px; align-items: flex-start; }
.topyn-process-num {
  flex-shrink: 0; width: 48px; height: 48px;
  background: #dbeafe; color: #2563eb;
  border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font-size: 1.25rem; font-weight: 800; font-family: var(--topyn-font);
}
.topyn-process-text h3 { font-size: 1.125rem !important; font-weight: 700 !important; color: #111827 !important; margin: 0 0 8px !important; }
.topyn-process-text p { font-size: 0.9375rem; color: #4b5563; line-height: 1.7; margin: 0; }

/* ============================================================
   CONTACT PAGE
   ============================================================ */
.topyn-contact { background: #f9fafb; padding: 80px 0; }

.topyn-contact-header { text-align: center; margin-bottom: 64px; }
.topyn-contact-header h1 {
  font-size: clamp(2rem, 5vw, 3rem) !important; font-weight: 900 !important;
  color: #111827 !important; margin: 0 0 20px !important;
}
.topyn-contact-header p { font-size: 1.125rem; color: #6b7280; max-width: 640px; margin: 0 auto; line-height: 1.7; }

.topyn-contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; }

.topyn-contact-info h2 { font-size: 1.5rem !important; font-weight: 700 !important; color: #111827 !important; margin: 0 0 32px !important; }
.topyn-contact-items { display: flex; flex-direction: column; gap: 24px; margin-bottom: 40px; }
.topyn-contact-item { display: flex; gap: 16px; align-items: flex-start; }
.topyn-contact-icon {
  flex-shrink: 0; width: 48px; height: 48px;
  background: #dbeafe; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
}
.topyn-contact-icon svg { width: 22px; height: 22px; stroke: currentColor; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.topyn-contact-icon::before{
  content: "";
  width: 22px;
  height: 22px;
  display: block;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}
/* If inline SVG exists, prefer it and hide fallback */
.topyn-contact-icon:has(svg)::before{ display:none; }

/* Fallback icons (useful when Elementor strips SVG) */
.topyn-contact-items .topyn-contact-item:nth-child(1) .topyn-contact-icon::before{
  background-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%232563eb'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M4%204h16c1.1%200%202%20.9%202%202v12c0%201.1-.9%202-2%202H4c-1.1%200-2-.9-2-2V6c0-1.1.9-2%202-2z'/%3E%3Cpolyline%20points='22,6%2012,13%202,6'/%3E%3C/svg%3E");
}
.topyn-contact-items .topyn-contact-item:nth-child(2) .topyn-contact-icon::before{
  background-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%232563eb'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M22%2016.92v3a2%202%200%200%201-2.18%202%2019.79%2019.79%200%200%201-8.63-3.07%2019.5%2019.5%200%200%201-7.09-7.09%2019.79%2019.79%200%200%201-3.1-8.56A2%202%200%200%201%203%201h3a2%202%200%200%201%202%201.72c.127.96.361%201.903.7%202.81a2%202%200%200%201-.45%202.11L7.09%208.91A16%2016%200%200%200%2015.1%2016.9l1.27-1.27a2%202%200%200%201%202.11-.45c.907.339%201.85.573%202.81.7A2%202%200%200%201%2022%2016.92z'/%3E%3C/svg%3E");
}
.topyn-contact-items .topyn-contact-item:nth-child(3) .topyn-contact-icon::before{
  background-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%232563eb'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Ccircle%20cx='12'%20cy='12'%20r='10'/%3E%3Cpolyline%20points='12%206%2012%2012%2016%2014'/%3E%3C/svg%3E");
}
.topyn-contact-items .topyn-contact-item:nth-child(4) .topyn-contact-icon::before{
  background-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%232563eb'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M21%2010c0%207-9%2013-9%2013S3%2017%203%2010a9%209%200%200%201%2018%200z'/%3E%3Ccircle%20cx='12'%20cy='10'%20r='3'/%3E%3C/svg%3E");
}
.topyn-contact-item h3 { font-size: 1.0625rem !important; font-weight: 600 !important; color: #111827 !important; margin: 0 0 4px !important; }
.topyn-contact-item p { font-size: 0.9rem; color: #4b5563; margin: 0 0 6px; line-height: 1.6; }
.topyn-contact-item p:last-child { margin-bottom: 0; }
.topyn-contact-item a { color: #2563eb !important; font-weight: 500; text-decoration: none !important; }
.topyn-contact-item a:hover { text-decoration: underline !important; }
.topyn-contact-sub { font-size: 0.8125rem !important; color: #9ca3af !important; }

.topyn-contact-callout {
  background: #eff6ff; border: 1px solid #bfdbfe;
  border-radius: 16px; padding: 28px;
}
.topyn-contact-callout h3 { font-size: 1.125rem !important; font-weight: 700 !important; color: #111827 !important; margin: 0 0 10px !important; }
.topyn-contact-callout p { font-size: 0.9375rem; color: #374151; line-height: 1.7; margin: 0; }

/* Form card */
.topyn-contact-form-card {
  background: #fff; padding: 48px;
  border-radius: 24px;
  box-shadow: 0 20px 60px rgba(0,0,0,.08), 0 4px 16px rgba(0,0,0,.04);
  border: 1px solid #f3f4f6;
}
.topyn-contact-form-card h2 { font-size: 1.5rem !important; font-weight: 700 !important; color: #111827 !important; margin: 0 0 28px !important; }

/* CF7 inside card */
.topyn-contact-form-card .wpcf7-form { display: flex !important; flex-direction: column !important; gap: 10px !important; }
.topyn-contact-form-card .wpcf7-form p { margin: 0 !important; }
.topyn-contact-form-card .wpcf7-form br { display: none !important; }
.topyn-contact-form-card .wpcf7-form label {
  font-size: 0.875rem !important;
  font-weight: 500 !important;
  color: #374151 !important;
  display: block !important;
  margin: 0 !important;
}
.topyn-contact-form-card .wpcf7-form .wpcf7-form-control-wrap {
  display: block !important;
}
.topyn-contact-form-card .wpcf7-form input[type=text],
.topyn-contact-form-card .wpcf7-form input[type=email],
.topyn-contact-form-card .wpcf7-form input[type=number],
.topyn-contact-form-card .wpcf7-form input[type=tel],
.topyn-contact-form-card .wpcf7-form textarea {
  width: 100% !important; padding: 12px 16px !important;
  border: 1.5px solid #d1d5db !important; border-radius: 12px !important;
  font-size: 1rem !important; color: #111827 !important; background: #fff !important;
  outline: none !important; transition: border-color .15s, box-shadow .15s !important;
  font-family: var(--topyn-font) !important; box-shadow: none !important;
}
.topyn-contact-form-card .wpcf7-form input:focus,
.topyn-contact-form-card .wpcf7-form textarea:focus { border-color: transparent !important; box-shadow: 0 0 0 2px #2563eb !important; }
.topyn-contact-form-card .wpcf7-form textarea { resize: none !important; height: 140px !important; }
.topyn-contact-form-card .wpcf7-form input[type=submit] {
  width: 100% !important; background: #2563eb !important; color: #fff !important;
  font-size: 1rem !important; font-weight: 700 !important; padding: 16px !important;
  border: none !important; border-radius: 12px !important; cursor: pointer !important;
  font-family: var(--topyn-font) !important; transition: all .15s !important;
  box-shadow: 0 4px 14px rgba(37,99,235,.3) !important;
}
.topyn-contact-form-card .wpcf7-form input[type=submit]:hover { background: #1d4ed8 !important; transform: translateY(-1px) !important; }
.topyn-contact-form-card .wpcf7-not-valid-tip {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  margin-top: 6px !important;
  font-size: 0.8125rem !important;
  font-weight: 600 !important;
  color: #b91c1c !important;
  line-height: 1.3 !important;
  font-family: var(--topyn-font) !important;
}
.topyn-contact-form-card .wpcf7-not-valid-tip::before {
  content: "!" !important;
  width: 18px !important;
  height: 18px !important;
  border-radius: 999px !important;
  background: #fee2e2 !important;
  color: #b91c1c !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 0.75rem !important;
  font-weight: 800 !important;
  flex-shrink: 0 !important;
}
.topyn-contact-form-card .wpcf7-form .wpcf7-not-valid {
  border-color: #ef4444 !important;
  box-shadow: 0 0 0 2px rgba(239,68,68,.18) !important;
}
.topyn-contact-form-card .wpcf7 form .wpcf7-response-output,
.topyn-contact-form-card .wpcf7-response-output {
  padding: 14px 18px !important;
  border-radius: 12px !important;
  border: 1px solid #fecaca !important;
  background: #fee2e2 !important;
  color: #991b1b !important;
  font-size: 0.875rem !important;
  font-weight: 600 !important;
  font-family: var(--topyn-font) !important;
  line-height: 1.5 !important;
}
.topyn-contact-form-card .wpcf7 form.invalid .wpcf7-response-output,
.topyn-contact-form-card .wpcf7 form.failed .wpcf7-response-output,
.topyn-contact-form-card .wpcf7 form.aborted .wpcf7-response-output {
  border-color: #fecaca !important;
  background: #fee2e2 !important;
  color: #991b1b !important;
}
.topyn-contact-form-card .wpcf7 form.sent .wpcf7-response-output {
  border-color: #a7f3d0 !important;
  background: #d1fae5 !important;
  color: #065f46 !important;
}
.topyn-contact-form-card .wpcf7 form.spam .wpcf7-response-output {
  border-color: #fde68a !important;
  background: #fef3c7 !important;
  color: #92400e !important;
}
.topyn-contact-form-card .wpcf7-mail-sent-ok { background: #d1fae5 !important; color: #065f46 !important; border-color: #a7f3d0 !important; border-radius: 10px !important; padding: 14px 18px !important; margin: 0 !important; }
.topyn-contact-form-card .wpcf7-validation-errors, .topyn-contact-form-card .wpcf7-mail-sent-ng { background: #fee2e2 !important; color: #991b1b !important; border-color: #fca5a5 !important; border-radius: 10px !important; padding: 14px 18px !important; margin: 0 !important; }
.cf7-name-row {
  display: flex !important;
  gap: 20px !important;
  width: 100% !important;
}
.cf7-name-row > p {
  flex: 1 1 0% !important;
  margin: 0 !important;
  min-width: 0 !important;
}
.cf7-name-row label { margin: 0 !important; }
.wpcf7-spinner {
  display: block !important;
  margin: 8px auto 0 !important;
}
.wpcf7 form .wpcf7-response-output {
    margin: 0em 0.5em 1em;
    padding: 0.2em 1em;
    border: 2px solid #00a0d2;
}
@media (max-width: 600px) {
  .cf7-name-row { flex-direction: column !important; }
}

/* ============================================================
   SHARED HELPERS
   ============================================================ */
.topyn-container-narrow { max-width: 896px !important; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
  .topyn-shop-layout { grid-template-columns: 200px 1fr; gap: 28px; }
  .topyn-shop-main ul.products { grid-template-columns: repeat(2,1fr) !important; }
  .topyn-grid-4 { grid-template-columns: repeat(2,1fr); }
  ul.topyn-related-grid { grid-template-columns: repeat(2,1fr) !important; }
}
@media (max-width: 768px) {
  .topyn-shop-layout { grid-template-columns: 1fr; }
  .topyn-shop-sidebar { display: none; }
  .topyn-shop-main ul.products { grid-template-columns: repeat(2,1fr) !important; gap: 16px !important; }
  .topyn-product-grid { grid-template-columns: 1fr; }
  .topyn-about-story { grid-template-columns: 1fr; }
  .topyn-about-story-img { order: -1; }
  .topyn-contact-grid { grid-template-columns: 1fr; }
  .topyn-product-specs { grid-template-columns: 1fr; }
  .topyn-condition-options { grid-template-columns: 1fr 1fr; }
  .topyn-tab-btn { padding: 14px 20px; font-size: 0.875rem; }
  .topyn-attr-table th { width: 140px; padding: 10px 12px; }
  .topyn-attr-table td { padding: 10px 12px; }
  .topyn-thumb-slider-wrap {
    --topyn-thumb-size: 64px;
    --topyn-thumb-visible: 3;
  }
  .topyn-tab-panel[data-panel="reviews"] #rehub-comments-tabs { flex-wrap: wrap !important; }
  .topyn-tab-panel[data-panel="reviews"] #rehub-comments-tabs span { flex: 1 1 auto !important; text-align: center !important; }
  .topyn-tab-panel[data-panel="reviews"] .mobileblockdisplay { flex-direction: column !important; }
  .topyn-tab-panel[data-panel="reviews"] .rh-line-left,
  .topyn-tab-panel[data-panel="reviews"] .rh-line-right { border-left: none !important; border-right: none !important; border-top: 1px solid #e5e7eb !important; border-bottom: 1px solid #e5e7eb !important; }
  .topyn-tab-panel[data-panel="reviews"] .woo-rev-part { padding: 16px !important; width: 100% !important; }
  .topyn-tab-panel[data-panel="reviews"] .woo_pros_cons_form { grid-template-columns: 1fr !important; }
}
@media (max-width: 480px) {
  .topyn-shop-main ul.products { grid-template-columns: 1fr !important; }
  .topyn-grid-4 { grid-template-columns: 1fr; }
  .topyn-contact-form-card { padding: 28px 20px; }
  ul.topyn-related-grid { grid-template-columns: repeat(2,1fr) !important; }
  .topyn-tab-btn { padding: 12px 16px; font-size: 0.8125rem; }
  .topyn-cur-price { font-size: 1.875rem !important; }
  .topyn-thumb-slider-wrap {
    --topyn-thumb-size: 56px;
    --topyn-thumb-visible: 3;
  }
  .topyn-tab-panel[data-panel="reviews"] .user-review-vote { flex-wrap: wrap !important; gap: 8px !important; }
}
/* ============================================================
   COMPLETE FIX â€” Logo, Spacing, Shop, Contact, Homepage
   ============================================================ */

/* â”€â”€ 1. GLOBAL CONTAINER â€” max-w-7xl with proper padding â”€â”€ */
.topyn-container,
.topyn-nav-container,
.topyn-footer-wrap {
  max-width: 1280px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 16px !important;
  padding-right: 16px !important;
  width: 100% !important;
  box-sizing: border-box !important;
}
@media (min-width: 640px) {
  .topyn-container,
  .topyn-nav-container,
  .topyn-footer-wrap { padding-left: 24px !important; padding-right: 24px !important; }
}
@media (min-width: 1024px) {
  .topyn-container,
  .topyn-nav-container,
  .topyn-footer-wrap { padding-left: 32px !important; padding-right: 32px !important; }
}

/* â”€â”€ 2. LOGO FIX â€” exact React size â”€â”€ */
/* Navbar logo */
.topyn-logo {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  text-decoration: none !important;
  flex-shrink: 0 !important;
  color: #111827 !important;
  max-width: fit-content !important;
}
/* SVG icon = exactly 24x24 like React h-6 w-6 */
.topyn-logo > svg {
  width: 24px !important;
  height: 24px !important;
  flex-shrink: 0 !important;
}
/* Text = font-bold text-xl tracking-tight */
.topyn-logo > span {
  font-size: 1.25rem !important;
  font-weight: 700 !important;
  letter-spacing: -0.025em !important;
  color: #111827 !important;
  white-space: nowrap !important;
  line-height: 1.3 !important;
  font-family: var(--topyn-font) !important;
}
/* Custom logo image â€” constrain height */
.topyn-logo .custom-logo-link { display: flex !important; align-items: center !important; }
.topyn-logo .custom-logo { height: 32px !important; width: auto !important; display: block !important; }

/* Footer logo â€” same as navbar */
.topyn-footer-logo {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  text-decoration: none !important;
  color: #111827 !important;
  margin-bottom: 16px !important;
}
.topyn-footer-logo > svg { width: 24px !important; height: 24px !important; flex-shrink: 0 !important; }
.topyn-footer-logo > span {
  font-size: 1.25rem !important;
  font-weight: 700 !important;
  letter-spacing: -0.025em !important;
  color: #111827 !important;
  white-space: nowrap !important;
  font-family: var(--topyn-font) !important;
}
.topyn-footer-logo .custom-logo { height: 32px !important; width: auto !important; }

/* â”€â”€ 3. NAVBAR HEIGHT â€” exact 64px like React h-16 â”€â”€ */
.topyn-nav-container {
  height: 64px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 32px !important;
}

/* â”€â”€ 4. SHOP PAGE â€” exact React match â”€â”€ */

/* Page wrapper */
.topyn-shop-wrap {
  max-width: 1280px !important;
  margin: 0 auto !important;
  padding: 60px 16px !important;
  box-sizing: border-box !important;
}
@media (min-width: 640px)  { .topyn-shop-wrap { padding: 60px 24px !important; } }
@media (min-width: 1024px) { .topyn-shop-wrap { padding: 60px 32px !important; } }

/* Shop header */
.topyn-shop-header {
  display: flex !important;
  align-items: baseline !important;
  justify-content: space-between !important;
  flex-wrap: wrap !important;
  gap: 16px !important;
  margin-bottom: 32px !important;
}
.topyn-shop-header h1 {
  font-size: 1.875rem !important;
  font-weight: 800 !important;
  color: #111827 !important;
  margin: 0 !important;
  text-transform: capitalize !important;
  font-family: var(--topyn-font) !important;
}

/* Header controls (Filter + Sort) */
.topyn-shop-controls {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  flex-wrap: wrap !important;
}
.topyn-filter-btn {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  height: 40px !important;
  padding: 0 14px !important;
  border-radius: 10px !important;
  border: 1px solid #e5e7eb !important;
  background: #fff !important;
  color: #111827 !important;
  font-weight: 600 !important;
  font-size: 0.9375rem !important;
  cursor: pointer !important;
  transition: background .15s, border-color .15s, box-shadow .15s !important;
  font-family: var(--topyn-font) !important;
}
.topyn-filter-btn:hover { background: #f9fafb !important; border-color: #d1d5db !important; }
.topyn-filter-btn:focus { outline: none !important; box-shadow: 0 0 0 3px rgba(37,99,235,.15) !important; border-color: #2563eb !important; }
.topyn-filter-btn svg { stroke: #6b7280 !important; }

.topyn-sort-wrap .woocommerce-ordering { margin: 0 !important; }
.topyn-sort-wrap .woocommerce-ordering select {
  appearance: none !important;
  height: 40px !important;
  background: #fff !important;
  border: 1px solid #e5e7eb !important;
  padding: 0 38px 0 14px !important;
  border-radius: 10px !important;
  font-size: 0.9375rem !important;
  font-family: var(--topyn-font) !important;
  color: #111827 !important;
  outline: none !important;
  cursor: pointer !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 12px center !important;
}
.topyn-sort-wrap .woocommerce-ordering select:focus {
  border-color: #2563eb !important;
  box-shadow: 0 0 0 3px rgba(37,99,235,.15) !important;
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   Filter Drawer â€” Professional WooCommerce Modal
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.topyn-filter-drawer {
  position: fixed !important;
  inset: 0 !important;
  background: rgba(17,24,39,.5) !important;
  backdrop-filter: blur(4px) !important;
  -webkit-backdrop-filter: blur(4px) !important;
  z-index: 10000 !important;
  display: none !important;
  align-items: flex-start !important;
  justify-content: center !important;
  padding: 40px 16px !important;
  overflow-y: auto !important;
}
.topyn-filter-drawer.is-open { display: flex !important; }
.topyn-filter-drawer-inner {
  width: min(700px, 100%) !important;
  background: #fff !important;
  border-radius: 20px !important;
  box-shadow: 0 25px 50px -12px rgba(0,0,0,.25) !important;
  display: flex !important;
  flex-direction: column !important;
  max-height: min(82vh, 780px) !important;
  overflow: hidden !important;
}

/* Header */
.topyn-filter-drawer-head {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
  padding: 20px 24px !important;
  border-bottom: 1px solid var(--topyn-border) !important;
  font-family: var(--topyn-font) !important;
  color: var(--topyn-text) !important;
  flex-shrink: 0 !important;
}
.topyn-filter-drawer-head strong {
  font-size: 1.125rem !important;
  font-weight: 800 !important;
  letter-spacing: -.01em !important;
}
.topyn-filter-drawer-actions {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
}
.topyn-clear-filters {
  font-size: 0.8125rem !important;
  font-weight: 600 !important;
  color: #ef4444 !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  padding: 6px 14px !important;
  border-radius: 8px !important;
  background: #fef2f2 !important;
  transition: background .15s, color .15s !important;
}
.topyn-clear-filters:hover {
  background: #fee2e2 !important;
  color: #dc2626 !important;
  text-decoration: none !important;
}
.topyn-filter-close {
  width: 34px !important;
  height: 34px !important;
  border-radius: 10px !important;
  border: 1px solid var(--topyn-border) !important;
  background: #fff !important;
  color: var(--topyn-text) !important;
  cursor: pointer !important;
  font-size: 20px !important;
  line-height: 1 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
}
.topyn-filter-close:hover { background: var(--topyn-bg) !important; }

/* Scrollable body â€” 2 equal columns */
.topyn-filter-drawer-body {
  display: flex !important;
  gap: 24px !important;
  padding: 24px !important;
  overflow-y: auto !important;
  flex: 1 1 auto !important;
  min-height: 0 !important;
  background: #fafbfc !important;
}
.topyn-filter-col {
  flex: 1 1 0% !important;
  min-width: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 16px !important;
}
.topyn-filter-block {
  border: 1px solid var(--topyn-border) !important;
  border-radius: 14px !important;
  padding: 18px !important;
  background: #fff !important;
}
.topyn-filter-block .widget { margin: 0 !important; padding: 0 !important; }

/* Footer removed — actions live in header + inline Apply */

/* Widget titles */
.topyn-filter-drawer .widget-title,
.topyn-filter-drawer .widgettitle,
.topyn-filter-drawer h2,
.topyn-filter-drawer h3 {
  font-family: var(--topyn-font) !important;
  font-weight: 700 !important;
  color: var(--topyn-text) !important;
  font-size: 0.875rem !important;
  margin: 0 0 10px !important;
  padding: 0 !important;
  border-bottom: none !important;
  letter-spacing: .02em !important;
  text-transform: uppercase !important;
  color: var(--topyn-muted) !important;
}

/* Widget list items */
.topyn-filter-drawer .widget ul {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}
/* Category list items — count inline next to name */
.topyn-filter-drawer .widget_product_categories ul li {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 8px !important;
  margin: 0 !important;
  padding: 11px 12px !important;
  border-bottom: none !important;
  border-radius: 10px !important;
  font-family: var(--topyn-font) !important;
  font-size: 0.9375rem !important;
  line-height: 1.3 !important;
  transition: background .15s !important;
}
.topyn-filter-drawer .widget_product_categories ul {
  display: flex !important;
  flex-direction: column !important;
  gap: 4px !important;
}
.topyn-filter-drawer .widget_product_categories ul li:hover {
  background: var(--topyn-bg) !important;
}
.topyn-filter-drawer .widget_product_categories ul li a {
  color: var(--topyn-text) !important;
  text-decoration: none !important;
  font-weight: 500 !important;
  flex: 1 !important;
  min-width: 0 !important;
}
.topyn-filter-drawer .widget_product_categories ul li a:hover {
  color: var(--topyn-primary) !important;
}
.topyn-filter-drawer .widget ul li .count {
  color: var(--topyn-muted) !important;
  font-weight: 500 !important;
  font-size: 0.75rem !important;
  flex-shrink: 0 !important;
  white-space: nowrap !important;
  background: #f3f4f6 !important;
  padding: 2px 8px !important;
  border-radius: 999px !important;
}

/* Generic widget list reset */
.topyn-filter-drawer .widget ul li {
  margin: 0 !important;
  padding: 0 !important;
  border-bottom: none !important;
  font-family: var(--topyn-font) !important;
  font-size: 0.9375rem !important;
  line-height: 1.3 !important;
  list-style: none !important;
}

/* Rating filter — ReHub uses .rhwoostar spans (not WC star font) */
.topyn-filter-drawer .widget_rating_filter ul {
  display: flex !important;
  flex-direction: column !important;
  gap: 4px !important;
}
.topyn-filter-drawer .wc-layered-nav-rating {
  padding: 10px 12px !important;
  border-radius: 10px !important;
  transition: background .15s !important;
}
.topyn-filter-drawer .wc-layered-nav-rating:hover {
  background: var(--topyn-bg) !important;
}
.topyn-filter-drawer .wc-layered-nav-rating a {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  color: var(--topyn-text) !important;
  text-decoration: none !important;
  font-weight: 500 !important;
  width: 100% !important;
}
.topyn-filter-drawer .wc-layered-nav-rating a:hover {
  color: var(--topyn-primary) !important;
}
.topyn-filter-drawer .star-rating {
  display: inline-flex !important;
  align-items: center !important;
  gap: 3px !important;
  flex-shrink: 0 !important;
  overflow: visible !important;
  position: static !important;
  width: auto !important;
  height: auto !important;
  font-family: var(--topyn-font) !important;
  float: none !important;
}
.topyn-filter-drawer .star-rating::before {
  content: none !important;
  display: none !important;
}
.topyn-filter-drawer .star-rating .rhwoostar {
  font-size: 1.25rem !important;
  line-height: 1 !important;
  color: #d1d5db !important;
  position: static !important;
  float: none !important;
  overflow: visible !important;
  padding: 0 !important;
}
.topyn-filter-drawer .star-rating .rhwoostar::before {
  content: none !important;
  display: none !important;
}
.topyn-filter-drawer .star-rating .rhwoostar.active {
  color: #f59e0b !important;
}

/* Price filter widget */
.topyn-filter-drawer .widget_price_filter .price_slider_wrapper .price_slider {
  margin: 14px 12px 20px !important;
}
.topyn-filter-drawer .widget_price_filter .price_slider_amount {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 12px !important;
  justify-content: space-between !important;
  padding: 0 4px 4px !important;
}
.topyn-filter-drawer .widget_price_filter .price_slider_amount .clear {
  display: none !important;
}
.topyn-filter-drawer .widget_price_filter .price_slider_amount .price_label {
  float: none !important;
  font-family: var(--topyn-font) !important;
  color: var(--topyn-text) !important;
  font-weight: 600 !important;
  font-size: 0.875rem !important;
  white-space: nowrap !important;
}
.topyn-filter-drawer .widget_price_filter .price_slider_amount .button {
  float: none !important;
  background: var(--topyn-primary) !important;
  border: 1px solid var(--topyn-primary) !important;
  color: #fff !important;
  border-radius: 10px !important;
  padding: 10px 0 !important;
  font-weight: 700 !important;
  font-family: var(--topyn-font) !important;
  text-transform: none !important;
  box-shadow: 0 4px 12px rgba(37,99,235,.25) !important;
  cursor: pointer !important;
  margin-top: 8px !important;
  font-size: 0 !important;
  line-height: 0 !important;
  width: 100% !important;
  flex-basis: 100% !important;
  text-align: center !important;
}
.topyn-filter-drawer .widget_price_filter .price_slider_amount .button::after {
  content: "Apply" !important;
  font-size: 0.875rem !important;
  line-height: 1 !important;
}
.topyn-filter-drawer .widget_price_filter .price_slider_amount .button:hover {
  background: var(--topyn-primary-h) !important;
  border-color: var(--topyn-primary-h) !important;
}
.topyn-filter-drawer .widget_price_filter .ui-slider {
  background: #e5e7eb !important;
  border: none !important;
  border-radius: 999px !important;
  height: 6px !important;
  position: relative !important;
  overflow: visible !important;
  margin-top: 10px !important;
  margin-bottom: 10px !important;
}
.topyn-filter-drawer .widget_price_filter .ui-slider .ui-slider-range {
  background: var(--topyn-primary) !important;
  border-radius: 999px !important;
  position: absolute !important;
  top: 0 !important;
  height: 100% !important;
  display: block !important;
}
.topyn-filter-drawer .widget_price_filter .ui-slider .ui-slider-handle,
.topyn-filter-drawer .widget_price_filter .ui-slider .ui-slider-handle.ui-state-default {
  display: block !important;
  position: absolute !important;
  border-radius: 50% !important;
  -webkit-border-radius: 50% !important;
  background: #fff !important;
  border: 3px solid var(--topyn-primary) !important;
  width: 24px !important;
  height: 24px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  margin-top: 0 !important;
  margin-left: -12px !important;
  box-shadow: 0 2px 10px rgba(37,99,235,.2), 0 1px 3px rgba(0,0,0,.1) !important;
  z-index: 2 !important;
  cursor: grab !important;
  outline: none !important;
  transition: box-shadow .15s !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  padding: 0 !important;
  box-sizing: border-box !important;
}
.topyn-filter-drawer .widget_price_filter .ui-slider .ui-slider-handle:hover {
  box-shadow: 0 4px 16px rgba(37,99,235,.25) !important;
}
.topyn-filter-drawer .widget_price_filter .ui-slider .ui-slider-handle:focus {
  outline: none !important;
  box-shadow: 0 0 0 4px rgba(37,99,235,.15), 0 4px 16px rgba(37,99,235,.25) !important;
}
.topyn-filter-drawer .widget_price_filter .ui-slider .ui-slider-handle.ui-state-active,
.topyn-filter-drawer .widget_price_filter .ui-slider .ui-slider-handle:active {
  cursor: grabbing !important;
  box-shadow: 0 0 0 5px rgba(37,99,235,.15), 0 6px 20px rgba(37,99,235,.3) !important;
}
.topyn-filter-drawer .widget_price_filter .ui-slider,
.topyn-filter-drawer .widget_price_filter .ui-slider * {
  pointer-events: auto !important;
}
.topyn-filter-drawer .widget_price_filter .topyn-price-fields {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 10px !important;
  margin: 12px 0 0 !important;
  font-family: var(--topyn-font) !important;
}
.topyn-filter-drawer .widget_price_filter .topyn-price-field {
  border: 1px solid var(--topyn-border) !important;
  border-radius: 10px !important;
  padding: 8px 12px !important;
  background: var(--topyn-bg) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 8px !important;
}
.topyn-filter-drawer .widget_price_filter .topyn-price-field-label {
  font-size: 0.75rem !important;
  font-weight: 700 !important;
  color: var(--topyn-muted) !important;
  letter-spacing: .03em !important;
  text-transform: uppercase !important;
}
.topyn-filter-drawer .widget_price_filter .topyn-price-field-value {
  font-size: 0.9375rem !important;
  font-weight: 800 !important;
  color: var(--topyn-text) !important;
  white-space: nowrap !important;
}

/* Responsive filter drawer */
@media (max-width: 640px) {
  .topyn-filter-drawer { padding: 16px 10px !important; }
  .topyn-filter-drawer-inner {
    max-height: 90vh !important;
    border-radius: 16px !important;
  }
  .topyn-filter-drawer-head,
  .topyn-filter-drawer-body {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }
  .topyn-filter-drawer-body { flex-direction: column !important; }
  .topyn-filter-col { flex: none !important; }
}

/* Product grid â€” React: grid-cols-1 sm:grid-cols-2 lg:grid-cols-3 xl:grid-cols-4 */
.topyn-shop-main ul.products,
.woocommerce ul.products {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 32px !important;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  align-items: stretch !important;
}

/* Full width shop (no left sidebar) */
.topyn-shop-layout.is-full {
  display: block !important;
}
.topyn-shop-main.is-full {
  width: 100% !important;
}
@media (max-width: 1280px) {
  .topyn-shop-main ul.products,
  .woocommerce ul.products { grid-template-columns: repeat(3, 1fr) !important; }
}
@media (max-width: 768px) {
  .topyn-shop-main ul.products,
  .woocommerce ul.products { grid-template-columns: repeat(2, 1fr) !important; gap: 16px !important; }
}
@media (max-width: 480px) {
  .topyn-shop-main ul.products,
  .woocommerce ul.products { grid-template-columns: 1fr !important; }
}

/* WC default li.product â€” remove default styles */
.woocommerce ul.products li.product {
  margin: 0 !important;
  padding: 0 !important;
  float: none !important;
  width: auto !important;
  background: none !important;
  border: none !important;
  box-shadow: none !important;
  height: 100% !important;
  display: flex !important;
  align-self: stretch !important;
  justify-self: stretch !important;
  min-width: 0 !important;
  clear: none !important;
}

/* Some themes add .first/.last with clear that breaks the first column */
.woocommerce ul.products li.product.first,
.woocommerce ul.products li.product.last,
.woocommerce ul.products li.product:nth-child(4n+1) {
  clear: none !important;
}

/* Ensure Woo adds no pseudo borders/clears that break first column */
.woocommerce ul.products::before,
.woocommerce ul.products::after,
.woocommerce ul.products li.product::before,
.woocommerce ul.products li.product::after {
  content: none !important;
  display: none !important;
}

/* Product card */
.topyn-product-card {
  display: flex !important;
  flex-direction: column !important;
  text-decoration: none !important;
  cursor: pointer !important;
  width: 100% !important;
  height: 100% !important;
  gap: 12px !important;
  min-width: 0 !important;
}
.topyn-product-card:hover { text-decoration: none !important; }

/* Keep each card's text area consistent height */
.topyn-product-info {
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
  flex: 1 1 auto !important;
  min-height: 132px !important;
}
.topyn-product-footer { margin-top: auto !important; }

/* Product image â€” aspect-ratio 1:1, rounded-2xl */
.topyn-product-img-wrap {
  display: block !important;
  position: relative !important;
  background: #f3f4f6 !important;
  border-radius: 16px !important;
  overflow: hidden !important;
  aspect-ratio: 1 / 1 !important;
  width: 100% !important;
}
.topyn-product-img-wrap img {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
  transition: transform 0.5s ease !important;
  border-radius: 16px !important;
}
.topyn-product-card:hover .topyn-product-img-wrap img { transform: scale(1.05) !important; }

/* Condition badge â€” React: absolute top-3 left-3 bg-white/90 backdrop-blur-sm */
.topyn-condition-badge {
  position: absolute !important;
  top: 12px !important;
  left: 12px !important;
  background: rgba(255,255,255,0.9) !important;
  backdrop-filter: blur(4px) !important;
  -webkit-backdrop-filter: blur(4px) !important;
  padding: 3px 10px !important;
  border-radius: 6px !important;
  font-size: 0.75rem !important;
  font-weight: 600 !important;
  color: #111827 !important;
  box-shadow: 0 1px 4px rgba(0,0,0,.1) !important;
  z-index: 1 !important;
}

/* Product name row */
.topyn-product-top {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 8px !important;
  margin-bottom: 4px !important;
}
.topyn-product-name {
  font-size: 1.125rem !important;  /* text-lg */
  font-weight: 700 !important;
  color: #111827 !important;
  text-decoration: none !important;
  line-height: 1.3 !important;
  transition: color .15s !important;
  font-family: var(--topyn-font) !important;
  /* Keep card heights consistent (2 lines) */
  overflow: hidden !important;
  display: -webkit-box !important;
  -webkit-box-orient: vertical !important;
  -webkit-line-clamp: 2 !important;
  line-clamp: 2 !important;
  max-height: calc(1.3em * 2) !important;
  min-height: calc(1.3em * 2) !important;
}
.topyn-product-card:hover .topyn-product-name { color: #2563eb !important; }

/* Star rating */
.topyn-product-rating {
  display: flex !important;
  align-items: center !important;
  gap: 3px !important;
  font-size: 0.875rem !important;
  color: #6b7280 !important;
  flex-shrink: 0 !important;
  white-space: nowrap !important;
}

/* Brand */
.topyn-product-brand {
  font-size: 0.875rem !important;
  color: #6b7280 !important;
  margin: 0 !important;
}

/* Price row */
.topyn-product-footer {
  display: grid !important;
  grid-template-columns: 1fr auto !important;
  align-items: center !important;
  gap: 12px !important;
  min-height: 56px !important; /* supports 2-line price + ranges */
}
.topyn-product-price {
  font-size: 1.25rem !important;
  font-weight: 800 !important;
  color: #111827 !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 4px !important;
  white-space: normal !important;
  line-height: 1.1 !important;
  min-height: 36px !important;
}

/* Center single-line prices vertically */
.topyn-product-price.is-single{
  justify-content: center !important;
}
.topyn-product-price .woocommerce-Price-amount,
.topyn-product-price bdi { font-size: inherit !important; font-weight: inherit !important; color: inherit !important; }
.topyn-product-price ins {
  background: transparent !important;
  text-decoration: none !important;
}
.topyn-product-price del {
  font-size: 0.875rem !important; /* professional 'was' size */
  color: #9ca3af !important;
  font-weight: 500 !important;
  margin: 0 !important;
  opacity: .95;
}
.topyn-product-price del .woocommerce-Price-amount { font-size: inherit !important; font-weight: inherit !important; color: inherit !important; }

/* Ensure 'was' range stays small too */
.topyn-product-price del .topyn-price-min .woocommerce-Price-amount,
.topyn-product-price del .topyn-price-min bdi,
.topyn-product-price del .topyn-price-max .woocommerce-Price-amount,
.topyn-product-price del .topyn-price-max bdi,
.topyn-product-price del .topyn-price-sep {
  font-size: 0.875rem !important;
  font-weight: 500 !important;
  color: #9ca3af !important;
}

/* View Details â€” match React: text-sm font-medium blue-600 hover:underline */
.topyn-product-footer .topyn-view-link{
  font-size: 0.875rem !important;
  font-weight: 500 !important;
  color: #2563eb !important;
  background: transparent !important;
  border: 0 !important;
  padding: 0 !important;
  height: auto !important;
  border-radius: 0 !important;
  display: inline !important;
  box-shadow: none !important;
}

.topyn-product-price .topyn-price-now {
  display: flex !important;
  align-items: baseline !important;
  gap: 6px !important;
  font-size: 1.25rem !important;
  font-weight: 800 !important;
  color: #111827 !important;
  white-space: nowrap !important;
}

.topyn-product-price .topyn-price-min .woocommerce-Price-amount,
.topyn-product-price .topyn-price-min bdi{
  font-size: 1.25rem !important;
  font-weight: 800 !important;
  color: #111827 !important;
}
.topyn-product-price .topyn-price-sep{
  color: #9ca3af !important;
  font-weight: 700 !important;
}
.topyn-product-price .topyn-price-max .woocommerce-Price-amount,
.topyn-product-price .topyn-price-max bdi{
  font-size: 1.25rem !important;
  font-weight: 800 !important;
  color: #111827 !important;
}

.topyn-view-link {
  font-size: 0.875rem !important;
  font-weight: 500 !important;
  color: #2563eb !important;
  text-decoration: none !important;
  transition: text-decoration .15s !important;
  white-space: nowrap !important;
  flex: 0 0 auto !important;
}
.topyn-product-card:hover .topyn-view-link { text-decoration: underline !important; }

/* Pagination â€” improved look */
.topyn-pagination { margin-top: 56px !important; }
.woocommerce nav.woocommerce-pagination ul,
.woocommerce nav.woocommerce-pagination ul li {
  border: none !important;
}
.topyn-pagination .woocommerce-pagination ul {
  border: none !important;
  box-shadow: none !important;
  background: transparent !important;
}
.topyn-pagination .woocommerce-pagination ul {
  display: flex !important;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  gap: 10px !important;
  justify-content: center !important;
  flex-wrap: wrap !important;
}
.topyn-pagination .woocommerce-pagination ul li { margin: 0 !important; }
.topyn-pagination .woocommerce-pagination .page-numbers {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 42px !important;
  height: 42px !important;
  padding: 0 14px !important;
  border-radius: 12px !important;
  background: #fff !important;
  color: #111827 !important;
  text-decoration: none !important;
  font-weight: 600 !important;
  transition: transform .12s, border-color .12s, box-shadow .12s, background .12s !important;
}
.topyn-pagination .woocommerce-pagination a.page-numbers:hover {
  box-shadow: 0 0 0 3px rgba(37,99,235,.12) !important;
  transform: translateY(-1px) !important;
}
.topyn-pagination .woocommerce-pagination .page-numbers.current {
  background: #2563eb !important;
  color: #fff !important;
}
.topyn-pagination .woocommerce-pagination .page-numbers.dots {
  border-color: transparent !important;
  background: transparent !important;
  padding: 0 6px !important;
  min-width: 18px !important;
}

/* â”€â”€ 5. CONTACT PAGE â€” force new template, hide Elementor content â”€â”€ */
/* When contact page uses our template, Elementor content should not show */
.page-template-page-contact .elementor,
.page-template-page-contact .entry-content > *:not(.topyn-contact) {
  display: none !important;
}
.topyn-contact { display: block !important; }

/* â”€â”€ 6. HOME PAGE â€” wrapper fix â”€â”€ */
#topyn-home {
  width: 100% !important;
  max-width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
}
/* Section inner containers use topyn-container for left/right spacing */
.topyn-hero .topyn-container,
.topyn-social-proof .topyn-container,
.topyn-section .topyn-container { width: 100% !important; }

/* â”€â”€ 7. FULL WIDTH â€” override any Rehub/WP body constraint â”€â”€ */
html, body {
  margin: 0 !important; padding: 0 !important;
  max-width: 100% !important; width: 100% !important;
  border: none !important; box-shadow: none !important;
}
#page, .site, #content, .hfeed, .rh_wrap,
#topyn-page, #topyn-content {
  max-width: 100% !important; width: 100% !important;
  margin: 0 !important; padding: 0 !important;
  border: none !important; box-shadow: none !important;
}

/* â”€â”€ Container â”€â”€ */
.topyn-policy {
  background: #ffffff;
  padding: 80px 0 50px 0;
  min-height: 60vh;
}
 
.topyn-policy-container {
  max-width: 896px;        /* max-w-4xl */
  margin: 0 auto;
  padding: 0 16px;
  box-sizing: border-box;
}
@media (min-width: 640px)  { .topyn-policy-container { padding: 0 24px; } }
@media (min-width: 1024px) { .topyn-policy-container { padding: 0 32px; } }
 
/* â”€â”€ Page title â€” text-4xl font-extrabold â”€â”€ */
.topyn-policy h1 {
  font-size: clamp(1.875rem, 4vw, 2.25rem) !important;
  font-weight: 900 !important;
  color: #111827 !important;
  margin: 0 0 32px !important;
  line-height: 1.15 !important;
  font-family: 'Inter', sans-serif !important;
  letter-spacing: -0.02em !important;
}
 
/* â”€â”€ Content wrapper â”€â”€ */
.topyn-policy-content {
  color: #4b5563;
  font-size: 1.0625rem;
  line-height: 1.8;
  font-family: 'Inter', sans-serif;
}
 
.topyn-policy-content p {
  margin: 0 0 20px !important;
  color: #4b5563 !important;
  font-size: 1.0625rem !important;
  line-height: 1.8 !important;
}
 
/* â”€â”€ Section headings â€” text-2xl font-bold â”€â”€ */
.topyn-policy-content h2 {
  font-size: 1.375rem !important;
  font-weight: 700 !important;
  color: #111827 !important;
  margin: 48px 0 24px !important;
  line-height: 1.25 !important;
  font-family: 'Inter', sans-serif !important;
}
 
/* â”€â”€ Lists â”€â”€ */
.topyn-policy-content ul,
.topyn-policy-content ol {
  padding-left: 24px !important;
  margin: 0 0 24px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
}
 
.topyn-policy-content ul { list-style: disc !important; }
.topyn-policy-content ol { list-style: decimal !important; }
 
.topyn-policy-content li {
  color: #4b5563 !important;
  font-size: 1.0625rem !important;
  line-height: 1.7 !important;
  padding-left: 4px !important;
}
 
/* â”€â”€ Bold â”€â”€ */
.topyn-policy-content strong {
  font-weight: 700 !important;
  color: #111827 !important;
}
 
/* â”€â”€ Links â”€â”€ */
.topyn-policy-content a {
  color: #2563eb !important;
  text-decoration: none !important;
  font-weight: 500 !important;
}
.topyn-policy-content a:hover {
  text-decoration: underline !important;
}
 
/* â”€â”€ Shipping table â”€â”€ */
.topyn-policy-table {
  overflow-x: auto;
  margin: 32px 0;
  border-radius: 12px;
  border: 1px solid #e5e7eb;
}
 
.topyn-policy-table table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9375rem;
}
 
.topyn-policy-table thead tr {
  background: #f9fafb;
}
 
.topyn-policy-table th {
  padding: 14px 20px !important;
  text-align: left !important;
  font-weight: 600 !important;
  color: #111827 !important;
  font-size: 0.9375rem !important;
  border-bottom: 1px solid #e5e7eb !important;
  white-space: nowrap !important;
}
 
.topyn-policy-table td {
  padding: 14px 20px !important;
  color: #4b5563 !important;
  font-size: 0.9375rem !important;
  border-bottom: 1px solid #f3f4f6 !important;
  vertical-align: top !important;
  line-height: 1.6 !important;
}
 
.topyn-policy-table tbody tr:last-child td {
  border-bottom: none !important;
}
 
.topyn-policy-table tbody tr:hover {
  background: #fafafa !important;
}
 
.topyn-policy-table .topyn-free {
  font-weight: 700 !important;
  color: #16a34a !important;
}
 
/* â”€â”€ Italic note â”€â”€ */
.topyn-policy-note {
  font-size: 0.875rem !important;
  color: #9ca3af !important;
  font-style: italic !important;
  margin-top: -16px !important;
}
 
/* â”€â”€ Responsive â”€â”€ */
@media (max-width: 640px) {
  .topyn-policy { padding: 48px 0; }
  .topyn-policy-content h2 { margin-top: 36px !important; }
  .topyn-policy-table { border-radius: 8px; }
}

/* ============================================================
   FAQ PAGE (Helpie FAQ) â€” Theme design (fresh)
   ============================================================ */
.topyn-faq-page {
  padding: 72px 0;
  background: #fff;
}
.topyn-faq-page .topyn-container {
  max-width: 960px;
  margin: 0 auto;
  padding: 0 16px;
}
@media (min-width: 640px) { .topyn-faq-page .topyn-container { padding: 0 24px; } }
@media (min-width: 1024px) { .topyn-faq-page .topyn-container { padding: 0 32px; } }

.topyn-faq-hero2 { text-align: center; margin-bottom: 28px; }
.topyn-faq-hero2 h1 {
  font-size: clamp(2.1rem, 4vw, 3rem);
  font-weight: 900;
  color: #111827;
  margin: 0 0 12px;
  letter-spacing: -0.03em;
}
.topyn-faq-hero2 p {
  font-size: 1.0625rem;
  color: #6b7280;
  line-height: 1.75;
  margin: 0 auto;
  max-width: 720px;
}

.topyn-faq-actions {
  margin-top: 16px;
  display: flex;
  justify-content: center;
  gap: 12px;
  flex-wrap: wrap;
}
.topyn-faq-actions a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 10px 16px;
  border-radius: 999px;
  text-decoration: none !important;
  font-weight: 700;
  font-size: 0.9375rem;
  border: 1px solid #e5e7eb;
  color: #111827 !important;
  background: #fff;
}
.topyn-faq-actions a.topyn-primary {
  background: #2563eb;
  border-color: #2563eb;
  color: #fff !important;
  box-shadow: 0 8px 30px rgba(37,99,235,.25);
}
.topyn-faq-actions a.topyn-primary:hover { background: #1d4ed8; border-color: #1d4ed8; }
.topyn-faq-actions a:hover { border-color: #d1d5db; }

.topyn-faq-search2 {
  margin: 18px auto 0;
  max-width: 640px;
  position: relative;
}
.topyn-faq-search2 input {
  width: 100%;
  height: 48px;
  border-radius: 14px;
  border: 1px solid #e5e7eb;
  background: #fff;
  padding: 0 14px 0 44px;
  font-size: 0.9375rem;
  outline: none;
  box-shadow: 0 1px 2px rgba(0,0,0,.04);
}
.topyn-faq-search2 input:focus {
  border-color: #93c5fd;
  box-shadow: 0 0 0 4px rgba(37,99,235,.15);
}
.topyn-faq-search2 svg {
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  stroke: #6b7280;
}
.topyn-faq-empty2 {
  display: none;
  margin-top: 16px;
  padding: 14px 16px;
  border-radius: 14px;
  background: #f9fafb;
  border: 1px solid #e5e7eb;
  color: #6b7280;
  text-align: center;
}

/* Helpie FAQ output â€” override plugin CSS */
.topyn-faq-page .helpie-faq.accordions,
.topyn-faq-page .helpie-faqs.accordions,
.topyn-faq-page .helpie-faq-wrap.accordions {
  width: 100% !important;
  margin: 10px 0 0 !important;
  opacity: 1 !important;
  transform: none !important;
  font-family: var(--topyn-font, 'Inter', sans-serif) !important;
}

/* Reduce FAQ list width a bit (more premium) */
.topyn-faq-page .helpie-faq.accordions,
.topyn-faq-page .helpie-faqs.accordions,
.topyn-faq-page .helpie-faq-wrap.accordions,
.topyn-faq-page .topyn-faq-empty2,
.topyn-faq-page .topyn-faq-search2 {
  max-width: 896px;
  margin-left: auto !important;
  margin-right: auto !important;
}
.topyn-faq-page .helpie-faq.accordions .accordion,
.topyn-faq-page .helpie-faqs.accordions .accordion,
.topyn-faq-page .helpie-faq-wrap.accordions .accordion {
  margin: 0 !important;
  padding: 0 !important;
  overflow: visible !important;
}
.topyn-faq-page .helpie-faq.accordions ul,
.topyn-faq-page .helpie-faqs.accordions ul,
.topyn-faq-page .helpie-faq-wrap.accordions ul {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  display: grid !important;
  gap: 14px !important;
}
.topyn-faq-page .helpie-faq.accordions .accordion__item,
.topyn-faq-page .helpie-faqs.accordions .accordion__item,
.topyn-faq-page .helpie-faq-wrap.accordions .accordion__item {
  border: 1px solid #e5e7eb !important;
  border-bottom: 1px solid #e5e7eb !important;
  border-radius: 18px !important;
  background: #fff !important;
  overflow: hidden !important;
  box-shadow: 0 10px 30px rgba(17,24,39,.06) !important;
  transition: box-shadow .2s ease, transform .2s ease, border-color .2s ease;
}
.topyn-faq-page .helpie-faq.accordions .accordion__item:hover,
.topyn-faq-page .helpie-faqs.accordions .accordion__item:hover,
.topyn-faq-page .helpie-faq-wrap.accordions .accordion__item:hover {
  border-color: #dbeafe !important;
  box-shadow: 0 16px 44px rgba(17,24,39,.10) !important;
  transform: translateY(-1px);
}
.topyn-faq-page .helpie-faq.accordions .accordion__header,
.topyn-faq-page .helpie-faqs.accordions .accordion__header,
.topyn-faq-page .helpie-faq-wrap.accordions .accordion__header {
  background: #fff !important;
  border: 0 !important;
  padding: 18px 18px !important;
  cursor: pointer !important;
  outline: none !important;
  display: block !important; /* plugin expects block */
  position: relative !important;
}
.topyn-faq-page .helpie-faq.accordions .accordion__title,
.topyn-faq-page .helpie-faqs.accordions .accordion__title,
.topyn-faq-page .helpie-faq-wrap.accordions .accordion__title {
  font-weight: 700 !important;
  color: #111827 !important;
  font-size: 1.00rem !important;
  line-height: 1.35 !important;
  padding-right: 48px !important; /* space for +/- */
}
.topyn-faq-page .helpie-faq.accordions .accordion__body,
.topyn-faq-page .helpie-faqs.accordions .accordion__body,
.topyn-faq-page .helpie-faq-wrap.accordions .accordion__body {
  background: #fff !important;
  padding: 10px 18px 18px !important;
  color: #4b5563 !important;
  line-height: 1.85 !important;
  font-size: 0.95rem !important;
  border-top: 1px solid #f3f4f6 !important;
}

/* Plugin +/- lines */
.topyn-faq-page .helpie-faq.accordions .accordion__header:before,
.topyn-faq-page .helpie-faq.accordions .accordion__header:after,
.topyn-faq-page .helpie-faqs.accordions .accordion__header:before,
.topyn-faq-page .helpie-faqs.accordions .accordion__header:after,
.topyn-faq-page .helpie-faq-wrap.accordions .accordion__header:before,
.topyn-faq-page .helpie-faq-wrap.accordions .accordion__header:after {
  margin-right: 18px !important;
  right: 0 !important;
  width: 14px !important;
  height: 2px !important;
  background: #9ca3af !important;
  border-radius: 2px !important;
}
.topyn-faq-page .helpie-faq.accordions .accordion__header.active:before,
.topyn-faq-page .helpie-faq.accordions .accordion__header[aria-expanded="true"]:before,
.topyn-faq-page .helpie-faqs.accordions .accordion__header.active:before,
.topyn-faq-page .helpie-faqs.accordions .accordion__header[aria-expanded="true"]:before,
.topyn-faq-page .helpie-faq-wrap.accordions .accordion__header.active:before,
.topyn-faq-page .helpie-faq-wrap.accordions .accordion__header[aria-expanded="true"]:before {
  transform: rotate(0deg) !important;
  background: #2563eb !important;
}
.topyn-faq-page .helpie-faq.accordions .accordion__header.active:after,
.topyn-faq-page .helpie-faq.accordions .accordion__header[aria-expanded="true"]:after,
.topyn-faq-page .helpie-faqs.accordions .accordion__header.active:after,
.topyn-faq-page .helpie-faqs.accordions .accordion__header[aria-expanded="true"]:after,
.topyn-faq-page .helpie-faq-wrap.accordions .accordion__header.active:after,
.topyn-faq-page .helpie-faq-wrap.accordions .accordion__header[aria-expanded="true"]:after {
  background: #2563eb !important;
}
.topyn-faq-page .helpie-faq.accordions .accordion__item .accordion__header:focus-visible,
.topyn-faq-page .helpie-faqs.accordions .accordion__item .accordion__header:focus-visible,
.topyn-faq-page .helpie-faq-wrap.accordions .accordion__item .accordion__header:focus-visible {
  outline: 3px solid rgba(37,99,235,.25) !important;
  outline-offset: 3px !important;
}

@media (max-width: 640px) {
  .topyn-faq-page { padding: 56px 0; }
  .topyn-faq-page .helpie-faq.accordions .accordion__header,
  .topyn-faq-page .helpie-faqs.accordions .accordion__header,
  .topyn-faq-page .helpie-faq-wrap.accordions .accordion__header { padding: 16px !important; }
  .topyn-faq-page .helpie-faq.accordions .accordion__body,
  .topyn-faq-page .helpie-faqs.accordions .accordion__body,
  .topyn-faq-page .helpie-faq-wrap.accordions .accordion__body { padding: 0 16px 16px !important; }
}
