
/* Home page
*/

/* Footer */
.footer {
    background: #1f2937;
    color: #f3f4f6;
    padding: 4rem 2rem 2rem;
}

.footer-content {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 2rem;
    margin-bottom: 2rem;
}

.footer-section h3 {
    color: #fff;
    margin-bottom: 1rem;
    font-size: 1.2rem;
    text-align: center;
}

.footer-section ul {
    list-style: none;
    padding: 0;
}

.footer-section ul li {
    margin-bottom: 0.5rem;
}

.footer-section a {
    color: #f3f4f6;
    text-decoration: none;
    transition: color 0.3s ease;
}

.footer-section a:hover {
    color: #fff;
    text-decoration: underline;
}

.footer-bottom {
    border-top: 1px solid #374151;
    padding-top: 2rem;
    text-align: center;
    font-size: 0.9rem;
}

.footer-bottom a {
    color: aquamarine;
}

.footer-section.contact {
    width: 100%;
}
.footer-section .container {
    padding: 0;
}
.footer-section .container.row .container.column {
    padding: 1vh 2vw;
}

@media (max-width: 768px) {
    .footer-content {
        grid-template-columns: 1fr;
        text-align: center;
    }
}

@media (max-width: 540px) {
    .nav-links {
        display: none;
    }
}
/* Common */
section {
    padding: 2rem;
}
p {
    width: 100%;
    font-size: 16px;
}
p.section-title,
p.section-subtitle {
    margin: 0 auto;
}
.section-subtitle {
    font-size: 18px;
}
ul li {
    font-size: 16px;
}

section.benefits .card.benefits,
section.social-proof .card.social-proof {
    display: flex;
}

section.problem,
section.benefits,
section.solution,
section.testimonial {
    padding: 4rem 2rem;
    background: var(--colour-page-background-1);
}
section.problem .card.problem,
section.benefits .card.benefits,
section.solution .card.solution,
section.testimonial .card.testimonial {
    background: var(--colour-text-background);
    border-radius: 8px;
    max-width: 800px;
    margin: 3rem auto 0;
    box-shadow: 0 4px 6px rgba(0,0,0,0.1);
}


/* Hero Section */
.hero {
    padding: 8rem 2rem 4rem;
    background: linear-gradient(45deg, var(--colour-page-background-1), var(--colour-page-background-2)); /* linear-gradient(45deg, #f8fafc, #eff6ff); */
}
.hero-content {
    max-width: 600px;
}
.hero h1 {
    line-height: 1.2;
    margin-bottom: 1.5rem;
    color: var(--colour-text);
}
.hero p {
    font-size: 1.25rem;
    margin-bottom: 2rem;
    color: var(--colour-secondary);
}
section.hero .button {
    margin: 0 auto;
    margin-bottom: 2vh;
    display: block;
    background-color: var(--colour-success-title);
    color: var(--colour-text-background);
}
section.hero .button:hover {
    background-color: var(--colour-success-highlight);
    color: var(--colour-success-title);
}


/* Problem Section */
section.problem {
    background-color: var(--colour-error-highlight);
}
section.problem h2 {
    color: var(--colour-error-title);
}
section.problem .card {
    border-left: 4px solid var(--colour-error-accent);
}
section.problem ul li {
    list-style: none;
}


/*
section.problem .problem.card:hover {
    transform: translateY(-5px);
}
*/
section.problem .section-subtitle {
    /* font-size: 18px; */
    font-weight: bold;
}
/*
section.problem ul li::before {
    content: "😤";
    position: absolute;
    left: 0;
  }
*/


/* Benefits Section * /
section.benefits .section-subtitle {
    font-size: 18px;
    font-weight: bold;
}
*/
section.benefits {
    background-color: var(--colour-success-highlight);
}
section.benefits .container .card .container {
    min-width: 250px;
}
section.benefits h2 {
    color: var(--colour-success);
}
section.benefits .card {
    border-left: 4px solid var(--colour-success);
}

/* Solution Section */
section.solution .container .card {
    margin-top: 1vh;
    max-width: min(2000px, 80vw);
}

section.benefits .card.benefits .container,
section.solution .container .card .container {
    padding: 1vh 2vw;
    max-width: min(500px, 80vw);
}
section.solution .container .card .container p {
    margin-bottom: 1vh;
}
section.solution .project-thumbnail img {
    max-width: min(500px, 80vw);
    max-height: min(500px, 80vw);
    border-radius: 1vh;
}

section.solution .project-thumbnail img {
    overflow: hidden;
    transition: transform 0.3s ease;
}
section.solution .project-thumbnail:hover {
    transform: scale(1.75);
}

/* Social Proof Section * /
section.social-proof {
    padding: 6rem 0;
    background: white;
}

section.social-proof .card.social-proof {
    background: var(--colour-page-background);
    padding: 2rem;
    border-radius: 8px;
    text-align: center;
    max-width: 400px;
    margin: 3rem auto 0;
}

section.social-proof ul {
    list-style: none;
    margin: 0;
}
* /

section.social-proof .section-subtitle {
    font-size: 16px;
}
section.social-proof ul li {
    font-size: 14px;
}
*/
section.social-proof {
    padding: 4rem 0;
    background: var(--colour-text-background);
}
section.social-proof .card.social-proof { 
    background: var(--colour-page-background);
    border-radius: 8px;
    transition: transform 0.3s ease;
    padding: 1.5vh;
}
section.social-proof .section-title {
    font-weight: bold;
    color: var(--colour-text-link-visited);
    margin-bottom: 0.25vh;
}
section.social-proof .section-subtitle {
    margin: 0 1vw 1vh;
}
section.social-proof .container {
    width: fit-content;
    margin: 0 2vw;
    min-width: 175px;
}
section.social-proof > .container {
    max-width: min(900px, 90vw);
    margin: 1vh auto;
}

/* Early Access Section * /
section.early-access {
    padding: 6rem 0;
    background: white;
}

section.early-access .card.early-access {
    background: var(--colour-page-background);
    padding: 2rem;
    border-radius: 8px;
    text-align: center;
    max-width: 400px;
    margin: 3rem auto 0;
}

section.early-access ul {
    list-style: none;
    margin: 0;
}
section.early-access a.button {
    margin: 0.25rem;
}
*/

/* Features section * /
section.features .button {
    margin-top: 0;
}
*/

/* Testimonials section */
section.testimonial p {
    margin-bottom: 1vh;
}
section.testimonial h2 {
    margin: 0 auto;
}

/* CTA Section */
.cta-1,
.cta-2 {
    padding: 6rem 2rem;
    background: linear-gradient(135deg, var(--colour-primary), var(--colour-text-link-visited));
    color: white;
    text-align: center;
}

section.cta-2 .button {
    margin: 2vh 1vw;
}
section.cta-2 .card {
    background-color: transparent;
    margin: 1vh auto;
}
section.cta-2 .card .container {
    background-color: var(--colour-page-background);
    color: var(--colour-primary);
    border-radius: 1vh;
    padding: 1.5vh 3vw;
    margin: 1vh;
    min-width: 200px;
    min-height: 120px;
}
section.cta-2 .card .container h3 {
    margin: 0 auto;
}
section.cta-2 .container p {
    margin-top: 1vh;
}
/* FAQs * /
section.faq .button {
    margin-bottom: 0.25rem;
}
*/


/* Animations */
/* Fallback styles to ensure content is visible without JS */
.reveal {
    opacity: 1; /* Default visible state */
}

/* Only hide elements if browser supports Intersection Observer */
@supports (animation-name: fade) {
    .reveal {
        opacity: 0;
    }

    .reveal.active {
        animation: fade-up 0.8s ease-out forwards;
    }
}

@keyframes fade-up {
    0% {
        opacity: 0;
        transform: translateY(30px);
    }
    100% {
        opacity: 1;
        transform: translateY(0);
    }
}

.delay-1 { animation-delay: 0.1s; }
.delay-2 { animation-delay: 0.2s; }
.delay-3 { animation-delay: 0.3s; }
.delay-4 { animation-delay: 0.4s; }

/* Buttons */
.topnav .nav-links .button {
    padding: 0.5vh 0.75vh;
}
.button {
    padding: 0.75rem 1.5rem;
    /* border-radius: 6px; * /
    margin: 0.75rem; */
    font-size: 1.2rem;
}

.button-primary {
    background: var(--colour-primary);
    color: white;
}

.button-primary:hover {
    background: var(--colour-secondary);
}

.button-light {
    background: white;
    color: var(--colour-primary);
}

.button-light:hover {
    background: var(--colour-page-background);
}

.logo:hover{
    cursor: pointer;
}

/*# sourceMappingURL=core_home.bundle.css.map*/