/* =====================================================
   RLA Shared Design Tokens & Section Utilities
   Loaded globally for all Revenue Leak Audit blocks
   ===================================================== */

/* --- Variables (extend theme root) --- */
:root {
    --rla-red-d: #e14f4f;
    --rla-red-glow: rgba(253, 101, 101, 0.13);
    --rla-red-light: #fff1f1;
    --rla-gray-bg: #F5F4F4;
    --rla-gray-text: #636363;
    --rla-gray-muted: #A8A8A8;
    --rla-border: rgba(0, 0, 0, 0.07);
    --rla-border-m: rgba(0, 0, 0, 0.13);
}

/* =====================================================
   Section wrappers
   ===================================================== */
.rla-sec {
    padding: 100px 0;
    overflow: hidden;
}

.rla-sec--gray {
    background: var(--rla-gray-bg);
}

.rla-sec--dark {
    background: var(--black, #080808);
}

.rla-sec--redlight {
    background: var(--rla-red-light);
}

/* =====================================================
   Centred section header
   ===================================================== */
.rla-ctr {
    text-align: center;
    margin-bottom: 60px;
}

.rla-ctr .rla-lead {
    margin: 0 auto;
}

.rla-ctr--mb56 {
    margin-bottom: 56px;
}

/* =====================================================
   Eyebrow label
   ===================================================== */
.rla-eyebrow {
    font-size: 11px;
    line-height: 1.6;
    font-weight: 800;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--red, #FD6565);
    margin-bottom: 14px;
    display: block;
}

.rla-eyebrow--muted {
    color: var(--rla-gray-muted);
}

.rla-eyebrow--redmuted {
    color: rgba(253, 101, 101, 0.80);
}

/* =====================================================
   Section heading (h2)
   ===================================================== */
h2.rla-h2 {
    font-size: clamp(28px, 3.6vw, 46px);
    font-weight: 900;
    letter-spacing: -1.8px;
    line-height: 1.08;
    color: var(--black, #080808);
    margin-bottom: 18px;
    font-family: "Albert Sans", sans-serif;
}

h2.rla-h2--white {
    color: #fff;
}

/* =====================================================
   Lead / body copy
   ===================================================== */
.rla-lead {
    font-size: 18px;
    color: var(--rla-gray-text);
    line-height: 1.7;
    max-width: 560px;
    font-family: "Albert Sans", sans-serif;
}

.rla-lead--mt {
    margin-top: 14px;
}

.rla-lead--center {
    margin: 0 auto;
}

.rla-lead--dim {
    color: rgba(255, 255, 255, 0.55);
}

/* =====================================================
   Dark-section overrides (used in How It Works)
   ===================================================== */
.rla-sec--dark h2.rla-h2 {
    color: #fff;
}

.rla-sec--dark .rla-lead {
    color: rgba(255, 255, 255, 0.55);
}

/* =====================================================
   RLA Form (Shared)
   ===================================================== */
.rla-form {
    display: flex;
    flex-direction: column;
    gap: 11px;
}

.rla-frow2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 11px;
}

.rla-fw {
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.rla-fi {
    width: 100% !important;
    height: 52px !important;
    padding: 0 16px !important;
    border: 1.5px solid var(--rla-border-m) !important;
    border-radius: 11px !important;
    background: var(--white, #fff) !important;
    color: var(--black, #080808) !important;
    font-family: "Albert Sans", sans-serif !important;
    font-size: 15px !important;
    outline: none !important;
    transition: border-color 0.2s, box-shadow 0.2s !important;
    margin-bottom: 0 !important;
}

.rla-fi::placeholder {
    color: var(--rla-gray-muted) !important;
}

.rla-fi:focus {
    border-color: var(--red, #FD6565) !important;
    box-shadow: 0 0 0 4px var(--rla-red-glow) !important;
}

.rla-fi.bad {
    border-color: #d42828 !important;
    box-shadow: 0 0 0 4px rgba(212, 40, 40, 0.09) !important;
}

.rla-ferr {
    font-size: 12px;
    color: #b31f1f;
    font-weight: 600;
    display: none;
    padding-left: 2px;
}

.rla-ferr.on {
    display: block;
}

.rla-email-hint {
    font-size: 12px;
    color: var(--rla-gray-muted);
    padding-left: 2px;
    margin-top: -4px;
}

.rla-sbtn {
    height: 58px;
    width: 100%;
    border: none;
    border-radius: 12px;
    background: var(--red, #FD6565);
    color: var(--white, #fff);
    font-family: "Albert Sans", sans-serif;
    font-size: 16px;
    font-weight: 800;
    letter-spacing: 0.02em;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    transition: background 0.2s, transform 0.12s, box-shadow 0.2s;
    box-shadow: 0 6px 24px rgba(253, 101, 101, 0.4);
    margin-top: 4px;
    text-decoration: none;
}

.rla-sbtn:hover {
    background: var(--rla-red-d);
    transform: translateY(-1px);
    box-shadow: 0 10px 32px rgba(253, 101, 101, 0.44);
    color: var(--white, #fff);
}

.rla-sbtn:disabled {
    opacity: 0.7;
    cursor: not-allowed;
    transform: none;
}

.rla-spin {
    width: 18px;
    height: 18px;
    border: 2.5px solid rgba(255, 255, 255, 0.28);
    border-top-color: #fff;
    border-radius: 50%;
    display: none;
    animation: rla-spin 0.7s linear infinite;
}

@keyframes rla-spin {
    to {
        transform: rotate(360deg);
    }
}

.rla-form-foot {
    font-size: 12px;
    color: var(--rla-gray-muted);
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 18px;
    margin-top: 4px;
}

.rla-form-foot span {
    display: flex;
    align-items: center;
    gap: 4px;
}

/* Dark section specific overrides for form foot */
.rla-sec--dark .rla-form-foot,
.rla-final-sec .rla-form-foot {
    color: rgba(255, 255, 255, 0.35);
}

.rla-sec--dark .rla-email-hint,
.rla-final-sec .rla-email-hint {
    color: rgba(255, 255, 255, 0.35);
}

/* =====================================================
   Responsive
   ===================================================== */
@media (max-width: 900px) {
    .rla-frow2 {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    .rla-sec {
        padding: 72px 0;
    }

    .rla-ctr {
        margin-bottom: 40px;
    }
}