/**
 * Josetta Saffirio - Design System
 * Implementazione completa del design system per il CRM
 * Version: 1.0.0
 */

/* Color Palette */
:root {
    --beige: #EAE5D9;
    --gold: #A39067;
    --white: #FFFFFF;
    --dark: #333333;
    --transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Typography */
body {
    font-family: 'Inter', sans-serif;
    color: var(--dark);
    font-weight: 400;
    line-height: 1.6;
}

h1, h2, h3, h4, h5, h6 {
    font-family: 'Playfair Display', serif;
    font-weight: 700;
    color: var(--dark);
}

.section-title {
    font-size: 2.5rem;
    margin-bottom: 1.5rem;
    position: relative;
}

/* Layout & Spacing */
.container {
    padding: 0 2rem;
    max-width: 1400px;
    margin: 0 auto;
}

.section {
    padding: 6rem 0;
}

/* Cards & Containers */
.card {
    background: var(--white);
    border: 1px solid var(--beige);
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
    transition: var(--transition);
}

.card:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
}

/* Buttons */
.btn {
    font-family: 'Montserrat', sans-serif;
    font-weight: 500;
    padding: 0.8rem 2rem;
    border-radius: 6px;
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 1px;
    transition: var(--transition);
    display: inline-block;
    border: none;
    cursor: pointer;
}

.btn-primary {
    background-color: var(--gold);
    color: var(--white);
}

.btn-primary:hover {
    background-color: var(--dark);
    transform: translateY(-2px);
}

.btn-outline {
    background-color: transparent;
    border: 1px solid var(--gold);
    color: var(--gold);
}

.btn-outline:hover {
    background-color: var(--gold);
    color: var(--white);
    transform: translateY(-2px);
}

/* Hero Section Overrides */
.hero {
    background-attachment: scroll; /* Better mobile compatibility */
}

.hero::before {
    background: radial-gradient(circle at center, rgba(0, 0, 0, 0.4) 0%, rgba(0, 0, 0, 0.7) 100%);
}

.hero h1 {
    font-family: 'Playfair Display', serif;
    font-weight: 700;
}

.hero-description p {
    font-family: 'Inter', sans-serif;
    font-weight: 400;
}

.hero-button {
    font-family: 'Montserrat', sans-serif;
    background-color: var(--gold);
    border: none;
    color: var(--white);
    padding: 1rem 2.5rem;
    border-radius: 6px;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
}

.hero-button:hover {
    background-color: var(--dark);
    transform: translateY(-2px);
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
}

/* Benefits Section Overrides */
.wine-club-benefits {
    background-color: var(--white);
    color: var(--dark);
    padding: 6rem 0;
    border-top: 1px solid var(--beige);
    border-bottom: 1px solid var(--beige);
}

.benefits-title {
    color: var(--dark);
    font-family: 'Playfair Display', serif;
    font-weight: 700;
}

.benefits-intro {
    color: var(--dark);
    font-family: 'Inter', sans-serif;
    font-weight: 400;
    opacity: 0.8;
}

.benefit-content {
    background-color: var(--white);
    border: 1px solid var(--beige);
    border-radius: 8px;
    padding: 2rem;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
}

.benefit-content h3 {
    color: var(--gold);
    font-family: 'Playfair Display', serif;
    font-weight: 600;
}

.benefit-content p {
    color: var(--dark);
    font-family: 'Inter', sans-serif;
    font-weight: 400;
    opacity: 0.8;
}

.benefit-item:hover .benefit-content {
    border-color: var(--gold);
    transform: translateY(-5px);
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
}

.benefits-button {
    font-family: 'Montserrat', sans-serif;
    background-color: var(--gold);
    color: var(--white);
    border: none;
    border-radius: 6px;
    padding: 0.8rem 2rem;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
}

.benefits-button:hover {
    background-color: var(--dark);
    color: var(--white);
    transform: translateY(-2px);
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
}

/* Subscription Section Overrides */
.subscription-section {
    background-attachment: scroll; /* Better mobile compatibility */
    padding: 6rem 0;
}

.subscription-section::before {
    background: linear-gradient(to bottom, rgba(0,0,0,0.8) 0%, rgba(0,0,0,0.6) 50%, rgba(0,0,0,0.8) 100%);
}

.subscription-title {
    font-family: 'Playfair Display', serif;
    font-weight: 700;
}

.subscription-box {
    border-radius: 8px;
    border: 1px solid rgba(255, 255, 255, 0.2);
}

.subscription-box.featured {
    border: 1px solid var(--gold);
}

.subscription-button {
    font-family: 'Montserrat', sans-serif;
    background-color: var(--gold);
    color: var(--white);
    border: none;
    border-radius: 6px;
    padding: 1rem 2.5rem;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
}

.subscription-button:hover {
    background-color: var(--dark);
    color: var(--white);
    transform: translateY(-2px);
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.2);
}

/* Adotta Filare Section */
.adotta-section {
    position: relative;
}

.adotta-button {
    font-family: 'Montserrat', sans-serif;
    background-color: var(--gold);
    color: var(--white);
    border: none;
    border-radius: 6px;
    padding: 1rem 2.5rem;
    transition: var(--transition);
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.adotta-button:hover {
    background-color: var(--dark);
    transform: translateY(-2px);
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.2);
}

/* Events Section */
.events-section {
    padding: 6rem 0;
    background-color: var(--white);
}

.events-title {
    font-family: 'Playfair Display', serif;
    font-weight: 700;
    color: var(--dark);
}

.events-subtitle {
    font-family: 'Inter', sans-serif;
    color: var(--dark);
    opacity: 0.8;
}

.featured-event {
    border: 1px solid var(--beige);
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
    background-color: var(--white);
}

.featured-event-content {
    padding: 2rem;
}

.featured-event-title {
    color: var(--dark);
    font-family: 'Playfair Display', serif;
    font-weight: 700;
}

.featured-label {
    background-color: var(--gold);
    color: var(--white);
    padding: 0.3rem 1rem;
    border-radius: 4px;
    font-family: 'Montserrat', sans-serif;
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.event-card {
    border: 1px solid var(--beige);
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
    transition: var(--transition);
    background-color: var(--white);
}

.event-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
}

.event-card-content {
    padding: 1.5rem;
}

.event-card-title {
    font-family: 'Playfair Display', serif;
    font-weight: 700;
    color: var(--dark);
}

.events-button {
    font-family: 'Montserrat', sans-serif;
    background-color: var(--gold);
    color: var(--white);
    border: none;
    border-radius: 6px;
    padding: 0.8rem 2rem;
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 1px;
    transition: var(--transition);
    display: inline-block;
}

.events-button:hover {
    background-color: var(--dark);
    transform: translateY(-2px);
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
}

/* Responsive Adjustments */
@media (max-width: 992px) {
    .section {
        padding: 4rem 0;
    }
    
    .section-title {
        font-size: 2rem;
    }
}

@media (max-width: 768px) {
    .section {
        padding: 3rem 0;
    }
    
    .section-title {
        font-size: 1.8rem;
    }
    
    .btn {
        padding: 0.7rem 1.5rem;
    }
}

@media (max-width: 480px) {
    .container {
        padding: 0 1rem;
    }
    
    .section {
        padding: 2rem 0;
    }
}