/* =============================================
   TossaDivers v2 — Shared Styles
   Deep navy + gold + Inter + glassmorphism
   Matches Next.js design system
   ============================================= */

/* =============================================
   CSS VARIABLES
   ============================================= */

:root {
  --td-deep-950: #0A1628;
  --td-deep-900: #0D1B2A;
  --td-deep-800: #132238;
  --td-deep-700: #1A2E4A;
  --td-gold-400: #F2D953;
  --td-gold-500: #C8A84E;
  --td-gold-600: #B08A3E;
  --td-neutral-50: #FCFCFC;
  --td-neutral-400: #9C9C9C;
  --td-neutral-500: #BFBFBF;
  --td-neutral-800: #444444;
  --td-font-sans: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --td-white-5: rgba(255,255,255,0.05);
  --td-white-10: rgba(255,255,255,0.1);
  --td-white-30: rgba(255,255,255,0.3);
  --td-transition: color 0.3s cubic-bezier(0.4,0,0.2,1),
                    background-color 0.3s cubic-bezier(0.4,0,0.2,1),
                    border-color 0.3s cubic-bezier(0.4,0,0.2,1),
                    opacity 0.3s cubic-bezier(0.4,0,0.2,1);
}

/* =============================================
   BASE
   ============================================= */

* { box-sizing: border-box; }

body.td-custom-header {
  background-color: var(--td-deep-950);
  color: var(--td-neutral-50);
  font-family: var(--td-font-sans);
  font-weight: 300;
  margin: 0;
  padding-top: 76px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Reset link underlines site-wide (parent theme dequeued — no color override needed) */
body.td-custom-header a {
  text-decoration: none;
}

/* Override WP global styles content-size constraint (800px → full width for our layouts) */
body.td-custom-header {
  --wp--style--global--content-size: 100%;
  --wp--style--global--wide-size: 100%;
}

/* Force transparent/dark backgrounds on all theme wrappers */
body.td-custom-header .site-main,
body.td-custom-header .page-content,
body.td-custom-header .page-header {
  background-color: transparent !important;
}

/* Override parent theme heading colors */
body.td-custom-header h1,
body.td-custom-header h2,
body.td-custom-header h3,
body.td-custom-header h4,
body.td-custom-header h5,
body.td-custom-header h6 {
  color: var(--td-neutral-50);
  font-family: var(--td-font-sans);
  font-weight: 400;
}

/* Hide the default page title (we use custom WC headings) */
body.td-custom-header .page-header .entry-title {
  display: none;
}

/* Ensure site-main fills properly and remove parent theme max-width */
body.td-custom-header .site-main {
  min-height: calc(100vh - 76px);
  max-width: 100% !important;
  padding: 0 !important;
}

/* Override parent theme button styles (#c36 border/color) */
body.td-custom-header button,
body.td-custom-header [type="button"],
body.td-custom-header [type="submit"] {
  border-color: transparent;
  color: inherit;
}

body.td-custom-header button:hover,
body.td-custom-header button:focus,
body.td-custom-header [type="submit"]:hover,
body.td-custom-header [type="submit"]:focus {
  background-color: inherit;
  color: inherit;
}

/* Override parent theme table styles for dark theme */
body.td-custom-header table {
  border-collapse: collapse;
  width: 100%;
  margin-bottom: 1.5rem;
  font-size: 0.875rem;
}

body.td-custom-header table td,
body.td-custom-header table th {
  border: 1px solid var(--td-deep-700);
  padding: 0.75rem 1rem;
  color: var(--td-neutral-400);
  font-weight: 300;
  vertical-align: top;
  line-height: 1.5;
}

body.td-custom-header table th {
  background-color: rgba(200, 168, 78, 0.08);
  color: var(--td-neutral-50);
  font-weight: 400;
  text-align: left;
}

body.td-custom-header table thead th {
  background-color: rgba(200, 168, 78, 0.12);
  color: var(--td-neutral-50);
  font-weight: 400;
  border-bottom: 2px solid var(--td-gold-500);
}

body.td-custom-header table tbody tr:nth-child(odd) td,
body.td-custom-header table tbody tr:nth-child(odd) th {
  background-color: rgba(255, 255, 255, 0.02);
}

body.td-custom-header table tbody tr:hover td {
  background-color: rgba(255, 255, 255, 0.04);
}

/* =============================================
   GLASSMORPHISM
   ============================================= */

.td-glass {
  background-color: rgba(217, 217, 217, 0.12);
  backdrop-filter: blur(7px);
  -webkit-backdrop-filter: blur(7px);
}

.td-glass-dark {
  background-color: rgba(20, 20, 20, 0.65);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.td-glass-header {
  background-color: rgba(10, 22, 40, 0.8);
  backdrop-filter: blur(7px);
  -webkit-backdrop-filter: blur(7px);
}

/* =============================================
   HEADER
   ============================================= */

.td-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 9999;
  font-family: var(--td-font-sans);
}

.td-header-inner {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 1rem;
}

@media (min-width: 1024px) {
  .td-header-inner {
    padding: 0 2.5rem;
  }
}

.td-header-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 76px;
}

/* Logo */
.td-logo {
  flex-shrink: 0;
  position: relative;
  z-index: 10;
  text-decoration: none;
}

.td-logo-img {
  height: 2.5rem !important;
  max-height: 2.5rem !important;
  width: auto !important;
  max-width: 160px !important;
  object-fit: contain;
  transition: opacity 0.3s ease;
}

@media (min-width: 768px) {
  .td-logo-img {
    height: 3rem !important;
    max-height: 3rem !important;
    max-width: 200px !important;
  }
}

.td-logo-img.scrolled {
  opacity: 0.4;
}

/* Desktop Navigation — glass pill */
.td-nav-desktop {
  display: none;
  align-items: center;
  gap: 2px;
  border-radius: 0.5rem;
  padding: 0.375rem 0.5rem;
}

@media (min-width: 1024px) {
  .td-nav-desktop {
    display: flex;
  }
}

.td-nav-link {
  display: block;
  padding: 0.375rem 1rem;
  font-size: 0.875rem;
  font-weight: 300;
  color: rgba(252, 252, 252, 0.8);
  text-decoration: none;
  border-radius: 0.25rem;
  transition: var(--td-transition);
}

.td-nav-link:hover {
  color: var(--td-neutral-50);
}

/* Right side controls */
.td-header-actions {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

/* Language Switcher — glass box */
.td-lang-switcher {
  display: none;
  align-items: center;
  gap: 2px;
  border-radius: 0.5rem;
  padding: 0.25rem;
}

@media (min-width: 640px) {
  .td-lang-switcher {
    display: flex;
  }
}

.td-lang-link {
  padding: 0.25rem 0.625rem;
  border-radius: 0.25rem;
  text-decoration: none;
  font-size: 0.875rem;
  font-weight: 300;
  color: var(--td-neutral-400);
  transition: var(--td-transition);
}

.td-lang-link:hover {
  color: var(--td-neutral-50);
}

.td-lang-link.active {
  color: var(--td-neutral-50);
  font-weight: 400;
}

/* Cart Icon — glass box */
.td-cart-link {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.625rem;
  border-radius: 0.5rem;
  color: var(--td-neutral-400);
  text-decoration: none;
  transition: var(--td-transition);
}

.td-cart-link:hover {
  color: var(--td-neutral-50);
}

.td-cart-link svg {
  width: 1.25rem;
  height: 1.25rem;
}

.td-cart-badge {
  position: absolute;
  top: 0.125rem;
  right: 0.125rem;
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 1rem;
  height: 1rem;
  padding: 0 0.25rem;
  font-size: 0.625rem;
  font-weight: 500;
  color: var(--td-deep-950);
  background-color: var(--td-gold-500);
  border-radius: 9999px;
  line-height: 1;
}

/* Mobile Menu Toggle — glass box */
.td-mobile-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.625rem;
  border-radius: 0.5rem;
  color: var(--td-neutral-400);
  background: none;
  border: none;
  cursor: pointer;
  transition: var(--td-transition);
}

@media (min-width: 1024px) {
  .td-mobile-toggle {
    display: none;
  }
}

.td-mobile-toggle:hover {
  color: var(--td-neutral-50);
}

.td-mobile-toggle svg {
  width: 1.25rem;
  height: 1.25rem;
}

/* Mobile Menu */
.td-mobile-menu {
  display: none;
  padding: 0 1rem 0.5rem;
  font-family: var(--td-font-sans);
}

@media (min-width: 1024px) {
  .td-mobile-menu {
    display: none !important;
  }
}

.td-mobile-menu.open {
  display: block;
}

.td-mobile-menu-inner {
  border-radius: 1rem;
  padding: 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.td-mobile-link {
  display: block;
  padding: 0.75rem 1rem;
  color: rgba(252, 252, 252, 0.8);
  text-decoration: none;
  border-radius: 0.5rem;
  transition: var(--td-transition);
  font-size: 1rem;
  font-weight: 300;
}

.td-mobile-link:hover {
  color: var(--td-neutral-50);
}

.td-mobile-lang {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding-top: 0.75rem;
  margin-top: 0.75rem;
  border-top: 1px solid var(--td-white-10);
}

.td-mobile-lang a {
  padding: 0.5rem 1rem;
  border-radius: 9999px;
  font-size: 0.875rem;
  text-decoration: none;
  color: var(--td-neutral-400);
  transition: var(--td-transition);
}

.td-mobile-lang a:hover {
  color: var(--td-neutral-50);
}

.td-mobile-lang a.active {
  color: var(--td-neutral-50);
  font-weight: 400;
  background-color: var(--td-white-10);
}

/* =============================================
   FOOTER
   ============================================= */

.td-footer {
  padding-top: 3rem;
  padding-bottom: 2rem;
  font-family: var(--td-font-sans);
  color: var(--td-neutral-50);
}

@media (min-width: 768px) {
  .td-footer {
    padding-top: 4rem;
    padding-bottom: 2.5rem;
  }
}

.td-footer-main {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 1.5rem;
}

@media (min-width: 1024px) {
  .td-footer-main {
    padding: 0 2.5rem;
  }
}

.td-footer-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.5rem 2rem;
  margin-bottom: 2rem;
}

@media (min-width: 768px) {
  .td-footer-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 3rem;
    margin-bottom: 4rem;
  }
}

/* Footer Column Title */
.td-footer-title {
  font-weight: 400;
  color: var(--td-neutral-50);
  font-size: 1.125rem;
  margin: 0 0 0.75rem 0;
}

@media (min-width: 768px) {
  .td-footer-title {
    font-size: 1.5rem;
    margin-bottom: 1.5rem;
  }
}

/* Footer Links */
.td-footer-links {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

@media (min-width: 768px) {
  .td-footer-links {
    gap: 0.75rem;
  }
}

.td-footer-links a {
  font-size: 0.875rem;
  font-weight: 300;
  color: var(--td-neutral-500);
  text-decoration: none;
  transition: var(--td-transition);
}

@media (min-width: 768px) {
  .td-footer-links a {
    font-size: 1rem;
  }
}

.td-footer-links a:hover {
  color: var(--td-neutral-50);
}

/* Footer Legal Column — spans 2 cols on mobile */
.td-footer-legal-col {
  grid-column: span 2;
}

@media (min-width: 768px) {
  .td-footer-legal-col {
    grid-column: span 1;
  }
}

.td-footer-legal-col .td-footer-links {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.5rem 2rem;
}

@media (min-width: 768px) {
  .td-footer-legal-col .td-footer-links {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
  }
}

/* Footer Bottom Bar */
.td-footer-bottom {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.75rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--td-neutral-800);
}

@media (min-width: 768px) {
  .td-footer-bottom {
    flex-direction: row;
    justify-content: space-between;
    gap: 1rem;
    padding-top: 2rem;
  }
}

.td-footer-copyright {
  font-size: 0.75rem;
  font-weight: 300;
  color: var(--td-neutral-400);
}

@media (min-width: 768px) {
  .td-footer-copyright {
    font-size: 0.875rem;
  }
}

.td-footer-bottom-right {
  display: flex;
  align-items: center;
  gap: 1rem;
}

@media (min-width: 768px) {
  .td-footer-bottom-right {
    gap: 2rem;
  }
}

.td-back-to-top {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  font-size: 0.75rem;
  font-weight: 300;
  color: var(--td-neutral-500);
  background: none;
  border: none;
  cursor: pointer;
  transition: var(--td-transition);
  padding: 0;
  font-family: var(--td-font-sans);
}

@media (min-width: 768px) {
  .td-back-to-top {
    font-size: 0.875rem;
  }
}

.td-back-to-top:hover {
  color: var(--td-neutral-50);
}

.td-back-to-top svg {
  width: 0.875rem;
  height: 0.875rem;
}

@media (min-width: 768px) {
  .td-back-to-top svg {
    width: 1rem;
    height: 1rem;
  }
}

.td-designed-by {
  font-size: 0.75rem;
  font-weight: 300;
  color: var(--td-neutral-400);
}

@media (min-width: 768px) {
  .td-designed-by {
    font-size: 0.875rem;
  }
}

.td-designed-by a {
  color: var(--td-neutral-400);
  text-decoration: none;
  transition: var(--td-transition);
}

.td-designed-by a:hover {
  color: var(--td-neutral-50);
}

/* =============================================
   WHATSAPP FLOATING BUTTON
   ============================================= */

.td-whatsapp-btn {
  position: fixed;
  bottom: 1.5rem;
  right: 1.5rem;
  z-index: 9990;
  width: 3.5rem;
  height: 3.5rem;
  background-color: #22c55e;
  border-radius: 9999px;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 14px rgba(34, 197, 94, 0.3);
  transition: background-color 0.3s ease, transform 0.3s ease;
  text-decoration: none;
}

.td-whatsapp-btn:hover {
  background-color: #4ade80;
  transform: scale(1.1);
}

.td-whatsapp-btn svg {
  width: 1.75rem;
  height: 1.75rem;
  color: #fff;
  fill: currentColor;
}

/* =============================================
   WOOCOMMERCE — Global Overrides
   ============================================= */

/* Prevent body.woocommerce from inheriting container constraints */
body.woocommerce,
body.woocommerce-page {
  max-width: none !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  padding-bottom: 0 !important;
}

/* Base WC container (scoped to inner div, not body) */
div.woocommerce,
.page-content > .woocommerce {
  max-width: 1400px;
  margin: 0 auto;
  padding: 2rem 1.5rem;
  font-family: var(--td-font-sans);
  color: var(--td-neutral-50);
}

@media (min-width: 1024px) {
  div.woocommerce,
  .page-content > .woocommerce {
    padding: 2.5rem;
  }
}

/* Page title */
.woocommerce .entry-title,
.woocommerce h1,
.woocommerce h2,
.woocommerce h3 {
  font-family: var(--td-font-sans);
  font-weight: 400;
  color: var(--td-neutral-50);
  letter-spacing: -0.01em;
}

/* Hide default page titles — we provide custom headings in templates */
.woocommerce-page .entry-title {
  display: none;
}

/* ---- Buttons ---- */
.woocommerce .button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce a.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 2.75rem;
  padding: 0 1.5rem;
  font-family: var(--td-font-sans);
  font-size: 0.875rem;
  font-weight: 500;
  border-radius: 0.5rem;
  cursor: pointer;
  transition: var(--td-transition);
  text-decoration: none;
  line-height: 1;
  border: 1px solid transparent;
}

/* Primary (alt) button — gold filled */
.woocommerce .button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.woocommerce a.button.alt,
.woocommerce #respond input#submit.alt,
.woocommerce #place_order {
  background-color: var(--td-gold-500) !important;
  color: var(--td-deep-950) !important;
  border-color: var(--td-gold-500) !important;
}

.woocommerce .button.alt:hover,
.woocommerce button.button.alt:hover,
.woocommerce input.button.alt:hover,
.woocommerce a.button.alt:hover,
.woocommerce #respond input#submit.alt:hover,
.woocommerce #place_order:hover {
  background-color: var(--td-gold-600) !important;
  border-color: var(--td-gold-600) !important;
}

/* Secondary button — outline */
.woocommerce .button:not(.alt),
.woocommerce button.button:not(.alt),
.woocommerce input.button:not(.alt),
.woocommerce a.button:not(.alt) {
  background-color: transparent;
  color: var(--td-neutral-50);
  border-color: var(--td-neutral-800);
}

.woocommerce .button:not(.alt):hover,
.woocommerce button.button:not(.alt):hover,
.woocommerce input.button:not(.alt):hover,
.woocommerce a.button:not(.alt):hover {
  border-color: var(--td-gold-500);
  color: var(--td-gold-500);
}

/* Disabled buttons */
.woocommerce .button:disabled,
.woocommerce button.button:disabled,
.woocommerce input.button:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* ---- Form Fields ---- */
.woocommerce input[type="text"],
.woocommerce input[type="email"],
.woocommerce input[type="tel"],
.woocommerce input[type="number"],
.woocommerce input[type="password"],
.woocommerce input[type="url"],
.woocommerce select,
.woocommerce textarea {
  background-color: var(--td-deep-800);
  border: 1px solid var(--td-deep-700);
  color: var(--td-neutral-50);
  font-family: var(--td-font-sans);
  font-size: 0.875rem;
  font-weight: 300;
  padding: 0.75rem 1rem;
  border-radius: 0.5rem;
  width: 100%;
  transition: border-color 0.3s ease;
  outline: none;
}

.woocommerce input[type="text"]:focus,
.woocommerce input[type="email"]:focus,
.woocommerce input[type="tel"]:focus,
.woocommerce input[type="number"]:focus,
.woocommerce input[type="password"]:focus,
.woocommerce input[type="url"]:focus,
.woocommerce select:focus,
.woocommerce textarea:focus {
  border-color: var(--td-gold-500);
}

.woocommerce select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%239C9C9C'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M19.5 8.25l-7.5 7.5-7.5-7.5'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.75rem center;
  background-size: 1rem;
  padding-right: 2.5rem;
}

.woocommerce select option {
  background-color: var(--td-deep-800);
  color: var(--td-neutral-50);
}

/* Labels */
.woocommerce label {
  font-size: 0.875rem;
  font-weight: 300;
  color: var(--td-neutral-400);
  display: block;
  margin-bottom: 0.375rem;
}

.woocommerce label .required {
  color: var(--td-gold-500);
}

/* Placeholder */
.woocommerce ::placeholder {
  color: var(--td-neutral-400);
  opacity: 0.6;
}

/* ---- Quantity Input ---- */
.woocommerce .quantity input[type="number"] {
  width: 5rem;
  text-align: center;
  padding: 0.5rem;
}

/* ---- Tables ---- */
.woocommerce table {
  width: 100%;
  border-collapse: collapse;
}

.woocommerce table th {
  font-weight: 400;
  color: var(--td-neutral-400);
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 0.75rem 1rem;
  text-align: left;
  border-bottom: 1px solid var(--td-white-10);
}

.woocommerce table td {
  padding: 1rem;
  border-bottom: 1px solid var(--td-white-5);
  vertical-align: middle;
  color: var(--td-neutral-50);
  font-weight: 300;
}

.woocommerce table.shop_table {
  border: none;
  background: transparent;
}

/* ---- Cart Page ---- */
.woocommerce-cart .woocommerce {
  padding-top: 3rem;
}

/* Cart form wrapper — glass card */
.woocommerce-cart .woocommerce-cart-form {
  background-color: rgba(20, 20, 20, 0.35);
  backdrop-filter: blur(7px);
  -webkit-backdrop-filter: blur(7px);
  border-radius: 0.75rem;
  padding: 1.5rem;
  border: 1px solid var(--td-white-10);
  margin-bottom: 2rem;
}

.woocommerce td.product-thumbnail img {
  width: 80px;
  height: 80px;
  object-fit: cover;
  border-radius: 0.5rem;
}

.woocommerce td.product-name a {
  color: var(--td-neutral-50);
  text-decoration: none;
  font-weight: 400;
  transition: var(--td-transition);
}

.woocommerce td.product-name a:hover {
  color: var(--td-gold-500);
}

.woocommerce td.product-remove a {
  color: var(--td-neutral-400) !important;
  font-size: 1.25rem;
  text-decoration: none;
  transition: var(--td-transition);
}

.woocommerce td.product-remove a:hover {
  color: var(--td-neutral-50) !important;
}

.woocommerce .cart-collaterals {
  margin-top: 2rem;
}

.woocommerce .cart_totals {
  background-color: rgba(20, 20, 20, 0.35);
  backdrop-filter: blur(7px);
  -webkit-backdrop-filter: blur(7px);
  border-radius: 0.75rem;
  padding: 1.5rem;
  border: 1px solid var(--td-white-10);
}

.woocommerce .cart_totals h2 {
  font-size: 1.25rem;
  margin-bottom: 1rem;
}

.woocommerce .cart_totals table td,
.woocommerce .cart_totals table th {
  padding: 0.75rem 0;
  border-bottom: 1px solid var(--td-white-5);
}

.woocommerce .cart_totals .order-total td {
  font-size: 1.25rem;
  font-weight: 400;
  color: var(--td-neutral-50);
}

/* Proceed to checkout button */
.woocommerce .wc-proceed-to-checkout a.checkout-button {
  display: block;
  width: 100%;
  text-align: center;
  height: 3rem;
  background-color: var(--td-gold-500) !important;
  color: var(--td-deep-950) !important;
  border-radius: 0.5rem;
  font-weight: 500;
  font-size: 1rem;
  margin-top: 1rem;
}

.woocommerce .wc-proceed-to-checkout a.checkout-button:hover {
  background-color: var(--td-gold-600) !important;
}

/* Cart empty */
.woocommerce .cart-empty {
  text-align: center;
  font-weight: 300;
  color: var(--td-neutral-400);
  font-size: 1.125rem;
  padding: 3rem 0 1rem;
}

.woocommerce .return-to-shop {
  text-align: center;
  padding-bottom: 3rem;
}

.woocommerce .return-to-shop a {
  background-color: var(--td-gold-500) !important;
  color: var(--td-deep-950) !important;
}

/* Coupon */
.woocommerce .coupon {
  display: flex;
  gap: 0.5rem;
  align-items: center;
}

.woocommerce .coupon input[type="text"] {
  width: auto;
  min-width: 200px;
}

/* ---- Checkout Page ---- */
.woocommerce-checkout .woocommerce {
  padding-top: 3rem;
}

/* Checkout billing/shipping form — glass card on col-1 */
.woocommerce-checkout .col2-set .col-1 {
  background-color: rgba(20, 20, 20, 0.35);
  backdrop-filter: blur(7px);
  -webkit-backdrop-filter: blur(7px);
  border-radius: 0.75rem;
  padding: 1.5rem;
  border: 1px solid var(--td-white-10);
}
/* Additional fields separator inside col-1 */
.woocommerce-checkout .col2-set .col-1 .woocommerce-additional-fields {
  margin-top: 1.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--td-white-10);
}

.woocommerce-checkout h3 {
  font-size: 1.25rem;
  font-weight: 400;
  margin: 0 0 1.5rem 0;
}

.woocommerce form.checkout {
  position: relative;
}

/* Two-column checkout layout */
.woocommerce .col2-set {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
  margin-bottom: 2rem;
}

@media (min-width: 768px) {
  .woocommerce .col2-set {
    grid-template-columns: 1fr;
  }
}

.woocommerce .col2-set .col-1,
.woocommerce .col2-set .col-2 {
  width: 100%;
  float: none;
}

/* Form row — grid layout for billing fields */
.woocommerce .woocommerce-billing-fields__field-wrapper {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.75rem;
}
@media (min-width: 640px) {
  .woocommerce .woocommerce-billing-fields__field-wrapper {
    grid-template-columns: 1fr 1fr;
  }
  .woocommerce .woocommerce-billing-fields__field-wrapper .form-row-wide {
    grid-column: 1 / -1;
  }
  .woocommerce .woocommerce-billing-fields__field-wrapper .form-row-first {
    grid-column: 1;
  }
  .woocommerce .woocommerce-billing-fields__field-wrapper .form-row-last {
    grid-column: 2;
  }
}

.woocommerce form .form-row {
  margin-bottom: 0;
  width: 100% !important;
  float: none !important;
}

/* Additional fields (order notes) also full-width */
.woocommerce-additional-fields__field-wrapper {
  margin-top: 0.5rem;
}
.woocommerce-additional-fields__field-wrapper .form-row {
  width: 100% !important;
}

/* Order Review */
.woocommerce #order_review_heading {
  font-size: 1.25rem;
  font-weight: 400;
  margin-bottom: 1rem;
}

.woocommerce #order_review {
  background-color: rgba(20, 20, 20, 0.35);
  backdrop-filter: blur(7px);
  -webkit-backdrop-filter: blur(7px);
  border-radius: 0.75rem;
  padding: 1.5rem;
  border: 1px solid var(--td-white-10);
}

/* Payment methods */
.woocommerce .woocommerce-checkout-payment {
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  border-radius: 0 !important;
}

.woocommerce ul.payment_methods {
  list-style: none;
  padding: 0;
  margin: 0 0 1.5rem 0;
}

.woocommerce ul.payment_methods li {
  padding: 1rem;
  margin-bottom: 0.5rem;
  border-radius: 0.5rem;
  border: 1px solid var(--td-white-10);
  background-color: rgba(20, 20, 20, 0.25);
  transition: var(--td-transition);
}

.woocommerce ul.payment_methods li:hover {
  border-color: var(--td-white-30);
}

.woocommerce ul.payment_methods li label {
  color: var(--td-neutral-50);
  font-weight: 400;
  cursor: pointer;
  display: inline;
}

.woocommerce ul.payment_methods li .payment_box {
  padding: 1rem 0 0 1.75rem;
  color: var(--td-neutral-400);
  font-weight: 300;
  font-size: 0.875rem;
}

.woocommerce ul.payment_methods li .payment_box p {
  margin: 0;
}

/* Radio/Checkbox inputs */
.woocommerce input[type="radio"],
.woocommerce input[type="checkbox"] {
  accent-color: var(--td-gold-500);
  width: 1rem;
  height: 1rem;
  margin-right: 0.5rem;
  vertical-align: middle;
}

/* Place order button */
.woocommerce #place_order {
  display: block;
  width: 100%;
  height: 3.25rem;
  font-size: 1rem;
  margin-top: 1rem;
}

/* Terms checkbox */
.woocommerce .woocommerce-terms-and-conditions-wrapper {
  margin: 1rem 0;
}

.woocommerce .woocommerce-terms-and-conditions-wrapper a {
  color: var(--td-gold-500);
  text-decoration: none;
}

.woocommerce .woocommerce-terms-and-conditions-wrapper a:hover {
  color: var(--td-gold-400);
}

/* ---- Thank You Page ---- */
.woocommerce .woocommerce-thankyou-order-received {
  text-align: center;
  font-size: 1.25rem;
  font-weight: 400;
  color: var(--td-neutral-50);
  padding: 2rem 0 1rem;
}

.woocommerce .woocommerce-order-details {
  background-color: rgba(20, 20, 20, 0.35);
  backdrop-filter: blur(7px);
  -webkit-backdrop-filter: blur(7px);
  border-radius: 0.75rem;
  padding: 1.5rem;
  border: 1px solid var(--td-white-10);
  margin-bottom: 2rem;
}

.woocommerce .woocommerce-customer-details {
  background-color: rgba(20, 20, 20, 0.35);
  backdrop-filter: blur(7px);
  -webkit-backdrop-filter: blur(7px);
  border-radius: 0.75rem;
  padding: 1.5rem;
  border: 1px solid var(--td-white-10);
}

/* ---- Notices ---- */
.woocommerce .woocommerce-message,
.woocommerce .woocommerce-info {
  background-color: rgba(20, 20, 20, 0.35);
  backdrop-filter: blur(7px);
  -webkit-backdrop-filter: blur(7px);
  border: 1px solid var(--td-gold-500);
  border-radius: 0.5rem;
  padding: 1rem 1.5rem;
  color: var(--td-neutral-50);
  font-weight: 300;
  margin-bottom: 1.5rem;
}

.woocommerce .woocommerce-message::before,
.woocommerce .woocommerce-info::before {
  color: var(--td-gold-500) !important;
}

.woocommerce .woocommerce-error {
  background-color: rgba(20, 20, 20, 0.35);
  backdrop-filter: blur(7px);
  -webkit-backdrop-filter: blur(7px);
  border: 1px solid #ef4444;
  border-radius: 0.5rem;
  padding: 1rem 1.5rem;
  color: var(--td-neutral-50);
  font-weight: 300;
  margin-bottom: 1.5rem;
  list-style: none;
}

.woocommerce .woocommerce-error::before {
  color: #ef4444 !important;
}

/* ---- Links (scoped to product content, not header/footer) ---- */
.td-product-hero a:not(.button),
.td-product-grid a:not(.button),
.woocommerce-page .woocommerce:not(.td-header):not(.td-footer) a:not(.button) {
  color: var(--td-gold-500);
  text-decoration: none;
  transition: var(--td-transition);
}

.td-product-hero a:not(.button):hover,
.td-product-grid a:not(.button):hover,
.woocommerce-page .woocommerce:not(.td-header):not(.td-footer) a:not(.button):hover {
  color: var(--td-gold-400);
}

/* Ensure header/footer links are NOT gold */
.td-header a,
.td-footer a,
.td-header a:hover,
.td-footer a:hover {
  color: inherit;
}

/* ---- Breadcrumb ---- */
.woocommerce .woocommerce-breadcrumb {
  color: var(--td-neutral-400);
  font-size: 0.875rem;
  font-weight: 300;
  margin-bottom: 1.5rem;
}

.woocommerce .woocommerce-breadcrumb a {
  color: var(--td-neutral-400);
}

.woocommerce .woocommerce-breadcrumb a:hover {
  color: var(--td-neutral-50);
}

/* ---- My Account ---- */
.woocommerce-account .woocommerce-MyAccount-navigation {
  width: 100%;
  margin-bottom: 2rem;
}

.woocommerce-account .woocommerce-MyAccount-content {
  width: 100%;
}

@media (min-width: 768px) {
  .woocommerce-account .woocommerce-MyAccount-navigation {
    float: left;
    width: 28%;
    margin-bottom: 0;
  }
  .woocommerce-account .woocommerce-MyAccount-content {
    float: right;
    width: 68%;
  }
}

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

.woocommerce-account .woocommerce-MyAccount-navigation ul li {
  border-bottom: 1px solid var(--td-white-5);
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
  display: block;
  padding: 0.75rem 1rem;
  color: var(--td-neutral-400);
  font-weight: 300;
  transition: var(--td-transition);
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover {
  color: var(--td-neutral-50);
  background-color: var(--td-white-5);
}

/* ---- Products / Shop Page ---- */
.woocommerce ul.products {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.5rem;
  list-style: none;
  padding: 0;
}

@media (min-width: 768px) {
  .woocommerce ul.products {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (min-width: 1024px) {
  .woocommerce ul.products {
    grid-template-columns: repeat(4, 1fr);
  }
}

.woocommerce ul.products li.product {
  background-color: rgba(20, 20, 20, 0.35);
  border-radius: 0.75rem;
  overflow: hidden;
  border: 1px solid var(--td-white-10);
  transition: var(--td-transition);
  width: 100% !important;
  margin: 0 !important;
  float: none !important;
}

.woocommerce ul.products li.product:hover {
  border-color: var(--td-white-30);
}

.woocommerce ul.products li.product img {
  width: 100%;
  height: auto;
  border-radius: 0;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-size: 1rem;
  font-weight: 400;
  color: var(--td-neutral-50);
  padding: 0.75rem 1rem 0.25rem;
}

.woocommerce ul.products li.product .price {
  padding: 0 1rem 0.75rem;
  color: var(--td-neutral-400);
  font-weight: 300;
}

.woocommerce ul.products li.product .price ins {
  text-decoration: none;
  color: var(--td-neutral-50);
}

.woocommerce ul.products li.product .price del {
  color: var(--td-neutral-400);
  opacity: 0.5;
}

.woocommerce ul.products li.product .onsale {
  background-color: var(--td-gold-500);
  color: var(--td-deep-950);
  font-weight: 500;
  border-radius: 0.25rem;
  padding: 0.25rem 0.625rem;
  font-size: 0.75rem;
}

.woocommerce ul.products li.product .button {
  margin: 0 1rem 1rem;
  width: calc(100% - 2rem);
}

/* Single product page */
.woocommerce div.product {
  color: var(--td-neutral-50);
}

.woocommerce div.product .product_title {
  font-size: 2rem;
  font-weight: 400;
  letter-spacing: -0.01em;
}

.woocommerce div.product p.price {
  font-size: 1.5rem;
  font-weight: 400;
  color: var(--td-neutral-50);
}

.woocommerce div.product .woocommerce-product-details__short-description {
  color: var(--td-neutral-400);
  font-weight: 300;
}

/* ---- Pagination ---- */
.woocommerce nav.woocommerce-pagination ul {
  display: flex;
  gap: 0.5rem;
  list-style: none;
  padding: 0;
  justify-content: center;
  margin-top: 2rem;
}

.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 0.5rem;
  border: 1px solid var(--td-white-10);
  color: var(--td-neutral-400);
  font-weight: 400;
  transition: var(--td-transition);
  background: transparent;
}

.woocommerce nav.woocommerce-pagination ul li a:hover {
  border-color: var(--td-gold-500);
  color: var(--td-gold-500);
}

.woocommerce nav.woocommerce-pagination ul li span.current {
  background-color: var(--td-gold-500);
  color: var(--td-deep-950);
  border-color: var(--td-gold-500);
}

/* ---- Select2 (WC enhanced select) ---- */
.woocommerce .select2-container--default .select2-selection--single {
  background-color: var(--td-deep-800);
  border: 1px solid var(--td-deep-700);
  border-radius: 0.5rem;
  height: 2.75rem;
}

.woocommerce .select2-container--default .select2-selection--single .select2-selection__rendered {
  color: var(--td-neutral-50);
  line-height: 2.75rem;
  padding-left: 1rem;
  font-weight: 300;
}

.woocommerce .select2-container--default .select2-selection--single .select2-selection__arrow {
  height: 2.75rem;
  right: 0.5rem;
}

.select2-container--default .select2-results__option {
  background-color: var(--td-deep-800);
  color: var(--td-neutral-50);
}

.select2-container--default .select2-results__option--highlighted {
  background-color: var(--td-deep-700) !important;
  color: var(--td-neutral-50) !important;
}

.select2-dropdown {
  background-color: var(--td-deep-800);
  border-color: var(--td-deep-700);
}

.select2-search--dropdown .select2-search__field {
  background-color: var(--td-deep-900);
  border-color: var(--td-deep-700);
  color: var(--td-neutral-50);
}

/* ---- WooCommerce login form ---- */
.woocommerce form.login,
.woocommerce form.register {
  background-color: rgba(20, 20, 20, 0.35);
  backdrop-filter: blur(7px);
  -webkit-backdrop-filter: blur(7px);
  border-radius: 0.75rem;
  padding: 1.5rem;
  border: 1px solid var(--td-white-10);
}

/* ---- Responsive cart table ---- */
@media (max-width: 767px) {
  .woocommerce table.shop_table_responsive thead {
    display: none;
  }
  .woocommerce table.shop_table_responsive tr {
    display: flex;
    flex-wrap: wrap;
    padding: 1rem 0;
    border-bottom: 1px solid var(--td-white-5);
    align-items: center;
    gap: 0.5rem;
  }
  .woocommerce table.shop_table_responsive td {
    border: none;
    padding: 0.25rem 0;
  }
  .woocommerce table.shop_table_responsive td::before {
    color: var(--td-neutral-400);
    font-weight: 400;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
  }
}

/* =============================================
   SINGLE PRODUCT — v2 layout
   ============================================= */

/* ---- Hero section ---- */
.td-product-hero {
  position: relative;
  padding-top: 7rem;
  padding-bottom: 4rem;
  overflow: hidden;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  margin-top: -76px;
}

.td-product-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    var(--td-deep-950) 0%,
    rgba(10, 22, 40, 0.6) 50%,
    rgba(10, 22, 40, 0.4) 100%
  );
}

.td-product-hero-content {
  position: relative;
  z-index: 10;
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 1.5rem;
}

.td-product-back-link {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: var(--td-gold-500) !important;
  color: var(--td-deep-950) !important;
  font-size: 0.875rem;
  font-weight: 600;
  text-decoration: none !important;
  padding: 0.5rem 1.25rem;
  border-radius: 0.5rem;
  transition: var(--td-transition);
}

.td-product-back-link:hover {
  background: var(--td-gold-400) !important;
  color: var(--td-deep-950) !important;
}

/* ---- Product grid ---- */
.td-product-section {
  padding: 5rem 0;
}

.td-product-grid {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 3rem;
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 1.5rem;
}

@media (min-width: 1024px) {
  .td-product-grid {
    padding: 0 2.5rem;
  }
  .td-product-hero-content {
    padding: 0 2.5rem;
  }
}

@media (min-width: 768px) {
  .td-product-hero {
    padding-top: 9rem;
    padding-bottom: 6rem;
  }
}

/* ---- Sidebar (sticky) ---- */
.td-product-sidebar-inner {
  position: sticky;
  top: 100px;
}

/* ---- Category eyebrow ---- */
.td-product-eyebrow {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 1.5rem;
}

.td-product-eyebrow-bar {
  width: 3px;
  height: 1.25rem;
  background-color: var(--td-gold-500);
  border-radius: 9999px;
}

.td-product-eyebrow span {
  color: var(--td-gold-500);
  font-weight: 300;
  font-size: 1rem;
}

/* ---- Title ---- */
.td-product-title {
  font-size: 2rem;
  font-weight: 400;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--td-neutral-50);
  margin: 0 0 1.5rem;
}

@media (min-width: 768px) {
  .td-product-title {
    font-size: 2.5rem;
  }
}

@media (min-width: 1024px) {
  .td-product-title {
    font-size: 3rem;
  }
}

/* ---- Price ---- */
.td-product-price-block {
  margin-bottom: 1.5rem;
}

.td-product-price-block p.price {
  display: flex;
  align-items: baseline;
  gap: 0.75rem;
  font-size: 3rem;
  font-weight: 400;
  letter-spacing: -0.02em;
  color: var(--td-neutral-50);
  margin: 0;
}

.td-product-price-block p.price del {
  font-size: 1.25rem;
  font-weight: 300;
  color: var(--td-neutral-500);
  text-decoration: line-through;
}

.td-product-price-block p.price ins {
  text-decoration: none;
}

.td-product-price-row {
  display: flex;
  align-items: baseline;
  gap: 0.75rem;
}

.td-product-price-current {
  font-size: 2.5rem;
  font-weight: 400;
  letter-spacing: -0.02em;
  color: var(--td-neutral-50);
}

@media (min-width: 768px) {
  .td-product-price-block p.price {
    font-size: 3rem;
  }
  .td-product-price-current {
    font-size: 3rem;
  }
}

.td-product-price-original {
  font-size: 1.25rem;
  font-weight: 300;
  color: var(--td-neutral-500);
  text-decoration: line-through;
}

.td-product-sale-badge {
  display: inline-block;
  margin-top: 0.5rem;
  padding: 0.25rem 0.75rem;
  font-size: 0.75rem;
  font-weight: 300;
  background-color: rgba(200, 168, 78, 0.1);
  color: var(--td-gold-500);
  border-radius: 0.25rem;
}

/* ---- Product specs bar (duration, depth, level) ---- */
.td-product-specs {
  display: flex;
  gap: 0;
  margin-bottom: 1.5rem;
  border: 1px solid var(--td-deep-700);
  border-radius: 12px;
  overflow: hidden;
  background: var(--td-deep-800);
}

.td-product-spec {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 0.75rem 0.5rem;
  gap: 0.25rem;
}

.td-product-spec + .td-product-spec {
  border-left: 1px solid var(--td-deep-700);
}

.td-product-spec-icon {
  color: var(--td-gold-500);
  display: flex;
  align-items: center;
  justify-content: center;
}

.td-product-spec-label {
  font-size: 0.6rem;
  font-weight: 500;
  color: var(--td-neutral-500);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.td-product-spec-value {
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--td-neutral-50);
}

/* ---- Short description ---- */
.td-product-short-desc {
  margin-bottom: 1.5rem;
}

.td-product-short-desc,
.td-product-short-desc p {
  font-size: 0.85rem;
  font-weight: 300;
  color: var(--td-neutral-400);
  line-height: 1.65;
}

.td-product-short-desc a {
  color: var(--td-gold-500);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.td-product-short-desc strong {
  color: var(--td-neutral-300);
  font-weight: 400;
}

.td-product-short-desc h1,
.td-product-short-desc h2,
.td-product-short-desc h3,
.td-product-short-desc h4 {
  font-size: 0.95rem;
  font-weight: 400;
  color: var(--td-neutral-200);
  margin: 0.75rem 0 0.5rem;
}

.td-product-short-desc ul,
.td-product-short-desc ol {
  padding-left: 1.25rem;
  margin: 0.5rem 0;
}

.td-product-short-desc li {
  font-size: 0.85rem;
  color: var(--td-neutral-400);
  margin-bottom: 0.25rem;
}

.td-product-short-desc img {
  display: none;
}

/* ---- Add to cart container ---- */
.td-product-add-to-cart {
  margin-bottom: 1.5rem;
}

/* WC add-to-cart button */
.td-product-add-to-cart .single_add_to_cart_button,
.td-product-wrap .single_add_to_cart_button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 3.5rem;
  padding: 0 2rem;
  background-color: var(--td-gold-500) !important;
  color: var(--td-deep-950) !important;
  font-family: var(--td-font-sans);
  font-size: 1rem;
  font-weight: 500;
  border: none;
  border-radius: 0.5rem;
  cursor: pointer;
  transition: var(--td-transition);
  text-transform: none;
  letter-spacing: 0;
}

.td-product-add-to-cart .single_add_to_cart_button:hover,
.td-product-wrap .single_add_to_cart_button:hover {
  background-color: var(--td-deep-950) !important;
  color: var(--td-neutral-50) !important;
  box-shadow: inset 0 0 0 1px var(--td-gold-500);
}

/* Space between quantity selector and add-to-cart button */
.woocommerce div.product form.cart .button {
  vertical-align: middle;
  float: left;
  margin-top: 1rem;
}

/* Quantity input */
.td-product-add-to-cart .quantity,
.td-product-wrap .quantity {
  margin-bottom: 1.5rem;
}

.td-product-add-to-cart .quantity .qty,
.td-product-wrap .cart .quantity .qty {
  width: 5rem;
  height: 2.75rem;
  text-align: center;
  background-color: var(--td-deep-800);
  border: 1px solid var(--td-deep-700);
  color: var(--td-neutral-50);
  border-radius: 0.5rem;
  font-family: var(--td-font-sans);
  font-size: 1rem;
  font-weight: 400;
}

.td-product-add-to-cart .quantity .qty:focus,
.td-product-wrap .cart .quantity .qty:focus {
  border-color: var(--td-gold-500);
  outline: none;
}

/* ---- Booking button ---- */
.td-booking-btn:hover {
  background: #C8A84E !important;
  color: #0A1628 !important;
}

/* ---- Product meta (SKU, cats, tags) ---- */
.td-product-wrap .product_meta {
  padding-top: 1rem;
  border-top: 1px solid var(--td-white-10);
  margin-top: 1rem;
}

.td-product-wrap .product_meta > span {
  display: block;
  font-size: 0.8125rem;
  font-weight: 300;
  color: var(--td-neutral-400);
  margin-bottom: 0.25rem;
}

.td-product-wrap .product_meta a {
  color: var(--td-gold-500);
  text-decoration: none;
}

.td-product-wrap .product_meta a:hover {
  color: var(--td-gold-400);
}

/* =============================================
   GALLERY
   ============================================= */

.td-product-gallery-main {
  position: relative;
  aspect-ratio: 16 / 10;
  border-radius: 0.75rem;
  overflow: hidden;
  margin-bottom: 1rem;
}

.td-product-gallery-main img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Thumbnails */
.td-product-thumbnails {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.5rem;
  margin-bottom: 3rem;
}

.td-product-thumb {
  position: relative;
  aspect-ratio: 4 / 3;
  border-radius: 0.5rem;
  overflow: hidden;
  border: 2px solid transparent;
  cursor: pointer;
  padding: 0;
  background: none;
  transition: var(--td-transition);
  opacity: 0.7;
}

.td-product-thumb:hover {
  opacity: 1;
  border-color: var(--td-deep-700);
}

.td-product-thumb.active {
  opacity: 1;
  border-color: var(--td-gold-500);
}

.td-product-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* =============================================
   PRODUCT DESCRIPTION (prose-invert equivalent)
   ============================================= */

.td-product-description {
  border-top: 1px solid var(--td-neutral-800);
  padding-top: 2.5rem;
}

.td-product-desc-title {
  font-size: 1.5rem;
  font-weight: 400;
  letter-spacing: -0.01em;
  color: var(--td-neutral-50);
  margin: 0 0 1.5rem;
}

.td-product-desc-content {
  color: var(--td-neutral-400);
  font-weight: 300;
  line-height: 1.7;
  font-size: 0.9375rem;
}

.td-product-desc-content h2,
.td-product-desc-content h3,
.td-product-desc-content h4 {
  color: var(--td-neutral-50);
  font-weight: 400;
  letter-spacing: -0.01em;
}

.td-product-desc-content h2 { font-size: 1.25rem; margin-top: 2rem; margin-bottom: 1rem; }
.td-product-desc-content h3 { font-size: 1.125rem; margin-top: 1.5rem; margin-bottom: 0.75rem; }
.td-product-desc-content h4 { font-size: 1rem; margin-top: 1.25rem; margin-bottom: 0.5rem; }

.td-product-desc-content p {
  margin-bottom: 1rem;
}

.td-product-desc-content a {
  color: var(--td-gold-500);
  text-decoration: none;
}

.td-product-desc-content a:hover {
  text-decoration: underline;
}

.td-product-desc-content strong,
.td-product-desc-content b {
  color: var(--td-neutral-50);
  font-weight: 400;
}

.td-product-desc-content ul,
.td-product-desc-content ol {
  padding-left: 1.5rem;
  margin-bottom: 1rem;
}

.td-product-desc-content li {
  font-weight: 300;
  margin-bottom: 0.25rem;
}

.td-product-desc-content li::marker {
  color: rgba(200, 168, 78, 0.5);
}

.td-product-desc-content img {
  border-radius: 0.5rem;
  border: 1px solid var(--td-neutral-800);
  max-width: 100%;
  height: auto;
  margin: 1rem 0;
}

/* Tables inside product description */
.td-product-desc-content table {
  width: 100%;
  border-collapse: collapse;
  margin: 1.5rem 0;
  font-size: 0.875rem;
}

.td-product-desc-content table td,
.td-product-desc-content table th {
  border: 1px solid var(--td-deep-700);
  padding: 0.75rem 1rem;
  color: var(--td-neutral-400);
  font-weight: 300;
  line-height: 1.5;
}

.td-product-desc-content table th,
.td-product-desc-content table thead td {
  background-color: rgba(200, 168, 78, 0.08);
  color: var(--td-neutral-50);
  font-weight: 400;
}

.td-product-desc-content table thead th {
  border-bottom: 2px solid var(--td-gold-500);
}

.td-product-desc-content table tbody tr:nth-child(odd) td {
  background-color: rgba(255, 255, 255, 0.02);
}

/* Blockquotes inside description */
.td-product-desc-content blockquote {
  border-left: 3px solid var(--td-gold-500);
  margin: 1.5rem 0;
  padding: 0.75rem 1.5rem;
  color: var(--td-neutral-400);
  font-style: italic;
}

/* Horizontal rules */
.td-product-desc-content hr {
  border: none;
  border-top: 1px solid var(--td-deep-700);
  margin: 2rem 0;
}

/* Description section blocks (from WC product descriptions with styled divs) */
.td-product-desc-content > div {
  margin-bottom: 1.5rem;
  border: 1px solid var(--td-deep-700);
  border-radius: 0.75rem;
  overflow: hidden;
}

.td-product-desc-content > div > div:first-child {
  background: var(--td-deep-800);
  color: var(--td-neutral-50);
  font-weight: 400;
  font-size: 1rem;
  padding: 0.875rem 1.25rem;
  border-bottom: 1px solid var(--td-deep-700);
}

.td-product-desc-content > div > div:last-child {
  padding: 1rem 1.25rem;
}

.td-product-desc-content > div > div:last-child ul {
  margin-bottom: 0;
}

/* Remove WC default product images/gallery (we render our own) */
.td-product-wrap .woocommerce-product-gallery,
.td-product-wrap .woocommerce-product-gallery__wrapper,
.td-product-wrap .flex-viewport {
  display: none !important;
}

/* Remove default WC title and price in summary (we render custom) */
.td-product-wrap .summary .product_title,
.td-product-wrap .summary > .price {
  display: none !important;
}

/* Hide default WC tabs (we render description directly) */
.td-product-wrap .woocommerce-tabs {
  display: none !important;
}

/* Hide upsells and related (optional) */
.td-product-wrap .upsells,
.td-product-wrap .related {
  max-width: 1400px;
  margin: 2rem auto;
  padding: 0 1.5rem;
}

/* =============================================
   EPO (TM Extra Product Options) — dark theme
   ============================================= */

.td-product-wrap .tc-extra-product-options,
.td-product-wrap .tc-extra-product-options-wrap {
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  margin-bottom: 1rem;
}

/* EPO section titles */
.td-product-wrap .tc-extra-product-options .tc-epo-label,
.td-product-wrap .tc-extra-product-options .tm-epo-field-label,
.td-product-wrap .tc-extra-product-options label {
  color: var(--td-neutral-400) !important;
  font-weight: 300 !important;
  font-family: var(--td-font-sans) !important;
  font-size: 0.875rem !important;
}

/* EPO headings */
.td-product-wrap .tc-extra-product-options .tc-cell-heading,
.td-product-wrap .tc-extra-product-options .tm-epo-element-label,
.td-product-wrap .tc-extra-product-options .tc-epo-label-heading {
  color: var(--td-neutral-50) !important;
  font-weight: 400 !important;
  font-size: 0.9375rem !important;
}

/* EPO select/input fields */
.td-product-wrap .tc-extra-product-options select,
.td-product-wrap .tc-extra-product-options input[type="text"],
.td-product-wrap .tc-extra-product-options input[type="number"],
.td-product-wrap .tc-extra-product-options input[type="email"],
.td-product-wrap .tc-extra-product-options input[type="date"],
.td-product-wrap .tc-extra-product-options textarea {
  background-color: var(--td-deep-800) !important;
  border: 1px solid var(--td-deep-700) !important;
  color: var(--td-neutral-50) !important;
  border-radius: 0.5rem !important;
  padding: 0.625rem 0.875rem !important;
  font-family: var(--td-font-sans) !important;
  font-size: 0.875rem !important;
  font-weight: 300 !important;
}

.td-product-wrap .tc-extra-product-options select:focus,
.td-product-wrap .tc-extra-product-options input:focus,
.td-product-wrap .tc-extra-product-options textarea:focus {
  border-color: var(--td-gold-500) !important;
  outline: none !important;
}

/* EPO radio/checkbox */
.td-product-wrap .tc-extra-product-options input[type="radio"],
.td-product-wrap .tc-extra-product-options input[type="checkbox"] {
  accent-color: var(--td-gold-500);
}

/* EPO price display */
.td-product-wrap .tc-extra-product-options .tc-price,
.td-product-wrap .tc-extra-product-options .tm-epo-price,
.td-product-wrap .tc-extra-product-options .price {
  color: var(--td-gold-400) !important;
  font-weight: 400 !important;
}

/* EPO choice containers */
.td-product-wrap .tc-extra-product-options .tmcp-field-wrap,
.td-product-wrap .tc-extra-product-options .tc-element-container {
  background: transparent !important;
  border-color: var(--td-white-10) !important;
}

/* EPO list items */
.td-product-wrap .tc-extra-product-options li,
.td-product-wrap .tc-extra-product-options .tm-li {
  background: transparent !important;
  border-color: var(--td-white-10) !important;
  color: var(--td-neutral-50) !important;
}

.td-product-wrap .tc-extra-product-options li:hover,
.td-product-wrap .tc-extra-product-options .tm-li:hover {
  background-color: var(--td-white-5) !important;
}

/* EPO description text */
.td-product-wrap .tc-extra-product-options .tc-description,
.td-product-wrap .tc-extra-product-options .tm-description {
  color: var(--td-neutral-400) !important;
  font-weight: 300 !important;
  font-size: 0.8125rem !important;
}

/* EPO h3 section title override (parent theme makes h3 too large) */
.td-product-wrap .tc-extra-product-options h3 {
  font-size: 0.9375rem !important;
  font-weight: 400 !important;
  color: var(--td-neutral-50) !important;
  margin: 0 0 0.75rem !important;
  line-height: 1.4 !important;
}

/* EPO dividers */
.td-product-wrap .tc-extra-product-options .tm_divider {
  border-color: var(--td-white-10) !important;
}

/* EPO totals box */
.td-product-wrap .tc-epo-totals,
.td-product-wrap #tm-epo-totals {
  background: transparent !important;
  border: none !important;
  color: var(--td-neutral-50) !important;
}

/* EPO checkbox label text (price display) */
.td-product-wrap .tc-extra-product-options .tc-epo-style-space .tc-price-wrap {
  color: var(--td-gold-400) !important;
}

/* EPO checkbox style (square custom) */
.td-product-wrap .tc-extra-product-options .tc-epo-style.square {
  border-color: var(--td-deep-700) !important;
  background-color: var(--td-deep-800) !important;
}

.td-product-wrap .tc-extra-product-options .tc-epo-style.square .tc-label {
  border-color: var(--td-deep-700) !important;
  background-color: var(--td-deep-800) !important;
}

/* EPO checked state */
.td-product-wrap .tc-extra-product-options input:checked + .tc-label {
  background-color: rgba(200, 168, 78, 0.15) !important;
  border-color: var(--td-gold-500) !important;
}

/* =============================================
   RESPONSIVE — mobile stacking
   ============================================= */

@media (max-width: 767px) {
  .td-product-grid {
    grid-template-columns: 1fr;
    gap: 2rem;
  }

  .td-product-sidebar-inner {
    position: static;
  }

  .td-product-title {
    font-size: 1.75rem;
  }

  .td-product-price-block p.price {
    font-size: 2rem;
  }
  .td-product-price-current {
    font-size: 2rem;
  }

  .td-product-thumbnails {
    grid-template-columns: repeat(3, 1fr);
  }

  .td-product-hero {
    padding-top: 7rem;
    padding-bottom: 3rem;
  }
}

/* ---- WC Notices on product page ---- */
.td-product-wrap .woocommerce-message,
.td-product-wrap .woocommerce-info {
  background-color: rgba(20, 20, 20, 0.35);
  backdrop-filter: blur(7px);
  -webkit-backdrop-filter: blur(7px);
  border: 1px solid var(--td-gold-500);
  border-radius: 0.5rem;
  color: var(--td-neutral-50);
  padding: 1rem 1.5rem;
  margin-bottom: 1.5rem;
}

.td-product-wrap .woocommerce-error {
  background-color: rgba(20, 20, 20, 0.35);
  backdrop-filter: blur(7px);
  -webkit-backdrop-filter: blur(7px);
  border: 1px solid #ef4444;
  border-radius: 0.5rem;
  color: var(--td-neutral-50);
  padding: 1rem 1.5rem;
  margin-bottom: 1.5rem;
}

/* =============================================
   FORM PAGES — Hero + Container
   ============================================= */

/* ---- Hero (compact, background photo) ---- */
.td-form-hero {
  position: relative;
  height: 340px;
  background-size: cover;
  background-position: center;
  background-color: var(--td-deep-900);
  margin-top: -76px;
}

.td-form-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(10, 22, 40, 0.3) 0%,
    rgba(10, 22, 40, 0.7) 60%,
    var(--td-deep-950) 100%
  );
}

@media (max-width: 767px) {
  .td-form-hero {
    height: 240px;
  }
}

/* ---- Form page: 1/3 + 2/3 layout (matches Next.js pattern) ---- */
.td-form-page {
  max-width: 1400px;
  margin: 0 auto;
  padding: 3rem 1.5rem 5rem;
}

@media (min-width: 1024px) {
  .td-form-page {
    padding: 4rem 2.5rem 5rem;
  }
}

.td-form-page-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}

@media (min-width: 768px) {
  .td-form-page-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
  }

  .td-form-sidebar {
    grid-column: span 1;
  }

  .td-form-main {
    grid-column: span 2;
  }
}

/* Left sidebar — sticky */
.td-form-sidebar-inner {
  position: static;
}

@media (min-width: 768px) {
  .td-form-sidebar-inner {
    position: sticky;
    top: 84px;
  }
}

/* Eyebrow */
.td-form-eyebrow {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 1rem;
}

.td-form-eyebrow-bar {
  width: 3px;
  height: 1.25rem;
  background-color: var(--td-gold-500);
  border-radius: 9999px;
}

.td-form-eyebrow span {
  color: var(--td-gold-500);
  font-weight: 300;
  font-size: 1rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* Title */
.td-form-title {
  font-size: 2rem;
  font-weight: 400;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--td-neutral-50);
  margin: 0 0 1.25rem;
}

@media (min-width: 768px) {
  .td-form-title {
    font-size: 2.25rem;
  }
}

@media (min-width: 1024px) {
  .td-form-title {
    font-size: 2.5rem;
  }
}

/* Sidebar description */
.td-form-sidebar-desc {
  color: var(--td-neutral-400);
  font-weight: 300;
  font-size: 0.95rem;
  line-height: 1.6;
  margin: 0;
}

/* ---- Forms listing page — photo cards (matches PricesPage) ---- */
.td-forms-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
}

@media (min-width: 640px) {
  .td-forms-grid {
    grid-template-columns: 1fr 1fr;
  }
}

/* Photo card */
.td-fcard {
  position: relative;
  display: block;
  aspect-ratio: 4 / 3;
  border-radius: 0.5rem;
  overflow: hidden;
  text-decoration: none;
}

.td-fcard-img {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  transition: transform 0.5s ease;
}

.td-fcard-img--empty {
  background-color: var(--td-deep-900);
}

.td-fcard:hover .td-fcard-img {
  transform: scale(1.05);
}

/* Default gradient overlay */
.td-fcard-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(10, 22, 40, 0.8) 0%, rgba(10, 22, 40, 0.2) 40%, transparent 100%);
  transition: opacity 0.3s ease;
}

.td-fcard:hover .td-fcard-overlay {
  opacity: 0;
}

/* Hover gradient — darker for readability */
.td-fcard-overlay-hover {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(10, 22, 40, 0.95) 0%, rgba(10, 22, 40, 0.7) 50%, rgba(10, 22, 40, 0.3) 100%);
  opacity: 0;
  transition: opacity 0.3s ease;
}

.td-fcard:hover .td-fcard-overlay-hover {
  opacity: 1;
}

/* Default state: glass bar at bottom with title */
.td-fcard-bottom {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 1.25rem;
  z-index: 2;
  transition: opacity 0.3s ease;
}

.td-fcard:hover .td-fcard-bottom {
  opacity: 0;
}

.td-fcard-bar {
  background-color: rgba(10, 22, 40, 0.5);
  backdrop-filter: blur(7px);
  -webkit-backdrop-filter: blur(7px);
  border: 1px solid var(--td-white-10);
  border-radius: 0.5rem;
  padding: 0.85rem 1rem;
}

.td-fcard-title {
  color: var(--td-neutral-50);
  font-weight: 400;
  font-size: 0.95rem;
  line-height: 1.3;
  margin: 0;
}

/* Hover state: full info */
.td-fcard-hover {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 1.25rem;
  z-index: 2;
  opacity: 0;
  transition: opacity 0.3s ease;
}

.td-fcard:hover .td-fcard-hover {
  opacity: 1;
}

.td-fcard-hover .td-fcard-title {
  margin-bottom: 0.5rem;
}

.td-fcard-desc {
  color: var(--td-neutral-400);
  font-weight: 300;
  font-size: 0.8rem;
  line-height: 1.5;
  margin: 0 0 1rem;
}

.td-fcard-cta {
  display: block;
  text-align: center;
  padding: 0.6rem;
  border-radius: 0.5rem;
  border: 1px solid rgba(200, 168, 78, 0.5);
  color: var(--td-gold-500);
  font-size: 0.85rem;
  font-weight: 300;
}

/* Intro text in sidebar */
.td-form-intro p,
.td-form-intro h3,
.td-form-intro h5 {
  color: var(--td-neutral-400);
  font-weight: 300;
  font-size: 0.95rem;
  line-height: 1.6;
  margin: 0 0 1rem;
}

/* Pre-form text block (legal text etc. inside card, above form) */
.td-form-pretext {
  margin-bottom: 2rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid var(--td-white-10);
}

.td-form-pretext h2,
.td-form-pretext h3 {
  color: var(--td-neutral-50);
  font-weight: 400;
  font-size: 1.1rem;
  margin: 1.5rem 0 0.75rem;
}

.td-form-pretext h2:first-child,
.td-form-pretext h3:first-child {
  margin-top: 0;
}

.td-form-pretext p {
  color: var(--td-neutral-400);
  font-weight: 300;
  font-size: 0.875rem;
  line-height: 1.6;
  margin: 0 0 0.75rem;
}

.td-form-pretext ul {
  color: var(--td-neutral-400);
  font-weight: 300;
  font-size: 0.875rem;
  line-height: 1.6;
  padding-left: 1.25rem;
  margin: 0 0 0.75rem;
}

.td-form-pretext li {
  margin-bottom: 0.35rem;
}

.td-form-pretext strong {
  color: var(--td-neutral-50);
  font-weight: 500;
}

/* Glass card wrapping the form */
.td-form-card {
  background-color: rgba(20, 20, 20, 0.35);
  backdrop-filter: blur(7px);
  -webkit-backdrop-filter: blur(7px);
  border: 1px solid var(--td-white-10);
  border-radius: 1rem;
  padding: 2rem 1.5rem;
}

@media (min-width: 768px) {
  .td-form-card {
    padding: 2.5rem 2.5rem;
  }
}

@media (min-width: 1024px) {
  .td-form-card {
    padding: 3rem;
  }
}

/* Intro text inside card (h2, h5, p from post content) */
.td-form-card > h2,
.td-form-card > h3,
.td-form-card > h4,
.td-form-card > h5 {
  color: var(--td-neutral-50);
  font-weight: 400;
  margin: 0 0 0.5rem;
}

.td-form-card > h2 {
  display: none; /* Title is in hero now */
}

.td-form-card > h5,
.td-form-card > p {
  color: var(--td-neutral-400);
  font-weight: 300;
  font-size: 0.95rem;
  line-height: 1.6;
  margin-bottom: 1.5rem;
}

/* =============================================
   GRAVITY FORMS — Dark v2 Theme
   GF theme CSS is dequeued in functions.php.
   Only gform_basic (structural) remains loaded.
   All selectors use .td-form-card ancestor.
   ============================================= */

/* Hide duplicate GF title (already shown in hero) */
.td-form-card .gform_heading {
  display: none !important;
}

/* Form body */
.td-form-card .gform_body {
  color: var(--td-neutral-50);
}

/* Field containers */
.td-form-card .gfield {
  margin-bottom: 1.25rem;
}

/* Section dividers */
.td-form-card .gsection {
  border-bottom: 1px solid var(--td-white-10) !important;
  border-top: none !important;
  padding-bottom: 0.75rem;
  margin-bottom: 1.5rem !important;
  margin-top: 1.5rem !important;
}

.td-form-card .gsection_title {
  font-size: 1.25rem;
  font-weight: 400;
  color: var(--td-neutral-50) !important;
}

.td-form-card .gsection_description {
  color: var(--td-neutral-400);
  font-weight: 300;
  font-size: 0.875rem;
}

/* Labels */
.td-form-card .gfield_label,
.td-form-card .gform-field-label,
.td-form-card .gfield_label.gform-field-label {
  color: var(--td-neutral-50) !important;
  font-weight: 400 !important;
  font-size: 0.875rem !important;
  margin-bottom: 0.5rem !important;
  display: block !important;
  font-family: var(--td-font-sans) !important;
}

.td-form-card .gfield_required {
  color: var(--td-gold-500) !important;
}

/* Sub-labels (under split fields like name first/last) */
.td-form-card .gform-field-label--type-sub {
  color: var(--td-neutral-400) !important;
  font-weight: 300 !important;
  font-size: 0.75rem !important;
  margin-bottom: 0.35rem !important;
  display: block !important;
}

/* ---- Inputs, textareas, selects ---- */
.td-form-card input[type="text"],
.td-form-card input[type="email"],
.td-form-card input[type="tel"],
.td-form-card input[type="number"],
.td-form-card input[type="url"],
.td-form-card input[type="date"],
.td-form-card input[type="password"],
.td-form-card textarea,
.td-form-card select {
  background-color: rgba(255, 255, 255, 0.05) !important;
  border: 1px solid var(--td-white-10) !important;
  border-radius: 0.5rem !important;
  color: var(--td-neutral-50) !important;
  font-family: var(--td-font-sans) !important;
  font-weight: 300 !important;
  font-size: 0.95rem !important;
  padding: 0.65rem 0.85rem !important;
  transition: border-color 0.2s ease !important;
  width: 100% !important;
  box-sizing: border-box !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  outline: none !important;
  box-shadow: none !important;
}

.td-form-card input:focus,
.td-form-card textarea:focus,
.td-form-card select:focus {
  border-color: var(--td-gold-500) !important;
  outline: none !important;
  box-shadow: 0 0 0 2px rgba(200, 168, 78, 0.15) !important;
}

/* Select custom chevron */
.td-form-card select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12' fill='none' stroke='%239C9C9C' stroke-width='1.5'%3E%3Cpath d='M3 4.5L6 7.5L9 4.5'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 0.75rem center !important;
  padding-right: 2.5rem !important;
}

.td-form-card select option {
  background-color: var(--td-deep-900);
  color: var(--td-neutral-50);
}

/* Placeholder */
.td-form-card ::placeholder {
  color: var(--td-neutral-400) !important;
  opacity: 0.6;
}

/* Description / help text */
.td-form-card .gfield_description,
.td-form-card .instruction {
  color: var(--td-neutral-400) !important;
  font-weight: 300 !important;
  font-size: 0.8rem !important;
  margin-top: 0.25rem;
}

/* ---- Radio & Checkbox ---- */
.td-form-card .gfield_radio label,
.td-form-card .gfield_checkbox label {
  color: var(--td-neutral-50) !important;
  font-weight: 300 !important;
  font-size: 0.95rem !important;
  cursor: pointer;
}

.td-form-card input[type="radio"],
.td-form-card input[type="checkbox"] {
  accent-color: var(--td-gold-500);
  width: 1rem !important;
  height: 1rem !important;
  -webkit-appearance: auto !important;
  appearance: auto !important;
  padding: 0 !important;
  border-radius: 0 !important;
}

.td-form-card input[type="radio"] {
  border-radius: 50% !important;
}

.td-form-card .gchoice {
  margin-bottom: 0.5rem;
}

/* Radio/checkbox horizontal layout */
.td-form-card .gfield_radio,
.td-form-card .gfield_checkbox {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 1rem !important;
}

/* ---- Complex fields (name, address) ---- */
.td-form-card .ginput_complex {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.td-form-card .ginput_complex > span {
  flex: 1;
  min-width: 140px;
}

/* Address fields: 3-row grid layout */
.td-form-card .ginput_container_address {
  display: grid !important;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem !important;
}

.td-form-card .ginput_container_address > span {
  display: block;
}

/* Row 1: Dirección full width */
.td-form-card .ginput_container_address > span.address_line_1 {
  grid-column: 1 / -1;
}

/* Row 2: Ciudad + Estado */
.td-form-card .ginput_container_address > span.address_city {
  grid-column: 1;
}

.td-form-card .ginput_container_address > span.address_state {
  grid-column: 2;
}

/* Row 3: ZIP + País */
.td-form-card .ginput_container_address > span.address_zip {
  grid-column: 1;
}

.td-form-card .ginput_container_address > span.address_country {
  grid-column: 2;
}

/* Date picker */
.td-form-card .datepicker {
  cursor: pointer;
}

/* GF datepicker calendar icon (injected by JS as img.ui-datepicker-trigger) */
.td-form-card img.ui-datepicker-trigger {
  filter: invert(1) brightness(2) !important;
  cursor: pointer;
  vertical-align: middle !important;
  margin-left: 0.5rem !important;
  margin-top: 0.35rem !important;
  width: 20px !important;
  height: 20px !important;
}

/* Also handle native date inputs just in case */
.td-form-card input[type="date"]::-webkit-calendar-picker-indicator {
  filter: invert(1) !important;
  cursor: pointer;
  opacity: 0.7;
}

/* ---- Progress Bar (multi-page forms) ---- */
.td-form-card .gf_progressbar_wrapper {
  margin-bottom: 2rem;
}

.td-form-card .gf_progressbar_wrapper .gf_progressbar_title {
  color: var(--td-neutral-50) !important;
  font-weight: 400;
  font-size: 0.875rem;
  margin-bottom: 0.5rem;
}

.td-form-card .gf_progressbar_wrapper .gf_step_current_page,
.td-form-card .gf_progressbar_wrapper .gf_step_page_count {
  color: var(--td-neutral-400);
  font-weight: 300;
  font-size: 0.8rem;
}

.td-form-card .gf_progressbar {
  background-color: var(--td-white-5) !important;
  border-radius: 9999px !important;
  overflow: hidden !important;
  height: 8px !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
}

.td-form-card .gf_progressbar_percentage {
  background: linear-gradient(90deg, var(--td-gold-600), var(--td-gold-500)) !important;
  border-radius: 9999px !important;
  height: 8px !important;
  font-size: 0 !important;
  line-height: 0 !important;
  padding: 0 !important;
  transition: width 0.4s ease !important;
}

.td-form-card .gf_progressbar_percentage span {
  display: none !important;
}

.td-form-card .gf_page_steps {
  color: var(--td-neutral-400);
  font-size: 0.8rem;
  margin-bottom: 0.5rem;
}

/* ---- Signature Field ---- */
.td-form-card .gfield_signature_container {
  border: 1px solid var(--td-white-10) !important;
  border-radius: 0.5rem !important;
  background-color: rgba(255, 255, 255, 0.03) !important;
  overflow: hidden;
}

.td-form-card .gfield_signature_container canvas {
  display: block;
  width: 100% !important;
}

.td-form-card .gform_signature_clear {
  color: var(--td-gold-500) !important;
  font-size: 0.8rem;
  cursor: pointer;
  margin-top: 0.35rem;
  display: inline-block;
}

/* ---- Buttons ---- */
.td-form-card .gform_button,
.td-form-card .gform_next_button,
.td-form-card .gform_previous_button,
.td-form-card input[type="submit"] {
  font-family: var(--td-font-sans) !important;
  font-weight: 500 !important;
  font-size: 0.95rem !important;
  padding: 0.7rem 2rem !important;
  border-radius: 0.5rem !important;
  cursor: pointer !important;
  transition: all 0.2s ease !important;
  border: none !important;
  width: auto !important;
  -webkit-appearance: none !important;
}

.td-form-card .gform_button,
.td-form-card .gform_next_button,
.td-form-card input[type="submit"] {
  background-color: var(--td-gold-500) !important;
  color: var(--td-deep-950) !important;
}

.td-form-card .gform_button:hover,
.td-form-card .gform_next_button:hover,
.td-form-card input[type="submit"]:hover {
  background-color: var(--td-gold-400) !important;
}

.td-form-card .gform_previous_button {
  background-color: transparent !important;
  color: var(--td-neutral-400) !important;
  border: 1px solid var(--td-white-10) !important;
  margin-right: 0.75rem;
}

.td-form-card .gform_previous_button:hover {
  color: var(--td-neutral-50) !important;
  border-color: var(--td-white-30) !important;
}

/* Footer (buttons row) */
.td-form-card .gform_page_footer,
.td-form-card .gform_footer {
  margin-top: 2rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--td-white-5);
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.td-form-card .gform_footer {
  justify-content: flex-end;
}

/* ---- Validation Errors ---- */
.td-form-card .gfield_error .gfield_label {
  color: #ef4444 !important;
}

.td-form-card .gfield_error input,
.td-form-card .gfield_error textarea,
.td-form-card .gfield_error select {
  border-color: #ef4444 !important;
}

.td-form-card .validation_message,
.td-form-card .gfield_validation_message {
  color: #ef4444 !important;
  font-size: 0.8rem !important;
  font-weight: 300 !important;
  margin-top: 0.25rem;
}

.td-form-card .validation_error,
.td-form-card .gform_validation_errors {
  background-color: rgba(239, 68, 68, 0.1) !important;
  border: 1px solid rgba(239, 68, 68, 0.3) !important;
  border-radius: 0.5rem !important;
  padding: 1rem 1.5rem !important;
  color: var(--td-neutral-50) !important;
  margin-bottom: 1.5rem !important;
}

.td-form-card .gform_validation_errors h2 {
  color: #ef4444 !important;
  font-size: 1rem !important;
  font-weight: 400 !important;
  display: block !important;
}

/* ---- Confirmation Message ---- */
.td-form-card .gform_confirmation_message {
  color: var(--td-neutral-50);
  font-weight: 300;
  font-size: 1rem;
  line-height: 1.6;
  text-align: center;
  padding: 2rem 0;
}

/* ---- Phone field (international) ---- */
.td-form-card .iti,
.gform_wrapper .iti {
  width: 100%;
  display: block;
}

.td-form-card .iti input[type="tel"],
.gform_wrapper .iti input[type="tel"] {
  padding-left: 3.2rem !important;
}

.td-form-card .iti__selected-flag,
.gform_wrapper .iti__selected-flag {
  background-color: transparent !important;
}

.td-form-card .iti__country-list,
.gform_wrapper .iti__country-list {
  background-color: var(--td-deep-900) !important;
  border-color: var(--td-white-10) !important;
  color: var(--td-neutral-50);
  z-index: 100 !important;
}

.td-form-card .iti__country:hover,
.td-form-card .iti__country--highlight,
.gform_wrapper .iti__country:hover,
.gform_wrapper .iti__country--highlight {
  background-color: var(--td-white-5) !important;
}

/* ---- Address Autocomplete ---- */
.pac-container {
  background-color: var(--td-deep-900) !important;
  border-color: var(--td-white-10) !important;
  color: var(--td-neutral-50) !important;
  z-index: 10000 !important;
}

.pac-item {
  color: var(--td-neutral-400) !important;
  border-color: var(--td-white-5) !important;
}

.pac-item:hover {
  background-color: var(--td-white-5) !important;
}

.pac-item-query {
  color: var(--td-neutral-50) !important;
}

/* ---- Consent / Legal scroll box ---- */
.td-form-card .gfield--type-consent .gfield_consent_description {
  background-color: rgba(255, 255, 255, 0.03) !important;
  border: 1px solid var(--td-white-10) !important;
  border-radius: 0.5rem !important;
  color: var(--td-neutral-400) !important;
  font-weight: 300 !important;
  font-size: 0.8rem !important;
  padding: 1rem !important;
  max-height: 150px;
  overflow-y: auto;
}

/* ---- File Upload ---- */
.td-form-card .gform_drop_area {
  background-color: rgba(255, 255, 255, 0.03) !important;
  border: 2px dashed var(--td-white-10) !important;
  border-radius: 0.5rem !important;
  padding: 2rem !important;
  text-align: center;
  color: var(--td-neutral-400) !important;
}

.td-form-card .gform_drop_area:hover {
  border-color: var(--td-gold-500) !important;
}

.td-form-card .gform_button_select_files {
  background-color: transparent !important;
  border: 1px solid var(--td-white-10) !important;
  color: var(--td-neutral-50) !important;
  border-radius: 0.5rem !important;
  padding: 0.5rem 1.25rem !important;
  cursor: pointer !important;
  font-size: 0.85rem !important;
}

/* ---- Responsive ---- */
@media (max-width: 767px) {
  .td-form-card {
    padding: 1.5rem 1rem;
    border-radius: 0.75rem;
  }

  .td-form-card .ginput_complex {
    flex-direction: column;
  }

  .td-form-card .gform_page_footer,
  .td-form-card .gform_footer {
    flex-direction: column;
  }

  .td-form-card .gform_previous_button {
    margin-right: 0;
    order: 2;
  }

  .td-form-card .gform_next_button,
  .td-form-card .gform_button {
    width: 100% !important;
    text-align: center;
  }
}

/* =============================================
   SIDE CART
   ============================================= */

.td-sidecart-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.5);
  z-index: 9998;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}
.td-sidecart-overlay.is-open {
  opacity: 1;
  visibility: visible;
}

.td-sidecart {
  position: fixed;
  top: 0;
  right: 0;
  width: 400px;
  max-width: 90vw;
  height: 100vh;
  height: 100dvh;
  z-index: 9999;
  background: var(--td-deep-900);
  border-left: 1px solid var(--td-white-10);
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1);
}
.td-sidecart.is-open {
  transform: translateX(0);
}

/* Header */
.td-sidecart__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.25rem 1.5rem;
  border-bottom: 1px solid var(--td-white-10);
  flex-shrink: 0;
}
.td-sidecart__title {
  font-size: 1rem;
  font-weight: 400;
  color: var(--td-neutral-50);
  margin: 0;
  letter-spacing: -0.01em;
}
.td-sidecart__count {
  font-size: 0.75rem;
  font-weight: 300;
  color: var(--td-neutral-400);
  margin-left: 0.5rem;
}
.td-sidecart__close {
  background: none;
  border: none;
  color: var(--td-neutral-400);
  cursor: pointer;
  padding: 0.25rem;
  transition: var(--td-transition);
  line-height: 1;
}
.td-sidecart__close:hover {
  color: var(--td-neutral-50);
}
.td-sidecart__close svg {
  width: 1.25rem;
  height: 1.25rem;
}

/* Items */
.td-sidecart__items {
  flex: 1;
  overflow-y: auto;
  padding: 0;
}
.td-sidecart__empty {
  padding: 3rem 1.5rem;
  text-align: center;
  color: var(--td-neutral-400);
  font-size: 0.875rem;
  font-weight: 300;
}

.td-sidecart__item {
  display: flex;
  gap: 1rem;
  padding: 1rem 1.5rem;
  border-bottom: 1px solid var(--td-white-5);
  position: relative;
}
.td-sidecart__item-img {
  width: 64px;
  height: 64px;
  border-radius: 0.5rem;
  overflow: hidden;
  flex-shrink: 0;
  background: var(--td-deep-800);
}
.td-sidecart__item-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.td-sidecart__item-info {
  flex: 1;
  min-width: 0;
}
.td-sidecart__item-name {
  font-size: 0.8125rem;
  font-weight: 400;
  color: var(--td-neutral-50);
  margin: 0 0 0.25rem;
  line-height: 1.3;
}
.td-sidecart__item-name a {
  color: inherit;
  text-decoration: none;
}
.td-sidecart__item-meta {
  font-size: 0.6875rem;
  font-weight: 300;
  color: var(--td-neutral-400);
  line-height: 1.4;
  margin-bottom: 0.375rem;
}
.td-sidecart__item-price {
  font-size: 0.8125rem;
  font-weight: 400;
  color: var(--td-neutral-50);
}
.td-sidecart__item-qty {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  margin-right: 0.75rem;
}
.td-sidecart__item-qty span {
  color: var(--td-neutral-400);
  font-size: 0.75rem;
  font-weight: 300;
}
.td-sidecart__item-remove {
  position: absolute;
  top: 1rem;
  right: 1.25rem;
  background: none;
  border: none;
  color: var(--td-neutral-400);
  cursor: pointer;
  padding: 0.125rem;
  transition: var(--td-transition);
  line-height: 1;
}
.td-sidecart__item-remove:hover {
  color: #ef4444;
}
.td-sidecart__item-remove svg {
  width: 0.875rem;
  height: 0.875rem;
}

/* Footer */
.td-sidecart__footer {
  flex-shrink: 0;
  padding: 1.25rem 1.5rem;
  border-top: 1px solid var(--td-white-10);
}
.td-sidecart__subtotal {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1rem;
}
.td-sidecart__subtotal-label {
  font-size: 0.875rem;
  font-weight: 300;
  color: var(--td-neutral-400);
}
.td-sidecart__subtotal-value {
  font-size: 1.125rem;
  font-weight: 400;
  color: var(--td-neutral-50);
}
.td-sidecart__btn-checkout {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 2.75rem;
  border-radius: 0.5rem;
  background: var(--td-gold-500);
  color: var(--td-deep-950);
  font-size: 0.875rem;
  font-weight: 600;
  text-decoration: none;
  transition: var(--td-transition);
  margin-bottom: 0.5rem;
  border: none;
  cursor: pointer;
}
.td-sidecart__btn-checkout:hover {
  background: var(--td-gold-400);
}
.td-sidecart__btn-cart {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 2.5rem;
  border-radius: 0.5rem;
  background: var(--td-white-5);
  backdrop-filter: blur(7px);
  border: 1px solid var(--td-white-10);
  color: var(--td-neutral-400);
  font-size: 0.8125rem;
  font-weight: 300;
  text-decoration: none;
  transition: var(--td-transition);
}
.td-sidecart__btn-cart:hover {
  color: var(--td-neutral-50);
  border-color: var(--td-white-30);
}
