:root {
    /* ======================================
        Global Variables 
    ========================================= */
    /* Primary color palette */
    --clr-primary-50: hsl(215, 63%, 97%);
    --clr-primary-100: hsl(214, 76%, 90%);
    --clr-primary-200: hsl(214, 76%, 79%);
    --clr-primary-300: hsl(214, 76%, 69%);
    --clr-primary-400: hsl(214, 76%, 58%);
    --clr-primary-500: hsl(214, 76%, 48%);
    --clr-primary-600: hsl(214, 76%, 37%);
    --clr-primary-700: hsl(214, 76%, 28%);
    --clr-primary-800: hsl(214, 75%, 19%);
    --clr-primary-900: hsl(214, 74%, 9%);
    --clr-primary-950: hsl(215, 76%, 5%);
    /* Secondary color palette */
    --clr-secondary-50: hsl(50, 69%, 95%);
    --clr-secondary-100: hsl(47, 73%, 90%);
    --clr-secondary-200: hsl(48, 71%, 80%);
    --clr-secondary-300: hsl(48, 71%, 70%);
    --clr-secondary-400: hsl(48, 72%, 60%);
    --clr-secondary-500: hsl(48, 71%, 50%);
    --clr-secondary-600: hsl(48, 71%, 40%);
    --clr-secondary-700: hsl(48, 71%, 30%);
    --clr-secondary-800: hsl(48, 71%, 20%);
    --clr-secondary-900: hsl(47, 73%, 10%);
    --clr-secondary-950: hsl(47, 69%, 5%);
    /* Neutral color palette*/
    --clr-neutral-50: hsl(216, 100%, 100%);
    --clr-neutral-100: hsl(213, 18%, 88%);
    --clr-neutral-200: hsl(217, 17%, 75%);
    --clr-neutral-300: hsl(215, 16%, 63%);
    --clr-neutral-400: hsl(214, 17%, 51%);
    --clr-neutral-500: hsl(216, 16%, 38%);
    --clr-neutral-600: hsl(215, 17%, 26%);
    --clr-neutral-700: hsl(215, 18%, 19%);
    --clr-neutral-800: hsl(218, 16%, 13%);
    --clr-neutral-900: hsl(216, 16%, 6%);
    --clr-neutral-950: hsl(220, 20%, 3%);
    /* font size */
    --fs-base-minus-2: clamp(0.69rem, 0.6744rem + 0.1003vw, 0.76rem);
    --fs-base-minus-1: clamp(0.83rem, 0.7976rem + 0.1785vw, 0.95rem);
    --fs-base: clamp(1rem, 0.29vw + 0.94rem, 1.19rem);
    --fs-base-plus-1: clamp(1.2rem, 1.113rem + 0.435vw, 1.4844rem);
    --fs-base-plus-2: clamp(1.44rem, 1.3129rem + 0.6355vw, 1.8555rem);
    --fs-base-plus-3: clamp(1.73rem, 1.5471rem + 0.9045vw, 2.3193rem);
    --fs-base-plus-4: clamp(2.07rem, 1.821rem + 1.2628vw, 2.8992rem);
    --fs-base-plus-5: clamp(2.49rem, 2.1409rem + 1.7371vw, 3.624rem);
    /* spacing */
    --space-3xs: clamp(0.25rem, 0.2309rem + 0.0956vw, 0.3125rem);
    --space-2xs: clamp(0.5rem, 0.4618rem + 0.1912vw, 0.625rem);
    --space-xs: clamp(0.75rem, 0.7118rem + 0.1912vw, 0.875rem);
    --space-s: clamp(1rem, 0.9426rem + 0.2868vw, 1.1875rem);
    --space-m: clamp(1.5rem, 1.4044rem + 0.478vw, 1.8125rem);
    --space-l: clamp(2rem, 1.8853rem + 0.5736vw, 2.375rem);
    --space-xl: clamp(3rem, 2.8279rem + 0.8604vw, 3.5625rem);
    --space-2xl: clamp(4rem, 3.7706rem + 1.1472vw, 4.75rem);
    --space-3xl: clamp(6rem, 5.6558rem + 1.7208vw, 7.125rem);
    --space-s-l: clamp(1rem, 0.5793rem + 2.1033vw, 2.375rem);
    --space-0-l: clamp(0, 0.5793rem + 2.1033vw, 2.375rem);
    /* ======================================
        Base Styles
    ========================================= */
    --primary-background-clr: var(--clr-primary-50);
    --primary-foreground-clr: var(--clr-primary-800);
    --primary-base-clr: var(--clr-primary-600);
    --primary-heading-foreground-clr: var(--clr-primary-700);
    --secondary-base-clr: var(--clr-secondary-500);
    --neutral-background-clr: var(--clr-neutral-50);
    --neutral-foreground-clr: var(--clr-neutral-800);
    --ff-body: 'Poppins', sans-serif;
    --ff-heading: 'Raleway', sans-serif;
    /* ======================================
        FluentUI Resets 
    ========================================= */
    --body-font: var(--ff-body);
    --type-ramp-base-font-size: var(--fs-base);
}

/* ======================================
    Global Resets
====================================== */
/* Box sizing rules */
*,
*::before,
*::after {
    box-sizing: border-box;
}
/* Remove default margin in favour of better control in authored CSS */
body, h1, h2, h3, h4, p,
figure, blockquote, dl, dd {
    margin: 0;
}
/* Remove list styles on ul, ol elements with a list role, which suggests default styling will be removed */
ul[role='list'],
ol[role='list'] {
    list-style: none;
}
/* A elements that don't have a class get default styles */
a:not([class]) {
    text-decoration-skip-ink: auto;
    color: currentColor;
}
/* Make images easier to work with */
img,
picture {
    display: block;
    font-style: italic;
    background-repeat: no-repeat;
    background-size: cover;
    max-width: 100%;
    height: auto;
    vertical-align: middle;
}

p, li, figcaption {
    text-wrap: pretty;
}

/* Inherit fonts for inputs and buttons */
input, button,
textarea, select {
    font-family: inherit;
    font-size: inherit;
}
    /* Make sure textareas without a rows attribute are not tiny */
    textarea:not([rows]) {
        min-height: 10em;
    }
/* Anything that has been anchored to should have extra scroll margin */
:target {
    scroll-margin-block: 5ex;
}

/* =========================================
    Global Styles
========================================= */
body {
    font-family:var(--ff-body);
    font-size:var(--fs-base);
    line-height:1.6;    
}

.body-content {
    min-height: calc(100dvh - 86px);
    color: var(--neutral-foreground-clr);
    background-color: var(--primary-background-clr);
}

main {
    /*color: var(--clr-foreground-base);
    background-color: var(--clr-background-base);*/
}

/* Content grid wrapper classes*/
.content-grid,
.full-width {
    --_padding-inline: var(--space-s-l);
    --_content-max-width: calc(70ch + var(--_padding-inline) * 2);
    --_breakout-max-width: 85ch;
    --_grid-max-width: 120ch;
    --_breakout-size: calc((var(--_breakout-max-width) - var(--_content-max-width)) / 2);
    --_grid-size: calc((var(--_grid-max-width) - var(--_content-max-width)) / 2);
    display: grid;
    grid-template-columns: [full-width-start] 1fr [card-grid-start] minmax(0, var(--_grid-size)) [breakout-start] minmax(0, var(--_breakout-size)) [content-start] min(100%, var(--_content-max-width)) [content-end] minmax(0, var(--_breakout-size)) [breakout-end] minmax(0, var(--_grid-size)) [card-grid-end] 1fr [full-width-end];
}
    
    .content-grid > * {
        grid-column: content;
        padding: var(--_padding-inline);
    }

    .content-grid > .breakout {
        grid-column: breakout;
        background-color: unset;
    }

    .content-grid > .card-grid {
        grid-column: card-grid;
        background-color: unset;
    }

    .content-grid > .full-width {
        grid-column: full-width;
        background-color: unset;
    }

/* Typography */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--ff-heading); /* heading font family */
    line-height: 1.2; /* heading line height */
    text-wrap: balance;
}

h1, h2, h3 {
    color: var(--primary-heading-foreground-clr);
}

h1 {
    font-size: var(--fs-base-plus-5); /* h1 font size */
    font-weight: 900; /* h1 font weight */
    line-height: 1.1;
}

h2 {
    font-size: var(--fs-base-plus-4); /* h2 font size */
    font-weight: 800; /* h2 font weight */
}

h3 {
    font-size: var(--fs-base-plus-3); /* h3 font size */
    font-weight: 700; /* h3 font weight */
}

h4 {
    font-size: var(--fs-base-plus-2); /* h4 font size */
    font-weight: 600; /* h4 font weight */
}

h5 {
    font-size: var(--fs-base-plus-1); /* h5 font size */
    font-weight: 500; /* h5 font weight */
}

h6 {
    font-size: var(--fs-base); /* h6 font size */
    font-weight: 500; /* h6 font weight */
    line-height: 1.5;
}

/* =========================================
    Blazor Styling
========================================= */
.alert {
    border: 1px dashed var(--primary-heading-foreground-clr);
    padding: 5px;
}

#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;
    margin: 20px 0;
}

    #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::before {
        content: "An error has occurred. "
    }

.loading-progress {
    position: relative;
    display: block;
    width: 10rem;
    height: 10rem;
    margin: 20vh auto 1rem auto;
}

    .loading-progress circle {
        fill: none;
        stroke: var(--clr-primary-200);
        stroke-width: 0.6rem;
        transform-origin: 50% 50%;
        transform: rotate(-90deg);
    }

        .loading-progress circle:last-child {
            stroke: var(--clr-primary-700);
            stroke-dasharray: calc(3.141 * 0% * 0.8), 500%;
            stroke-dasharray: calc(3.141 * var(--blazor-load-percentage, 0%) * 0.8), 500%;
            transition: stroke-dasharray 0.05s ease-in-out;
        }

.loading-progress-text {
    position: absolute;
    text-align: center;
    font-weight: bold;
    top: calc(20vh + 6rem);
    right: 0;
    bottom: auto;
    left: 0.2rem;
}

    .loading-progress-text:after {
        content: "Loading";
        content: var(--blazor-load-percentage-text, "Loading");
    }

.loading-progress-logo {
    position: absolute;
    text-align: center;
    top: calc(20vh + 2.5rem);
    right: 0;
    bottom: auto;
    left: calc(50% - 2.5rem);
}

code {
    color: #c02d76;
}

/* =========================================
    Utilities
========================================= */
.visually-hidden:not(:focus):not(:active) {
    clip: rect(0 0 0 0);
    clip-path: inset(50%);
    height: 1px;
    color: var(--brand-accent-300);
    overflow: hidden;
    position: absolute;
    white-space: nowrap;
    width: 1px;
}

.even-columns {
    display: grid;
    gap: 1rem;
    min-height: 600px;
    align-items: flex-end;
}

.summary {
    display: grid;
    gap: var(--space-xs);
}

.bg-neutral {
    background-color: var(--neutral-background-clr);
}

.button {
    cursor: pointer;
    padding: 0.25rem 0.625rem;
    font-size: var(--fs-base);
    display: flex;
    flex-direction: row;
    gap: var(--space-2xs);
    align-items: flex-end;
    justify-content: center;
    border: 1px solid var(--primary-background-clr);
    border-radius: var(--space-3xs);
    box-shadow: 2px 2px 15px var(--clr-neutral-400);
    text-decoration: none;
    width: max-content;
}

    .button > * {
        align-self: center;
    }

.button--primary {
    background-color: var(--primary-background-clr);
    color: var(--clr-primary-800);
}

    .button--primary:hover {
        background-color: var(--clr-primary-100);
    }

.button--cta {
    color: var(--primary-heading-foreground-clr);
    background-color: var(--secondary-base-clr);
    border-color: var(--primary-heading-foreground-clr);
}

    .button--cta:hover {
        background-color: var(--clr-secondary-400);
    }

@media (min-width:62em) {
    .even-columns {
        grid-auto-flow: column;
        grid-auto-columns: 1fr;
        height: 600px;
    }
}

.card-grid {
    display: grid;
    gap: var(--space-m);
    grid-template-columns: repeat(auto-fit, minmax(min(19rem,100%), 1fr));
    padding-top: var(--space-s-l);
}

/*@media (min-width: 50em) {
    .card--content {
        background-color: var(--clr-neutral-200);
    }
    .card--content:hover {
        background-color: var(--clr-neutral-800);
    }
}*/

@media (min-width: 50em) {
    .photo--dialog {
        display: grid;
        align-items: center;
        justify-content: center;
    }
}

