:root {
    --bg-primary: #0d1b2e;
    --bg-secondary: #111e30;
    --border: #1a2d45;
    --text-primary: #ffffff;
    --text-secondary: #8ba4bc;
    --cyan: #00c8d4;
    --purple: #6b5fd6;
    --btn-primary: #0A4F6E;
    --btn-primary-hover: #083D56;
    --btn-secondary: #111E30;
    --btn-secondary-hover: #0D1825;
}

@font-face {
    font-family: 'Exo 2';
    src: url("/Assets/Fonts/Exo 2.ttf");
}

html, body {
    margin: 0;
    padding: 0;
    font-family: 'Exo 2';
    background-color: var(--bg-primary);
}

#header {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: row;
    background-color: var(--bg-secondary);
    border-bottom: 1px solid var(--border);
    box-shadow: 0px 0px 5px 0.5px var(--border);
    padding: 20px;
}

#headerLogo {
    width: 100px;
}

#headerLinksDesktop, #headerLinksMobile, #headerLinksMobileMenu {
    display: none;
}

@media (min-width: 769px) {
    #headerLinksDesktop {
        display: flex;
        flex-direction: row;
        margin-left: auto;
        gap: 20px;
        align-items: center;
    }

    #headerLinksDesktop a {
        text-decoration: none;
        color: var(--cyan);
        font-size: 16px;
        transition: color 0.3s ease;
    }

    #headerLinksDesktop a:hover {
        color: var(--purple);
    }

    #footer {
        width: 100%;
        background-color: var(--bg-secondary);
        border-top: 1px solid var(--border);
        box-shadow: 0px 0px 5px 0.5px var(--border);
        margin-top: 40px;
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 20px 0 20px 0;
        gap: 100px;
        flex-direction: row;
    }

    #pageLinks {
        display: flex;
        gap: 20px;
        display: flex;
        flex-direction: row;
        align-items: center;
    }

    #placedPopup {
        position: fixed;
        background-color: var(--bg-secondary);
        padding: 40px;
        top: 100px;
        max-width: 700px;
        bottom: auto;
        border-radius: 10px;
        border: 1px solid var(--border);
        z-index: 3;
        display: flex;
        flex-direction: column;
        align-items: center;
        overflow-y: auto;
        max-height: 750px;
        overflow-x: hidden;
    }

    #form {
        display: flex;
        flex-direction: row;
        align-items: start;
        justify-content: center;
        gap: 40px;
        width: 100%;
    }

    #left, #right {
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        width: 45%;
    }
}

@media (max-width: 768px) {
    #headerLinksMobile {
        display: flex;
        margin-left: auto;
    }

    #menuButton, #menuCloseButton {
        cursor: pointer;
        border: none;
        background-color: #00000000;
        padding: 0;
        outline: none;
        z-index: 2;
    }

    #headerLinksMobileMenu {
        position: fixed;
        display: flex;
        top: 0;
        bottom: 0;
        left: 0;
        right: 0;
        width: 100vw;
        height: 100vh;
        align-items: center;
        justify-content: center;
        flex-direction: column;
        z-index: 1;
        overflow: hidden;
        background-color: var(--bg-secondary);
        gap: 40px;
    }

    #headerLinksMobileMenu a {
        text-decoration: none;
        color: var(--cyan);
        font-size: 24px;
        transition: color 0.3s ease;
    }

    #headerLinksMobileMenu a:hover {
        color: var(--purple);
    }

    #footer {
        width: 100%;
        background-color: var(--bg-secondary);
        border-top: 1px solid var(--border);
        box-shadow: 0px 0px 5px 0.5px var(--border);
        margin-top: 40px;
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 20px 0 20px 0;
        gap: 40px;
        flex-direction: column;
    }

    #pageLinks {
        display: flex;
        gap: 20px;
        display: flex;
        flex-direction: column;
        align-items: center;
    }

    #placedPopup {
        position: fixed;
        background-color: var(--bg-secondary);
        padding: 40px;
        left: 0;
        right: 0;
        top: 0;
        bottom: 0;
        border: 1px solid var(--border);
        z-index: 3;
        display: flex;
        flex-direction: column;
        align-items: center;
        overflow-y: auto;
    }

    #form {
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 40px;
        width: 100%;
    }

    #left, #right {
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        width: 85%;
    }
}

#headerQuoteLink {
    color: var(--cyan);
    background-color: var(--btn-primary);
    padding: 10px;
    border-radius: 50px;
    font-size: 14px;
    border: 1px solid var(--border);
    cursor: pointer;
    font-family: "Exo 2";
    transition: background-color 0.3s ease, border-color 0.3s ease;
}

#headerQuoteLink:hover {
    background-color: var(--btn-primary-hover);
    border-color: var(--cyan);
}

#content {
    margin-top: 150px;
    display: flex;
    flex-direction: column;
    align-items: center;
}

#heading {
    font-size: 48px;
    color: var(--text-primary);
    margin-bottom: 20px;
    text-align: center;
}

#subheading {
    font-size: 24px;
    color: var(--text-secondary);
    margin-bottom: 40px;
    text-align: center;
    max-width: 1500px;
    padding: 20px;
}

#subheading a {
    color: var(--cyan);
    font-size: 16px;
    text-decoration: none;
    transition: color 0.3s ease;
    font-size: 24px;
}

#subheading a:hover {
    color: var(--purple);
}

#nameInput:focus, #emailInput:focus, #phoneInput:focus, #address1Input:focus, #address2Input:focus, #cityInput:focus, #postcodeInput:focus, #countyInput:focus, #countryInput:focus, #quantity:focus, #nameInput:hover, #emailInput:hover, #phoneInput:hover, #address1Input:hover, #address2Input:hover, #cityInput:hover, #postcodeInput:hover, #countyInput:hover, #countryInput:hover, #quantity:hover {
    background-color: var(--btn-secondary-hover);
    border-color: var(--cyan);
}

#nameHeading, #emailHeading, #phoneHeading, #address1Heading, #address2Heading, #cityHeading, #postcodeHeading, #countyHeading, #countryHeading {
    color: var(--text-secondary);
    font-size: 18px;
    margin-bottom: 10px;
}

#legalBox {
    display: flex;
    flex-direction: row;
    align-items: start;
    gap: 10px;
    margin-bottom: 20px;
}

#legalText {
    color: var(--text-secondary);
    font-size: 16px;
}

#legalText a {
    color: var(--cyan);
    font-size: 16px;
    text-decoration: none;
    transition: color 0.3s ease;
}

#legalText a:hover {
    color: var(--purple);
}

#readLegalBox {
    accent-color: var(--cyan);
}

#fileDiv {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 5px;
    margin-bottom: 40px;
}

#filePickerBtn {
    color: var(--cyan);
    background-color: var(--btn-primary);
    padding: 10px;
    border-radius: 10px;
    font-size: 16px;
    border: 1px solid var(--border);
    cursor: pointer;
    font-family: "Exo 2";
    transition: background-color 0.3s ease, border-color 0.3s ease;
}

#filePickerBtn:hover {
    background-color: var(--btn-primary-hover);
    border-color: var(--cyan);
}

#fileText {
    color: var(--text-secondary);
    font-size: 16px;
}

#dim {
    background-color: #000000b6;
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 2;
}

#orderStatusHeading {
    font-size: 48px;
    color: var(--text-primary);
    margin-bottom: 40px;
    text-align: center;
}

#nameInput, #emailInput, #phoneInput, #address1Input, #address2Input, #cityInput, #postcodeInput, #countyInput, #countryInput {
    border-radius: 10px;
    border: 1px solid var(--border);
    padding: 10px;
    margin-bottom: 20px;
    font-size: 16px;
    background-color: var(--btn-secondary);
    outline: none;
    caret-color: var(--text-secondary);
    color: var(--text-secondary);
    transition: background-color 0.3s ease, border-color 0.3s ease;
    font-family: "Exo 2";
    width: 100%;
}

#orderSucccesfulSubheading {
    font-size: 24px;
    color: var(--text-secondary);
    margin-bottom: 100px;
    text-align: center;
}

#orderNumberText {
    font-size: 24px;
    color: var(--text-primary);
    margin-bottom: 20px;
    text-align: center;
}

#orderNumber {
    font-size: 48px;
    color: var(--text-primary);
    text-align: center;
    margin-bottom: 40px;
}

#closeBtn {
    color: var(--cyan);
    background-color: var(--btn-primary);
    padding: 10px;
    border-radius: 10px;
    font-size: 16px;
    border: 1px solid var(--border);
    cursor: pointer;
    font-family: "Exo 2";
    transition: background-color 0.3s ease, border-color 0.3s ease;
    width: 100%;
    margin-top: auto;
}

#closeBtn:hover {
    background-color: var(--btn-primary-hover);
    border-color: var(--cyan);
}

#submitBtn {
    color: var(--cyan);
    background-color: var(--btn-primary);
    padding: 10px;
    border-radius: 10px;
    font-size: 16px;
    border: 1px solid var(--border);
    cursor: pointer;
    font-family: "Exo 2";
    transition: background-color 0.3s ease, border-color 0.3s ease;
    width: 100%;
}

#submitBtn:hover {
    background-color: var(--btn-primary-hover);
    border-color: var(--cyan);
}

#modelFileHeading, #quantityHeading, #materialsHeading, #finishHeading, #extraInfoHeading, #shippingHeading {
    color: var(--text-primary);
    font-size: 24px;
    margin-bottom: 20px;
    text-align: center;
}

#shipping {
    appearance: none;
    background-color: var(--btn-secondary);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 10px;
    font-family: "Exo 2";
    font-size: 16px;
    color: var(--text-secondary);
    margin-bottom: 40px;
    cursor: pointer;
    outline: none;
    background-image: url("/Assets/Images/Arrow Down.svg");
    background-repeat: no-repeat;
    background-position: right 1rem center;
    height: 45px;
    width: 300px;
    transition: background-color 0.3s ease, border-color 0.3s ease;
}

#shippingDescription, #modelFileDescription {
    color: var(--text-secondary);
    margin-bottom: 20px;
    font-size: 18px;
    text-align: center;
}

#shippingDescription a, #modelFileDescription a {
    color: var(--cyan);
    font-size: 16px;
    text-decoration: none;
    transition: color 0.3s ease;
    font-size: 18px;
}

#shippingDescription a:hover, #modelFileDescription a:hover {
    color: var(--purple);
}

#shipping:focus, #shipping:hover {
    background-color: var(--btn-secondary-hover);
    border-color: var(--cyan);
}

#extraInfo {
    background-color: var(--btn-secondary);
    border: 1px solid var(--border);
    resize: vertical;
    padding: 10px;
    border-radius: 10px;
    outline: none;
    transition: background-color 0.3s ease, border-color 0.3s ease;
    font-family: "Exo 2";
    font-size: 16px;
    height: 185px;
    width: 100%;
    caret-color: var(--text-secondary);
    color: var(--text-secondary);
}

#quantity {
    padding: 10px;
    border-radius: 10px;
    background-color: var(--btn-secondary);
    border: 1px solid var(--border);
    outline: none;
    font-family: "Exo 2";
    font-size: 16px;
    color: var(--text-secondary);
    transition: background-color 0.3s ease, border-color 0.3s ease;
    margin-bottom: 40px;
    width: 50px;
}

#quantity:focus, #quantity:hover {
    background-color: var(--btn-secondary-hover);
    border-color: var(--cyan);
}

#finish {
    appearance: none;
    background-color: var(--btn-secondary);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 10px;
    font-family: "Exo 2";
    font-size: 16px;
    color: var(--text-secondary);
    margin-bottom: 40px;
    cursor: pointer;
    outline: none;
    background-image: url("/Assets/Images/Arrow Down.svg");
    background-repeat: no-repeat;
    background-position: right 1rem center;
    height: 45px;
    width: 350px;
    transition: background-color 0.3s ease, border-color 0.3s ease;
}

#finish:focus, #extraInfo:focus, #finish:hover, #extraInfo:hover {
    background-color: var(--btn-secondary-hover);
    border-color: var(--cyan);
}

#materialsInfo {
    color: var(--text-secondary);
    font-size: 18px;
    margin-bottom: 20px;
    text-align: center;
}

#materialsInfo a {
    color: var(--cyan);
    font-size: 16px;
    text-decoration: none;
    transition: color 0.3s ease;
    font-size: 18px;
}

#materialsInfo a:hover {
    color: var(--purple);
}

#ABSHeading, #PLAHeading {
    color: var(--text-primary);
    font-size: 18px;
    margin-bottom: 10px;
    cursor: help;
}

#ABSColours, #PLAColours {
    display: flex;
    flex-direction: row;
    gap: 20px;
    margin-bottom: 20px;
}

.ABSColour, .PLAColour {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 5px;
    cursor: pointer;
}

.ABSColourBtn, .PLAColourBtn {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    outline-offset: 2px;
    outline: 2px solid #00000000;
    transition: outline 0.3s ease;
}

.ABSColourText, .PLAColourText {
    color: var(--text-secondary);
    font-size: 14px;
}

#copyright {
    color: var(--text-secondary);
    font-size: 16px;
    text-align: center;
}

#pageLinks a {
    text-decoration: none;
    color: var(--cyan);
    font-size: 16px;
    transition: color 0.3s ease;
}

#pageLinks a:hover {
    color: var(--purple);
}

#footerQuoteLink {
    color: var(--cyan);
    background-color: var(--btn-primary);
    padding: 10px;
    border-radius: 50px;
    font-size: 14px;
    border: 1px solid var(--border);
    cursor: pointer;
    font-family: "Exo 2";
    transition: background-color 0.3s ease, border-color 0.3s ease;
}

#footerQuoteLink:hover {
    background-color: var(--btn-primary-hover);
    border-color: var(--cyan);
}

#socialLinks {
    display: flex;
    flex-direction: row;
    gap: 10px;
}

#socialLinks img {
    cursor: pointer;
    width: 24px;
}