body {
    font-family: Arial, sans-serif;
    background: #f4f6fa;
    margin: 0;
    padding: 0;
}
.container {
    width: 550px;
    background: #fff;
    padding: 24px;
    border-radius: 8px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.08);
    text-align: center;
    margin: 0 auto;
}
.container.legal {
    text-align: justify;
}
h1, h2 {
    color: #2d3a4b;
    margin-bottom: 16px;
    margin-top: 0;
}
form {
    margin-top: 24px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
input[type="text"], input[type="email"], input[type="password"] {
    padding: 10px;
    border: 1px solid #cfd8dc;
    border-radius: 4px;
    font-size: 1em;
}
button, .button {
    padding: 10px 24px;
    background: #1976d2;
    color: #fff;
    border: none;
    border-radius: 4px;
    font-size: 1em;
    cursor: pointer;
    text-decoration: none;
}
button:hover, .button:hover {
    background-color: #005fa3;
}
.logout-form .button {
    background: #d32f2f;
}
.logout-form .button:hover,
.logout-form .button:focus {
    background-color: #b71c1c;
}
.main-nav .login-link{
    margin-top: 0;
}
.register-link, .login-link {
    margin-top: 18px;
    font-size: 0.97em;
}
.register-link a, .login-link a {
    color: #1976d2;
    text-decoration: none;
}
.register-link a:hover, .login-link a:hover {
    text-decoration: underline;
}
.welcome-message, .campaigns-table, .create-campaign {
    color: #4a5a6a;
    font-size: 1.08em;
}
.error {
    color: #d32f2f;
    margin-bottom: 16px;
    text-align: left;
}
.button {
    display: inline-block;
    padding: 10px 24px;
    background-color: #1976d2;
    color: #fff;
    border: none;
    border-radius: 4px;
    font-size: 1em;
    font-weight: 500;
    text-decoration: none;
    cursor: pointer;
    transition: background 0.2s, box-shadow 0.2s;
    box-shadow: 0 2px 8px rgba(49,66,91,0.08);
}

.button:hover,
.button:focus {
    background-color: #005fa3;
    color: #fff;
    box-shadow: 0 4px 16px rgba(49,66,91,0.12);
    text-decoration: none;
}
.marketing-section {
    background: #f8f9fa;
    border-radius: 10px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.04);
    padding: 2em 1.5em;
    margin-top: 2em;
    margin-bottom: 2em;
    text-align: left;
}

.marketing-section ul {
    list-style: disc inside;
    margin-bottom: 1em;
    padding-left: 1em;
}

.marketing-section li {
    margin-bottom: 0.7em;
    font-size: 1.08em;
}

.marketing-section p {
    margin-top: 1.5em;
    font-size: 1.1em;
}

a.highlight {
    color: #28a745;
    text-decoration: underline;
    font-weight: bold;
}

a.highlight:hover {
    color: #218838;
    text-decoration: none;
}
.marketing-list {
    list-style: none;
    padding: 0;
    margin: 0 0 1.5em 0;
    display: flex;
    flex-direction: column;
    gap: 1.5em;
}

.marketing-list li {
    display: flex;
    align-items: flex-start;
    gap: 1em;
    background: #fff;
    border-radius: 8px;
    box-shadow: 0 1px 4px rgba(49,66,91,0.06);
    padding: 1.2em 1em;
    transition: box-shadow 0.2s;
}

.marketing-list li:hover {
    box-shadow: 0 4px 16px rgba(49,66,91,0.10);
}

.marketing-list strong {
    display: block;
    font-size: 1.13em;
    margin-bottom: 0.2em;
    color: #2d3a4b;
}

.marketing-list span {
    color: #4a5a6a;
    font-size: 1em;
}

.legal ul {
    padding-left: 0;
    margin-bottom: 1.5em;
    list-style-type: none;
}

.legal ul li {
    background: #f8f9fa;
    border: 1px solid #e2e6ea;
    border-radius: 6px;
    margin-bottom: 0.7em;
    padding: 0.8em 1em;
    line-height: 1.6;
    /* Remove the disc */
    list-style: none;
}

/* Add to style.css */
.footer-container {
    max-width: 900px;
    margin: 0 auto;
    padding: 24px 0 8px 0;
    text-align: center;
    color: #6c7a89;
    font-size: 0.98em;
}

.footer-links {
    margin-bottom: 8px;
}

.footer-links a {
    color: #1976d2;
    text-decoration: none;
    margin: 0 8px;
    font-weight: 500;
}

.footer-links a:hover {
    text-decoration: underline;
    color: #31425b;
}

.footer-separator {
    color: #b0b8c1;
    margin: 0 4px;
}

.footer-copy {
    margin-bottom: 6px;
    color: #8a99a8;
    font-size: 0.97em;
}

.footer-legal {
    font-size: 0.93em;
    color: #b0b8c1;
    margin-top: 4px;
}

        .hero {
            text-align: center;
            padding: 3em 1em 2em 1em;
            width: calc(1092px - 2em);
            margin: 0 auto;
        }
        .hero h1 {
            font-size: 2.5em;
            margin-bottom: 0.3em;
        }
        .hero p {
            font-size: 1.3em;
            color: #4a5a6a;
            margin-bottom: 1.5em;
        }

        .overview-card-container {
            display: flex;
            justify-content: center;
            margin: 2.5em 0;
        }
        .overview-card {
            background: #fff;
            border-radius: 10px;
            box-shadow: 0 2px 8px rgba(49,66,91,0.08);
            padding: 2.5em 2em 2.5em 2em;
            max-width: 550px;
            width: 100%;
        }
        .product-overview-container {
            display: flex;
            flex-wrap: wrap;
            gap: 2em;
            justify-content: center;
            margin: 0 auto;
            padding: 0 1em;
        }
        .product-card {
            background: #ffffff;
            border-radius: 10px;
            box-shadow: 0 2px 8px rgba(49,66,91,0.06);
            margin-bottom: 2em;
            padding: 2em 1.5em 2em 1.5em;
            position: relative;
            display: flex;
            flex-direction: column;
            width: 32%;
            min-width: 300px;
            max-width: 380px;
            flex: 1 1 32%;
        }

.product-card .icon {
    font-size: 3em;
    display: flex;
    align-items: center;   /* Vertically center icon itself */
    justify-content: center;
    margin: 0 0.5em;
}

.product-card-content {
    display: flex;
    flex-direction: column;
}

.product-card-header {
    width: 100%;
}

.product-card-main {
    display: flex;
    flex-direction: row;
    align-items: center; /* Vertically center the icon with the list */
    width: 100%;
}

.product-card-main ul {
    margin: 0;
    padding-left: 1.2em;
    flex: 1 1 0;
}

    .product-card .button {
        width: calc(100% - 48px);
        text-align: center;;
    }

    .soon-label {
        background: #ffd600;
        color: #31425b;
        font-weight: bold;
        border-radius: 3px;
        padding: 0.2em 0.7em;
        margin-left: 0.7em;
        font-size: 0.95em;
        border-radius: .5em;
        white-space: nowrap;
    }

        .features-list {
            padding: 0;
            list-style: none;
            margin-block-start: 0;
        }
        .features-list li {
            background: #f7fafd;
            border-radius: 8px;
            margin-bottom: 1.5em;
            padding: 1.5em 1.5em 1.5em 5.5em;
            position: relative;
            box-shadow: 0 2px 8px rgba(49,66,91,0.06);
            font-size: 1.1em;
        }
        .features-list li .icon {
            position: absolute;
            left: 0;
            top: 0;
            font-size: 3em;
            color: #1976d2;
            margin: 37px 20px;
        }
        .features-list strong {
            display: block;
            font-size: 1.15em;
            margin-bottom: 0.3em;
            color: #31425b;
        }

        .pricing-table {
            display: flex;
            justify-content: center;
            gap: 2em;
            margin: 2em 0;
            flex-wrap: wrap;
        }
        .pricing-plan {
            background: #fff;
            border-radius: 8px;
            box-shadow: 0 2px 8px rgba(49,66,91,0.08);
            padding: 2em 1.5em;
            width: 270px;
            text-align: center;
            border: 2px solid #f4f6fa;
            transition: border 0.2s;
        }
        .pricing-plan.featured {
            border: 2px solid #1976d2;
        }
        .pricing-title {
            font-size: 1.3em;
            color: #1976d2;
            margin-bottom: 0.5em;
            font-weight: bold;
        }
        .pricing-price {
            font-size: 2.2em;
            color: #2d3a4b;
            margin-bottom: 0.5em;
            font-weight: bold;
        }
        .pricing-desc {
            color: #4a5a6a;
            margin-bottom: 1em;
            font-size: 1.05em;
        }
        .pricing-features {
            list-style: none;
            padding: 0;
            margin: 0 0 1.2em 0;
            color: #31425b;
            font-size: 1em;
            text-align: left;
        }
        .pricing-features li {
            margin-bottom: 0.7em;
            padding-left: 1.2em;
            position: relative;
        }
        .pricing-features li:before {
            content: "✔";
            color: #1976d2;
            position: absolute;
            left: 0;
        }
        .pricing-btn {
            display: inline-block;
            padding: 10px 24px;
            background-color: #1976d2;
            color: #fff;
            border: none;
            border-radius: 4px;
            font-size: 1em;
            font-weight: 500;
            text-decoration: none;
            cursor: pointer;
            transition: background 0.2s, box-shadow 0.2s;
            box-shadow: 0 2px 8px rgba(49,66,91,0.08);
        }

body.login-page {
    min-height: 75vh;
    display: flex;
}

body.login-page .container {
    background: #fff;
    padding: 24px;
    border-radius: 8px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.08);
    text-align: center;
    margin: auto; /* Center horizontally and vertically */
    /* If you want to only center vertically, use: margin-top: auto; margin-bottom: auto; */
}

/* Greater than 1080px */
@media  (min-width: 771px) and (max-width: 1092px) {
    .hero {
        width: calc(770px - 2em);
    }
    .product-overview-container {
        flex-direction: column;
        align-items: center;
        gap: 1.2em;
    }
    .product-card {
        width: 100%;
        min-width: 0;
    }
}

/* 770px and below */
@media (min-width: 551px) and (max-width: 770px) {
    .hero {
        width: calc(550px - 2em);
    }
}

/* Less than 550px */
@media (max-width: 550px) {
    .hero {
        width: calc(100% - 2em);
    }

    .soon-label {
        font-size: .75em;
    }
}