/*
Theme Name: RG Store v5.0.0
Theme URI: https://digitaltecnologiar.com
Author: Digital Tecnología RG
Author URI: https://digitaltecnologiar.com
Description: Tema Premium SaaS con Glassmorphism, Bento Grid y Handshake Protocol para el ecosistema Digital Tecnología RG. Basado en especificaciones .windsurfdiseño.
Version: 5.0.0
License: MIT
License URI: https://opensource.org/licenses/MIT
Text Domain: rg-store
Domain Path: /languages
Tags: glassmorphism, bento-grid, saas, whatsapp-bot, pos, reservations

RG Store v5.0.0 - Premium Fluid Design System
==========================================================

Este tema implementa:
- Handshake Protocol (validación de licencias con Panel RG)
- Sistema de Diseño con Variables CSS Nativas
- Bento Grid Layout para features
- Animaciones de scroll y micro-interacciones
- Control de planes (Emprendedor, Profesional, Business, Enterprise)
- Integración con Bot Engine WhatsApp (Baileys)
- Conexión con Backend Cerebro (FastAPI)

Arquitectura: Modular Core-Plugins (Center + Nodes)
Basado en: .windsurfdiseño specifications
*/

/* ═══════════════════════════════════════════════════════════════════════════════
   THEME STYLES - RG STORE
   ═══════════════════════════════════════════════════════════════════════════════ */

/* Variables CSS nativas según .windsurfdiseño */
:root {
    /* Colores Primarios */
    --color-primary: #2563EB;
    --color-primary-light: #3b82f6;
    --color-primary-dark: #1d4ed8;
    
    /* Colores de Acento */
    --color-emerald: #10b981;
    --color-emerald-light: #34d399;
    --color-emerald-dark: #059669;
    
    --color-purple: #8b5cf6;
    --color-purple-light: #a78bfa;
    --color-purple-dark: #7c3aed;
    
    --color-amber: #f59e0b;
    --color-amber-light: #fbbf24;
    --color-amber-dark: #d97706;
    
    /* Colores de Fondo (Dark Theme) */
    --color-bg-primary: #0A1628;
    --color-bg-secondary: #0B1120;
    --color-bg-tertiary: #020617;
    
    /* Colores de Texto */
    --color-text-primary: #f8fafc;
    --color-text-secondary: #e2e8f0;
    --color-text-muted: #94a3b8;
    
    /* Bordes */
    --color-border: rgba(255, 255, 255, 0.1);
    --color-border-light: rgba(255, 255, 255, 0.05);
    
    /* Sombras */
    --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.3);
    --shadow-md: 0 4px 6px rgba(0, 0, 0, 0.3);
    --shadow-lg: 0 10px 15px rgba(0, 0, 0, 0.3);
    
    /* Radios */
    --radius-sm: 8px;
    --radius-md: 12px;
    --radius-lg: 16px;
    --radius-xl: 24px;
    
    /* Espaciado */
    --spacing-xs: 4px;
    --spacing-sm: 8px;
    --spacing-md: 16px;
    --spacing-lg: 24px;
    --spacing-xl: 32px;
    --spacing-2xl: 48px;
    
    /* Transiciones */
    --transition-fast: 0.15s ease;
    --transition-base: 0.2s ease;
    --transition-slow: 0.3s ease;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   WORDPRESS SPECIFIC OVERRIDES
   ═══════════════════════════════════════════════════════════════════════════════ */

/* Admin bar compensation */
body.admin-bar .dtrg-header {
    top: 32px;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   WOOCOMMERCE CHECKOUT - Mejora completa de legibilidad
   ═══════════════════════════════════════════════════════════════════════════════ */

/* Fondo del checkout */
.woocommerce-checkout {
    background: #ffffff !important;
    padding: 20px !important;
    border-radius: 12px !important;
    margin: 0 !important;
}

/* Eliminar espacios en blanco del checkout */
.woocommerce-checkout .woocommerce,
.woocommerce-checkout .woocommerce-billing-fields,
.woocommerce-checkout .woocommerce-shipping-fields,
.woocommerce-checkout .woocommerce-additional-fields,
.woocommerce-checkout .col2-set,
.woocommerce-checkout .col-1,
.woocommerce-checkout .col-2 {
    margin: 0 !important;
    padding: 0 !important;
}

.woocommerce-checkout .woocommerce-form-row,
.woocommerce-checkout .form-row {
    margin-bottom: 15px !important;
}

.woocommerce-checkout h3 {
    margin-top: 20px !important;
    margin-bottom: 15px !important;
}

/* Títulos de secciones */
.woocommerce-checkout h3,
.woocommerce-checkout .woocommerce-billing-fields h3,
.woocommerce-checkout .woocommerce-shipping-fields h3,
.woocommerce-checkout .woocommerce-additional-fields h3 {
    font-size: 20px !important;
    font-weight: 700 !important;
    color: #0f172a !important;
    margin-bottom: 20px !important;
    padding-bottom: 12px !important;
    border-bottom: 2px solid #e2e8f0 !important;
}

/* Labels - Negrilla y legibles */
.woocommerce-checkout .woocommerce-billing-fields label,
.woocommerce-checkout .woocommerce-shipping-fields label,
.woocommerce-checkout .woocommerce-additional-fields label,
.woocommerce-checkout .form-row label,
.woocommerce-checkout .woocommerce-form__label {
    font-weight: 700 !important;
    color: #0f172a !important;
    font-size: 14px !important;
    margin-bottom: 8px !important;
    display: block !important;
}

/* Placeholders - Texto dentro de los campos (selectores más específicos) */
.woocommerce-checkout .woocommerce-billing-fields .form-row input::placeholder,
.woocommerce-checkout .woocommerce-shipping-fields .form-row input::placeholder,
.woocommerce-checkout .woocommerce-additional-fields .form-row input::placeholder,
.woocommerce-checkout .form-row input::placeholder,
.woocommerce-checkout .woocommerce-billing-fields .form-row textarea::placeholder,
.woocommerce-checkout .woocommerce-shipping-fields .form-row textarea::placeholder,
.woocommerce-checkout .woocommerce-additional-fields .form-row textarea::placeholder,
.woocommerce-checkout .form-row textarea::placeholder,
.woocommerce-checkout #billing_first_name::placeholder,
.woocommerce-checkout #billing_last_name::placeholder,
.woocommerce-checkout #billing_email::placeholder,
.woocommerce-checkout #billing_phone::placeholder,
.woocommerce-checkout #billing_address_1::placeholder,
.woocommerce-checkout #billing_city::placeholder,
.woocommerce-checkout #billing_postcode::placeholder,
.woocommerce-checkout #billing_country::placeholder,
.woocommerce-checkout #billing_state::placeholder,
.woocommerce-checkout input[type="text"]::placeholder,
.woocommerce-checkout input[type="email"]::placeholder,
.woocommerce-checkout input[type="tel"]::placeholder {
    color: #1e293b !important;
    font-weight: 700 !important;
    font-size: 15px !important;
    opacity: 1 !important;
}

/* Placeholder en select (opciones) */
.woocommerce-checkout .form-row select option,
.woocommerce-checkout select option {
    color: #0f172a !important;
    font-weight: 600 !important;
    font-size: 15px !important;
}

/* Texto dentro de los inputs cuando tienen valor */
.woocommerce-checkout .woocommerce-billing-fields .form-row input[type="text"],
.woocommerce-checkout .woocommerce-shipping-fields .form-row input[type="text"],
.woocommerce-checkout .woocommerce-additional-fields .form-row input[type="text"],
.woocommerce-checkout .form-row input[type="text"],
.woocommerce-checkout .woocommerce-billing-fields .form-row input[type="email"],
.woocommerce-checkout .woocommerce-shipping-fields .form-row input[type="email"],
.woocommerce-checkout .woocommerce-additional-fields .form-row input[type="email"],
.woocommerce-checkout .form-row input[type="email"],
.woocommerce-checkout .woocommerce-billing-fields .form-row input[type="tel"],
.woocommerce-checkout .woocommerce-shipping-fields .form-row input[type="tel"],
.woocommerce-checkout .woocommerce-additional-fields .form-row input[type="tel"],
.woocommerce-checkout .form-row input[type="tel"],
.woocommerce-checkout .woocommerce-billing-fields .form-row input[type="password"],
.woocommerce-checkout .woocommerce-shipping-fields .form-row input[type="password"],
.woocommerce-checkout .woocommerce-additional-fields .form-row input[type="password"],
.woocommerce-checkout .form-row input[type="password"],
.woocommerce-checkout .woocommerce-billing-fields .form-row select,
.woocommerce-checkout .woocommerce-shipping-fields .form-row select,
.woocommerce-checkout .woocommerce-additional-fields .form-row select,
.woocommerce-checkout .form-row select,
.woocommerce-checkout .woocommerce-billing-fields .form-row textarea,
.woocommerce-checkout .woocommerce-shipping-fields .form-row textarea,
.woocommerce-checkout .woocommerce-additional-fields .form-row textarea,
.woocommerce-checkout .form-row textarea {
    color: #0f172a !important;
    font-weight: 600 !important;
    font-size: 15px !important;
}

/* Inputs - Mejor visibilidad */
.woocommerce-checkout .form-row input[type="text"],
.woocommerce-checkout .form-row input[type="email"],
.woocommerce-checkout .form-row input[type="tel"],
.woocommerce-checkout .form-row input[type="password"],
.woocommerce-checkout .form-row select,
.woocommerce-checkout .form-row textarea {
    padding: 12px 16px !important;
    border: 2px solid #cbd5e1 !important;
    border-radius: 8px !important;
    font-size: 15px !important;
    color: #0f172a !important;
    background: #ffffff !important;
    transition: all 0.2s ease !important;
    width: 100% !important;
}

/* Focus en inputs */
.woocommerce-checkout .form-row input:focus,
.woocommerce-checkout .form-row select:focus,
.woocommerce-checkout .form-row textarea:focus {
    border-color: #2563EB !important;
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1) !important;
    background: #f8fafc !important;
}

/* Campos requeridos */
.woocommerce-checkout .form-row .required {
    color: #ef4444 !important;
    font-weight: 700 !important;
}

/* Botones de checkout */
.woocommerce-checkout button.button,
.woocommerce-checkout #place_order {
    background: #2563EB !important;
    color: #ffffff !important;
    font-weight: 700 !important;
    font-size: 16px !important;
    padding: 14px 32px !important;
    border-radius: 8px !important;
    border: none !important;
    transition: all 0.2s ease !important;
}

.woocommerce-checkout button.button:hover,
.woocommerce-checkout #place_order:hover {
    background: #1d4ed8 !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 12px rgba(37, 99, 235, 0.3) !important;
}

/* Mensajes de error */
.woocommerce-checkout .woocommerce-error,
.woocommerce-checkout .woocommerce-info,
.woocommerce-checkout .woocommerce-message {
    padding: 16px !important;
    border-radius: 8px !important;
    font-size: 14px !important;
    font-weight: 500 !important;
}

@media screen and (max-width: 782px) {
    body.admin-bar .dtrg-header {
        top: 46px;
    }
}

/* WordPress alignments */
.alignleft {
    float: left;
    margin-right: 1.5rem;
}

.alignright {
    float: right;
    margin-left: 1.5rem;
}

.aligncenter {
    clear: both;
    display: block;
    margin-left: auto;
    margin-right: auto;
}

/* WordPress gallery */
.gallery {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.gallery-item {
    margin: 0;
}

.gallery-icon img {
    width: 100%;
    height: auto;
    border-radius: 0.75rem;
}

/* WordPress captions */
.wp-caption {
    max-width: 100%;
    margin-bottom: 1.5rem;
}

.wp-caption-text {
    font-size: 0.875rem;
    color: rgba(255, 255, 255, 0.6);
    text-align: center;
    margin-top: 0.5rem;
}

/* WordPress blockquotes */
blockquote.wp-block-quote {
    border-left: 4px solid #6366F1;
    padding-left: 1.5rem;
    margin: 1.5rem 0;
    font-style: italic;
    color: rgba(255, 255, 255, 0.8);
}

/* WordPress tables */
.wp-block-table table {
    width: 100%;
    border-collapse: collapse;
}

.wp-block-table th,
.wp-block-table td {
    padding: 0.75rem;
    border: 1px solid rgba(255, 255, 255, 0.1);
    text-align: left;
}

.wp-block-table th {
    background: rgba(255, 255, 255, 0.05);
    font-weight: 600;
}

/* WordPress forms */
.wp-block-search__input {
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 0.75rem;
    padding: 0.75rem 1rem;
    color: white;
}

.wp-block-search__button {
    background: linear-gradient(135deg, #6366F1 0%, #8B5CF6 100%);
    color: white;
    border: none;
    border-radius: 0.75rem;
    padding: 0.75rem 1.5rem;
    cursor: pointer;
    transition: all 0.3s ease;
}

.wp-block-search__button:hover {
    box-shadow: 0 4px 20px rgba(99, 102, 241, 0.4);
}

/* ═══════════════════════════════════════════════════════════════════════════════
   ANIMATION KEYFRAMES (Fallback)
   ═══════════════════════════════════════════════════════════════════════════════ */

@keyframes fadeIn {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(30px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes slideIn {
    from {
        transform: translateX(100%);
        opacity: 0;
    }
    to {
        transform: translateX(0);
        opacity: 1;
    }
}

@keyframes scaleIn {
    from {
        transform: scale(0.9);
        opacity: 0;
    }
    to {
        transform: scale(1);
        opacity: 1;
    }
}

@keyframes pulseGlow {
    0%, 100% {
        box-shadow: 0 0 20px rgba(99, 102, 241, 0.3);
    }
    50% {
        box-shadow: 0 0 40px rgba(99, 102, 241, 0.6);
    }
}

@keyframes float {
    0%, 100% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-20px);
    }
}

@keyframes shimmer {
    0% {
        background-position: -200% 0;
    }
    100% {
        background-position: 200% 0;
    }
}

@keyframes bounce {
    0%, 100% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-10px);
    }
}

/* ═══════════════════════════════════════════════════════════════════════════════
   PRINT STYLES
   ═══════════════════════════════════════════════════════════════════════════════ */

@media print {
    .dtrg-header,
    .dtrg-btn,
    .dtrg-btn-outline,
    .fixed {
        display: none !important;
    }
    
    body {
        background: white !important;
        color: black !important;
    }
    
    .dtrg-card {
        background: white !important;
        border: 1px solid #ddd !important;
        box-shadow: none !important;
    }
}
