/**
 * Unified Button System
 * All buttons in the theme use these consistent styles
 * Includes support for primary, secondary, outline, and custom button types
 * 
 * Button Classes:
 * - .tc-btn: Base button class
 * - .tc-btn--primary: Main CTA button (gold/coral background)
 * - .tc-btn--secondary: Alternative CTA (light background)
 * - .tc-btn--outline: Transparent with border
 * - .tc-btn--large: Larger button for hero sections
 * - .tc-btn--small: Compact button for cards
 * 
 * @package TablyClub
 */

/* ========== BASE BUTTON ========== */
.tc-btn,
.tc-hero-btn,
.tc-btn-view,
.tc-btn-booking,
.tc-footer-subscribe-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.875rem 1.75rem;
    font-family: var(--tc-font-body);
    font-size: 1rem;
    font-weight: 600;
    line-height: 1.5;
    text-decoration: none;
    text-align: center;
    border: 2px solid transparent;
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.3s ease;
    white-space: nowrap;
}

/* ========== PRIMARY BUTTON (Main CTA) ========== */
.tc-btn--primary,
.tc-hero-btn--primary,
.tc-btn.tc-btn--primary {
    background-color: var(--tc-color-3);
    color: var(--tc-color-1);
    border-color: var(--tc-color-3);
}

.tc-btn--primary:hover,
.tc-hero-btn--primary:hover {
    background-color: var(--tc-color-2);
    color: var(--tc-color-1);
    border-color: var(--tc-color-2);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

/* ========== SECONDARY BUTTON (Alternative CTA) ========== */
.tc-btn--secondary,
.tc-hero-btn--secondary,
.tc-btn.tc-btn--secondary {
    background-color: var(--tc-color-1);
    color: var(--tc-color-2);
    border-color: var(--tc-color-2);
}

.tc-btn--secondary:hover,
.tc-hero-btn--secondary:hover {
    background-color: var(--tc-color-2);
    color: var(--tc-color-1);
    border-color: var(--tc-color-2);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

/* ========== OUTLINE BUTTON (Subtle CTA) ========== */
.tc-btn--outline {
    background-color: transparent;
    color: var(--tc-color-2);
    border-color: var(--tc-color-2);
}

.tc-btn--outline:hover {
    background-color: var(--tc-color-2);
    color: var(--tc-color-1);
    transform: translateY(-2px);
}

/* ========== LARGE BUTTON ========== */
.tc-btn--large {
    padding: 1.125rem 2.5rem;
    font-size: 1.125rem;
}

/* ========== SMALL BUTTON ========== */
.tc-btn--small {
    padding: 0.625rem 1.25rem;
    font-size: 0.875rem;
}

/* ========== BUTTON ICONS ========== */
.tc-btn-icon {
    font-size: 1.25em;
    transition: transform 0.3s ease;
}

.tc-btn:hover .tc-btn-icon,
.tc-hero-btn:hover .tc-btn-icon {
    transform: translateX(3px);
}

/* ========== SPECIFIC BUTTON TYPES ========== */

/* View/Details Button (Archive pages) */
.tc-btn-view {
    background-color: var(--tc-color-3);
    color: var(--tc-color-1);
    border-color: var(--tc-color-3);
}

.tc-btn-view:hover {
    background-color: var(--tc-color-2);
    color: var(--tc-color-1);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

/* Booking Button (Forms) */
.tc-btn-booking {
    width: 100%;
    padding: 1rem;
    background-color: var(--tc-color-3);
    color: var(--tc-color-1);
    border: 2px solid var(--tc-color-3);
    font-size: 1.125rem;
    font-weight: 600;
    cursor: pointer;
}

.tc-btn-booking:hover {
    background-color: var(--tc-color-2);
    border-color: var(--tc-color-2);
    transform: translateY(-2px);
    box-shadow: 0 5px 15px rgba(0,0,0,0.2);
}

.tc-btn-booking:disabled {
    opacity: 0.6;
    cursor: not-allowed;
    transform: none;
}

/* ========== BUTTON HOVER TEXT ========== */
/* Buttons with data-hover-text attribute will swap text on hover */
.tc-btn[data-hover-text],
.tc-hero-btn[data-hover-text],
.tc-footer-subscribe-btn[data-hover-text] {
    position: relative;
    overflow: hidden;
}

.tc-btn[data-hover-text] .tc-btn-text,
.tc-hero-btn[data-hover-text] .tc-btn-text,
.tc-footer-subscribe-btn[data-hover-text] .tc-btn-text {
    transition: transform 0.3s ease, opacity 0.3s ease;
    display: inline-block;
}

.tc-btn[data-hover-text]:hover .tc-btn-text,
.tc-hero-btn[data-hover-text]:hover .tc-btn-text,
.tc-footer-subscribe-btn[data-hover-text]:hover .tc-btn-text {
    transform: translateY(-100%);
    opacity: 0;
}

.tc-btn[data-hover-text]::after,
.tc-hero-btn[data-hover-text]::after,
.tc-footer-subscribe-btn[data-hover-text]::after {
    content: attr(data-hover-text);
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    transition: transform 0.3s ease, opacity 0.3s ease;
    opacity: 0;
    white-space: nowrap;
}

.tc-btn[data-hover-text]:hover::after,
.tc-hero-btn[data-hover-text]:hover::after,
.tc-footer-subscribe-btn[data-hover-text]:hover::after {
    transform: translateX(-50%) translateY(-100%);
    opacity: 1;
}

/* ========== BUTTON STATES ========== */
.tc-btn:disabled,
.tc-hero-btn:disabled {
    opacity: 0.6;
    cursor: not-allowed;
    pointer-events: none;
}

.tc-btn:focus,
.tc-hero-btn:focus {
    outline: 3px solid var(--tc-color-3);
    outline-offset: 2px;
}

/* ========== RESPONSIVE ========== */
@media (max-width: 768px) {
    .tc-btn,
    .tc-hero-btn {
        padding: 0.75rem 1.5rem;
        font-size: 0.9375rem;
    }
    
    .tc-btn--large {
        padding: 1rem 2rem;
        font-size: 1rem;
    }
}

@media (max-width: 480px) {
    .tc-btn,
    .tc-hero-btn {
        width: 100%;
        justify-content: center;
    }
}
