/* 20251217100018 - v2 */
.gui,
.gui-block-linklist li a {
  color: #666666;
}

.gui-page-title,
.gui a.gui-bold,
.gui-block-subtitle,
.gui-table thead tr th,
.gui ul.gui-products li .gui-products-title a,
.gui-form label,
.gui-block-title.gui-dark strong,
.gui-block-title.gui-dark strong a,
.gui-content-subtitle {
  color: #2a2a2a;
}

.gui-block-inner strong {
  color: #7f7f7f;
}

.gui a {
  color: #cb8fa1;
}

.gui-input.gui-focus,
.gui-text.gui-focus,
.gui-select.gui-focus {
  border-color: #cb8fa1;
  box-shadow: 0 0 2px #cb8fa1;
}

.gui-select.gui-focus .gui-handle {
  border-color: #cb8fa1;
}

.gui-block,
.gui-block-title,
.gui-buttons.gui-border,
.gui-block-inner,
.gui-image {
  border-color: #181616;
}

.gui-block-title {
  color: #2a2a2a;
  background-color: #f1d9e7;
}

.gui-content-title {
  color: #2a2a2a;
}

.gui-form .gui-field .gui-description span {
  color: #666666;
}

.gui-block-inner {
  background-color: #e7d0dd;
}

.gui-block-option {
  border-color: #dcdcdc;
  background-color: #f3f3f3;
}

.gui-block-option-block {
  border-color: #dcdcdc;
}

.gui-block-title strong {
  color: #2a2a2a;
}

.gui-line,
.gui-cart-sum .gui-line {
  background-color: #979696;
}

.gui ul.gui-products li {
  border-color: #b9b9b9;
}

.gui-block-subcontent,
.gui-content-subtitle {
  border-color: #b9b9b9;
}

.gui-faq,
.gui-login,
.gui-password,
.gui-register,
.gui-review,
.gui-sitemap,
.gui-block-linklist li,
.gui-table {
  border-color: #b9b9b9;
}

.gui-block-content .gui-table {
  border-color: #dcdcdc;
}

.gui-table thead tr th {
  border-color: #979696;
  background-color: #f3f3f3;
}

.gui-table tbody tr td {
  border-color: #dcdcdc;
}

.gui a.gui-button-large,
.gui a.gui-button-small {
  border-color: #8d8d8d;
  color: #000000;
  background-color: #ffffff;
}

.gui a.gui-button-large.gui-button-action,
.gui a.gui-button-small.gui-button-action {
  border-color: #2a2a2a;
  color: #000000;
  background-color: #ffffff;
}

.gui a.gui-button-large:active,
.gui a.gui-button-small:active {
  background-color: #cccccc;
  border-color: #707070;
}

.gui a.gui-button-large.gui-button-action:active,
.gui a.gui-button-small.gui-button-action:active {
  background-color: #cccccc;
  border-color: #212121;
}

.gui-input,
.gui-text,
.gui-select,
.gui-number {
  border-color: #e5e5e5;
  background-color: #ffffff;
}

.gui-select .gui-handle,
.gui-number .gui-handle {
  border-color: #e5e5e5;
}

.gui-number .gui-handle a {
  background-color: #ffffff;
}

.gui-input input,
.gui-number input,
.gui-text textarea,
.gui-select .gui-value {
  color: #2a2a2a;
}

.gui-progressbar {
  background-color: #cb8fa1;
}

/* custom */
/* ============================================
   THE DANCE STORE — CUSTOM CSS
   For Lightspeed Ignite Theme (Vanilla)
   
   Paste into: Design → Advanced → Customize CSS
   ============================================ */

/* Google Fonts */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;600;700&family=Inter:wght@300;400;500;600&display=swap');

/* ============================================
   BRAND TOKENS
   ============================================ */
:root {
    --tds-primary-pink: #FFD1DC;
    --tds-secondary-pink: #CB8FA1;
    --tds-accent-gold: #D4AF37;
    --tds-bg-white: #FFFFFF;
    --tds-bg-light: #FAFAFA;
    --tds-text-main: #2A2A2A;
    --tds-text-muted: #666666;
    --tds-border-color: #E5E5E5;
    --tds-radius: 4px;
    --tds-transition: all 0.3s ease;
}

/* ============================================
   TYPOGRAPHY
   ============================================ */
body {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif !important;
    color: var(--tds-text-main);
    line-height: 1.7;
}

h1, h2, h3, h4, h5, h6 {
    font-family: 'Playfair Display', Georgia, serif !important;
    font-weight: 600;
    color: var(--tds-text-main);
}

/* ============================================
   PROMO / ANNOUNCEMENT BAR
   ============================================ */
.announcement-bar,
.message-bar,
.top-bar,
#announcement-bar {
    background-color: var(--tds-text-main) !important;
    color: var(--tds-bg-white) !important;
    font-size: 0.8rem;
    letter-spacing: 0.5px;
    text-transform: uppercase;
}

/* ============================================
   HEADER / NAVIGATION
   ============================================ */
header,
.header,
.site-header,
#header {
    background-color: rgba(255, 255, 255, 0.98) !important;
    border-bottom: 1px solid var(--tds-border-color);
}

.logo,
.site-logo,
.header-logo,
.header-logo a,
.logo a {
    font-family: 'Playfair Display', serif !important;
    font-size: 1.5rem !important;
    font-weight: 700 !important;
    color: var(--tds-text-main) !important;
    text-decoration: none !important;
}

/* Navigation Links */
nav a,
.nav a,
.nav-link,
.main-nav a,
.navigation a,
.menu a {
    font-family: 'Inter', sans-serif !important;
    font-size: 0.9rem !important;
    font-weight: 500 !important;
    color: var(--tds-text-main) !important;
    text-decoration: none;
    position: relative;
    transition: var(--tds-transition);
}

nav a:hover,
.nav a:hover,
.nav-link:hover,
.main-nav a:hover {
    color: var(--tds-secondary-pink) !important;
}

/* Book Fitting Link - Gold Accent */
nav a[href*="fitting"],
nav a[href*="book"],
.nav a[href*="fitting"],
.menu a[href*="fitting"] {
    color: var(--tds-accent-gold) !important;
    font-weight: 600 !important;
}

/* ============================================
   BUTTONS
   ============================================ */
.btn,
.btn-primary,
.button,
button[type="submit"],
input[type="submit"],
.add-to-cart,
.btn-cart,
.cart-button {
    display: inline-block;
    background-color: var(--tds-text-main) !important;
    color: white !important;
    padding: 14px 36px;
    font-family: 'Inter', sans-serif !important;
    font-size: 0.85rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1px;
    border-radius: var(--tds-radius) !important;
    border: none !important;
    cursor: pointer;
    transition: var(--tds-transition);
    text-decoration: none !important;
}

.btn:hover,
.btn-primary:hover,
.button:hover,
button[type="submit"]:hover,
input[type="submit"]:hover,
.add-to-cart:hover,
.btn-cart:hover {
    background-color: var(--tds-secondary-pink) !important;
    transform: translateY(-2px);
    box-shadow: 0 10px 20px rgba(203, 143, 161, 0.3);
    color: white !important;
}

/* Secondary / Outline Buttons */
.btn-secondary,
.btn-outline,
.button-secondary {
    background-color: transparent !important;
    color: var(--tds-text-main) !important;
    border: 2px solid var(--tds-text-main) !important;
}

.btn-secondary:hover,
.btn-outline:hover,
.button-secondary:hover {
    background-color: var(--tds-text-main) !important;
    color: white !important;
}

/* Gold Accent Button */
.btn-accent,
.btn-gold {
    background-color: var(--tds-accent-gold) !important;
}

.btn-accent:hover,
.btn-gold:hover {
    background-color: #c9a430 !important;
}

/* ============================================
   HERO / BANNER SECTION
   ============================================ */
.hero,
.banner,
.slider,
.headline,
.headlines,
#slider,
.home-slider {
    position: relative;
}

.hero h1,
.banner h1,
.headline h1,
.slider h1,
.headlines h1 {
    font-family: 'Playfair Display', serif !important;
    font-size: 3rem;
    color: var(--tds-text-main);
}

.hero p,
.banner p,
.headline p {
    font-size: 1.1rem;
    color: var(--tds-text-muted);
}

/* ============================================
   PRODUCT CARDS
   ============================================ */
.product,
.product-item,
.product-card,
.product-block {
    transition: var(--tds-transition);
}

.product:hover,
.product-item:hover,
.product-card:hover,
.product-block:hover {
    transform: translateY(-4px);
}

/* Product Image */
.product-image,
.product-img,
.product-card img,
.product-thumbnail {
    border-radius: var(--tds-radius);
    overflow: hidden;
}

/* Product Badges */
.badge,
.label,
.product-badge,
.product-label,
.tag {
    padding: 4px 10px;
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    border-radius: 2px;
}

.badge-new,
.label-new,
.new {
    background: var(--tds-text-main) !important;
    color: white !important;
}

.badge-sale,
.label-sale,
.sale {
    background: var(--tds-secondary-pink) !important;
    color: white !important;
}

/* Product Brand */
.product-brand,
.brand,
.vendor {
    font-size: 0.75rem;
    color: var(--tds-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 0.25rem;
}

/* Product Title */
.product-title,
.product-name,
.product h3,
.product-card h3 {
    font-family: 'Inter', sans-serif !important;
    font-size: 1rem;
    font-weight: 500;
    color: var(--tds-text-main);
    margin-bottom: 0.25rem;
}

/* Product Price */
.product-price,
.price,
.product .price {
    font-weight: 600;
    color: var(--tds-text-main);
}

.price-old,
.compare-price,
.was-price,
.original-price {
    text-decoration: line-through;
    color: var(--tds-text-muted);
    font-weight: 400;
    margin-right: 0.5rem;
}

/* ============================================
   CATEGORY CARDS
   ============================================ */
.category,
.category-card,
.collection-card,
.category-item {
    position: relative;
    border-radius: var(--tds-radius);
    overflow: hidden;
    transition: var(--tds-transition);
}

.category:hover,
.category-card:hover,
.collection-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 15px 30px rgba(0,0,0,0.1);
}

.category-title,
.category-name,
.collection-title {
    font-family: 'Playfair Display', serif !important;
    font-weight: 600;
}

/* ============================================
   FORM ELEMENTS
   ============================================ */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="tel"],
input[type="number"],
input[type="search"],
textarea,
select,
.form-control,
.input-text {
    width: 100%;
    padding: 14px;
    border: 1px solid var(--tds-border-color) !important;
    border-radius: var(--tds-radius) !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 1rem;
    transition: border-color 0.3s;
    background: white;
}

input:focus,
textarea:focus,
select:focus,
.form-control:focus {
    outline: none;
    border-color: var(--tds-secondary-pink) !important;
    box-shadow: 0 0 0 3px rgba(203, 143, 161, 0.1) !important;
}

/* ============================================
   VARIANT SELECTORS (Product Options)
   ============================================ */
.variant-option,
.option-btn,
.swatch,
.variant-selector button,
.size-selector button {
    padding: 10px 16px;
    border: 1px solid var(--tds-border-color);
    background: white;
    cursor: pointer;
    border-radius: var(--tds-radius);
    font-size: 0.9rem;
    transition: all 0.2s;
    min-width: 44px;
    text-align: center;
}

.variant-option:hover,
.option-btn:hover,
.swatch:hover {
    border-color: var(--tds-text-main);
}

.variant-option.selected,
.variant-option.active,
.option-btn.selected,
.swatch.selected,
.swatch.active {
    background-color: var(--tds-text-main) !important;
    color: white !important;
    border-color: var(--tds-text-main) !important;
}

.variant-option.unavailable,
.option-btn.unavailable,
.swatch.unavailable,
.out-of-stock-variant {
    opacity: 0.3;
    text-decoration: line-through;
    cursor: not-allowed;
}

/* Stock Status */
.in-stock,
.available {
    color: #22c55e;
}

.out-of-stock,
.unavailable {
    color: #ef4444;
}

/* ============================================
   SECTION HEADERS
   ============================================ */
.section-header,
.section-title,
.block-title {
    text-align: center;
    margin: 3rem 0 2rem;
}

.section-header h2,
.section-title h2,
.block-title h2 {
    font-size: 2.25rem;
    margin-bottom: 0.5rem;
}

.section-header p,
.section-subtitle {
    color: var(--tds-text-muted);
    font-style: italic;
}

/* ============================================
   FOOTER
   ============================================ */
footer,
.footer,
.site-footer,
#footer {
    background-color: #1a1a1a !important;
    color: white;
    padding: 4rem 2rem 2rem;
}

footer h4,
footer h5,
.footer h4,
.footer-heading {
    font-family: 'Playfair Display', serif !important;
    color: white !important;
    margin-bottom: 1.5rem;
    font-size: 1rem;
}

footer p,
footer a,
footer li,
.footer p,
.footer a {
    color: #999 !important;
    font-size: 0.9rem;
    line-height: 2;
    text-decoration: none;
}

footer a:hover,
.footer a:hover {
    color: white !important;
}

.footer-social a,
.social-icons a,
footer .social a {
    color: #999;
    font-size: 1.2rem;
    margin-right: 1rem;
    transition: var(--tds-transition);
}

.footer-social a:hover,
.social-icons a:hover,
footer .social a:hover {
    color: white !important;
}

.footer-bottom,
.copyright {
    border-top: 1px solid #333;
    margin-top: 3rem;
    padding-top: 1.5rem;
    text-align: center;
    font-size: 0.8rem;
    color: #666 !important;
}

/* ============================================
   CART & CHECKOUT ELEMENTS
   ============================================ */
.cart-item,
.line-item {
    border-bottom: 1px solid var(--tds-border-color);
    padding: 1.5rem 0;
}

.cart-total,
.order-total {
    font-size: 1.25rem;
    font-weight: 600;
}

/* ============================================
   BREADCRUMBS
   ============================================ */
.breadcrumbs,
.breadcrumb {
    font-size: 0.85rem;
    color: var(--tds-text-muted);
    margin-bottom: 1.5rem;
}

.breadcrumbs a,
.breadcrumb a {
    color: var(--tds-text-muted);
    text-decoration: none;
}

.breadcrumbs a:hover,
.breadcrumb a:hover {
    color: var(--tds-secondary-pink);
}

/* ============================================
   PAGINATION
   ============================================ */
.pagination,
.pager {
    display: flex;
    justify-content: center;
    gap: 0.5rem;
    margin: 3rem 0;
}

.pagination a,
.pagination span,
.pager a,
.pager span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    height: 40px;
    padding: 0 12px;
    border: 1px solid var(--tds-border-color);
    border-radius: var(--tds-radius);
    text-decoration: none;
    color: var(--tds-text-main);
    transition: var(--tds-transition);
}

.pagination a:hover,
.pager a:hover {
    border-color: var(--tds-text-main);
}

.pagination .active,
.pagination .current,
.pager .active {
    background: var(--tds-text-main);
    color: white;
    border-color: var(--tds-text-main);
}

/* ============================================
   SEARCH
   ============================================ */
.search-form input,
.search-input,
input[type="search"] {
    border-radius: var(--tds-radius) !important;
}

/* ============================================
   ACCOUNT PAGES
   ============================================ */
.account-page,
.login-page {
    background: var(--tds-bg-light);
}

.login-form,
.account-form,
.register-form {
    background: white;
    padding: 2.5rem;
    border-radius: var(--tds-radius);
    box-shadow: 0 4px 20px rgba(0,0,0,0.08);
    max-width: 450px;
    margin: 2rem auto;
}

/* ============================================
   ANIMATIONS
   ============================================ */
/* Hover lift for cards */
.hover-lift {
    transition: var(--tds-transition);
}

.hover-lift:hover {
    transform: translateY(-8px);
    box-shadow: 0 20px 40px rgba(203, 143, 161, 0.2);
}

/* Fade in animation */
@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.fade-in {
    animation: fadeInUp 0.6s ease forwards;
}

/* ============================================
   UTILITY CLASSES
   ============================================ */
.text-gold {
    color: var(--tds-accent-gold) !important;
}

.text-pink {
    color: var(--tds-secondary-pink) !important;
}

.bg-pink {
    background-color: var(--tds-primary-pink) !important;
}

.bg-light {
    background-color: var(--tds-bg-light) !important;
}

/* ============================================
   RESPONSIVE ADJUSTMENTS
   ============================================ */
@media (max-width: 768px) {
    h1, .hero h1, .banner h1 {
        font-size: 2rem !important;
    }
    
    h2, .section-header h2 {
        font-size: 1.75rem !important;
    }
    
    .btn,
    .btn-primary,
    .button {
        padding: 12px 24px;
        font-size: 0.8rem;
    }
    
    footer,
    .footer {
        padding: 3rem 1.5rem 1.5rem;
    }
}

.social-share,
.social-sharing,
.share-buttons,
.product-share,
[class*="social-share"],
[class*="share-button"],
.addthis_toolbox,
a[href*="twitter.com/share"],
a[href*="facebook.com/share"],
a[href*="pinterest.com/pin"] {
    display: none !important;
}

/* Hide price slider */
.slider--multi-value,
.js-slider,
.slider--multi-value.js-slider,
div.slider {
    display: none !important;
}

/* Hide the whole price filter section including the $0 - $200 text */
.accordion__item:has(.slider--multi-value),
.accordion_item:has(.slider),
li:has(.slider--multi-value) {
    display: none !important;
}

.bg-contrast-lower,
.bg-contrast-low,
.bg-contrast-medium,
.bg-contrast-high,
[class*="bg-contrast"] {
    background-color: transparent !important;
}

/* Also remove the ::before pseudo-element overlay if present */
.hero::before,
section.hero::before,
[class*="bg-contrast"]::before {
    display: none !important;
    background: none !important;
}

/* Make hero slideshow text black */
.hero-slideshow__label,
.hero-slideshow__title,
.hero-slideshow__tite,
.hero-slideshow h2,
.hero-slideshow p,
.hero-slideshow span,
[class*="hero-slideshow"] h2,
[class*="hero-slideshow"] p,
[class*="hero-slideshow"] span {
    color: var(--tds-text-main) !important;
}
