/*
Theme Name: Merch3DTheme2
Theme URI: https://merch3d.com
Author: Darshan S
Description: Astra child theme for a custom WooCommerce site.
Version: 1.0.0
Template: astra
Text Domain: merch3dtheme
*/

:root {
  --font-sans: 'Rajdhani', sans-serif;
  --font-display: 'Orbitron', sans-serif;

  /* Dark Charcoal Background */
  --background: 210 14% 9%; /* #13171C */
  --foreground: 180 10% 98%;

  /* Darker Card Backgrounds */
  --card: 210 14% 12%;
  --card-foreground: 180 10% 98%;

  --popover: 210 14% 9%;
  --popover-foreground: 180 10% 98%;

  /* Neon Teal Primary */
  --primary: 180 100% 50%; /* #00FFFF - Cyan/Teal */
  --primary-foreground: 210 14% 9%; /* Dark text on neon */

  /* Electric Blue Secondary */
  --secondary: 195 100% 50%; /* #00BFFF */
  --secondary-foreground: 210 14% 9%;

  --muted: 210 14% 18%;
  --muted-foreground: 210 10% 70%;

  --accent: 180 100% 50%;
  --accent-foreground: 210 14% 9%;

  --destructive: 0 100% 60%;
  --destructive-foreground: 210 14% 9%;

  --border: 210 14% 20%;
  --input: 210 14% 20%;
  --ring: 180 100% 50%;

  --radius: 0rem; /* Industrial sharp edges */

  --chart-1: 180 100% 50%;
  --chart-2: 195 100% 50%;
  --chart-3: 280 100% 60%;
  --chart-4: 320 100% 60%;
  --chart-5: 40 100% 60%;
  
  --sidebar: 210 14% 8%;
  --sidebar-foreground: 240 5% 96%;
  --sidebar-primary: 180 100% 50%;
  --sidebar-primary-foreground: 0 0% 100%;
  --sidebar-accent: 210 14% 15%;
  --sidebar-accent-foreground: 240 5% 96%;
  --sidebar-border: 220 13% 91%;
  --sidebar-ring: 217.2 91.2% 59.8%;
}

* {
  border-color: hsl(var(--border));
}

body {
  font-family: var(--font-sans);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  background-color: hsl(var(--background)) !important;
  color: hsl(var(--foreground));
}

html {
  background-color: hsl(var(--background));
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-display);
  letter-spacing: 0.05em;
}

/* Custom Neon Glow Utilities */
.text-glow {
  text-shadow: 0 0 10px hsla(180, 100%, 50%, 0.5), 0 0 20px hsla(180, 100%, 50%, 0.3);
}

.box-glow {
  box-shadow: 0 0 15px hsla(180, 100%, 50%, 0.1), 0 0 5px hsla(180, 100%, 50%, 0.1) inset;
}

.border-glow {
    box-shadow: 0 0 5px hsla(180, 100%, 50%, 0.5), 0 0 10px hsla(180, 100%, 50%, 0.2) inset;
}

/* Matrix/Grid Background */
.bg-grid-pattern {
  background-image: 
    linear-gradient(to right, rgba(0, 255, 255, 0.05) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(0, 255, 255, 0.05) 1px, transparent 1px);
  background-size: 40px 40px;
}

/* Tailwind-style utility fallbacks for PHP templates */
.bg-background {
  background-color: hsl(var(--background));
}

.bg-background\/80 {
  background-color: hsl(var(--background) / 0.8);
}

.text-primary {
  color: hsl(var(--primary));
}

.bg-primary {
  background-color: hsl(var(--primary));
}

.bg-card {
  background-color: hsl(var(--card));
}

.bg-primary\/10 {
  background-color: hsl(var(--primary) / 0.1);
}

.bg-primary\/20 {
  background-color: hsl(var(--primary) / 0.2);
}

.bg-primary\/90 {
  background-color: hsl(var(--primary) / 0.9);
}

.border-primary\/50 {
  border-color: hsl(var(--primary) / 0.5);
}

.border-primary\/40 {
  border-color: hsl(var(--primary) / 0.4);
}

.border-primary\/30 {
  border-color: hsl(var(--primary) / 0.3);
}

.border-white\/10 {
  border-color: rgba(255, 255, 255, 0.1);
}

.border-white\/20 {
  border-color: rgba(255, 255, 255, 0.2);
}

.border-white\/5 {
  border-color: rgba(255, 255, 255, 0.05);
}

.bg-white\/10 {
  background-color: rgba(255, 255, 255, 0.1);
}

.bg-primary\/30 {
  background-color: hsl(var(--primary) / 0.3);
}

.bg-black\/40 {
  background-color: rgba(0, 0, 0, 0.4);
}

.bg-black\/60 {
  background-color: rgba(0, 0, 0, 0.6);
}

.text-primary\/80 {
  color: hsl(var(--primary) / 0.8);
}

.text-slate-200\/80 {
  color: rgba(226, 232, 240, 0.8);
}

.text-slate-200\/70 {
  color: rgba(226, 232, 240, 0.7);
}

.text-white\/20 {
  color: rgba(255, 255, 255, 0.2);
}

.text-white\/40 {
  color: rgba(255, 255, 255, 0.4);
}

.text-white\/60 {
  color: rgba(255, 255, 255, 0.6);
}

.text-card-foreground {
  color: hsl(var(--card-foreground));
}

/* WooCommerce cart theming */
.woocommerce table.shop_table {
  background-color: hsl(var(--background));
  color: hsl(var(--foreground));
  border-color: rgba(255, 255, 255, 0.1);
  border-radius: 0.75rem;
  overflow: hidden;
}

.woocommerce table.shop_table thead {
  background-color: rgba(255, 255, 255, 0.04);
}

.woocommerce table.shop_table thead th {
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 700;
  font-size: 0.8rem;
  padding-top: 1rem;
  padding-bottom: 1rem;
  color: hsl(var(--foreground));
}

.woocommerce table.shop_table th,
.woocommerce table.shop_table td {
  border-color: rgba(255, 255, 255, 0.1);
}

.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button {
  background-color: hsl(var(--primary));
  color: hsl(var(--primary-foreground));
  border: 1px solid hsl(var(--primary) / 0.4);
  border-radius: 0.5rem;
  padding: 0.65rem 1rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  transition: background-color 150ms ease, color 150ms ease, border-color 150ms ease;
}

.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover {
  background-color: hsl(var(--primary) / 0.9);
  color: hsl(var(--background));
}

.woocommerce input[type="text"],
.woocommerce input[type="email"],
.woocommerce input[type="tel"],
.woocommerce input[type="number"],
.woocommerce select {
  background-color: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.15);
  color: hsl(var(--foreground));
  border-radius: 0.5rem;
  padding: 0.55rem 0.75rem;
}

.woocommerce a.remove {
  color: hsl(var(--primary));
}

.woocommerce-message,
.woocommerce-error,
.woocommerce-info {
  background-color: rgba(255, 255, 255, 0.05);
  border-color: rgba(255, 255, 255, 0.1);
  color: hsl(var(--foreground));
}

/* Hide cart updated notice to reduce UI noise on cart page */
body.woocommerce-cart .woocommerce-message {
  display: none !important;
}

/* Product tabs (description/reviews) */
.woocommerce div.product .woocommerce-tabs {
  margin-top: 2rem;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 0.75rem;
  background: hsl(var(--background) / 0.8);
  overflow: hidden;
}

.woocommerce div.product .woocommerce-tabs ul.tabs {
  display: flex;
  gap: 0.5rem;
  padding: 1rem 1.25rem 0.5rem;
  margin: 0;
  border: none;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li {
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.04);
  margin: 0;
  border-radius: 0.5rem;
  padding: 0.5rem 0.9rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 700;
  font-size: 0.8rem;
  color: hsl(var(--foreground));
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active {
  border-color: hsl(var(--primary) / 0.6);
  background: hsl(var(--primary) / 0.12);
  color: hsl(var(--primary));
}

.woocommerce div.product .woocommerce-tabs ul.tabs::before,
.woocommerce div.product .woocommerce-tabs ul.tabs::after,
.woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::after {
  display: none;
}

.woocommerce div.product .woocommerce-tabs .panel {
  padding: 1.25rem;
  color: hsl(var(--foreground));
  line-height: 1.6;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.woocommerce-Reviews {
  background: rgba(0, 0, 0, 0.25);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 0.75rem;
  padding: 1rem;
}

.woocommerce-Reviews-title,
.comment-reply-title {
  font-family: var(--font-display);
  color: hsl(var(--foreground));
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 1rem;
}

.woocommerce .commentlist li {
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  padding: 1rem 0;
}

.woocommerce #reviews #comment {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.1);
  color: hsl(var(--foreground));
}

/* Hide shipping calculator on cart and the manual update button (auto-updates enabled) */
.woocommerce .cart .shipping-calculator-form,
.woocommerce .cart .shipping-calculator-button,
.woocommerce button[name="update_cart"] {
  display: none !important;
}

.bg-gradient-to-r {
  background-image: linear-gradient(to right, hsl(var(--primary)), hsl(var(--secondary)));
}

.bg-gradient-to-br {
  background-image: linear-gradient(135deg, hsl(var(--primary)), hsl(var(--secondary)));
}

.from-primary {
  --tw-gradient-from: hsl(var(--primary));
}

.to-secondary {
  --tw-gradient-to: hsl(var(--secondary));
}

.text-foreground {
  color: hsl(var(--foreground));
}

.hover\:border-primary\/60:hover {
  border-color: hsl(var(--primary) / 0.6);
}

.transition-transform {
  transition-property: transform, box-shadow, border-color, opacity;
}

.duration-300 {
  transition-duration: 300ms;
}

.hover\:-translate-y-2:hover {
  transform: translateY(-0.5rem);
}

.hover\:shadow-primary-glow:hover {
  box-shadow: 0 10px 30px hsla(180, 100%, 50%, 0.2), 0 0 0 1px hsla(180, 100%, 50%, 0.15);
}

.group:hover .group-hover\:translate-x-1 {
  transform: translateX(0.25rem);
}

.group:hover .group-hover\:opacity-10 {
  opacity: 0.1;
}

@keyframes fade-in-up {
  from {
    opacity: 0;
    transform: translateY(12px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.animate-fade-in-up {
  animation: fade-in-up 0.8s ease forwards;
}

.ast-container {
  padding: 0px;
  margin: 0px !important;
  width: 100% !important;
}

main {
  margin: 0px !important;
  width: 100% !important;
}

.ast-separate-container .ast-article-post, .ast-separate-container .ast-article-single {
  border: 0px !important;
}

.woocommerce .woocommerce-ordering, .woocommerce-js .woocommerce-ordering {
  margin: 0px !important;
}

.select2-selection {
  background-color: rgba(255, 255, 255, 0.05) !important;
  border: 1px solid rgba(255, 255, 255, 0.15) !important;
  color: white !important;
  border-radius: 0.5rem !important;
  padding: 0.55rem 0.75rem !important;
}

.select2-container--default .select2-selection--single .select2-selection__rendered {
  color: white !important;
}

.select2-container--default .select2-results__option--highlighted[aria-selected], .select2-container--default .select2-results__option--highlighted[data-selected] {
  background-color: hsl(var(--primary)) !important;
  color: hsl(var(--primary-foreground)) !important;
}

.woocommerce-js .select2-results__option, .woocommerce-js .select2-search--dropdown .select2-search__field {
  background-color: hsl(var(--background)) !important;
  color: white !important;
}

.select2-search--dropdown {
  display: block;
  padding: 0px;
}

.woocommerce form .form-row label, .woocommerce-page form .form-row label {
  color: white;
}

.woocommerce-js ul#shipping_method li label,
.wc-blocks-components-select__label {
  color: white;
}
.wc-block-components-text-input input[type=email],
.wc-block-components-text-input input[type=text],
.wc-block-components-text-input input[type=tel],
.wc-block-components-text-input input[type=password],
.woocommerce-js form .form-row input.input-text,
.woocommerce-js form .form-row textarea,
.woocommerce-page textarea,
.woocommerce-page select
{
  background-color: rgba(255, 255, 255, 0.05) !important;
  border: 1px solid rgba(255, 255, 255, 0.15) !important;
  color: hsl(var(--foreground)) !important;
  border-radius: 0.5rem !important;
  padding: 1.2rem 0.75rem 0.75rem 0.75rem !important;
}

.wp-block-woocommerce-checkout .wc-block-components-text-input.is-active label {
  top: 0.5px !important;
  padding-left: 4px;
}

textarea::placeholder {
  color: hsl(var(--foreground)) !important;
}

.wp-block-woocommerce-checkout .wc-block-components-address-form .wc-block-components-address-form__address_2-toggle {
 border: 0px; 
}

.wc-blocks-components-select__container {
  background-color: rgba(255, 255, 255, 0.05) !important;
}

legend,
.wc-block-components-checkbox__label,
.wc-block-components-checkout-step__title,
.woocommerce-js div.product .product_title,
.woocommerce-Price-amount,
.woocommerce-js #reviews .comment-form-rating label,
.comment-form-comment label,
.woocommerce-js div.product .woocommerce-tabs ul.tabs li a,
.woocommerce-js div.product .related.products > h2 {
  color: white !important;
}

header.entry-header .entry-title {
  max-width: 1296px !important;
  margin: 0 auto !important;
  color: hsl(var(--primary)) !important;
}

body:not(.woocommerce-block-theme-has-button-styles) .wc-block-components-button:not(.is-link) {
  background-color: hsl(var(--primary)) !important;
  color: hsl(var(--primary-foreground)) !important;
  border: 1px solid hsl(var(--primary) / 0.4) !important;
  border-radius: 0.5rem !important;
  padding: 0.65rem 2rem !important;
}

.woocommerce .addresses .title .edit, .woocommerce-account .addresses .title .edit {
  color: black !important;
}

.woocommerce-js .woocommerce-ordering select {
  height: 55px;
}

/* Front page product grid fallback to 4 columns on desktop. */
.home .woocommerce ul.products {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1.5rem;
}

.home .woocommerce ul.products li.product {
  width: auto;
  float: none;
  margin: 0;
}

@media (max-width: 1024px) {
  .home .woocommerce ul.products {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .home .woocommerce ul.products {
    grid-template-columns: 1fr;
  }
}
