/* =========================================
   ETHNOSKIN LANDING PAGE - COMPLETE STYLES
   Adapted for WordPress + Astra Theme
   ========================================= */

/* =========================================
   CSS VARIABLES
   ========================================= */


:root {
    --es-bronze: #735536;
    --es-bronze-light: #C4A77D;
    --es-bronze-fade: rgba(115, 85, 54, 0.1);
    --es-dark: #1a1410 !important;
    --es-dark-muted: #3D322A;
    --es-bg: #FAFAF8;
    --es-white: #ffffff;
}


/* =========================================
   RESET ASTRA THEME CONFLICTS
   ========================================= */
.es-landing-page *,
.es-landing-page *::before,
.es-landing-page *::after {
    box-sizing: border-box !important;
}

.es-landing-page {
    max-width: none !important;
    margin: 0 !important;
    padding: 0 !important;
    width: 100% !important;
}

.es-landing-page .site-main {
    max-width: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

.es-landing-page .entry-content {
    margin: 0 !important;
    padding: 0 !important;
}

/* Kill Astra Typography Overrides - BUT ONLY FOR HEADINGS */
.es-landing-page h1,
.es-landing-page h2,
.es-landing-page h3,
.es-landing-page h4,
.es-landing-page h5,
.es-landing-page h6 {
    margin: 0 !important;
    padding: 0 !important;
}

/* =========================================
   UTILITIES
   ========================================= */
.es-container {
    max-width: 1200px !important;
    margin: 0 auto !important;
    padding: 0 20px !important;
}

.es-text-center {
    text-align: center !important;
}

/* =========================================
   TYPOGRAPHY BASE
   ========================================= */
.es-section-label {
    font-size: 10px !important;
    font-weight: 500 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.1em !important;
    color: var(--es-bronze) !important;
    display: block !important;
    margin: 0 0 12px 0 !important;
}

.es-section-title {
 font-size: 1.875rem !important;
  font-weight: 300;
  letter-spacing: -0.025em;    font-weight: 300 !important;
    line-height: 1.2 !important;
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    color: var(--es-dark) !important;
}

.es-section-title span {
    color: var(--es-bronze) !important;
}

.es-section-subtitle {
    font-size: 16px !important;
    color: rgba(26, 20, 16, 0.6) !important;
    margin-top: 8px !important;
    margin-bottom: 0 !important;
    line-height: 1.6 !important;
}

/* =========================================
   ANIMATIONS
   ========================================= */
@keyframes esFadeInUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

[data-animate] {
    opacity: 1 !important;
}

[data-animate].es-visible {
    animation: esFadeInUp 0.6s ease-out forwards !important;
}

/* =========================================
   HERO SECTION - FULL WIDTH
   ========================================= */
.es-hero {
    position: relative !important;
    min-height: 90vh !important;
    overflow: hidden !important;
    width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
}

.es-hero-bg {
    position: absolute !important;
    inset: 0 !important;
    z-index: 1 !important;
}

.es-hero-bg img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
}

.es-hero-bg::after {
    content: '' !important;
    position: absolute !important;
    inset: 0 !important;
    background: linear-gradient(to right, rgba(26, 20, 16, 0.9), rgba(26, 20, 16, 0.7), transparent) !important;
    z-index: 2 !important;
}

.es-hero-content {
    position: relative !important;
    z-index: 10 !important;
    display: flex !important;
    align-items: center !important;
    min-height: 90vh !important;
    max-width: 1200px !important;
    margin: 0 auto !important;
    padding: 0 20px !important;
}

@media (min-width: 768px) {
    .es-hero-content {
        padding: 0 20px !important;
    }

}

@media (min-width: 1024px) {
    .es-hero-content {
        padding: 0 20px !important;
    }
}

.es-hero-content-inner {
    max-width: 740px !important;
}

.es-hero-badge {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 8px 16px !important;
    border-radius: 50px !important;
    background: rgba(255, 255, 255, 0.1) !important;
    backdrop-filter: blur(8px) !important;
    margin-bottom: 24px !important;
}

.es-hero-badge-dot {
    width: 6px !important;
    height: 6px !important;
    border-radius: 50% !important;
    background: var(--es-bronze-light) !important;
}

.es-hero-badge-text {
    font-size: 11px !important;
    font-weight: 500 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.1em !important;
    color: rgba(255, 255, 255, 0.8) !important;
    margin: 0 !important;
}

.es-hero-title {
    font-size: clamp(34px, 8vw, 72px) !important;
    font-weight: 300 !important;
    line-height: 1.1 !important;
    letter-spacing: -0.02em !important;
    color: white !important;
    margin: 0 !important;
}

.es-hero-title em {
    font-style: italic !important;
    color: var(--es-bronze-light) !important;
}

.es-hero-desc {
    max-width: 580px !important;
    margin-top: 24px !important;
    margin-bottom: 0 !important;
    font-size: 18px !important;
    line-height: 1.6 !important;
    color: rgba(255, 255, 255, 0.7) !important;
}

.es-hero-meta {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    gap: 32px !important;
    margin-top: 40px !important;
}

.es-hero-meta-item {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
}

.es-hero-meta-icon {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 40px !important;
    height: 40px !important;
    border-radius: 50% !important;
    background: rgba(255, 255, 255, 0.1) !important;
    flex-shrink: 0 !important;
}

.es-hero-meta-icon svg {
    width: 16px !important;
    height: 16px !important;
    color: var(--es-bronze-light) !important;
}

.es-hero-meta-label {
    font-size: 11px !important;
    color: rgba(255, 255, 255, 0.5) !important;
    display: block !important;
    margin: 0 !important;
}

.es-hero-meta-value {
    font-weight: 500 !important;
    color: white !important;
    display: block !important;
    margin: 0 !important;
}

.es-hero-ctas {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    gap: 16px !important;
    margin-top: 40px !important;
}

.es-btn-primary {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 16px 32px !important;
    border-radius: 12px !important;
    background: var(--es-bronze-light) !important;
    font-weight: 500 !important;
    color: var(--es-dark) !important;
    text-decoration: none !important;
    transition: all 0.2s !important;
    border: none !important;
}

.es-btn-primary:hover {
    background: #B8956A !important;
    transform: translateY(-1px) !important;
    color: var(--es-dark) !important;
}

.es-btn-primary svg {
    width: 16px !important;
    height: 16px !important;
    transition: transform 0.2s !important;
}

.es-btn-primary:hover svg {
    transform: translateX(4px) !important;
}

.es-btn-secondary {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 16px 32px !important;
    border-radius: 12px !important;
    border: 1px solid rgba(255, 255, 255, 0.2) !important;
    font-weight: 500 !important;
    color: white !important;
    text-decoration: none !important;
    transition: all 0.2s !important;
    background: transparent !important;
}

.es-btn-secondary:hover {
    border-color: rgba(255, 255, 255, 0.4) !important;
    background: rgba(255, 255, 255, 0.05) !important;
    color: white !important;
}

.es-hero-scroll {
    position: absolute !important;
    bottom: 32px !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    z-index: 10 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 8px !important;
}

.es-hero-scroll-text {
    font-size: 10px !important;
    letter-spacing: 0.1em !important;
    color: rgba(255, 255, 255, 0.4) !important;
}

.es-hero-scroll-line {
    width: 1px !important;
    height: 48px !important;
    background: linear-gradient(to bottom, rgba(255, 255, 255, 0.4), transparent) !important;
}

/* =========================================
   TRUST BAR - FULL WIDTH BACKGROUND
   ========================================= */
.es-trust-bar {
    background: linear-gradient(135deg, #2C231B, #3D322A, #2C231B) !important;
    width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
}

.es-trust-bar-inner {
    max-width: 1200px !important;
    margin: 0 auto !important;
    padding: 40px 20px !important;
}

@media (min-width: 768px) {
    .es-trust-bar-inner {
        padding: 48px 32px !important;
    }
}

.es-trust-bar-grid {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 16px !important;
}

@media (min-width: 768px) {
    .es-trust-bar-grid {
        gap: 32px !important;
    }
}

.es-trust-bar-item {
    text-align: center !important;
}

.es-trust-bar-value {
    font-size: clamp(24px, 5vw, 40px) !important;
    font-weight: 400 !important;
    letter-spacing: -0.02em !important;
    color: white !important;
    margin: 0 !important;
}

.es-trust-bar-label {
    margin-top: 4px !important;
    margin-bottom: 0 !important;
    font-size: 10px !important;
    line-height: 1.4 !important;
    color: rgba(255, 255, 255, 0.5) !important;
}

@media (min-width: 768px) {
    .es-trust-bar-label {
        margin-top: 8px !important;
        font-size: 12px !important;
    }
}

/* =========================================
   PROBLEM SECTION - FULL WIDTH BACKGROUND, 1200PX CONTENT
   ========================================= */
.es-problem-section {
    padding: 64px 0 !important;
    background: var(--es-bg) !important;
    width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
}

@media (min-width: 768px) {
    .es-problem-section {
        padding: 96px 0 !important;
    }
}

.es-problem-grid {
    max-width: 1200px !important;
    margin: 0 auto !important;
    padding: 0 20px !important;
    display: grid !important;
    gap: 32px !important;
    align-items: start !important;
}

@media (min-width: 1024px) {
    .es-problem-grid {
        grid-template-columns: 1fr 1fr !important;
        gap: 48px !important;
    }
}

.es-problem-header {
    position: relative !important;
}

@media (min-width: 1024px) {
    .es-problem-header {
        position: sticky !important;
        top: 128px !important;
    }
}

.es-problem-desc {
    max-width: 400px !important;
    margin-top: 12px !important;
    margin-bottom: 0 !important;
    font-size: 16px !important;
    line-height: 1.6 !important;
    color: rgba(26, 20, 16, 0.6) !important;
}

.es-problem-cards {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
}

.es-problem-card {
    position: relative !important;
    overflow: hidden !important;
    padding: 20px !important;
    border-radius: 12px !important;
    background: white !important;
    transition: box-shadow 0.3s, transform 0.3s !important;
}

@media (min-width: 768px) {
    .es-problem-card {
        padding: 24px !important;
    }
}

.es-problem-card:hover {
    box-shadow: 0 8px 30px -12px rgba(115, 85, 54, 0.12) !important;
    transform: translateY(-2px) !important;
}

.es-problem-card::before {
    content: '' !important;
    position: absolute !important;
    left: 0 !important;
    top: 0 !important;
    width: 2px !important;
    height: 100% !important;
    background: var(--es-bronze) !important;
    transform: scaleY(0) !important;
    transform-origin: top !important;
    transition: transform 0.3s !important;
}

.es-problem-card:hover::before {
    transform: scaleY(1) !important;
}

.es-problem-card-inner {
    display: flex !important;
    align-items: flex-start !important;
    gap: 16px !important;
}

.es-problem-card-number {
    font-size: 24px !important;
    font-weight: 400 !important;
    color: rgba(115, 85, 54, 0.2) !important;
    flex-shrink: 0 !important;
}

@media (min-width: 768px) {
    .es-problem-card-number {
        font-size: 28px !important;
    }
}

.es-problem-card-content {
    transition: transform 0.3s !important;
}

.es-problem-card:hover .es-problem-card-content {
    transform: translateX(4px) !important;
}

.es-problem-card-title {
    font-size: 16px !important;
    font-weight: 400 !important;
    color: var(--es-dark) !important;
    margin: 0 !important;
}

@media (min-width: 768px) {
    .es-problem-card-title {
        font-size: 22px !important;
    }
}

.es-problem-card-desc {
    margin-top: 4px !important;
    margin-bottom: 0 !important;
    font-size: 12px !important;
    line-height: 1.5 !important;
    color: rgba(26, 20, 16, 0.6) !important;
}

@media (min-width: 768px) {
    .es-problem-card-desc {
        font-size: 14px !important;
    }
}

/* =========================================
   SOLUTION SECTION - FULL WIDTH BACKGROUND, 1200PX CONTENT
   ========================================= */
.es-solution-section {
    position: relative !important;
    padding: 64px 0 !important;
    background: var(--es-dark) !important;
    overflow: hidden !important;
    width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
}

@media (min-width: 768px) {
    .es-solution-section {
        padding: 96px 0 !important;
    }
}

.es-solution-section::before {
    content: '' !important;
    position: absolute !important;
    inset: 0 !important;
    background: linear-gradient(135deg, rgba(115, 85, 54, 0.1), transparent) !important;
}

.es-solution-grid {
    position: relative !important;
    max-width: 1200px !important;
    margin: 0 auto !important;
    padding: 0 20px !important;
    display: grid !important;
    gap: 40px !important;
    align-items: center !important;
}

@media (min-width: 1024px) {
    .es-solution-grid {
        grid-template-columns: 1fr 1fr !important;
        gap: 48px !important;
    }
}

.es-solution-content {
    order: 2 !important;
}

@media (min-width: 1024px) {
    .es-solution-content {
        order: 1 !important;
    }
}

.es-solution-badge {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 6px 12px !important;
    border-radius: 50px !important;
    background: rgba(255, 255, 255, 0.1) !important;
    backdrop-filter: blur(8px) !important;
    margin-bottom: 16px !important;
}

.es-solution-badge-dot {
    width: 6px !important;
    height: 6px !important;
    border-radius: 50% !important;
    background: var(--es-bronze-light) !important;
}

.es-solution-badge-text {
    font-size: 10px !important;
    font-weight: 500 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.1em !important;
    color: rgba(255, 255, 255, 0.8) !important;
    margin: 0 !important;
}

@media (min-width: 768px) {
    .es-solution-badge-text {
        font-size: 12px !important;
    }
}

.es-solution-title {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    font-size: clamp(20px, 4vw, 28px) !important;
    font-weight: 400 !important;
    line-height: 1.2 !important;
    letter-spacing: -0.02em !important;
    color: white !important;
}

.es-solution-desc {
    margin-top: 12px !important;
    margin-bottom: 0 !important;
    font-size: 16px !important;
    line-height: 1.6 !important;
    color: rgba(255, 255, 255, 0.6) !important;
}

.es-solution-outcomes {
    display: flex !important;
    flex-direction: column !important;
    gap: 16px !important;
    margin-top: 24px !important;
}

@media (min-width: 768px) {
    .es-solution-outcomes {
        gap: 20px !important;
        margin-top: 32px !important;
    }
}

.es-solution-outcome {
    display: flex !important;
    align-items: flex-start !important;
    gap: 12px !important;
    opacity: 0 !important;
    transform: translateX(-24px) !important;
    transition: opacity 0.7s, transform 0.7s !important;
}

@media (min-width: 768px) {
    .es-solution-outcome {
        gap: 16px !important;
    }
}

.es-solution-outcome.es-visible {
    opacity: 1 !important;
    transform: translateX(0) !important;
}

.es-solution-outcome-number {
    position: relative !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 32px !important;
    height: 32px !important;
    flex-shrink: 0 !important;
}

@media (min-width: 768px) {
    .es-solution-outcome-number {
        width: 40px !important;
        height: 40px !important;
    }
}

.es-solution-outcome-ring {
    position: absolute !important;
    inset: 0 !important;
    border: 2px solid var(--es-bronze-light) !important;
    border-radius: 50% !important;
    opacity: 0 !important;
    transform: scale(1.5) !important;
    transition: opacity 0.7s, transform 0.7s !important;
}

.es-solution-outcome.es-visible .es-solution-outcome-ring {
    opacity: 1 !important;
    transform: scale(1) !important;
}

.es-solution-outcome-fill {
    position: absolute !important;
    inset: 4px !important;
    background: var(--es-bronze-light) !important;
    border-radius: 50% !important;
    opacity: 0 !important;
    transform: scale(0) !important;
    transition: opacity 0.5s 0.2s, transform 0.5s 0.2s !important;
}

.es-solution-outcome.es-visible .es-solution-outcome-fill {
    opacity: 1 !important;
    transform: scale(1) !important;
}

.es-solution-outcome-value {
    position: relative !important;
    z-index: 1 !important;
    font-size: 12px !important;
    font-weight: 400 !important;
    color: var(--es-dark) !important;
}

@media (min-width: 768px) {
    .es-solution-outcome-value {
        font-size: 14px !important;
    }
}

.es-solution-outcome-title {
    font-size: 16px !important;
    font-weight: 500 !important;
    color: white !important;
    margin: 0 !important;
}

@media (min-width: 768px) {
    .es-solution-outcome-title {
        font-size: 16px !important;
    }
}

.es-solution-outcome-subtitle {
    margin-top: 2px !important;
    margin-bottom: 0 !important;
    font-size: 12px !important;
    color: rgba(255, 255, 255, 0.5) !important;
}

.es-solution-link {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    margin-top: 24px !important;
    font-size: 16px !important;
    font-weight: 500 !important;
    color: var(--es-bronze-light) !important;
    text-decoration: none !important;
    transition: color 0.2s !important;
}

@media (min-width: 768px) {
    .es-solution-link {
        margin-top: 32px !important;
    }
}

.es-solution-link:hover {
    color: rgba(196, 167, 125, 0.8) !important;
}

.es-solution-link svg {
    width: 16px !important;
    height: 16px !important;
}

.es-solution-visual {
    order: 1 !important;
    position: relative !important;
}

@media (min-width: 1024px) {
    .es-solution-visual {
        order: 2 !important;
    }
}

.es-solution-image {
    aspect-ratio: 4 / 3 !important;
    border-radius: 12px !important;
    overflow: hidden !important;
    background: linear-gradient(135deg, rgba(115, 85, 54, 0.2), rgba(115, 85, 54, 0.05)) !important;
}

@media (min-width: 768px) {
    .es-solution-image {
        aspect-ratio: 4 / 5 !important;
        border-radius: 16px !important;
    }
}

.es-solution-image img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    transition: transform 1s !important;
}

.es-solution-image.es-visible img {
    transform: scale(1) !important;
}

.es-solution-image:not(.es-visible) img {
    transform: scale(1.1) !important;
}

.es-solution-stat {
    position: absolute !important;
    bottom: -16px !important;
    left: -16px !important;
    padding: 16px !important;
    border-radius: 12px !important;
    background: white !important;
    box-shadow: 0 16px 40px -12px rgba(0, 0, 0, 0.2) !important;
    opacity: 0 !important;
    transform: translateY(32px) !important;
    transition: opacity 0.7s, transform 0.7s !important;
}

@media (min-width: 768px) {
    .es-solution-stat {
        bottom: -24px !important;
        left: -32px !important;
        padding: 20px !important;
        border-radius: 16px !important;
    }
}

.es-solution-stat.es-visible {
    opacity: 1 !important;
    transform: translateY(0) !important;
}

.es-solution-stat-value {
    font-size: 24px !important;
    font-weight: 400 !important;
    color: var(--es-dark) !important;
    margin: 0 !important;
}

@media (min-width: 768px) {
    .es-solution-stat-value {
        font-size: 28px !important;
    }
}

.es-solution-stat-label {
    margin-top: 2px !important;
    margin-bottom: 0 !important;
    font-size: 12px !important;
    color: rgba(26, 20, 16, 0.6) !important;
}

@media (min-width: 768px) {
    .es-solution-stat-label {
        font-size: 14px !important;
    }
}

/* =========================================
   MID CTA - FULL WIDTH BACKGROUND, 1200PX CONTENT
   ========================================= */
.es-mid-cta {
    padding: 40px 0 !important;
    background: var(--es-bg) !important;
    width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
}

@media (min-width: 768px) {
    .es-mid-cta {
        padding: 56px 0 !important;
    }
}

.es-mid-cta-card {
    max-width: 1200px !important;
    margin: 0 20px !important;
    padding: 20px !important;
    border-radius: 12px !important;
    border: 1px solid rgba(115, 85, 54, 0.1) !important;
    background: white !important;
}

@media (min-width: 768px) {
    .es-mid-cta-card {
        padding: 32px !important;
        border-radius: 16px !important;
    }
}

.es-mid-cta-inner {
    display: flex !important;
    flex-direction: column !important;
    gap: 20px !important;
    text-align: center !important;
}

@media (min-width: 768px) {
    .es-mid-cta-inner {
        flex-direction: row !important;
        align-items: center !important;
        gap: 24px !important;
        text-align: left !important;
    }
}

.es-mid-cta-content {
    flex: 1 !important;
}

.es-mid-cta-title {
    font-size: 18px !important;
    font-weight: 400 !important;
    color: var(--es-dark) !important;
    margin: 0 !important;
}

@media (min-width: 768px) {
    .es-mid-cta-title {
        font-size: 20px !important;
    }
}

.es-mid-cta-desc {
    margin-top: 6px !important;
    margin-bottom: 0 !important;
    font-size: 16px !important;
    color: rgba(26, 20, 16, 0.6) !important;
}

.es-mid-cta-badges {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    gap: 12px !important;
    margin-top: 12px !important;
}

@media (min-width: 768px) {
    .es-mid-cta-badges {
        justify-content: flex-start !important;
        gap: 16px !important;
    }
}

.es-mid-cta-badge {
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
    font-size: 12px !important;
    color: rgba(26, 20, 16, 0.5) !important;
}

.es-mid-cta-badge svg {
    width: 14px !important;
    height: 14px !important;
    color: var(--es-bronze) !important;
}

.es-mid-cta-action {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 6px !important;
}

.es-mid-cta-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    width: 100% !important;
    padding: 10px 20px !important;
    border-radius: 50px !important;
    background: var(--es-bronze) !important;
    font-size: 16px !important;
    font-weight: 500 !important;
    color: white !important;
    text-decoration: none !important;
    transition: background 0.2s !important;
    border: none !important;
}

@media (min-width: 768px) {
    .es-mid-cta-btn {
        width: auto !important;
        padding: 12px 24px !important;
    }
}

.es-mid-cta-btn:hover {
    background: #5c452b !important;
    color: white !important;
}

.es-mid-cta-btn svg {
    width: 16px !important;
    height: 16px !important;
}

.es-mid-cta-note {
    font-size: 12px !important;
    color: rgba(26, 20, 16, 0.4) !important;
    margin: 0 !important;
}

/* =========================================
   ALL REMAINING SECTIONS FOLLOW SAME PATTERN:
   - Full width background with viewport trick
   - 1200px max-width container inside with padding
   ========================================= */

/* CURRICULUM SECTION */
.es-curriculum-section {
    padding: 64px 0 !important;
    background: var(--es-bg) !important;
    width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
}

@media (min-width: 768px) {
    .es-curriculum-section {
        padding: 96px 0 !important;
    }
}

.es-curriculum-grid {
    max-width: 1200px !important;
    margin: 0 auto !important;
    padding: 0 20px !important;
    display: grid !important;
    gap: 32px !important;
}

@media (min-width: 1024px) {
    .es-curriculum-grid {
        grid-template-columns: 240px 1fr !important;
        gap: 40px !important;
    }
}

.es-curriculum-header {
    position: relative !important;
    display:block;
}

@media (min-width: 1024px) {
    .es-curriculum-header {
        position: sticky !important;
        top: 128px !important;
        align-self: start !important;
    }
}

.es-curriculum-tabs {
    display: inline-flex !important;
    margin-top: 16px !important;
    padding: 4px !important;
    border-radius: 50px !important;
    background: rgba(26, 20, 16, 0.05) !important;
}

.es-curriculum-tab {
    padding: 6px 14px !important;
    border-radius: 50px !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    color: rgba(26, 20, 16, 0.6) !important;
    transition: all 0.2s !important;
    border: none !important;
    background: transparent !important;
    cursor: pointer !important;
        box-shadow: none !important;
    
}

@media (min-width: 768px) {
    .es-curriculum-tab {
        padding: 8px 16px !important;
        font-size: 14px !important;
    }
}

.es-curriculum-tab.active {
    background: var(--es-dark) !important;
    color: white !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1) !important;
}

.es-curriculum-tab:not(.active):hover {
    color: var(--es-dark) !important;
}

.es-curriculum-content {
    padding: 16px !important;
    border-radius: 12px !important;
    background: white !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05) !important;
}

@media (min-width: 768px) {
    .es-curriculum-content {
        padding: 24px !important;
        border-radius: 16px !important;
    }
}

.es-curriculum-day-header {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    margin-bottom: 16px !important;
}

@media (min-width: 768px) {
    .es-curriculum-day-header {
        margin-bottom: 20px !important;
    }
}

.es-curriculum-day-number {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 32px !important;
    height: 32px !important;
    border-radius: 50% !important;
    background: var(--es-bronze) !important;
    font-size: 12px !important;
    font-weight: 400 !important;
    color: white !important;
    flex-shrink: 0 !important;
}

@media (min-width: 768px) {
    .es-curriculum-day-number {
        width: 36px !important;
        height: 36px !important;
        font-size: 14px !important;
    }
}

.es-curriculum-day-title {
    font-size: 16px !important;
    font-weight: 400 !important;
    color: var(--es-dark) !important;
    margin: 0 !important;
}

@media (min-width: 768px) {
    .es-curriculum-day-title {
        font-size: 16px !important;
    }
}

.es-curriculum-modules {
    border-top: 1px solid rgba(26, 20, 16, 0.05) !important;
}

.es-curriculum-module {
    border-bottom: 1px solid rgba(26, 20, 16, 0.05) !important;
}

.es-curriculum-module:last-child {
    border-bottom: none !important;
}

.es-curriculum-module-btn {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    width: 100% !important;
    padding: 12px 0 !important;
    text-align: left !important;
    transition: color 0.2s !important;
    border: none !important;
    background: transparent !important;
    cursor: pointer !important;
    box-shadow: none !important;
}

@media (min-width: 768px) {
    .es-curriculum-module-btn {
        gap: 12px !important;
        padding: 14px 0 !important;
    }
}

.es-curriculum-module-btn:hover {
    color: var(--es-bronze) !important;
}

.es-curriculum-module-number {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 20px !important;
    height: 20px !important;
    flex-shrink: 0 !important;
    border-radius: 50% !important;
    background: rgba(26, 20, 16, 0.05) !important;
    font-size: 10px !important;
    font-weight: 400 !important;
    color: rgba(26, 20, 16, 0.4) !important;
    transition: background 0.2s, color 0.2s !important;
}

@media (min-width: 768px) {
    .es-curriculum-module-number {
        width: 24px !important;
        height: 24px !important;
        font-size: 12px !important;
    }
}

.es-curriculum-module.open .es-curriculum-module-number {
    background: var(--es-bronze) !important;
    color: white !important;
}

.es-curriculum-module-title {
    flex: 1 !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    color: var(--es-dark) !important;
}

@media (min-width: 768px) {
    .es-curriculum-module-title {
        font-size: 14px !important;
    }
}

.es-curriculum-module-icon {
    width: 14px !important;
    height: 14px !important;
    color: rgba(26, 20, 16, 0.3) !important;
    transition: transform 0.3s, color 0.3s !important;
    flex-shrink: 0 !important;
}

@media (min-width: 768px) {
    .es-curriculum-module-icon {
        width: 16px !important;
        height: 16px !important;
    }
}

.es-curriculum-module.open .es-curriculum-module-icon {
    transform: rotate(180deg) !important;
    color: var(--es-bronze) !important;
}

.es-curriculum-module-content {
    display: grid !important;
    grid-template-rows: 0fr !important;
    transition: grid-template-rows 0.3s !important;
}

.es-curriculum-module.open .es-curriculum-module-content {
    grid-template-rows: 1fr !important;
}

.es-curriculum-module-content-inner {
    overflow: hidden !important;
}

.es-curriculum-module-desc {
    padding: 0 0 12px 28px !important;
    font-size: 12px !important;
    line-height: 1.5 !important;
    color: rgba(26, 20, 16, 0.6) !important;
    margin: 0 !important;
}

@media (min-width: 768px) {
    .es-curriculum-module-desc {
        padding: 0 0 12px 36px !important;
        font-size: 14px !important;
    }
}

/* INCLUDES SECTION */
.es-includes-section {
    padding: 64px 0 !important;
    background: white !important;
    width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
}

@media (min-width: 768px) {
    .es-includes-section {
        padding: 96px 0 !important;
    }
}

.es-includes-header {
    max-width: 1200px !important;
    margin: 0 auto 40px !important;
    padding: 0 20px !important;
}

.es-includes-grid {
    max-width: 1200px !important;
    margin: 0 auto !important;
    padding: 0 20px !important;
    display: grid !important;
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 10px !important;
}

@media (min-width: 768px) {
    .es-includes-grid {
        grid-template-columns: repeat(3, 1fr) !important;
        gap: 12px !important;
    }
}

.es-includes-item {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 12px !important;
    padding: 16px !important;
    border-radius: 12px !important;
    background: var(--es-bg) !important;
    text-align: center !important;
    transition: background 0.3s, box-shadow 0.3s !important;
}

@media (min-width: 768px) {
    .es-includes-item {
        flex-direction: row !important;
        gap: 16px !important;
        padding: 20px !important;
        text-align: left !important;
    }
}

.es-includes-item:hover {
    background: white !important;
    box-shadow: 0 8px 30px -12px rgba(115, 85, 54, 0.1) !important;
}

.es-includes-icon {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 36px !important;
    height: 36px !important;
    flex-shrink: 0 !important;
    border-radius: 8px !important;
    background: rgba(115, 85, 54, 0.05) !important;
    color: var(--es-bronze) !important;
    transition: background 0.3s, color 0.3s !important;
}

@media (min-width: 768px) {
    .es-includes-icon {
        width: 40px !important;
        height: 40px !important;
    }
}

.es-includes-item:hover .es-includes-icon {
    background: var(--es-bronze) !important;
    color: white !important;
}

.es-includes-icon svg {
    width: 16px !important;
    height: 16px !important;
}

.es-includes-text {
    font-size: 12px !important;
    font-weight: 500 !important;
    line-height: 1.4 !important;
    color: var(--es-dark) !important;
}

@media (min-width: 768px) {
    .es-includes-text {
        font-size: 14px !important;
    }
}



/* FOUNDER SECTION */
.es-founder-section {
    position: relative !important;
    padding: 48px 0 !important;
    background: var(--es-dark-muted) !important;
    color: white !important;
    overflow: hidden !important;
    width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
}

@media (min-width: 768px) {
    .es-founder-section {
        padding: 80px 0 !important;
    }
}

.es-founder-grid {
    max-width: 1200px !important;
    margin: 0 auto !important;
    padding: 0 20px !important;
    display: grid !important;
    gap: 24px !important;
    align-items: center !important;
}

@media (min-width: 768px) {
    .es-founder-grid {
        grid-template-columns: 1fr 1fr !important;
        gap: 40px !important;
    }
}

.es-founder-image {
    max-width: 280px !important;
    margin: 0 auto !important;
    
}

@media (min-width: 768px) {
    .es-founder-image {
        max-width: none !important;
        margin: 0 !important;
    }
}

.es-founder-image-inner {
    aspect-ratio: 3 / 4 !important;
    border-radius: 12px !important;
    overflow: hidden !important;
}

@media (min-width: 768px) {
    .es-founder-image-inner {
        border-radius: 16px !important;
    }
}

.es-founder-image-inner img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    transition: transform 1s !important;
}

.es-founder-image.es-visible img {
    transform: scale(1) !important;
}

.es-founder-image:not(.es-visible) img {
    transform: scale(1.1) !important;
}

.es-founder-content-label {
    font-size: 11px !important;
    font-weight: 500 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.1em !important;
    color: var(--es-bronze-light) !important;
    margin: 0 0 8px 0 !important;
}

.es-founder-content-name {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    font-size: clamp(18px, 3vw, 24px) !important;
    font-weight: 400 !important;
    line-height: 1.2 !important;
    letter-spacing: -0.02em !important;
    color: white !important;
}

.es-founder-content-role {
    margin-top: 4px !important;
    margin-bottom: 0 !important;
    font-size: 12px !important;
    color: rgba(255, 255, 255, 0.6) !important;
}

@media (min-width: 768px) {
    .es-founder-content-role {
        font-size: 14px !important;
    }
}

.es-founder-content-text {
    margin-top: 16px !important;
    margin-bottom: 0 !important;
    font-size: 16px !important;
    line-height: 1.6 !important;
    color: rgba(255, 255, 255, 0.8) !important;
}

.es-founder-content-text + .es-founder-content-text {
    margin-top: 12px !important;
}

.es-founder-stats {
    display: flex !important;
    gap: 20px !important;
    margin-top: 20px !important;
    padding-top: 20px !important;
    border-top: 1px solid rgba(255, 255, 255, 0.1) !important;
}

@media (min-width: 768px) {
    .es-founder-stats {
        gap: 24px !important;
        margin-top: 24px !important;
        padding-top: 24px !important;
    }
}

.es-founder-stat-value {
    font-size: 20px !important;
    font-weight: 400 !important;
    color: var(--es-bronze-light) !important;
    margin: 0 !important;
}

@media (min-width: 768px) {
    .es-founder-stat-value {
        font-size: 24px !important;
    }
}

.es-founder-stat-label {
    margin: 0 !important;
    font-size: 9px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
    color: rgba(255, 255, 255, 0.4) !important;
}

@media (min-width: 768px) {
    .es-founder-stat-label {
        font-size: 10px !important;
    }
}

/* VIDEO TESTIMONIALS */
.es-video-section {
    padding: 64px 0 !important;
    background: white !important;
    width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
}

@media (min-width: 768px) {
    .es-video-section {
        padding: 96px 0 !important;
    }
}

.es-video-header {
    max-width: 1200px !important;
    margin: 0 auto 40px !important;
    padding: 0 20px !important;
}

.es-video-grid {
    max-width: 1200px !important;
    margin: 0 auto !important;
    padding: 0 20px !important;
    display: grid !important;
    gap: 16px !important;
}

@media (min-width: 768px) {
    .es-video-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 24px !important;
    }
}

.es-video-card {
    position: relative !important;
    border-radius: 12px !important;
    overflow: hidden !important;
    background: var(--es-dark) !important;
    cursor: pointer !important;
}

@media (min-width: 768px) {
    .es-video-card {
        border-radius: 16px !important;
    }
}

.es-video-thumbnail {
    position: relative !important;
    aspect-ratio: 4 / 5 !important;
}

@media (min-width: 640px) {
    .es-video-thumbnail {
        aspect-ratio: 3 / 4 !important;
    }
}

@media (min-width: 768px) {
    .es-video-thumbnail {
        aspect-ratio: 16 / 9 !important;
    }
}

.es-video-thumbnail img {
    width: 100% !important;
    height: 100% !important;
        object-position: center top !important; /* Changed from default center */
    object-fit: cover !important;
    transition: transform 0.5s !important;
}

.es-video-card:hover .es-video-thumbnail img {
    transform: scale(1.05) !important;
}

.es-video-thumbnail::after {
    content: '' !important;
    position: absolute !important;
    inset: 0 !important;
    background: linear-gradient(to top, var(--es-dark), rgba(26, 20, 16, 0.2), transparent) !important;
}

.es-video-play {
    position: absolute !important;
    top: 50% !important;
    left: 50% !important;
    transform: translate(-50%, -50%) !important;
    z-index: 1 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 56px !important;
    height: 56px !important;
    border-radius: 50% !important;
    background: rgba(255, 255, 255, 0.95) !important;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2) !important;
    transition: transform 0.3s !important;
}

@media (min-width: 768px) {
    .es-video-play {
        width: 64px !important;
        height: 64px !important;
    }
}

.es-video-card:hover .es-video-play {
    transform: translate(-50%, -50%) scale(1.1) !important;
}

.es-video-play svg {
    width: 20px !important;
    height: 20px !important;
    margin-left: 2px !important;
    fill: var(--es-bronze) !important;
    color: var(--es-bronze) !important;
}

@media (min-width: 768px) {
    .es-video-play svg {
        width: 24px !important;
        height: 24px !important;
    }
}

.es-video-info {
    position: absolute !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 1 !important;
    padding: 16px !important;
}

@media (min-width: 768px) {
    .es-video-info {
        padding: 24px !important;
    }
}

.es-video-quote {
    font-size: 12px !important;
    font-style: italic !important;
    color: rgba(255, 255, 255, 0.9) !important;
    margin: 0 !important;
}

@media (min-width: 768px) {
    .es-video-quote {
        font-size: 14px !important;
    }
}

.es-video-author {
    margin-top: 8px !important;
}

@media (min-width: 768px) {
    .es-video-author {
        margin-top: 12px !important;
    }
}

.es-video-author-name {
    font-size: 12px !important;
    font-weight: 400 !important;
    color: white !important;
    margin: 0 !important;
}

@media (min-width: 768px) {
    .es-video-author-name {
        font-size: 14px !important;
    }
}

.es-video-author-role {
    font-size: 10px !important;
    color: rgba(255, 255, 255, 0.6) !important;
    margin: 0 !important;
}

@media (min-width: 768px) {
    .es-video-author-role {
        font-size: 12px !important;
    }
}

/* TEXT TESTIMONIALS */
.es-testimonials-section {
    padding: 64px 0 !important;
    background: var(--es-bg) !important;
    width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
}

@media (min-width: 768px) {
    .es-testimonials-section {
        padding: 96px 0 !important;
    }
}

.es-testimonials-header {
    max-width: 1200px !important;
    margin: 0 auto 40px !important;
    padding: 0 20px !important;
}

.es-testimonials-grid {
    max-width: 1200px !important;
    margin: 0 auto !important;
    padding: 0 20px !important;
    display: grid !important;
    gap: 12px !important;
}

@media (min-width: 768px) {
    .es-testimonials-grid {
        grid-template-columns: repeat(3, 1fr) !important;
        gap: 16px !important;
    }
}

.es-testimonial-card {
    display: flex !important;
    flex-direction: column !important;
    padding: 20px !important;
    border-radius: 12px !important;
    background: white !important;
    transition: transform 0.3s, box-shadow 0.3s !important;
}

@media (min-width: 768px) {
    .es-testimonial-card {
        padding: 24px !important;
        border-radius: 16px !important;
    }
}

.es-testimonial-card:hover {
    transform: translateY(-4px) !important;
    box-shadow: 0 16px 40px -12px rgba(115, 85, 54, 0.1) !important;
}

.es-testimonial-stars {
    display: flex !important;
    gap: 2px !important;
    margin-bottom: 16px !important;
}

.es-testimonial-stars svg {
    width: 12px !important;
    height: 12px !important;
    fill: var(--es-bronze-light) !important;
    color: var(--es-bronze-light) !important;
}

@media (min-width: 768px) {
    .es-testimonial-stars svg {
        width: 14px !important;
        height: 14px !important;
    }
}

.es-testimonial-quote {
    flex: 1 !important;
    font-size: 12px !important;
    line-height: 1.6 !important;
    color: rgba(26, 20, 16, 0.7) !important;
    margin: 0 !important;
}

@media (min-width: 768px) {
    .es-testimonial-quote {
        font-size: 14px !important;
    }
}

.es-testimonial-author {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    margin-top: 20px !important;
    padding-top: 16px !important;
    border-top: 1px solid rgba(26, 20, 16, 0.05) !important;
}

.es-testimonial-avatar {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 36px !important;
    height: 36px !important;
    border-radius: 50% !important;
    background: rgba(115, 85, 54, 0.1) !important;
    font-size: 12px !important;
    font-weight: 400 !important;
    color: var(--es-bronze) !important;
    flex-shrink: 0 !important;
}

.es-testimonial-author-name {
    font-size: 12px !important;
    font-weight: 400 !important;
    color: var(--es-dark) !important;
    margin: 0 !important;
}

@media (min-width: 768px) {
    .es-testimonial-author-name {
        font-size: 14px !important;
    }
}

.es-testimonial-author-role {
    font-size: 10px !important;
    color: rgba(26, 20, 16, 0.5) !important;
    margin: 0 !important;
}

@media (min-width: 768px) {
    .es-testimonial-author-role {
        font-size: 12px !important;
    }
}

/* FAQ SECTION */
.es-faq-section {
    padding: 64px 0 !important;
    background: white !important;
    width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
}

@media (min-width: 768px) {
    .es-faq-section {
        padding: 96px 0 !important;
    }
}

.es-faq-header {
    max-width: 1200px !important;
    margin: 0 auto 40px !important;
    padding: 0 20px !important;
}

.es-faq-list {
    max-width: 1200px !important;
    margin: 0 auto !important;
    padding: 0 20px !important;
    border-top: 1px solid rgba(26, 20, 16, 0.05) !important;
}

.es-faq-item {
    border-bottom: 1px solid rgba(26, 20, 16, 0.05) !important;
}

.es-faq-btn {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    width: 100% !important;
    padding: 16px 0 !important;
    text-align: left !important;
    transition: color 0.2s !important;
    border: none !important;
    background: transparent !important;
    cursor: pointer !important;
    box-shadow: none !important;
}

@media (min-width: 768px) {
    .es-faq-btn {
        padding: 20px 0 !important;
    }
}

.es-faq-btn:hover {
    color: var(--es-bronze) !important;
}

.es-faq-question {
    flex: 1 !important;
    padding-right: 24px !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    color: var(--es-dark) !important;
}

@media (min-width: 768px) {
    .es-faq-question {
        padding-right: 32px !important;
        font-size: 14px !important;
    }
}

.es-faq-icon {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 24px !important;
    height: 24px !important;
    flex-shrink: 0 !important;
    border-radius: 50% !important;
    background: rgba(26, 20, 16, 0.05) !important;
    transition: background 0.2s, color 0.2s !important;
}

@media (min-width: 768px) {
    .es-faq-icon {
        width: 28px !important;
        height: 28px !important;
    }
}

.es-faq-item.open .es-faq-icon {
    background: var(--es-bronze) !important;
}

.es-faq-icon svg {
    width: 12px !important;
    height: 12px !important;
    stroke: rgba(26, 20, 16, 0.6) !important;
    fill: none !important;
    opacity: 1 !important;
    visibility: visible !important;
    display: block !important;
    transition: stroke 0.2s !important;
}

.es-faq-item.open .es-faq-icon svg {
    stroke: white !important;
}
.es-faq-answer {
    display: grid !important;
    grid-template-rows: 0fr !important;
    transition: grid-template-rows 0.3s !important;
}

.es-faq-item.open .es-faq-answer {
    grid-template-rows: 1fr !important;
}

.es-faq-answer-inner {
    overflow: hidden !important;
}

.es-faq-answer-text {
    padding: 0 40px 16px 0 !important;
    font-size: 12px !important;
    line-height: 1.6 !important;
    color: rgba(26, 20, 16, 0.6) !important;
    margin: 0 !important;
}

@media (min-width: 768px) {
    .es-faq-answer-text {
        padding: 0 48px 20px 0 !important;
        font-size: 14px !important;
    }
}

/* STICKY CTA */
.es-sticky-cta {
    position: fixed !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 100 !important;
    border-top: 1px solid rgba(26, 20, 16, 0.05) !important;
    background: rgba(255, 255, 255, 0.95) !important;
    backdrop-filter: blur(12px) !important;
    transform: translateY(100%) !important;
    transition: transform 0.3s !important;
}

.es-sticky-cta.es-visible {
    transform: translateY(0) !important;
}

.es-sticky-cta-inner {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
    max-width: 1200px !important;
    margin: 0 auto !important;
    padding: 10px 20px !important;
}

@media (min-width: 768px) {
    .es-sticky-cta-inner {
        gap: 16px !important;
        padding: 12px 32px !important;
    }
}

.es-sticky-cta-info {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
}

@media (min-width: 768px) {
    .es-sticky-cta-info {
        gap: 12px !important;
    }
}

.es-sticky-cta-icon {
    display: none !important;
    align-items: center !important;
    justify-content: center !important;
    width: 32px !important;
    height: 32px !important;
    border-radius: 50% !important;
    background: rgba(115, 85, 54, 0.1) !important;
}

@media (min-width: 640px) {
    .es-sticky-cta-icon {
        display: flex !important;
    }
}

@media (min-width: 768px) {
    .es-sticky-cta-icon {
        width: 36px !important;
        height: 36px !important;
    }
}

.es-sticky-cta-icon svg {
    width: 14px !important;
    height: 14px !important;
    color: var(--es-bronze) !important;
}

@media (min-width: 768px) {
    .es-sticky-cta-icon svg {
        width: 16px !important;
        height: 16px !important;
    }
}

.es-sticky-cta-label {
    font-size: 10px !important;
    color: rgba(26, 20, 16, 0.5) !important;
    margin: 0 !important;
}

@media (min-width: 768px) {
    .es-sticky-cta-label {
        font-size: 12px !important;
    }
}

.es-sticky-cta-date {
    font-size: 12px !important;
    font-weight: 400 !important;
    color: var(--es-dark) !important;
    margin: 0 !important;
}

@media (min-width: 768px) {
    .es-sticky-cta-date {
        font-size: 14px !important;
    }
}

.es-sticky-cta-badge {
    display: flex !important;
    align-items: center !important;
    gap: 4px !important;
    padding: 2px 8px !important;
    border-radius: 50px !important;
    background: #fef2f2 !important;
}

@media (min-width: 768px) {
    .es-sticky-cta-badge {
        gap: 6px !important;
        padding: 4px 12px !important;
    }
}

.es-sticky-cta-pulse {
    position: relative !important;
    width: 6px !important;
    height: 6px !important;
}

@media (min-width: 768px) {
    .es-sticky-cta-pulse {
        width: 8px !important;
        height: 8px !important;
    }
}

@keyframes esPing {
    75%, 100% {
        transform: scale(2);
        opacity: 0;
    }
}

.es-sticky-cta-pulse::before {
    content: '' !important;
    position: absolute !important;
    inset: 0 !important;
    border-radius: 50% !important;
    background: #ef4444 !important;
    animation: esPing 1s cubic-bezier(0, 0, 0.2, 1) infinite !important;
}

.es-sticky-cta-pulse::after {
    content: '' !important;
    position: relative !important;
    display: block !important;
    width: 6px !important;
    height: 6px !important;
    border-radius: 50% !important;
    background: #ef4444 !important;
}

@media (min-width: 768px) {
    .es-sticky-cta-pulse::after {
        width: 8px !important;
        height: 8px !important;
    }
}

.es-sticky-cta-spots {
    font-size: 10px !important;
    font-weight: 500 !important;
    color: #dc2626 !important;
    margin: 0 !important;
}

@media (min-width: 768px) {
    .es-sticky-cta-spots {
        font-size: 12px !important;
    }
}

.es-sticky-cta-actions {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
}

.es-sticky-cta-link {
    display: none !important;
    padding: 6px 12px !important;
    border-radius: 50px !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    color: rgba(26, 20, 16, 0.7) !important;
    text-decoration: none !important;
    transition: background 0.2s !important;
}

@media (min-width: 768px) {
    .es-sticky-cta-link {
        display: block !important;
        padding: 8px 16px !important;
        font-size: 14px !important;
    }
}

.es-sticky-cta-link:hover {
    background: rgba(26, 20, 16, 0.05) !important;
}

.es-sticky-cta-btn {
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
    padding: 8px 12px !important;
    border-radius: 50px !important;
    background: var(--es-bronze) !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    color: white !important;
    text-decoration: none !important;
    transition: background 0.2s !important;
    border: none !important;
}

@media (min-width: 768px) {
    .es-sticky-cta-btn {
        gap: 8px !important;
        padding: 10px 16px !important;
        font-size: 14px !important;
    }
}

.es-sticky-cta-btn:hover {
    background: #5c452b !important;
    color: white !important;
}

.es-sticky-cta-btn svg {
    width: 12px !important;
    height: 12px !important;
}

@media (min-width: 768px) {
    .es-sticky-cta-btn svg {
        width: 14px !important;
        height: 14px !important;
    }
}

.es-sticky-cta-btn-text-short {
    display: inline !important;
}

.es-sticky-cta-btn-text-full {
    display: none !important;
}

@media (min-width: 640px) {
    .es-sticky-cta-btn-text-short {
        display: none !important;
    }
    
    .es-sticky-cta-btn-text-full {
        display: inline !important;
    }
}