
:root {
    --brand: #cb1002;
    --brand-2: #0f0f0f;
    --accent: #f5d4d4;
}

body {
    scroll-behavior: smooth;
}

.navbar-brand b {
    display: inline-block;
    vertical-align: middle;
    font-size: 1.25rem;
    color: var(--brand-2);
    letter-spacing: .3px;
}

@media (max-width: 575.98px) {
    .navbar-brand b {
        display: none !important;
    }

    .navbar-brand img {
        margin-right: 0 !important;
        max-width: 140px;
        height: 28px !important;
    }
}

.hero {
    background: linear-gradient(180deg, #fff5f5, #fffefb);
}

    .hero .ratio {
        box-shadow: 0 10px 30px rgba(0, 0, 0, .1);
    }

.confidence .icon {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    background: var(--accent);
    display: grid;
    place-items: center;
}

.card-hover {
    transition: transform .2s, box-shadow .2s;
}

    .card-hover:hover {
        transform: translateY(-4px);
        box-shadow: 0 10px 24px rgba(0, 0, 0, .08);
    }

.eyebrow {
    font-size: .85rem;
    text-transform: uppercase;
    letter-spacing: .12em;
    color: var(--brand);
}

.featured .price {
    font-weight: 600;
}

.cta-band {
    background: linear-gradient(90deg, var(--brand), #b30f02);
}

    .cta-band .btn-outline-light {
        border-color: #fff;
    }

.link-underline {
    position: relative;
}

    .link-underline::after {
        content: "";
        position: absolute;
        left: 0;
        bottom: -2px;
        width: 0;
        height: 2px;
        background: currentColor;
        transition: width .2s;
    }

    .link-underline:hover::after {
        width: 100%;
    }

.bg-dots {
    background-image: radial-gradient(#e9ecef 2px, transparent 2px);
    background-size: 24px 24px;
}

.btn:focus-visible {
    outline: 3px solid #000;
    outline-offset: 2px;
}

.btn-primary {
    background-color: var(--brand);
    border-color: var(--brand);
}

    .btn-primary:hover {
        background-color: #b30f02;
        border-color: #b30f02;
    }

.btn-outline-primary {
    color: var(--brand);
    border-color: var(--brand);
}

    .btn-outline-primary:hover {
        background-color: var(--brand);
        border-color: var(--brand);
        color: #fff;
    }

a {
    color: var(--brand);
}

    a:hover {
        color: #b30f02;
    }

.footer-sleek {
    background: linear-gradient(120deg, var(--brand-2) 80%, var(--brand) 100%);
    color: #fff;
    border-top: 4px solid var(--brand);
    box-shadow: 0 -2px 24px rgba(0,0,0,0.12);
    font-size: 1rem;
}

    .footer-sleek .footer-logo {
        filter: drop-shadow(0 2px 8px rgba(0,0,0,0.12));
        background: #fff;
        border-radius: 6px;
        padding: 6px 12px 6px 0;
        margin-bottom: 1rem;
        max-width: 220px;
    }

    .footer-sleek h5, .footer-sleek .h6 {
        color: var(--brand);
        letter-spacing: .04em;
        font-weight: 700;
        margin-bottom: .7rem;
    }

    .footer-sleek a.link-light {
        color: #fff !important;
        opacity: 0.92;
        transition: color .18s, opacity .18s;
    }

    .footer-sleek a.link-light:hover {
        color: var(--brand);
        opacity: 1;
        text-decoration: underline;
    }

    .footer-sleek .footer-hr {
        border: none;
        border-top: 1.5px solid #333;
        margin: 2.5rem 0 1.5rem 0;
        opacity: 0.5;
    }

    .footer-sleek .footer-bottom {
        font-size: .97rem;
        color: #bbb;
    }

    .footer-sleek .footer-bottom a {
        color: #bbb;
        margin-left: 1.5rem;
        transition: color .18s;
    }

    .footer-sleek .footer-bottom a:hover {
        color: var(--brand);
    }

.submit-section {
    text-align: center;
    margin-top: 40px;
}

.submit-btn {
    border-radius: 50px;
    font-size: 18px;
    font-weight: 600;
    min-width: 200px;
    padding: 10px 20px;
}
