:root {
    --brand-navy: #0e2345;
    --brand-green: #7ac943;
    --brand-light: #f5f7fa;
    --brand-grey: #bcc5cf;
}

* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

body {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    background-color: var(--brand-navy);
    color: var(--brand-light);
    height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 1rem;
}

html, body {
    margin: 0;
    padding: 0;
    height: 100%;
    background-color: var(--brand-navy);
}

.wrapper {
    max-width: 650px;
    width: 100%;
    padding-left: 20px;
    padding-right: 20px;
}

.logo {
    display: inline-block;
    background: #fff;
    padding: 0.5rem 1rem;
    border-radius: 6px;
}

    .logo img {
        display: block;
        max-width: 100%;
        height: auto;
    }


h1 {
    font-size: 2.5rem;
    margin-top: 1.5rem;
    margin-bottom: 1.5rem;
    line-height: 1.1;
}

p {
    margin-bottom: 1.5rem;
    color: var(--brand-grey);
}

.subscribe {
    display: flex;
    width: 100%;
    margin-top: 2rem;
    margin-bottom: 2rem;
}

    .subscribe input {
        flex: 1;
        padding: 0.75rem 1rem;
        border: none;
        border-radius: 4px 0 0 4px;
        font-size: 1rem;
    }

    .subscribe button {
        padding: 0.75rem 1.25rem;
        border: none;
        border-radius: 0 4px 4px 0;
        background-color: var(--brand-green);
        color: var(--brand-navy);
        font-weight: bold;
        cursor: pointer;
        transition: background 0.2s;
    }

/*        .subscribe button:hover {
            background-color: darken(var(--brand-green), 10%);
        }*/

        .subscribe button:hover:not(:disabled) {
            background-color: #6fb33e; /* darker shade of your --brand-green */
        }

/*        .subscribe button:disabled {
            background-color: var(--brand-navy);
            color: var(--brand-light);
            opacity: 1;
        }*/

        .subscribe button:disabled,
        .subscribe button:disabled:hover {
            background-color: var(--brand-green) !important;
            color: var(--brand-navy) !important;
            opacity: 1 !important;
            cursor: default;
        }


footer {
    font-size: 0.85rem;
    color: var(--brand-grey);
}

/* Optional: constrain modal width to match your design */
#responseModal .modal-dialog {
    max-width: 400px;
}

/* Remove Bootstrap’s default borders and give a soft radius */
#responseModal .modal-content {
    background: var(--brand-light);
    border: none;
    border-radius: 8px;
    overflow: hidden;
}

/* Navy header, white title text, no bottom border */
#responseModal .modal-header {
    background-color: var(--brand-navy);
    color: var(--brand-light);
    border-bottom: none;
    padding: 1rem 1.5rem;
}

    /* White “×” icon on navy */
    #responseModal .modal-header .close span {
        color: var(--brand-light);
        opacity: 1;
    }

/* Body text in navy on a light background */
#responseModal .modal-body {
    padding: 1.5rem;
    color: var(--brand-navy);
    font-size: 1rem;
    background: var(--brand-light);
}

/* Light footer, no top border */
#responseModal .modal-footer {
    background: var(--brand-light);
    border-top: none;
    justify-content: center;
    padding: 1rem;
}

    /* Green primary button instead of btn-secondary */
    #responseModal .modal-footer .btn {
        background-color: var(--brand-green);
        color: var(--brand-navy);
        border: none;
        font-weight: bold;
        padding: 0.6rem 1.2rem;
        border-radius: 4px;
        transition: background 0.2s;
    }

        /* On hover, slightly darker green */
        #responseModal .modal-footer .btn:hover {
            background-color: #6fb33e;
        }
