/* -------------------------------------------------------------------------- */
/* RTB-MAIN.CSS (c) richardthebrave.com ------------------------------------- */

/* -------------------------------------------------------------------------- */
/* MARK: Variables
*/

:root {

    --ratio: auto;

    --primary-light:#EEF3EC;
    --primary-mid:  #C3D4BF;
    --primary:      #5d7257;
    --primary-dark: #414D3D;

    --secondary-light:  #EEF2FC;
    --secondary-mid:    #C3D0F1;
    --secondary:        #8ca6ed;
    --secondary-dark:   #687ad6;

    --accent-light: #F6FEDF;
    --accent-mid:   #E0F79E;
    --accent:       #abd933;
    --accent-dark:  #6C9307;

    --neutral-light:    #EEEFEC;
    --neutral-mid:      #C7CCBF;
    --neutral:          #525749;
    --neutral-dark:     #21231E;

    --illustration-light:   #C3D4BF;
    --illustration-accent:  #C3D0F1;
    --illustration-dark:    #414D3D;

    --white: #fff;
    --black: #000;

    /* 360px -> 1440px */
    --space-1:      clamp(0.375rem, 0.3333rem + 0.1852vw, 0.5rem);  /*  6->8px  */
    --space-2:      clamp(0.5625rem, 0.5rem + 0.2778vw, 0.75rem);   /*  9->12px */
    --space-3:      clamp(0.75rem, 0.6667rem + 0.3704vw, 1rem);     /* 12->16px */
    --space-4:      clamp(1rem, 0.9167rem + 0.3704vw, 1.25rem);     /* 16->20px */
    --space-5:      clamp(1.3125rem, 1.25rem + 0.2778vw, 1.5rem);   /* 21->24px */
    --space-6:      clamp(1.6875rem, 1.5833rem + 0.463vw, 2rem);    /* 27->32px */
    --space-7:      clamp(2.0625rem, 1.75rem + 1.3889vw, 3rem);     /* 33->48px */
    --space-8:      clamp(2.8125rem, 2.4167rem + 1.7593vw, 4rem);   /* 45->64px */
    --space-9:      clamp(3.375rem, 2.8333rem + 2.4074vw, 5rem);    /* 54->80px */
    --space-10:     clamp(3.9375rem, 3.25rem + 3.0556vw, 6rem);     /* 63->96px */

    /* https://utopia.fyi/clamp/calculator/?a=360,1440,10%E2%80%9412|15%E2%80%9417|17%E2%80%9419|21%E2%80%9426|27%E2%80%9436|36%E2%80%9448|44%E2%80%9464&p=text */
    /* 360px -> 1440px */

    --text-xs: clamp(0.625rem, 0.5833rem + 0.1852vw, 0.75rem);       /* 10->12px .text-xs */
    --text-sm: clamp(0.9375rem, 0.8958rem + 0.1852vw, 1.0625rem);    /* 15->17px .text-sm */
    --text-base: clamp(1.0625rem, 1.0208rem + 0.1852vw, 1.1875rem);  /* 17->19px .text-base */
    --text-md: clamp(1.3125rem, 1.2083rem + 0.463vw, 1.625rem);      /* 21->26px .text-md */
    --text-lg: clamp(1.6875rem, 1.5rem + 0.8333vw, 2.25rem);         /* 27->36px .text-lg */
    --text-xl: clamp(2.25rem, 2rem + 1.1111vw, 3rem);                /* 36->48px .text-xl */
    --text-xxl: clamp(2.75rem, 2.3333rem + 1.8519vw, 4rem);          /* 44->64px .text-xxl */


    --radius-xs: var(--space-1);
    --radius-sm: var(--space-2);
    --radius-base: var(--space-3);
    --radius-md: var(--space-4);
    --radius-lg: var(--space-5);
    --radius-xl: var(--space-6);

    --max-narrow:   50rem;  /* 800px */
    --max-wide:     75rem;  /* 1200px */
    --max-full:     112.5rem;  /* 1800px */

    --gutter:   clamp(1rem, 0rem + 4.4444vw, 4rem); /* 16->64px */

}

/* -------------------------------------------------------------------------- */
/* MARK: Reset
*/

*, *::before, *::after            { box-sizing: border-box; }
*                                 { XXXborder: 1px solid salmon; margin: 0; }
html                              { font-size: 100%; scrollbar-gutter: stable; }
body                              { background-color: var(--primary-light); color: var(--neutral-dark); font-family: 'font-primary', system-ui, sans-serif; font-size: var(--text-base); font-style: normal; font-weight: 375; line-height: 1.4; -webkit-font-smoothing: antialiased; }
img, picture, video, canvas, svg  { aspect-ratio: var(--ratio); display: block; height: auto; max-width: 100%; }
input, button, textarea, select   { font: inherit; }
p, h1, h2, h3, h4, h5, h6         { overflow-wrap: break-word; }
hr                                { background-color: black; border: 0; box-sizing: content-box; height: 1px; margin: 0; overflow: visible; }
#root, #__next                    { isolation: isolate; }
strong                            { font-weight: 700; }
em                                { font-style: italic; }
:focus:not(:focus-visible)        { outline: none; box-shadow: none; }
:focus-visible                    { outline: none; box-shadow: 0 0 0 6px var(--success); }

/* Smooth scrolling IF user doesn't have a preference due to motion sensitivities */
/* https://moderncss.dev/pure-css-smooth-scroll-back-to-top/ */
@media screen and (prefers-reduced-motion: no-preference) {
    html {
        scroll-behavior: smooth;
    }
}

/* -------------------------------------------------------------------------- */
/* MARK: Fonts
*/

/* Supreme Var */
@font-face {
    font-family: 'font-primary';
    src:    url('/assets/fonts/supreme-var/supreme-var.woff2') format('woff2-variations'),
            url('/assets/fonts/supreme-var/supreme-var.ttf') format('truetype-variations');
    font-weight: 100 800;
    font-display: swap;
        
}
.font-primary { font-family: 'font-primary', sans-serif; font-style: normal; }
.font-primary-100 { font-family: 'font-primary', sans-serif; font-style: normal; font-weight: 100; }
.font-primary-200 { font-family: 'font-primary', sans-serif; font-style: normal; font-weight: 200; }
.font-primary-300 { font-family: 'font-primary', sans-serif; font-style: normal; font-weight: 300; }
.font-primary-400 { font-family: 'font-primary', sans-serif; font-style: normal; font-weight: 400; }
.font-primary-500 { font-family: 'font-primary', sans-serif; font-style: normal; font-weight: 500; }
.font-primary-600 { font-family: 'font-primary', sans-serif; font-style: normal; font-weight: 600; }
.font-primary-700 { font-family: 'font-primary', sans-serif; font-style: normal; font-weight: 700; }
.font-primary-800 { font-family: 'font-primary', sans-serif; font-style: normal; font-weight: 800; }

/* Supreme Var Italic */
@font-face {
    font-family: 'font-primary';
    src:    url('/assets/fonts/supreme-var/supreme-var-italic.woff2') format('woff2-variations'),
            url('/assets/fonts/supreme-var/supreme-var-italic.ttf') format('truetype-variations');
    font-weight: 100 800;
    font-display: swap;
    font-style: italic; 
}
.font-primary-i { font-family: 'font-primary', sans-serif; font-style: italic; }
.font-primary-100i { font-family: 'font-primary', sans-serif; font-style: italic; font-weight: 100; font-style: italic; }
.font-primary-200i { font-family: 'font-primary', sans-serif; font-style: italic; font-weight: 200; font-style: italic; }
.font-primary-300i { font-family: 'font-primary', sans-serif; font-style: italic; font-weight: 300; font-style: italic; }
.font-primary-400i { font-family: 'font-primary', sans-serif; font-style: italic; font-weight: 400; font-style: italic; }
.font-primary-500i { font-family: 'font-primary', sans-serif; font-style: italic; font-weight: 500; font-style: italic; }
.font-primary-600i { font-family: 'font-primary', sans-serif; font-style: italic; font-weight: 600; font-style: italic; }
.font-primary-700i { font-family: 'font-primary', sans-serif; font-style: italic; font-weight: 700; font-style: italic; }
.font-primary-800i { font-family: 'font-primary', sans-serif; font-style: italic; font-weight: 800; font-style: italic; }

/* Sentient Var */
@font-face {
    font-family: 'font-secondary';
    src:    url('/assets/fonts/sentient-var/sentient-var.woff2') format('woff2-variations'),
            url('/assets/fonts/sentient-var/sentient-var.ttf') format('truetype-variations');
    font-weight: 200 700;
    font-display: swap;
        
}
.font-secondary { font-family: 'font-secondary', sans-serif; font-style: normal; }
.font-secondary-200 { font-family: 'font-secondary', sans-serif; font-style: normal; font-weight: 200; }
.font-secondary-300 { font-family: 'font-secondary', sans-serif; font-style: normal; font-weight: 300; }
.font-secondary-400 { font-family: 'font-secondary', sans-serif; font-style: normal; font-weight: 400; }
.font-secondary-500 { font-family: 'font-secondary', sans-serif; font-style: normal; font-weight: 500; }
.font-secondary-600 { font-family: 'font-secondary', sans-serif; font-style: normal; font-weight: 600; }
.font-secondary-700 { font-family: 'font-secondary', sans-serif; font-style: normal; font-weight: 700; }

/* Sentient Var Italic */
@font-face {
    font-family: 'font-secondary';
    src:    url('/assets/fonts/sentient-var/sentient-var-italic.woff2') format('woff2-variations'),
            url('/assets/fonts/sentient-var/sentient-var-italic.ttf') format('truetype-variations');
    font-weight: 200 700;
    font-display: swap;
    font-style: italic; 
}
.font-secondary-i { font-family: 'font-secondary', sans-serif; font-style: italic; }
.font-secondary-200i { font-family: 'font-secondary', sans-serif; font-style: italic; font-weight: 200; font-style: italic; }
.font-secondary-300i { font-family: 'font-secondary', sans-serif; font-style: italic; font-weight: 300; font-style: italic; }
.font-secondary-400i { font-family: 'font-secondary', sans-serif; font-style: italic; font-weight: 400; font-style: italic; }
.font-secondary-500i { font-family: 'font-secondary', sans-serif; font-style: italic; font-weight: 500; font-style: italic; }
.font-secondary-600i { font-family: 'font-secondary', sans-serif; font-style: italic; font-weight: 600; font-style: italic; }
.font-secondary-700i { font-family: 'font-secondary', sans-serif; font-style: italic; font-weight: 700; font-style: italic; }



/* -------------------------------------------------------------------------- */
/* MARK: Colours
*/

.bg-neutral-light   { background-color: var(--neutral-light); }
.bg-neutral-mid     { background-color: var(--neutral-mid); }
.bg-neutral         { background-color: var(--neutral); }
.bg-neutral-dark    { background-color: var(--neutral-dark); }
.bg-primary-light   { background-color: var(--primary-light); }
.bg-primary-mid     { background-color: var(--primary-mid); }
.bg-primary         { background-color: var(--primary); }
.bg-primary-dark    { background-color: var(--primary-dark); }
.bg-secondary-light { background-color: var(--secondary-light); }
.bg-secondary-mid   { background-color: var(--secondary-mid); }
.bg-secondary       { background-color: var(--secondary); }
.bg-secondary-dark  { background-color: var(--secondary-dark); }
.bg-accent-light    { background-color: var(--accent-light); }
.bg-accent-mid      { background-color: var(--accent-mid); }
.bg-accent          { background-color: var(--accent); }
.bg-accent-dark     { background-color: var(--accent-dark); }
.bg-white           { background-color: var(--white); }
.bg-black           { background-color: var(--black); }

.neutral-light      { color: var(--neutral-light); }
.neutral-mid        { color: var(--neutral-mid); }
.neutral            { color: var(--neutral); }
.neutral-dark       { color: var(--neutral-dark); }
.primary-light      { color: var(--primary-light); }
.primary-mid        { color: var(--primary-mid); }
.primary            { color: var(--primary); }
.primary-dark       { color: var(--primary-dark); }
.secondary-light    { color: var(--secondary-light); }
.secondary-mid      { color: var(--secondary-mid); }
.secondary          { color: var(--secondary); }
.secondary-dark     { color: var(--secondary-dark); }
.accent-light       { color: var(--accent-light); }
.accent-mid         { color: var(--accent-mid); }
.accent             { color: var(--accent); }
.accent-dark        { color: var(--accent-dark); }
.white              { color: var(--white); }
.black              { color: var(--black); }

/* -------------------------------------------------------------------------- */
/* MARK: Typography
*/

h1, h2, h3, h4, h5, h6, p, ul, ol {
    margin-bottom: var(--space-3);
}

h1, h2, h3, h4, h5, h6 {
    font-family: 'font-secondary';
    font-weight: 400;
    line-height: 1.1;
}

.text-xxl       { font-size: var(--text-xxl); }
.text-xl, h1    { font-size: var(--text-xl); }
.text-lg, h2    { font-size: var(--text-lg); }
.text-md, h3    { font-size: var(--text-md); }
.text-base, h4  { font-size: var(--text-base); }
.text-sm, h5    { font-size: var(--text-sm); }
.text-xs, h6    { font-size: var(--text-xs); }

.list-none { list-style: none; }

.caps {
    font-family: 'font-primary';
    font-size: var(--text-sm);
    font-weight: 400;
    letter-spacing: 0.1em; /* spacing relative to font size */
    text-transform: uppercase;
}

a.caps {
    display: inline-block;
    color: var(--accent);
    font-weight: 600;
    padding: var(--space-1) 0;
    text-decoration: none;
}
a.caps::after {
    content: '➜';
    display: inline-block;
    margin-left: var(--space-1);
    font-weight: 400;
    transition: margin 0.3s ease-in-out;
}
a.caps:hover:after {
    margin-left: var(--space-3);
}

.text-center { text-align: center; }
.text-left { text-align: left; }
.text-right { text-align: right; }


/* -------------------------------------------------------------------------- */
/* MARK: Links
*/

a           { color: var(--primary-dark); text-decoration-color: var(--accent); text-underline-offset: 0.2em; text-decoration-thickness: 0.1em; }
a:hover     { color: var(--primary); }
a:active    { color: var(--accent-dark); }

.white-links a       { color: var(--white); }
.white-links a:hover { color: var(--accent); }

/* -------------------------------------------------------------------------- */
/* MARK: Buttons
*/

.btn    {
    background-color: var(--accent);
    border: 1px solid transparent;
    /* border-radius: var(--radius-xl); */
    color: var(--white);
    cursor: pointer;
    display: inline-block;
    font-size: inherit;
    font-weight: 600;
    line-height: 1.2;
    padding: var(--space-2) var(--space-4);
    text-decoration: none;
}

.btn:hover { background-color: var(--accent-dark); color: var(--white); }

.btn--light { background-color: var(--accent-light); color: var(--neutral-dark) }
.btn--light:hover { background-color: var(--accent-mid); }

.btn--primary { background-color: var(--primary); }
.btn--primary:hover { background-color: var(--primary-dark); }
.btn--primary.btn--light { background-color: var(--primary-light); }
.btn--primary.btn--light:hover { background-color: var(--primary-mid); }

.btn--secondary { background-color: var(--secondary); }
.btn--secondary:hover { background-color: var(--secondary-dark); }
.btn--secondary.btn--light { background-color: var(--secondary-light); }
.btn--secondary.btn--light:hover { background-color: var(--secondary-mid); }

.btn--neutral { background-color: var(--neutral); }
.btn--neutral:hover { background-color: var(--neutral-dark); }
.btn--neutral.btn--light { background-color: var(--neutral-light); }
.btn--neutral.btn--light:hover { background-color: var(--neutral-mid); }

.btn--small { font-size: var(--text-sm); padding: var(--space-1) var(--space-3); }
.btn--block { display: block; text-align: center; }

.btn--outline { background-color: transparent; color: var(--primary); border-color: currentColor; }
.btn--outline:hover { background-color: transparent; border-color: currentColor; color:  var(--primary-dark); }

.buttons {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2) var(--space-2);
}

/* -------------------------------------------------------------------------- */
/* MARK: Padding
*/

.p0 { padding: 0 }              .p0-l { padding-left: 0 }              .p0-r { padding-right: 0 }              .p0-t { padding-top: 0 }              .p0-b { padding-bottom: 0 }              .p0-tb { padding-top: 0; padding-bottom: 0 }                           .p0-lr { padding-left: 0; padding-right: 0 }
.p1 { padding: var(--space-1) } .p1-l { padding-left: var(--space-1) } .p1-r { padding-right: var(--space-1) } .p1-t { padding-top: var(--space-1) } .p1-b { padding-bottom: var(--space-1) } .p1-tb { padding-top: var(--space-1); padding-bottom: var(--space-1) } .p1-lr { padding-left: var(--space-1); padding-right: var(--space-1) }
.p2 { padding: var(--space-2) } .p2-l { padding-left: var(--space-2) } .p2-r { padding-right: var(--space-2) } .p2-t { padding-top: var(--space-2) } .p2-b { padding-bottom: var(--space-2) } .p2-tb { padding-top: var(--space-2); padding-bottom: var(--space-2) } .p2-lr { padding-left: var(--space-2); padding-right: var(--space-2) }
.p3 { padding: var(--space-3) } .p3-l { padding-left: var(--space-3) } .p3-r { padding-right: var(--space-3) } .p3-t { padding-top: var(--space-3) } .p3-b { padding-bottom: var(--space-3) } .p3-tb { padding-top: var(--space-3); padding-bottom: var(--space-3) } .p3-lr { padding-left: var(--space-3); padding-right: var(--space-3) }
.p4 { padding: var(--space-4) } .p4-l { padding-left: var(--space-4) } .p4-r { padding-right: var(--space-4) } .p4-t { padding-top: var(--space-4) } .p4-b { padding-bottom: var(--space-4) } .p4-tb { padding-top: var(--space-4); padding-bottom: var(--space-4) } .p4-lr { padding-left: var(--space-4); padding-right: var(--space-4) }
.p5 { padding: var(--space-5) } .p5-l { padding-left: var(--space-5) } .p5-r { padding-right: var(--space-5) } .p5-t { padding-top: var(--space-5) } .p5-b { padding-bottom: var(--space-5) } .p5-tb { padding-top: var(--space-5); padding-bottom: var(--space-5) } .p5-lr { padding-left: var(--space-5); padding-right: var(--space-5) }
.p6 { padding: var(--space-6) } .p6-l { padding-left: var(--space-6) } .p6-r { padding-right: var(--space-6) } .p6-t { padding-top: var(--space-6) } .p6-b { padding-bottom: var(--space-6) } .p6-tb { padding-top: var(--space-6); padding-bottom: var(--space-6) } .p6-lr { padding-left: var(--space-6); padding-right: var(--space-6) }
.p7 { padding: var(--space-7) } .p7-l { padding-left: var(--space-7) } .p7-r { padding-right: var(--space-7) } .p7-t { padding-top: var(--space-7) } .p7-b { padding-bottom: var(--space-7) } .p7-tb { padding-top: var(--space-7); padding-bottom: var(--space-7) } .p7-lr { padding-left: var(--space-7); padding-right: var(--space-7) }
.p8 { padding: var(--space-8) } .p8-l { padding-left: var(--space-8) } .p8-r { padding-right: var(--space-8) } .p8-t { padding-top: var(--space-8) } .p8-b { padding-bottom: var(--space-8) } .p8-tb { padding-top: var(--space-8); padding-bottom: var(--space-8) } .p8-lr { padding-left: var(--space-8); padding-right: var(--space-8) }
.p9 { padding: var(--space-9) } .p9-l { padding-left: var(--space-9) } .p9-r { padding-right: var(--space-9) } .p9-t { padding-top: var(--space-9) } .p9-b { padding-bottom: var(--space-9) } .p9-tb { padding-top: var(--space-9); padding-bottom: var(--space-9) } .p9-lr { padding-left: var(--space-9); padding-right: var(--space-9) }
.p10 { padding: var(--space-10) } .p10-l { padding-left: var(--space-10) } .p10-r { padding-right: var(--space-10) } .p10-t { padding-top: var(--space-10) } .p10-b { padding-bottom: var(--space-10) } .p10-tb { padding-top: var(--space-10); padding-bottom: var(--space-10) } .p10-lr { padding-left: var(--space-10); padding-right: var(--space-10) }

.gutter { padding-inline: var(--gutter); }

/* -------------------------------------------------------------------------- */
/* MARK: Margins
*/

.m0 { margin: 0 }              .m0-l { margin-left: 0 }              .m0-r { margin-right: 0 }              .m0-t { margin-top: 0 }              .m0-b { margin-bottom: 0 }
.m1 { margin: var(--space-1) } .m1-l { margin-left: var(--space-1) } .m1-r { margin-right: var(--space-1) } .m1-t { margin-top: var(--space-1) } .m1-b { margin-bottom: var(--space-1) }
.m2 { margin: var(--space-2) } .m2-l { margin-left: var(--space-2) } .m2-r { margin-right: var(--space-2) } .m2-t { margin-top: var(--space-2) } .m2-b { margin-bottom: var(--space-2) }
.m3 { margin: var(--space-3) } .m3-l { margin-left: var(--space-3) } .m3-r { margin-right: var(--space-3) } .m3-t { margin-top: var(--space-3) } .m3-b { margin-bottom: var(--space-3) }
.m4 { margin: var(--space-4) } .m4-l { margin-left: var(--space-4) } .m4-r { margin-right: var(--space-4) } .m4-t { margin-top: var(--space-4) } .m4-b { margin-bottom: var(--space-4) }
.m5 { margin: var(--space-5) } .m5-l { margin-left: var(--space-5) } .m5-r { margin-right: var(--space-5) } .m5-t { margin-top: var(--space-5) } .m5-b { margin-bottom: var(--space-5) }
.m6 { margin: var(--space-6) } .m6-l { margin-left: var(--space-6) } .m6-r { margin-right: var(--space-6) } .m6-t { margin-top: var(--space-6) } .m6-b { margin-bottom: var(--space-6) }
.m7 { margin: var(--space-7) } .m7-l { margin-left: var(--space-7) } .m7-r { margin-right: var(--space-7) } .m7-t { margin-top: var(--space-7) } .m7-b { margin-bottom: var(--space-7) }
.m8 { margin: var(--space-8) } .m8-l { margin-left: var(--space-8) } .m8-r { margin-right: var(--space-8) } .m8-t { margin-top: var(--space-8) } .m8-b { margin-bottom: var(--space-8) }
.m9 { margin: var(--space-9) } .m9-l { margin-left: var(--space-9) } .m9-r { margin-right: var(--space-9) } .m9-t { margin-top: var(--space-9) } .m9-b { margin-bottom: var(--space-9) }
.m10 { margin: var(--space-10) } .m10-l { margin-left: var(--space-10) } .m10-r { margin-right: var(--space-10) } .m10-t { margin-top: var(--space-10) } .m10-b { margin-bottom: var(--space-10) }

/* -------------------------------------------------------------------------- */
/* MARK: Alignment
*/

.align-top      { align-items: start; }
.align-center   { align-items: center; }
.align-bottom   { align-items: end; }

.z1 { z-index: 1; }
.z2 { z-index: 2; }
.z3 { z-index: 3; }
.z4 { z-index: 4; }
.z5 { z-index: 5; }

/* -------------------------------------------------------------------------- */
/* MARK: Widths
*/

.max-narrow     { max-width: var(--max-narrow); }
.max-wide       { max-width: var(--max-wide); }
.max-full       { max-width: var(--max-full); }
.mauto          { margin-inline: auto; }
.max-ch         { max-width: 60ch; }

.full {
    max-width: var(--max-full);
    margin-inline: auto;
}
.wide {
    max-width: var(--max-wide);
    margin-inline: auto;
}
.narrow {
    max-width: var(--max-narrow);
    margin-inline: auto;
}

/* -------------------------------------------------------------------------- */
/* MARK: Display
*/

.block 			{ display: block; }
.none 			{ display: none; }
.inline-block 	{ display: inline-block; }
.flex 		    { display: flex; }

.overflow-hide  { overflow: hidden; }

.pos-rel        { position: relative; }

/* -------------------------------------------------------------------------- */
/* MARK: Grid & Flex
*/

.flex-stacked {
    display: flex;
    flex-direction: column;
    gap: var(--space-6);
}
.flex-stacked > * {
    margin-block: 0;
}


/* -------------------------------------------------------------------------- */
/* MARK: Images
*/

figure[data-ratio=""] img {
    object-fit: contain;
    width: 100%;
}

figure[data-crop=""][data-ratio=""] img {
    object-fit: cover;
    width: 100%;
}

figcaption {
    font-size: var(--text-sm);
    font-style: italic;
    margin-top: var(--space-3);
    text-align: center;
}

figcaption em {
    font-style: normal;
}

.aspect-square {
    aspect-ratio: 1;
    object-fit: cover;
    height: 100%;
    width: 100%;
}
.aspect-3-2 {
    aspect-ratio: 3/2;
    object-fit: cover;
    height: 100%;
    width: 100%;
}
.aspect-3-4 {
    aspect-ratio: 3/4;
    object-fit: cover;
    height: 100%;
    width: 100%;
}
.aspect-2-3 {
    aspect-ratio: 2/3;
    object-fit: cover;
    height: 100%;
    width: 100%;
}

/* -------------------------------------------------------------------------- */
/* MARK: Icons
*/

.icon svg {
    aspect-ratio: 1;
    max-width: var(--space-7);
}

.icon--sm svg   { max-width: var(--space-6); }
.icon--md svg   { max-width: var(--space-7); }
.icon--lg svg   { max-width: var(--space-8); }
.icon--xl svg   { max-width: var(--space-9); }

.cls-1,
.cls-2 {
    fill: none !important;
    stroke: currentColor !important;
    stroke-linecap: round !important;
    stroke-linejoin: round !important;
    stroke-width: 2px !important;
}
.cls-2 {
    stroke-linecap: round !important;
}

/* -------------------------------------------------------------------------- */
/* MARK: Divders / HRs / Lines
*/

.ornamental-hr {
    background-color: var(--accent);
    height: 0.25rem;
    width: 6rem;
    margin-bottom: var(--space-4);
    max-width: 25%;
}

/* -------------------------------------------------------------------------- */
/* MARK: Header
*/

.banner {
    background-color: var(--primary);
    color: var(--white);
    font-size: var(--text-sm);
    padding: var(--space-3) var(--gutter);
}

.header__pad {
    /* border-bottom: 1px solid var(--primary-mid); */
    padding: var(--space-4) var(--gutter);
}

.header__logo-nav   {
    align-items: center;
    display: flex;
    gap: var(--space-5);
    justify-content: space-between;
    margin-bottom: var(--space-4);
}

.header__logo {
    --logo-width: 12.5rem;
    display: block;
    width: var(--logo-width);
}
.header__logo-img {
    width: var(--logo-width);
}

.header__nav {
    margin: var(--space-4) 0;
}

.mobile-nav__btn {
    background-color: var(--primary-light);
    color: var(--primary-dark);
    padding: 0;
}

.mobile-nav__btn:hover {
    background-color: transparent;
    color: var(--primary-dark);
}

.mobile-nav__label {
    padding-right: 3px;
}

/* -------------------------------------------------------------------------- */
/* MARK: Page Titles & Hero
*/

.page-title {
}

.page-title__inner  {
    align-items: center;
    display: grid;
    gap: var(--space-4);
}

.page-title--hero .page-title__inner  {
    align-items: stretch;
}

.page-title__img    {
    aspect-ratio: 1;
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: 1;
}
.page-title__img:not(.svg)    {
    /* border-radius: var(--radius-xl); */
}
.page-title--minimal .page-title__img {
    aspect-ratio: 1;
    height: 100%;
    max-width: 10rem;
    max-height: 10rem;
    margin-left: auto;
}

.page-title--minimal .page-title__img:not(.svg) {
    /* border-radius: 50%; */
}

.page-title--hero .page-title__copy {
    padding: var(--space-8) 0;
}

.page-title__copy {
    gap: var(--space-4);
    z-index: 2;
}

.h1 {
    line-height: 1;
    margin: 0;
}

.bullets {
    display: grid;
    gap: var(--space-4);
    grid-template-columns: repeat(auto-fit, minmax(12rem, 1fr));
    margin: var(--space-4) 0 0 0;
    padding: 0;
}

.bullets li {
    display: flex;
    height: 3rem;
    align-items: center;
    gap: var(--space-2);
}

.bullets .svg-wrap {
    aspect-ratio: 1;
    fill: currentColor;
    height: 3rem;
}


/* -------------------------------------------------------------------------- */
/* MARK: Post Pages with Sidebar
*/

.sidebar-module {
    /* border-radius: var(--radius-lg); */
}

.post {
}

.post-sidebar--article {
    margin-top: var(--space-8);
}

.post__inner {
    display: flex;
    flex-direction: column;
    gap: var(--space-8);
    margin-inline: auto;
}

.post-sidebar {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}
.post-sidebar > * {
    margin-block: 0;
}

.post-sidebar--staff {
    align-items: center;
    gap: var(--space-4);
    display: flex;
}

.post-sidebar--staff img {
    aspect-ratio: 3/4;
    /* border-radius: var(--radius-xs); */
    height: 100%;
    object-fit: cover;
    width: 100%;
    max-width: 12rem;
}

.post-sidebar--nav  {
    display: flex;
    flex-direction: column;
    align-content: center;
}

.post-sidebar--nav > div {
    margin: auto;
    width: 100%;
}

.post-sidebar--nav ul {
    padding: 0;
    list-style: none;
}

.post-sidebar--nav li {
    margin-top: var(--space-1);
}

.post-sidebar--nav a {
    background: var(--primary-light);
    border: 0;
    outline: 1px solid var(--white);
    /* border-radius: var(--radius-xs); */
    display: block;
    padding: var(--space-1) var(--space-2);
    text-decoration: none;
}
.post-sidebar--nav a:hover {
    background-color: var(--secondary);
    color: white;
}

.post-sidebar--nav a.active {
    outline-color: var(--primary-mid);
    background-color: var(--white);
    color: var(--primary);
}

.post-sidebar--nav a:focus {
    outline: .125rem solid var(--accent);
}

/* -------------------------------------------------------------------------- */
/* MARK: Layout Rows & Columns
*/

.layout__row {
    /* border-top: 2px dashed pink; */
    margin: var(--space-10) 0;
    padding-inline: var(--gutter);
}

.layout__inner {
    --colCount: 12;
    --colSpan: 12;
    display: grid;
    row-gap: var(--space-6);
    grid-template-columns: repeat(var(--colCount), 1fr);
    margin-inline: auto;
}

.layout__col {
    align-content: start;
    display: flex;
    flex-wrap: wrap;
    row-gap: var(--space-6);
    grid-column: span 12;
}

.layout__col > * {
    margin-block: 0;
    width: 100%;
}

/* -------------------------------------------------------------------------- */
/* MARK: Blocks
*/

.blocks {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    /* padding: 1.5rem; */
}

.blocks > * {
    /* border-top: 2px dotted purple; */
    margin-block: 0;
    width: 100%;
}

/* heading? add some top margin */
.blocks > :is(h2, h3, h4, h5, h6):not(:first-child) {
    margin-top: calc(var(--space-3) * 4);
}

/* things that look like new sections get some top margin */
.blocks > :is(div, section, header):not(:first-child, .feature, .narrow-text) {
    margin-top: calc(var(--space-3) * 4);
}

/* anything that follows a header block? no top margin */
.blocks > header + * {  
    margin-top: calc(var(--space-3) * 2) !important;
}
/* whenever a cards block follows anything?? no top margin */
.blocks > * + .cards {
    margin-top: calc(var(--space-3) * 1) !important;
} 
.blocks > .cards + :is(p, ol, li) {
    margin-top: calc(var(--space-3) * 1) !important;
}

/* -------------------------------------------------------------------------- */
/* MARK: Breadcrumbs
*/

.breadcrumbs {
    padding: 0 var(--gutter);
}

/* if breadcrumbs are first in the main element, skip the top border */
.main > *:is(:first-child):is(.breadcrumbs) ol {
    border-top: 0;
}
.main > *:is(:last-child):is(.breadcrumbs) ol {
    border-bottom: 0;
}
.breadcrumbs ol {
    border-bottom: 1px solid var(--primary-mid);
    border-top: 1px solid var(--primary-mid);
    display: flex;
    list-style: none;
    margin-bottom: 0;
    padding: var(--space-3) 0;
    position: relative;
    gap: var(--space-3);
}

.breadcrumbs a {
    position: relative;
}
.breadcrumbs li:last-child a {
    text-decoration: none;
}

.breadcrumbs li:not(:last-child) a::after {
    color: var(--primary-mid);
    content: '/';
    position: absolute;
    right: calc(var(--space-2) * -1);
    width: var(--space-3);
    text-align: center;
}


/* -------------------------------------------------------------------------- */
/* MARK: Block Header
*/

.block-header {
    display: flex;
    flex-direction: column;
    gap: var(--space-3)
}
.block-header > * {
    margin-block: 0;
}


/* -------------------------------------------------------------------------- */
/* MARK: Gallery Block
*/

.gallery__ul {
    --galleryGap: var(--space-4);
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: var(--galleryGap);
    justify-content: center;
    list-style: none;
    margin: 0;
    padding: 0;
    width: 100%;
    max-width: 100%;
}

.gallery__li {
    /* default to 2 per row, since that's the min required */
    --itemsPerRow: 2;
    --itemWidth: calc(100% / var(--itemsPerRow));
    --itemGap: calc(( var(--galleryGap) * (var(--itemsPerRow) - 1) / var(--itemsPerRow) ));
    width: calc( var(--itemWidth) - var(--itemGap));
}

.gallery__ul.count-3 .gallery__li {
    --itemsPerRow: 3;
}

/* -------------------------------------------------------------------------- */
/* MARK: Disclosures Block
*/

.disclosures {
    /* background-color: var(--white);
    border-radius: var(--radius-lg);
    padding: var(--space-6) */
}
.disclosure {
    border: 1px solid var(--primary-mid);
    display: block;
    overflow: hidden;
    text-decoration: none;
}
.disclosure {
    margin-top: -1px
}
.disclosure[open=""] {
    background-color: white;
    outline-color: var(--white);
}
.disclosure-summary {
    padding: var(--space-3);
}

.disclosure-hidden {
    padding: 0 var(--space-4) var(--space-4) var(--space-4);
}

.disclosure:hover {
    background-color: white;
}

.details-summary:hover {
    text-decoration: underline;
}

.details-summary {
    cursor: pointer;
}

.disclosure:focus-within {
    outline: .125rem solid var(--accent);
}


/* -------------------------------------------------------------------------- */
/* MARK: CTA Block
*/

.cta .text-col {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}
.cta .text-col > * {
    margin-block: 0;
    width: 100%;
}
.cta h2 {
    text-wrap: balance;
}

.cta--minimal {
    align-items: center;
    display: grid;
    grid-template-areas: "stack";
    justify-items: center;
    position: relative;
    text-align: center;
}

.cta--minimal > * {
    grid-area: stack;
}

.cta--minimal .cta-btns {
    justify-content: center;
}

.cta--minimal > .text-col {
    padding: var(--space-10) var(--space-6);
    position: relative;
    z-index: 2;
}

.cta--minimal .img-col,
.cta--minimal .img-col img {
    position: absolute;
    left: 0;right: 0;top: 0;bottom: 0;
}
.cta--minimal .img-col img {
    filter: brightness(50%) saturate(1.4);
    height: 100%;
    object-fit: cover;
    width: 100%;
}


.cta--full {
    overflow: hidden;
    display: grid;
    gap: var(--space-6);
    grid-template-areas: 'stack';
    grid-template-columns: 1fr;
    grid-template-rows: 1fr;
}

.cta--full > * {
    grid-area: stack;
    position: relative;
}

.cta--full .text-col {
    background-color: var(--white);
    z-index: 2;
    padding: var(--space-6);
    margin: var(--space-10) var(--space-4);
    align-self: center;
    justify-self: center;
}

.cta--full .cta-img {
    height: 100%;
    width: 100%;
    object-fit: cover;
}

/* -------------------------------------------------------------------------- */
/* MARK: Image Block
*/

.image-block:not([data-crop=""]):not([data-caption=""]) {
}

.image-block:not([data-crop=""]) {
    display: grid;
    gap: var(--space-4);
}

.image-block:not([data-crop=""]) > * {
    height: 100%;
}

.image-block:not([data-crop=""]) img {
    height: 100%;
    width: 100%;
    object-fit: cover;
}

.image-block:not([data-crop=""])[data-caption=""] figcaption {
    background-color: var(--primary-mid);
    margin: 0;
    text-align: left;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: var(--space-6);
    font-size: var(--text-md);
    font-family: 'font-secondary';
    font-style: normal;
    font-weight: 300;
}

/* -------------------------------------------------------------------------- */
/* MARK: Video Block
*/

.video__wrap {
    aspect-ratio: 16/9;
    /* border-radius: var(--radius-lg); */
    overflow: hidden;
    position: relative;
    width: 100%;
} 
.video__wrap iframe {
    border: 0;
    box-shadow: 0;
    height: calc(100% + 4px);
    position: absolute;
    left: -2px; right: -2px; top: -2px; bottom: -2px;
    width: calc(100% + 4px);
}

/* -------------------------------------------------------------------------- */
/* MARK: Code Block
*/

.code {
    background-color: var(--neutral-dark);
    /* border-radius: var(--radius-lg); */
    color: var(--neutral-mid);
    font-size: var(--text-sm);
    overflow-x: scroll;
    padding: var(--space-6);
}

/* -------------------------------------------------------------------------- */
/* MARK: Quote Block
*/

.quote {
    border-left: var(--space-4) solid var(--primary-mid);
    font-family: 'font-secondary', sans-serif;
    font-size: var(--text-md);
    font-weight: 300;
    margin-left: calc(-1 * (var(--space-4) * 2));
    padding-left: var(--space-4);
}
.quote strong {
    font-weight: 500;
}
.quote em {
    font-weight: 500;
}

.quote__author {
    font-style: italic;
    margin-top: var(--space-2);
}


/* -------------------------------------------------------------------------- */
/* MARK: Footer CTA
*/

.footer-cta {
    background-color: var(--primary-dark);
    border-bottom: 1px solid var(--primary);
    color: var(--white);
    padding: var(--space-8) var(--gutter);
}

.footer-cta__inner {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-4);
    justify-content: space-between;
}

/* -------------------------------------------------------------------------- */
/* MARK: Cards
*/

.cards {
    --gap: var(--space-3);
    display: grid;
    gap: var(--gap);
    grid-template-columns: repeat(auto-fit, minmax(12rem, 1fr));
}

/* these three use max() to choose the larger of the two values */
.cards.card-max-half {
    --max: calc( (100% - (var(--gap) * 1)) / 2  );
    grid-template-columns: repeat(auto-fit, max(12rem, var(--max)));
}
.cards.card-max-third {
    --max: calc( (100% - (var(--gap) * 2)) / 3  );
    grid-template-columns: repeat(auto-fit, max(12rem, var(--max)));
}
.cards.card-max-quarter {
    --max: calc( (100% - (var(--gap) * 3)) / 4  );
    grid-template-columns: repeat(auto-fit, max(12rem, var(--max)));
}

.cards .svg-wrap svg {
    aspect-ratio: 1;
    fill: currentColor;
    max-height: 100%;
    max-width: calc(var(--space-7) * 2);
}

.cards .card {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.cards > .card.padded {
    border: 1px solid var(--primary-mid);
    padding: var(--space-3);
}

.cards > .card:not(.padded) {
    /* border-left: 1px solid var(--primary-mid); */
    padding-right: var(--space-4);
}

.cards > .card.padded svg {
    /* margin-inline: auto; */
}


/* -------------------------------------------------------------------------- */
/* MARK: Promote Block
*/

.promote-block {
    border-left: 1rem solid var(--accent);
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    padding-left: var(--space-4);
}

.promote-block > * {
    margin: 0;
}

/* -------------------------------------------------------------------------- */
/* MARK: Feature
*/

.feature {
    align-items: center;
    display: grid;
    gap: var(--space-3);
}
.feature > .text-col {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    justify-self: end;
}

.feature > .text-col > * {
    margin-block: 0;
}

.feature > .img-col {
    aspect-ratio: 4/3;
}

.feature > .img-col.has-two-img {
    display: grid;
    gap: var(--space-3);
    grid-template-columns: 1fr 1fr;
    grid-template-rows: var(--space-6) max-content var(--space-6);
}

.feature > .img-col.has-two-img .feature-img.alpha {
    grid-row: 1 / 3;
}
.feature > .img-col.has-two-img .feature-img.omega {
    grid-row: 2 / 4;
}

.feature .feature-img {
    /* border-radius: var(--radius-xl); */
    display: block;
    height: 100%;
    object-fit: cover;
    width: 100%;
}

/* -------------------------------------------------------------------------- */
/* MARK: FAQs
*/

.faqs-block {
    display: grid;
    gap: var(--space-3);
}
.faqs-block header {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    margin-bottom: calc(var(--space-3) * 2);
    text-align: center;
}
.faqs-block header > * {
    margin-block: 0;
}


.faqs {
    margin: 0;
    list-style: none;
    padding: 0;
}

.faqs > li details {
    border: 1px solid var(--primary-mid);
    font-size: var(--text-sm);
}

.faqs > li details[open] {
    background-color: var(--white);
}

.faqs > li:hover details {
    background-color: var(--white);
}

.faqs > li:hover summary {
    text-decoration: underline;
}

.faqs > li {
    margin-top: -1px
}

.faqs summary {
    cursor: pointer;
    padding: var(--space-3);
}

.faqs .answer {
    padding: 0 var(--space-3) var(--space-3) var(--space-3);
}

.faqs > li details:focus-within {
    outline: .125rem solid var(--accent);
}

/* -------------------------------------------------------------------------- */
/* MARK: Footer
*/

.footer {
    background-color: var(--primary-dark);
    color: var(--primary-mid);
    padding: 0 var(--gutter);
}

.footer__inner {
    display: grid;
    gap: var(--space-6);
}

.footer h3 {
    color: var(--accent);
    font-family: 'font-primary';
    font-size: var(--text-sm);
    font-weight: 700;
    margin: 0 0 var(--space-1) 0;
    text-transform: uppercase;
}

.footer__alpha .search-form {
    gap: var(--space-2);
}

.footer__alpha .search-form__text {
    width: 100%;
}

.footer__hr {
    /* always full width, regardless of columns */
    grid-column: 1 / -1;
}

.footer__nav a,
.footer__contact a {
    text-decoration: none;
}

.footer__logo {
    max-width: 16rem;
}

.footer__logo .logo-light { fill: var(--primary-mid); }
.footer__logo .logo-dark { fill: var(--primary-light); }

/* -------------------------------------------------------------------------- */
/* MARK: Copyright
*/

.copyright {
    border-top: 1px solid var(--primary);
    padding-block: var(--space-3);
}

#top-link	{
	background-color: rgba(0,0,0,0.5);
	border: 0;
	/* border-radius: 2px; */
	bottom: 10px;
	color: #fff;
	display: none;
	height: 40px;
	line-height: 1 !important;
	padding: 10px;
	position: fixed;
	right: 10px;
	text-decoration: none;
	transition: background-color 0.3s ease-in-out;
	width: 40px;
	z-index: 100;
}

#top-link:hover	{
	background-color: rgba(0,0,0,1);
}

/* -------------------------------------------------------------------------- */
/* MARK: Search
*/

.search-modal {
    cursor: zoom-out;
    display: none;
    position: fixed;
    z-index: 1000;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    overflow: auto;
    background-color: #414D3Dee;
}

.search-modal-content {
    cursor: default;
    background-color: var(--primary);
    /* border-radius: var(--radius-xs); */
    margin: auto;
    max-width: 100%;
    min-width: 30rem;
    padding: var(--space-6);
    position: relative;
    width: 40%;
}

.search-modal .search-form {
    gap: var(--space-3);
    justify-content: start;
    width: calc(100% - 60px);
}
.search-modal .search-form__text {
    max-width: none;
    width: 100%;
}

.search-close {
    position: absolute;
    top: 50%;
    margin-top: -20px;
    right: 20px;
    color: var(--primary-mid);
    font-size: 40px;
    height: 40px;
    width: 40px;
    font-weight: bold;
    line-height: 35px;
    cursor: pointer;
    text-align: center;
}

.modal-hidden {
    display: none !important;
}

/* -------------------------------------------------------------------------- */
/* MARK: TEMP
*/

/* temporary or dev-focused stuff */

.dev-notice {
    background-color: rgb(255, 230, 234);
    border: 1px solid pink;
    padding: var(--space-6)
}
.dev-notice li p {
    margin: var(--space-1) 0 0 0;
}

.portal {
    display: grid;
    gap: var(--space-4);
    grid-template-columns: repeat(auto-fit, minmax(16rem, 1fr));
}
.portal-item {
    background-color: var(--white);
    /* border-radius: var(--radius-xs); */
    display: flex;
    line-height: 1.1;
    flex-direction: column;
    outline: .125rem solid transparent;
    overflow: hidden;
    padding: 0;
    text-decoration: none;
    transition: outline 0.4s ease-in-out;
    width: 100%;
}

.portal-item:focus {
    outline: .125rem solid var(--accent);
}
.portal-item .svg-wrap {
    border-bottom: 1px solid var(--primary-light);
}
.portal-item .svg-wrap svg {
    width: 50%;
}
.portal-sidekick {
    margin-top: var(--space-1);
}
.portal-copy {
    padding: var(--space-4) var(--space-5) var(--space-4) var(--space-5);
    height: 100%;
    display: flex;
    flex-direction: column;
}
.portal-item:hover {
    outline: .125rem solid var(--primary-mid);
}
.portal-label {
    margin-top: auto;
}

/* -------------------------------------------------------------------------- */
/* MARK: Helpers
*/

.trim > :first-child    { margin-top: 0; }
.trim > :last-child     { margin-bottom: 0; }

.screen-reader-text     { border: 0; clip: rect(1px, 1px, 1px, 1px); clip-path: inset(50%); height: 1px; margin: -1px; overflow: hidden; padding: 0; position: absolute !important; width: 1px; word-wrap: normal !important; }