/* ─── Morgans Landing — Club de Fidelización ─────────────────────────────── */

/* ─── Tokens ────────────────────────────────────────────────────────────── */

:root {
    --mgns-l-bg:            #00091d;
    --mgns-l-bg-alt:        #000e2a;
    --mgns-l-surface:       #0a1630;
    --mgns-l-surface-hover: #0f1e3d;
    --mgns-l-border:        rgba(255, 255, 255, .1);
    --mgns-l-text:          #ffffff;
    --mgns-l-text-muted:    #d9d9d9;
    --mgns-l-accent:        #dcaa22;
    --mgns-l-accent-dark:   #e2a516;
    --mgns-l-accent-glow:   rgba(220, 170, 34, .25);
    --mgns-l-gold:          #dcaa22;
    --mgns-l-gold-soft:     rgba(220, 170, 34, .12);
    --mgns-l-radius:        0px;
    --mgns-l-radius-sm:     0px;
    --mgns-l-font:          'Montserrat', sans-serif;
    --mgns-l-font-display:  'Open Sans Condensed', sans-serif;
    --mgns-l-max-w:         1080px;
}

/* ─── Background textures (CSS-only, no external images) ────────────────── */

/* Subtle noise grain — SVG filter as data-URI */
.mgns-land-grain {
    /* Generated via ::after on sections that need texture */
}

/* Diagonal barbershop lines pattern */
.mgns-land-lines {
    /* Applied via repeating-linear-gradient */
}

/* ─── Reset scope ───────────────────────────────────────────────────────── */

.mgns-land {
    font-family: var(--mgns-l-font);
    color: var(--mgns-l-text-muted);
    font-weight: 600;
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    overflow-x: hidden;
}

.mgns-land *,
.mgns-land *::before,
.mgns-land *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

.mgns-land img {
    max-width: 100%;
    display: block;
}

/* ─── Container ─────────────────────────────────────────────────────────── */

.mgns-land-container {
    max-width: var(--mgns-l-max-w);
    margin: 0 auto;
    padding: 0 24px;
}

/* ─── Fade-up animation ─────────────────────────────────────────────────── */

.mgns-land-fade-up {
    opacity: 0;
    transform: translateY(32px);
    transition: opacity .7s cubic-bezier(.22, 1, .36, 1),
                transform .7s cubic-bezier(.22, 1, .36, 1);
}

.mgns-land-fade-up.is-visible {
    opacity: 1;
    transform: translateY(0);
}

/* ═══════════════════════════════════════════════════════════════════════════
   HERO
   ═══════════════════════════════════════════════════════════════════════════ */

.mgns-land-hero {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 92vh;
    background:
        /* Diagonal barber stripes — very subtle */
        repeating-linear-gradient(
            -45deg,
            transparent,
            transparent 40px,
            rgba(220, 170, 34, .015) 40px,
            rgba(220, 170, 34, .015) 41px
        ),
        var(--mgns-l-hero-bg, none) center / cover no-repeat,
        var(--mgns-l-bg);
    overflow: hidden;
}

/* Gradient overlay — dramatic spotlight from top + warm bottom glow */
.mgns-land-hero__overlay {
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse 70% 40% at 50% -5%, rgba(220, 170, 34, .1), transparent 70%),
        radial-gradient(ellipse 50% 50% at 80% 110%, rgba(220, 170, 34, .06), transparent 70%),
        radial-gradient(circle at 20% 50%, rgba(0, 9, 29, .6), transparent 60%);
    pointer-events: none;
}

/* Noise grain on hero */
.mgns-land-hero::after {
    content: '';
    position: absolute;
    inset: 0;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");
    background-repeat: repeat;
    background-size: 200px 200px;
    pointer-events: none;
    z-index: 0;
    opacity: .5;
}

.mgns-land-hero__content {
    position: relative;
    z-index: 1;
    text-align: center;
    max-width: 720px;
    padding: 60px 24px;
}

.mgns-land-hero__badge {
    display: inline-block;
    background: transparent;
    color: var(--mgns-l-gold);
    font-family: var(--mgns-l-font-display);
    font-size: .85rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    padding: 10px 24px;
    border-radius: var(--mgns-l-radius);
    border: 2px solid var(--mgns-l-gold);
    margin-bottom: 28px;
}

.mgns-land-hero__title {
    font-family: var(--mgns-l-font);
    font-size: clamp(2.4rem, 6vw, 4rem);
    font-weight: 900;
    line-height: 1;
    letter-spacing: .02em;
    text-transform: uppercase;
    margin-bottom: 20px;
    color: var(--mgns-l-text);
}

.mgns-land-hero__accent {
    display: block;
    background: linear-gradient(135deg, #f0c97a, var(--mgns-l-gold));
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

.mgns-land-hero__subtitle {
    font-size: clamp(1rem, 2.2vw, 1.15rem);
    color: var(--mgns-l-text-muted);
    max-width: 540px;
    margin: 0 auto 36px;
    line-height: 1.5;
    font-weight: 600;
}

.mgns-land-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    justify-content: center;
}

/* ═══════════════════════════════════════════════════════════════════════════
   BUTTONS
   ═══════════════════════════════════════════════════════════════════════════ */

.mgns-land-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 52px;
    padding: 0 32px;
    border: 3px solid var(--mgns-l-accent);
    border-radius: var(--mgns-l-radius-sm);
    font-family: var(--mgns-l-font-display);
    font-size: 1rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    text-decoration: none;
    cursor: pointer;
    transition: background .2s, color .2s, border-color .2s;
}

.mgns-land-btn:active {
    transform: scale(.97);
}

.mgns-land-btn--primary {
    background: transparent;
    color: var(--mgns-l-accent);
}

.mgns-land-btn--primary:hover {
    background: var(--mgns-l-accent);
    color: var(--mgns-l-bg);
    border-color: var(--mgns-l-accent);
    text-decoration: none;
}

.mgns-land-btn--outline {
    background: transparent;
    color: var(--mgns-l-text-muted);
    border-color: var(--mgns-l-text-muted);
}

.mgns-land-btn--outline:hover {
    border-color: var(--mgns-l-text);
    color: var(--mgns-l-text);
    background: transparent;
    text-decoration: none;
}

.mgns-land-btn--lg {
    height: 58px;
    padding: 0 40px;
    font-size: 1.05rem;
}

/* ═══════════════════════════════════════════════════════════════════════════
   SECTIONS (generic)
   ═══════════════════════════════════════════════════════════════════════════ */

.mgns-land-section {
    position: relative;
    padding: 96px 0;
    background:
        /* Subtle crosshatch texture */
        repeating-linear-gradient(
            90deg,
            transparent,
            transparent 60px,
            rgba(255, 255, 255, .01) 60px,
            rgba(255, 255, 255, .01) 61px
        ),
        repeating-linear-gradient(
            0deg,
            transparent,
            transparent 60px,
            rgba(255, 255, 255, .01) 60px,
            rgba(255, 255, 255, .01) 61px
        ),
        var(--mgns-l-bg-alt);
}

.mgns-land-section--dark {
    background:
        /* Diagonal stripes */
        repeating-linear-gradient(
            -45deg,
            transparent,
            transparent 50px,
            rgba(220, 170, 34, .012) 50px,
            rgba(220, 170, 34, .012) 51px
        ),
        var(--mgns-l-bg);
}

.mgns-land-section__title {
    font-family: var(--mgns-l-font-display);
    font-size: clamp(1.7rem, 4vw, 2.4rem);
    font-weight: 700;
    text-align: center;
    text-transform: uppercase;
    letter-spacing: .06em;
    margin-bottom: 20px;
    padding-bottom: 16px;
    color: var(--mgns-l-text);
    position: relative;
}

/* Gold underline accent */
.mgns-land-section__title::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 60px;
    height: 3px;
    background: var(--mgns-l-accent);
}

.mgns-land-section__subtitle {
    text-align: center;
    color: var(--mgns-l-text-muted);
    max-width: 560px;
    margin: 0 auto 56px;
    font-size: 1rem;
    font-weight: 600;
    line-height: 1.5;
}

/* ═══════════════════════════════════════════════════════════════════════════
   BENEFITS GRID
   ═══════════════════════════════════════════════════════════════════════════ */

.mgns-land-benefits {
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px;
}

.mgns-land-benefit {
    background: var(--mgns-l-surface);
    border: 2px solid var(--mgns-l-border);
    border-radius: var(--mgns-l-radius);
    padding: 32px 28px;
    transition: border-color .25s;
}

.mgns-land-benefit:hover {
    border-color: var(--mgns-l-accent);
}

.mgns-land-benefit__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    border-radius: 0;
    background:
        linear-gradient(135deg, rgba(220, 170, 34, .2), rgba(220, 170, 34, .08));
    border: 1px solid rgba(220, 170, 34, .2);
    color: var(--mgns-l-accent);
    margin-bottom: 20px;
}

.mgns-land-benefit__title {
    font-family: var(--mgns-l-font-display);
    font-size: 1.15rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    margin-bottom: 8px;
    color: var(--mgns-l-text);
}

.mgns-land-benefit__desc {
    font-size: .94rem;
    color: var(--mgns-l-text-muted);
    font-weight: 600;
    line-height: 1.5;
}

/* ═══════════════════════════════════════════════════════════════════════════
   STEPS (How it works)
   ═══════════════════════════════════════════════════════════════════════════ */

.mgns-land-steps {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 24px;
}

.mgns-land-step {
    text-align: center;
    max-width: 300px;
}

.mgns-land-step__number {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 54px;
    height: 54px;
    border-radius: 0;
    background: var(--mgns-l-accent);
    color: var(--mgns-l-bg);
    font-family: var(--mgns-l-font);
    font-size: 1.25rem;
    font-weight: 900;
    margin: 0 auto 16px;
    box-shadow: 0 4px 20px var(--mgns-l-accent-glow);
}

.mgns-land-step__title {
    font-family: var(--mgns-l-font-display);
    font-size: 1.1rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    margin-bottom: 8px;
    color: var(--mgns-l-text);
}

.mgns-land-step__desc {
    font-size: .92rem;
    color: var(--mgns-l-text-muted);
    font-weight: 600;
    line-height: 1.5;
}

.mgns-land-step-arrow {
    color: var(--mgns-l-accent);
    opacity: .4;
    transform: rotate(90deg);
}

/* ═══════════════════════════════════════════════════════════════════════════
   FEATURES (Experience grid)
   ═══════════════════════════════════════════════════════════════════════════ */

.mgns-land-features {
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px;
}

.mgns-land-feature {
    text-align: center;
    padding: 36px 24px;
    background: var(--mgns-l-surface);
    border: 2px solid var(--mgns-l-border);
    border-radius: var(--mgns-l-radius);
    transition: border-color .25s;
}

.mgns-land-feature:hover {
    border-color: var(--mgns-l-accent);
}

.mgns-land-feature__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 64px;
    height: 64px;
    margin: 0 auto 16px;
    color: var(--mgns-l-accent);
    background: linear-gradient(135deg, rgba(220, 170, 34, .15), rgba(220, 170, 34, .05));
    border: 1px solid rgba(220, 170, 34, .2);
}

.mgns-land-feature__title {
    font-family: var(--mgns-l-font-display);
    font-size: 1.05rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    margin-bottom: 8px;
    color: var(--mgns-l-text);
}

.mgns-land-feature__desc {
    font-size: .9rem;
    color: var(--mgns-l-text-muted);
    font-weight: 600;
    line-height: 1.5;
}

/* ═══════════════════════════════════════════════════════════════════════════
   CTA
   ═══════════════════════════════════════════════════════════════════════════ */

.mgns-land-cta {
    padding: 96px 0;
    background:
        repeating-linear-gradient(
            -45deg,
            transparent,
            transparent 40px,
            rgba(220, 170, 34, .012) 40px,
            rgba(220, 170, 34, .012) 41px
        ),
        var(--mgns-l-bg);
    position: relative;
    overflow: hidden;
}

/* Gold glow from bottom + top vignette */
.mgns-land-cta::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse 80% 50% at 50% 110%, rgba(220, 170, 34, .12), transparent 70%),
        radial-gradient(ellipse 100% 40% at 50% -10%, rgba(0, 9, 29, .5), transparent 60%);
    pointer-events: none;
}

/* Noise grain on CTA */
.mgns-land-cta::after {
    content: '';
    position: absolute;
    inset: 0;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");
    background-repeat: repeat;
    background-size: 200px 200px;
    pointer-events: none;
    opacity: .4;
}

.mgns-land-cta__content {
    position: relative;
    z-index: 1;
    text-align: center;
    max-width: 580px;
    margin: 0 auto;
}

.mgns-land-cta__title {
    font-family: var(--mgns-l-font-display);
    font-size: clamp(1.8rem, 4.5vw, 2.6rem);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    margin-bottom: 24px;
    padding-bottom: 16px;
    line-height: 1.1;
    color: var(--mgns-l-text);
    position: relative;
}

.mgns-land-cta__title::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 60px;
    height: 3px;
    background: var(--mgns-l-accent);
}

.mgns-land-cta__desc {
    font-size: 1rem;
    color: var(--mgns-l-text-muted);
    font-weight: 600;
    margin-bottom: 36px;
    line-height: 1.5;
}

.mgns-land-cta__actions {
    margin-bottom: 24px;
}

.mgns-land-cta__note {
    font-size: .88rem;
    color: var(--mgns-l-text-muted);
    font-weight: 600;
    opacity: .7;
}

/* ═══════════════════════════════════════════════════════════════════════════
   RESPONSIVE — Tablet
   ═══════════════════════════════════════════════════════════════════════════ */

@media (min-width: 600px) {
    .mgns-land-benefits {
        grid-template-columns: 1fr 1fr;
    }

    .mgns-land-features {
        grid-template-columns: 1fr 1fr;
    }

    .mgns-land-steps {
        flex-direction: row;
        justify-content: center;
        gap: 16px;
    }

    .mgns-land-step-arrow {
        transform: rotate(0deg);
        align-self: center;
    }
}

/* ═══════════════════════════════════════════════════════════════════════════
   RESPONSIVE — Desktop
   ═══════════════════════════════════════════════════════════════════════════ */

@media (min-width: 960px) {
    .mgns-land-section {
        padding: 120px 0;
    }

    .mgns-land-cta {
        padding: 120px 0;
    }

    .mgns-land-benefits {
        grid-template-columns: 1fr 1fr;
        gap: 24px;
    }

    .mgns-land-features {
        grid-template-columns: repeat(4, 1fr);
        gap: 24px;
    }

    .mgns-land-steps {
        gap: 24px;
    }

    .mgns-land-step {
        max-width: 260px;
    }
}
