@import url('https://fonts.googleapis.com/css2?family=Epilogue:ital,wght@0,300;0,400;0,500;0,600;0,700;1,300;1,400;1,500;1,600;1,700&display=swap');

*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
}

:root {
    /* Base */
    --color-background: #f1f1f1;
    --color-surface: #ffffff;
    --color-text: #212529;
    --color-text-light: #595b5d;
    --color-text-inverted: var(--color-surface);
    --color-accent-light: rgba(81, 12, 118, 0.5);
    --color-accent: #510c76;
    --color-accent-dark: #2D0050;
    --color-warning: #ffc400;
    --color-danger-light: #ffccca;
    --color-danger: #880009;
    --color-success: #00935a;
    --color-temp-banner: #44276a;
    --spacing-0: 4px;
    --spacing-1: 8px;
    --spacing-2: 16px;
    --spacing-3: 24px;
    --spacing-4: 32px;
    --spacing-5: 48px;
    --spacing-6: 64px;
    --spacing-7: 128px;
    /* Semantic */

    --color-border: var(--color-text);
    --color-border-light: var(--color-text-light);
    --color-button: var(--color-surface);
    --color-text-button: var(--color-text);
    --color-button-hover: var(--color-surface);
    --text-label: 14px;
    --text-body: 16px;
    --text-body-large: 18px;
    --text-header: 24px;
    --text-header-large: 32px;
    --shadow-card: rgba(0, 0, 0, 0.15) 0 1.95px 2px;
    --shadow-card-hover: rgba(0, 0, 0, 0.5) 0 2px 4px;
    --spacing-radius: var(--spacing-0);
    --spacing-radius-large: var(--spacing-1);
}

html {
    scroll-behavior: smooth;
}

body {
    overflow-x: hidden;
    font-family: Epilogue, system-ui, sans-serif;
    font-size: var(--text-body);
    color: var(--color-text);
    background-color: var(--color-background);
}

h1, h2 {
    margin-bottom: var(--spacing-2);
}

h3, h4 {
    margin-bottom: var(--spacing-1);
}

h1 {
    font-size: var(--text-header-large);
}

    h1:focus {
        outline: none;
    }

h2 {
    font-size: var(--text-header);
    font-weight: 600;
}

main p, span, div {
    line-height: 1.4;
}

p.large {
    font-size: var(--text-body-large);
}

a {
    color: var(--color-accent);
}

svg {
    width: var(--spacing-2);
    height: var(--spacing-2);
    stroke-width: 3px;
}

    svg.loading {
        -webkit-animation: rotation 1s infinite linear;
        animation: rotation 1s infinite linear;
    }

@-webkit-keyframes rotation {
    from {
        -webkit-transform: rotate(0deg);
    }

    to {
        -webkit-transform: rotate(359deg);
    }
}

@keyframes rotation {
    from {
        transform: rotate(0deg);
    }

    to {
        transform: rotate(359deg);
    }
}

button {
    display: flex;
    align-items: center;
    gap: var(--spacing-1);
    cursor: pointer;
    font-family: inherit;
    font-size: var(--text-label);
    font-weight: 500;
    background-color: var(--color-button);
    color: var(--color-text-button);
    transition: all 0.125s ease-in;
    border: none;
    padding: var(--spacing-1) var(--spacing-2);
    border-radius: var(--spacing-radius);
}

    button .animate__animated {
        display: flex;
        align-items: center;
        gap: var(--spacing-1);
    }

    button:hover {
        outline: 1px solid var(--color-border);
    }

    button:hover, button:focus {
        background-color: var(--color-button-hover);
    }

    button:active {
        font-weight: bold;
        box-shadow: 0 0 0 0.2rem var(--color-accent-light);
    }

    button:disabled {
        cursor: not-allowed;
        opacity: .4;
    }

        button:disabled:hover, button:disabled:focus, button:disabled:active {
            font-weight: 500;
            box-shadow: none;
            outline: none;
            background-color: var(--color-button);
        }

    button.icon {
        padding: 0;
    }

        button.icon:hover {
            outline: none;
        }

        button.icon svg {
            width: 20px;
            height: 20px;
            stroke-width: 2px;
            stroke: var(--color-accent);
            transition: stroke-width 0.125s ease-in;
        }

        button.icon:hover svg {
            stroke-width: 2.5px;
        }

    button.large {
        font-size: var(--text-body-large);
    }

    button.primary {
        --color-button: var(--color-accent);
        --color-text-button: var(--color-text-inverted);
        --color-button-hover: var(--color-accent-dark);
    }

label, input, select {
    display: block;
}

label {
    font-size: var(--text-label);
    font-weight: 500;
    margin-bottom: var(--spacing-1);
}

input, select, textarea {
    all: unset;
    width: 100%;
    font-family: inherit;
    font-size: var(--text-label);
    transition: outline 0.05s ease-out;
    padding: var(--spacing-1);
    background-color: var(--color-surface);
}

    select.admin {
        outline: 1px solid var(--color-accent-light);
        white-space: nowrap;
        padding: 0px 0px 0px 0px;
        font-size: small;
        overflow: hidden;
    }

    input:hover, select:hover, textarea:hover {
        outline: 1px solid var(--color-accent-light);
    }

    input:focus, select:focus, textarea:focus {
        outline: 2px solid var(--color-accent);
    }

    input.error, select.error, textarea.error {
        outline: 2px solid var(--color-danger);
    }

/* might need polyfill for IE */
label:has(+ input:required)::after, label:has(+ select:required)::after, th.required::after {
    content: '*';
    color: var(--color-danger);
    padding-left: 2px;
}

input[type="number"] {
    width: var(--spacing-5);
    padding-right: 0;
}

input[type=number]::-webkit-inner-spin-button {
    padding-left: var(--spacing-2);
}

input[type="checkbox"] {
    position: relative;
    display: inline-block;
    width: var(--spacing-2);
    height: var(--spacing-2);
    outline: 1px solid var(--color-border);
    padding: 0;
}

    input[type="checkbox"]:checked {
        stroke: var(--color-text-inverted);
        background-color: var(--color-accent);
        background-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'></polyline></svg>");
        background-repeat: no-repeat;
        background-size: 100%;
        background-position: top;
    }

select[id*="expiration"] {
    width: fit-content;
    padding-right: var(--spacing-4);
}

select {
    max-width: 200px;
    background-image: url("data:image/svg+xml,<svg height='10px' width='10px' viewBox='0 0 16 16' fill='currentColor' xmlns='http://www.w3.org/2000/svg'><path d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/></svg>");
    background-repeat: no-repeat;
    background-position: calc(100% - 0.75rem) center;
    padding-right: var(--spacing-2);
}

textarea {
    resize: none;
    box-sizing: border-box;
}

.messageinput {
    width: 100%;
    height: 100%;
}

.container input, .container textarea,
.input-field input, .input-field select,
header select {
    background-color: var(--color-background);
}

.input-field.large * {
    font-size: var(--text-body);
}

.container {
    width: 100%;
    overflow-x: auto;
    padding: var(--spacing-4);
    background-color: var(--color-surface);
}

.container-menu {
    width: 250px;
}

@media print {
    .container-menu, .container-menu * {
        display: none !important;
    }
}

.container-flex {
    display: flex;
    justify-content: space-evenly;
    align-items: flex-start;
    gap: var(--spacing-4);
}

.container .form, .container .form button {
    width: 100%;
    justify-content: center;
}


.form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0 var(--spacing-4);
}

.container input:not([type="checkbox"]),
.container select:not([id*="expiration"]) {
    width: calc(100% - var(--spacing-2));
    max-width: calc(100% - var(--spacing-2));
}

.input-field {
    margin-bottom: var(--spacing-2);
}

    .input-field * {
        font-size: var(--text-label);
    }

    .input-field input[type="checkbox"] {
        margin-right: var(--spacing-0);
    }

.currency {
    font-weight: bold;
    color: var(--color-accent);
    padding-left: var(--spacing-3);
}

.error-box {
    color: var(--color-danger);
    background-color: var(--color-danger-light);
    padding: var(--spacing-2);
    margin-bottom: var(--spacing-2);
    border-radius: var(--spacing-radius);
}

.error {
    color: var(--color-danger);
    margin-bottom: var(--spacing-1);
}

table {
    width: 100%;
    table-layout: auto;
    border-collapse: collapse;
}

tbody tr:not(:last-of-type) {
    border-bottom: 0.5px solid var(--color-border);
}

tbody tr.noborder {
    border-bottom: none;
}

thead th {
    width: 100px;
}

thead tr {
    font-weight: 500;
    border-bottom: 1px solid var(--color-border);
}

th, td {
    padding: var(--spacing-0);
}

    th:first-of-type, td:first-of-type {
        padding-left: 0;
    }

    th:last-of-type, td:last-of-type {
        padding-right: 0;
    }

th {
    text-align: left;
}

    th.small {
        width: 6ch;
    }

table.table-small th, td {
    font-size: smaller;
}

h3.reportsubheader {
    color: #404040;
}

.flex {
    display: flex;
    align-items: center;
    gap: var(--spacing-2);
}

    .flex.small {
        gap: var(--spacing-1);
    }

    .flex.center {
        justify-content: center;
    }

    .flex.between {
        justify-content: space-between;
    }

.hidden {
    height: 0;
    opacity: 0;
    padding: 0;
    margin: 0;
}

.tabs {
    display: flex;
}

    .tabs button {
        --color-button: var(--color-background);
        flex-grow: 1;
        justify-content: center;
        border-radius: 0;
    }

        .tabs button:hover {
            --color-button-hover: var(--color-background);
            font-weight: bold;
            outline: none;
        }

        .tabs button.selected:hover {
            --color-button-hover: var(--color-button);
        }

        .tabs button.selected {
            --color-button: var(--color-surface);
            font-weight: bold;
        }

.spacer {
    width: 100%;
    height: var(--spacing-6);
}

.overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.header-left {
    text-align: left;
}

.logo {
    max-height: 48px;
    width: auto;
    overflow: clip;
    overflow-clip-margin: content-box;
}

.hero-banner {
    position: relative;
    width: 100vw;
    height: 270px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    background-image: url('/images/cpdpaymentbackground.jpg');
    background-size: 100%;
    background-position: right;
    background-repeat: no-repeat;
    background-color: var(--color-temp-banner);
    text-shadow: 1.5px 1.5px var(--color-temp-banner);
    color: var(--color-text-inverted);
    padding: var(--spacing-5) var(--spacing-7);
}

    /* uncomment to restore the snow flakes overlay on the banner
.hero-banner .festive-overlay {
    background: url('/images/snowflakes.png'), linear-gradient(180deg, rgba(255,54,54, 0.2) 0%, rgba(0,0,0,0) 100%);
    background-size: contain;
    background-position: center;
}
*/

    .hero-banner h1, .hero-banner p {
        z-index: 2;
    }

        .hero-banner h1, .hero-banner p span {
            width: fit-content;
        }

    .hero-banner h1 {
        margin-bottom: 0;
    }

    .hero-banner p {
        font-size: var(--text-body-large);
        font-style: italic;
    }

.text h1, .text h2 {
    margin-bottom: 0;
}

main {
    width: max(50vw, 1024px);
    display: flex;
    gap: var(--spacing-4);
    padding: var(--spacing-4);
    margin: 0 auto;
}

    main section {
        flex-grow: 1;
    }

.details .text, .container .text {
    margin-bottom: var(--spacing-2);
}

.navigation-buttons {
    width: 100%;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: var(--spacing-2);
    padding-top: var(--spacing-3);
}

    .navigation-buttons button:only-child {
        margin-left: auto;
    }

.valid.modified:not([type=checkbox]) {
    outline: 1px solid var(--color-success);
}

.invalid {
    outline: 1px solid var(--color-danger);
}

.validation-message {
    color: var(--color-danger);
}

#blazor-error-ui {
    background: lightyellow;
    bottom: 0;
    box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2);
    display: none;
    left: 0;
    padding: 0.6rem 1.25rem 0.7rem 1.25rem;
    position: fixed;
    width: 100%;
    z-index: 1000;
}

    #blazor-error-ui .dismiss {
        cursor: pointer;
        position: absolute;
        right: 0.75rem;
        top: 0.5rem;
    }

.blazor-error-boundary {
    background: url() no-repeat 1rem/1.8rem, #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
}

    .blazor-error-boundary::after {
        content: "An error has occured.";
        color: var(--color-danger);
    }

/* :global hacks */
input[value="es-do"] ~ main .product button {
    font-size: var(--text-body);
    padding-left: var(--spacing-1);
    padding-right: var(--spacing-1);
}

input[value="es-do"] ~ main .cart-item .product {
    font-size: var(--text-body);
}

@media (min-width: 1024px) {
    input[value="es-do"] ~ main {
        width: max(50vw, 1152px);
    }

        input[value="es-do"] ~ main.product-page {
            grid-template-columns: 4fr minmax(224px, 3fr);
        }
}

@media (max-width: 400px) {
    .hero-banner, main {
        padding: var(--spacing-3);
    }
}

@media (max-width: 640px) {
    :root {
        --text-label: 14px;
        --text-body: 14px;
        --text-body-large: 16px;
        --text-header: 20px;
        --text-header-large: 24px;
    }

    .logo {
        max-height: 40px;
    }

    .hero-banner {
        background-position: center;
    }

        .hero-banner p {
            max-width: 30ch;
        }

    .hero-banner, main {
        padding: var(--spacing-3);
    }

    input[type="number"] {
        width: 40px;
    }
}

@media (max-width: 800px) {
    table, form {
        width: 100%;
    }

    .spacer {
        display: none;
    }

    /* remove and replace with actual image */
    .hero-banner {
        height: 160px;
        background-size: 125%;
        background-position: right -30vw bottom 50%;
        padding: var(--spacing-4);
    }

        .hero-banner h1 {
            text-shadow: 4px 4px var(--color-temp-banner);
        }

    main, .container-flex {
        flex-direction: column;
    }

    .form {
        width: 100%;
    }

    .form-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 1024px) {
    main {
        width: 100%;
    }

    form {
        overflow-x: auto;
    }

    .hero-banner::after {
        content: "";
        position: absolute;
        left: 0;
        right: 0;
        top: 0;
        bottom: 0;
        background: var(--color-temp-banner);
        opacity: 0.5;
    }

    .hero-banner h1, .hero-banner p {
        z-index: 2;
        max-width: 30ch;
    }
}

@media (max-width: 1110px) {
    .hero-banner {
        background-image: url('/images/cpdpaymentbackground.jpg');
        height: 200px;
    }
}

.loaderContainer {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 90vw;
    height: 90vh;
}

.loader {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    position: relative;
    animation: rotate 1s linear infinite
}

.loader::before {
    content: "";
    box-sizing: border-box;
    position: absolute;
    inset: 0px;
    border-radius: 50%;
    border: 5px solid #808080;
    animation: prixClipFix 2s linear infinite;
}

@keyframes rotate {
    100% {
        transform: rotate(360deg)
    }
}

@keyframes prixClipFix {
    0% {
        clip-path: polygon(50% 50%,0 0,0 0,0 0,0 0,0 0)
    }

    25% {
        clip-path: polygon(50% 50%,0 0,100% 0,100% 0,100% 0,100% 0)
    }

    50% {
        clip-path: polygon(50% 50%,0 0,100% 0,100% 100%,100% 100%,100% 100%)
    }

    75% {
        clip-path: polygon(50% 50%,0 0,100% 0,100% 100%,0 100%,0 100%)
    }

    100% {
        clip-path: polygon(50% 50%,0 0,100% 0,100% 100%,0 100%,0 0)
    }
}
