/* ─── About Hero ─────────────────────────────── */

.slux-ab-hero {
    width: 100vw;
    position: relative;
    left: 50%;
    margin-left: -50vw;
    min-height: 100vh;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    isolation: isolate;
}

/* Blurred bg on a child so edges don't clip */
.slux-ab-hero-bg {
    position: absolute;
    inset: -40px;
    background-size: cover;
    background-position: center 30%;
    background-repeat: no-repeat;
    filter: blur(10px) brightness(0.42) saturate(0.85);
    z-index: 0;
}

/* Vignette + bottom fade */
.slux-ab-hero::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse 90% 70% at 50% 40%, transparent 10%, rgba(0,0,0,0.5) 100%),
        linear-gradient(to bottom,
            rgba(0,0,0,0.15) 0%,
            transparent 25%,
            transparent 60%,
            rgba(0,0,0,0.9) 100%);
    z-index: 1;
    pointer-events: none;
}

/* ─── Hero Content ───────────────────────────── */

.slux-ab-hero-inner {
    position: relative;
    z-index: 2;
    text-align: center;
    padding: max(110px, 7.64vw) max(24px, calc(1.67vw * var(--scale)));
    max-width: max(700px, calc(54vw * var(--scale)));
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: max(14px, 0.97vw);
}

.slux-ab-hero-eyebrow {
    font-family: var(--font2);
    font-size: max(11px, calc(0.76vw * var(--scale)));
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--accent-color);
    display: flex;
    align-items: center;
    gap: 14px;
    animation: slux-ab-rise 0.9s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.slux-ab-hero-eyebrow::before,
.slux-ab-hero-eyebrow::after {
    content: "";
    display: block;
    width: 24px;
    height: 1px;
    background: var(--accent-color);
    flex-shrink: 0;
}

.slux-ab-hero-title {
    font-family: var(--font1);
    font-size: max(52px, calc(3.61vw * var(--scale)));
    font-weight: 400;
    line-height: 1.05;
    letter-spacing: -0.03em;
    margin: 0;
    color: inherit;
    animation: slux-ab-rise 1s cubic-bezier(0.22, 1, 0.36, 1) 0.12s both;
}

.slux-ab-hero-sub {
    font-family: var(--font2);
    font-size: max(15px, calc(1.04vw * var(--scale)));
    line-height: 1.65;
    opacity: 0.68;
    margin: 0;
    max-width: 50ch;
    animation: slux-ab-rise 1s cubic-bezier(0.22, 1, 0.36, 1) 0.26s both;
}

@keyframes slux-ab-rise {
    from { opacity: 0; transform: translateY(16px); }
    to   { transform: translateY(0); }
}

/* ─── Scroll Indicator ───────────────────────── */

.slux-ab-scroll {
    position: absolute;
    bottom: max(32px, 2.22vw);
    left: 50%;
    z-index: 3;
    transform: translateX(-50%);
    display: flex;
    justify-content: center;
    pointer-events: none;
    transition: opacity 0.4s ease;
}

.slux-ab-scroll-chev {
    width: 34px;
    height: 52px;
    position: relative;
}

.slux-ab-sc {
    position: absolute;
    left: 50%;
    top: 0;
    width: 22px;
    height: 22px;
    transform: translateX(-50%) rotate(45deg);
    border-right: 1.5px solid var(--accent-color);
    border-bottom: 1.5px solid var(--accent-color);
    border-radius: 1px;
    opacity: 0;
    animation: slux-ab-chev 1.8s ease-out infinite;
}

.slux-ab-sc.c1 { animation-delay: 0s; }
.slux-ab-sc.c2 { animation-delay: 0.18s; top: 11px; border-color: color-mix(in srgb, var(--accent-color) 65%, transparent); }
.slux-ab-sc.c3 { animation-delay: 0.36s; top: 22px; border-color: color-mix(in srgb, var(--accent-color) 38%, transparent); }

@keyframes slux-ab-chev {
    0%   { opacity: 0; transform: translate(-50%, -6px) rotate(45deg); }
    50%  { opacity: 1; }
    100% { opacity: 0; transform: translate(-50%, 9px) rotate(45deg); }
}

/* ─── Second Order CTA block ────────────────── */
/* Scoped under .post-content-inner to beat post-content.css specificity */

.post-content-inner .slux-ab-cta {
    margin: max(48px, calc(3.33vw * var(--scale))) 0;
    padding: max(36px, calc(2.5vw * var(--scale)));
    border: 1px solid color-mix(in srgb, var(--accent-color) 35%, transparent);
    background:
        linear-gradient(135deg, color-mix(in srgb, var(--accent-color) 8%, transparent) 0%, transparent 60%),
        color-mix(in srgb, var(--text-color) 3%, transparent);
    box-shadow: 0 0 40px color-mix(in srgb, var(--accent-color) 8%, transparent),
                inset 0 1px 0 color-mix(in srgb, var(--accent-color) 20%, transparent);
    display: flex;
    flex-direction: column;
    gap: max(20px, 1.39vw);
    position: relative;
    overflow: hidden;
}

.post-content-inner .slux-ab-cta::before {
    content: "";
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 1px;
    background: linear-gradient(to right,
        transparent,
        color-mix(in srgb, var(--accent-color) 70%, transparent) 30%,
        color-mix(in srgb, var(--accent-color) 30%, transparent) 70%,
        transparent);
}

.post-content-inner .slux-ab-cta-eyebrow {
    font-family: var(--font2);
    font-size: max(10px, calc(0.69vw * var(--scale)));
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--accent-color);
    display: flex;
    align-items: center;
    gap: 10px;
    opacity: 1;
}

.post-content-inner .slux-ab-cta-eyebrow::before {
    content: "";
    display: block;
    width: 16px;
    height: 1px;
    background: var(--accent-color);
    flex-shrink: 0;
}

.post-content-inner .slux-ab-cta-title {
    font-family: var(--font1);
    font-size: max(30px, calc(2.08vw * var(--scale))) !important;
    font-weight: 400;
    letter-spacing: -0.025em;
    line-height: 1.1;
    margin: 0 !important;
    color: inherit;
}

.post-content-inner .slux-ab-cta-sub {
    font-family: var(--font2);
    font-size: max(14px, calc(0.97vw * var(--scale)));
    line-height: 1.65;
    opacity: 0.65;
    margin: 0;
    max-width: 52ch;
}

.post-content-inner .slux-ab-cta-perks {
    display: flex !important;
    flex-wrap: wrap;
    gap: 8px;
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

.post-content-inner .slux-ab-cta-perks li {
    font-family: var(--font2);
    font-size: max(11px, calc(0.76vw * var(--scale)));
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--accent-color);
    border: 1px solid color-mix(in srgb, var(--accent-color) 30%, transparent);
    background: color-mix(in srgb, var(--accent-color) 8%, transparent);
    padding: 5px 12px !important;
    margin: 0 !important;
    opacity: 0.85;
    list-style: none !important;
}

.post-content-inner .slux-ab-cta-perks li::before {
    display: none !important;
}

.post-content-inner .slux-ab-cta-actions {
    display: flex;
    align-items: center;
    gap: max(14px, 0.97vw);
    flex-wrap: wrap;
    padding-top: max(4px, 0.28vw);
}

.post-content-inner .slux-ab-cta-btn {
    display: inline-flex !important;
    align-items: center;
    gap: 8px;
    font-family: var(--font2);
    font-size: max(12px, calc(0.83vw * var(--scale)));
    letter-spacing: 0.1em;
    text-transform: uppercase;
    text-decoration: none !important;
    color: var(--background-color) !important;
    background: var(--accent-color) !important;
    padding: max(12px, 0.83vw) max(24px, 1.67vw) !important;
    transition: opacity 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
    box-shadow: 0 0 20px color-mix(in srgb, var(--accent-color) 40%, transparent);
    border: none;
}

.post-content-inner .slux-ab-cta-btn:hover {
    opacity: 0.88;
    transform: translateY(-1px);
    box-shadow: 0 4px 28px color-mix(in srgb, var(--accent-color) 55%, transparent);
    color: var(--background-color) !important;
}

.post-content-inner .slux-ab-cta-link {
    font-family: var(--font2);
    font-size: max(12px, calc(0.83vw * var(--scale)));
    letter-spacing: 0.06em;
    text-decoration: none !important;
    color: inherit !important;
    opacity: 0.45;
    transition: opacity 0.2s ease;
}

.post-content-inner .slux-ab-cta-link:hover {
    opacity: 0.8;
    text-decoration: none !important;
}

/* ─── Post body spacing ──────────────────────── */

.slux-ab-hero + .post-content {
    padding-top: max(64px, calc(4.44vw * var(--scale)));
}

/* ─── Mobile ─────────────────────────────────── */

@media (max-width: 991px) {
    .slux-ab-hero-title {
        font-size: 44px !important;
    }
}

@media (max-width: 479px) {
    .slux-ab-scroll { display: none; }
    .slux-ab-hero-title { font-size: 34px !important; }
    .slux-ab-hero-sub { font-size: 14px !important; }
}
