/* -------------------------------------------------------------------------- */
/* RTB-MAIN.CSS (c) richardthebrave.com ------------------------------------- */

/* -------------------------------------------------------------------------- */
/* MARK: Variables
*/

:root {

    --ratio: auto;

    --primary-light:#ffdedf;
    --primary-mid:  #ff989b;
    --primary:      #f80a10;
    --primary-dark: #8e0e11;

    --secondary-light:  #f3e6ff;
    --secondary-mid:    #d7afff;
    --secondary:        #a549ff;
    --secondary-dark:   #57148f;

    --accent-light: #faf1c7;
    --accent-mid:   #f0c954;
    --accent:       #da9a18;
    --accent-dark:  #7d4416;

    --neutral-bg:       #F3F3F2;
    --neutral-light:    #e5e4e2;
    --neutral-mid:      #a8a7a0;
    --neutral:          #54534d;
    --neutral-dark:     #171715;

    --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, 1rem + 0.2778vw, 1.25rem);         /* 17->20px .text-base */
    --text-md: clamp(1.3125rem, 1.2083rem + 0.463vw, 1.625rem);      /* 21->26px .text-md */
    --text-lg: clamp(1.625rem, 1.5rem + 0.5556vw, 2rem);             /* 26->32px .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: white; 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.5; -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); }

@view-transition {
    navigation: auto;
}

/* 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
*/

/* Merchant Ledger 300 */
@font-face { font-family: 'font-typewriter'; src: url('/assets/fonts/merchant-ledger/merchant-ledger-300.woff2') format('woff2'), url('/assets/fonts/merchant-ledger/merchant-ledger-300.woff') format('woff'), url('/assets/fonts/merchant-ledger/merchant-ledger-300.ttf') format('truetype'); font-weight: 300; font-style: normal; font-display: swap; }
.font-typewriter-300 { font-family: 'font-typewriter', sans-serif; font-style: normal; font-weight: 300; }

/* Merchant Ledger 400 */
@font-face { font-family: 'font-typewriter'; src: url('/assets/fonts/merchant-ledger/merchant-ledger-400.woff2') format('woff2'), url('/assets/fonts/merchant-ledger/merchant-ledger-400.woff') format('woff'), url('/assets/fonts/merchant-ledger/merchant-ledger-400.ttf') format('truetype'); font-weight: 400; font-style: normal; font-display: swap; }
.font-typewriter-400 { font-family: 'font-typewriter', sans-serif; font-style: normal; font-weight: 400; }

/* Plex Sans Var */
@font-face {
    font-family: 'font-primary';
    src:    url('/assets/fonts/plex-sans-var/plex-sans-var.woff2') format('woff2-variations'),
            url('/assets/fonts/plex-sans-var/plex-sans-var.ttf') format('truetype-variations');
    font-weight: 100 700;
    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; }

/* Plex Sans Var Italic */
@font-face {
    font-family: 'font-primary';
    src:    url('/assets/fonts/plex-sans-var/plex-sans-var-italic.woff2') format('woff2-variations'),
            url('/assets/fonts/plex-sans-var/plex-sans-var-italic.ttf') format('truetype-variations');
    font-weight: 100 700;
    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; }

/* Antonio Var */
@font-face {
    font-family: 'font-secondary';
    src:    url('/assets/fonts/antonio-var/antonio-var.woff2') format('woff2-variations'),
            url('/assets/fonts/antonio-var/antonio-var.ttf') format('truetype-variations');
    font-weight: 100 700;
    font-display: swap;
        
}
.font-secondary { font-family: 'font-secondary', sans-serif; font-style: normal; }
.font-secondary-100 { font-family: 'font-secondary', sans-serif; font-style: normal; font-weight: 100; }
.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; }

/* -------------------------------------------------------------------------- */
/* MARK: Auto-Grid
*/
/* This CSS utility creates a responsive grid layout that automatically adjusts the number of columns
* based on the available space and specified constraints. It aims to fit as many cells as possible
* in a single row, while respecting minimum cell width and maximum columns constraints.
*
* Customizable Properties:
* --auto-grid-min-size: Sets the minimum width for each cell in the grid.
*                       Default is 10rem.
* --auto-grid-max-columns: Sets the maximum number of columns in the grid.
*                          Default is 'infinity' (as many as can fit).
* --auto-grid-gap: Sets the horizontal gap between grid cells. It also sets
*                  the vertical gap if --auto-grid-gap-vertical is not defined.
*                  Default is 1rem.
* --auto-grid-gap-vertical: Specifically sets the vertical gap between rows
*                           of cells. If not set, it falls back to the value
*                           of '--auto-grid-gap'.
*
* The grid utilizes CSS 'display: grid' with the 'auto-fit' feature and the 'minmax()'
* function to ensure that cells expand to fill available space while maintaining
* the set minimum size.
*
* Example Usage:
* <div class="auto-grid" style="--auto-grid-min-size: 10rem; --auto-grid-max-columns: 3; --auto-grid-gap: 0.5rem;">
*   <!-- grid items here -->
* </div>
*
* The above example will create a grid with a minimum cell width of 10rem, a maximum
* of 3 columns, and a gap of 0.5rem between both rows and columns.
*/

.auto-grid {
    --max-column-width: 100% / var(--auto-grid-max-columns, infinity) - var(--auto-grid-gap);
    --column-width: max(var(--max-column-width), min(var(--auto-grid-min-size, 10rem), 100%));
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(var(--column-width), 1fr));
    /* vertical gap falls back to general gap then falls back to 1rem*/
    gap: var(--auto-grid-gap-vertical, var(--auto-grid-gap, 1rem)) var(--auto-grid-gap, 1rem);
}

/* -------------------------------------------------------------------------- */
/* MARK: Colours
*/

.bg-neutral-bg      { background-color: var(--neutral-bg); }
.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-bg         { color: var(--neutral-bg); }
.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-4);
}

h1, h2, h3, h4, h5, h6 {
    font-family: 'font-secondary';
    font-weight: 700;
    line-height: 1.1;
    text-transform: uppercase;
}

.text-xxl, h1   { font-size: var(--text-xxl); }
.text-xl, h2    { font-size: var(--text-xl); }
.text-lg, h3    { font-size: var(--text-lg); }
.text-md, h4    { font-size: var(--text-md); }
.text-base, h5  { font-size: var(--text-base); }
.text-sm, h6    { font-size: var(--text-sm); }
.text-xs        { font-size: var(--text-xs); }

.balance    { text-wrap: balance; }
.text-upper { text-transform: uppercase; }
.list-none  { list-style: none; }

.underlined span {
    position: relative;
    z-index: 1;
    display: inline-block;
    transform: rotate(-3deg);
}

.underlined span::after {
    clip-path: polygon(2% 0, 99% 2%, 97% 100%, 3% 99%);
    content: '';
    position: absolute;
    left: -1.25rem; right: -0.75rem; bottom: -0.75rem;
    height: 50%;
    background-color: var(--primary);
    z-index: -1;
    transform: rotate(2deg);
}

.underlined.alt span::after {
    background-color: var(--accent);
}

.caps {
    font-family: 'font-typewriter';
    font-size: var(--text-sm);
    font-weight: 400;
    letter-spacing: var(--space-1);
    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: inherit; text-decoration-color: var(--primary); text-underline-offset: 0.2em; text-decoration-thickness: 0.1em; }
a:hover     { color: var(--primary); }
a:active    { opacity: 0.5; }

.white-links a       { color: var(--white); }
.white-links a:hover { color: var(--primary); }

/* -------------------------------------------------------------------------- */
/* MARK: Buttons
*/

.btn    {
    background-color: var(--primary);
    border: 1px solid transparent;
    font-family: 'font-secondary';
    clip-path: polygon(0 0, 100% 0%, 99% 100%, 1% 97%);
    color: var(--white);
    cursor: pointer;
    display: inline-block;
    font-size: inherit;
    font-weight: 700;
    line-height: 1.2;
    padding: var(--space-2) var(--space-4) var(--space-3) var(--space-4);
    text-decoration: none;
    text-transform: uppercase;
    transform: rotate(2deg);
}

.btn:hover { background-color: var(--accent); 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--accent { background-color: var(--accent); }
.btn--accent:hover { background-color: var(--white); color: var(--accent) }
.btn--accent.btn--light { background-color: var(--accent-light); }
.btn--accent.btn--light:hover { background-color: var(--accent-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 { clip-path: none; 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;
}

.stacked-tight {
    gap: var(--space-4);
}


/* -------------------------------------------------------------------------- */
/* 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 {
    padding: var(--space-3) var(--gutter);
}

.header__inner {
    display: grid;
    gap: var(--space-4) var(--space-1);
    grid-template-columns: repeat(4, 1fr);
}

.header__logo {
    --logo-width: 12.5rem;
    display: block;
    width: var(--logo-width);
    grid-column: span 3;
}

.header__logo svg {
    fill: white;
    width: var(--logo-width);
}

.header__btn {
    grid-column: span 4;
}

.header__nav {
    margin: var(--space-4) 0;
}

.mobile-nav__btn {
    align-items: center;
    background-color: transparent;
    border: 0;
    border-left: 1px solid var(--neutral);
    color: white;
    display: flex;
    gap: var(--space-1);
    padding: 0 var(--space-1);
    justify-content: center;
}

.mobile-nav__btn:hover {
    background-color: transparent;
    color: white;
}

/* -------------------------------------------------------------------------- */
/* MARK: Page Titles & Hero
*/

.page-title-search {
    display: flex;
    flex-direction: row;
    gap: var(--space-2);
    flex-wrap: wrap;
    max-width: 100% !important;
}

.page-title-form {
    padding-bottom: var(--space-8);
    position: relative;
    z-index: 2;
}

.page-title-form h2 {
    color: white;
}

.page-title-form .rtbform {
    gap: var(--space-2);
}

.page-title-form .rtbform label {
    background-color: var(--neutral-dark);
    border-top: 1px solid var(--neutral);
    color: white;
    display: inline-block;
    margin: 0;
    padding: var(--space-1);
    width: auto;
    transform: translateY(5px) translateX(5px);
}

.page-title-form h2 span {
    color: var(--primary);
    display: block;
}

.page-title__inner  {
    align-items: center;
    display: grid;
    gap: var(--space-4);
}

.page-title__h1 {
    text-wrap: balance;
}

.page-title--hero .page-title__inner  {
    align-items: stretch;
}

.page-title__img    {
    aspect-ratio: 1;
    filter: contrast(1.2) saturate(0) brightness(1.2);
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: 1;
    /* opacity: 0.8; */
    mix-blend-mode: lighten;
}
.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;
}

.page-title__lede {
    text-wrap: balance;
}

.page-title__prehead {
    display: block;
    font-size: var(--text-md);
    transform: rotate(-2deg) translateY(calc(-1 * var(--space-4)));
}


/* -------------------------------------------------------------------------- */
/* MARK: Post Pages with Sidebar
*/

.recent-nav-list {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

.recent-nav-item {
    display: flex;
    gap: var(--space-4);
    align-items: center;
}

.recent-nav-item a {
    text-decoration-color: var(--neutral-light);
}

.recent-nav-date {
    transform: rotate(-4deg);
}

.recent-nav-item.active {
    color: var(--primary);
}

/* -------------------------------------------------------------------------- */
/* MARK: Layout Rows & Columns
*/

.layout__row {
    /* border-top: 2px dashed pink; */
    margin: var(--space-10) 0;
    padding-inline: var(--gutter);
}

.layout__inner {
    --gap: var(--space-4);
    display: grid;
    gap: var(--gap);
    margin-inline: auto;
}

.layout__inner > * {
    margin-block: 0;
}

.layout__inner > :is(h2, h3, h4, h5, h6):not(:first-child) {
    margin-top: var(--space-4);
}

.layout__inner > :is(hr, figure, blockquote, iframe, .cards, .portal, .disclosures, .mega):not(:first-child) {
    margin-block: var(--space-4);
}

.layout__inner > :is(h2, h3, h4, h5, h6) + * {
    margin-top: 0 !important;
}

/* -------------------------------------------------------------------------- */
/* MARK: Blocks
*/

.blocks {
    --gap: var(--space-4);
    display: grid;
    gap: var(--gap);
    margin-inline: auto;
}

.blocks > * {
    margin-block: 0;
}

.blocks > :is(h2, h3, h4, h5, h6):not(:first-child) {
    margin-top: var(--space-4);
}

.blocks > :is(hr, figure, blockquote, iframe, .cards, .portal, .disclosures, .mega):not(:first-child) {
    margin-block: var(--space-4);
}



/* -------------------------------------------------------------------------- */
/* MARK: Breadcrumbs
*/

.breadcrumbs {
    background-color: var(--neutral-bg);
    padding: 0 var(--gutter);
}

.breadcrumbs ol {
    display: flex;
    flex-wrap: wrap;
    list-style: none;
    margin-bottom: 0;
    padding: var(--space-2) 0;
    position: relative;
    gap: 0 var(--space-3);
}

.breadcrumbs a {
    color: var(--neutral);
    position: relative;
    text-decoration: none;
}
.breadcrumbs a:hover {
    color: var(--primary);
}

.breadcrumbs li:not(:last-child) a::after {
    color: var(--neutral);
    content: '/';
    position: absolute;
    right: calc(var(--space-2) * -1);
    bottom: -1px;
    width: var(--space-3);
    text-align: center;
}


/* -------------------------------------------------------------------------- */
/* MARK: Mega Block
*/

.mega {
    background-color: var(--neutral-bg);
    hyphens: auto;
    letter-spacing: -0.02em;
    position: relative;
    padding: var(--space-5) var(--space-4) var(--space-4) var(--space-4);
}
.mega::before,
.mega::after {
    position: absolute;
    left: 0.25rem; top: -1rem;
    height: var(--space-10);
    width: var(--space-5);
    background-color: var(--neutral-mid);
    opacity: 0.5;
    content: '';
    transform: rotate(32deg);
}

.mega::after {
    left: auto;
    right: 0.25rem;
    top: -1.5rem;
    transform: rotate(-40deg);
}

.mega strong {
    font-weight: 400;
    display: inline-block;
    transform: rotate(2deg);
}

.mega strong:nth-of-type(2) {
    transform: rotate(-1deg);
}


.mega strong:nth-of-type(3) {
    transform: rotate(2deg);
}


/* -------------------------------------------------------------------------- */
/* MARK: Block Header
*/

.block-header {
    display: flex;
    flex-direction: column;
    gap: var(--space-3)
}
.block-header > * {
    margin-block: 0;
}

/* -------------------------------------------------------------------------- */
/* MARK: Watch Listen Read WLR
*/

.wlr-anchors {
    display: grid;
    gap: var(--space-4) var(--space-6);
    margin-bottom: var(--space-6);
}

.wlr-anchor {
    background-color: var(--neutral-dark);
    color: white;
    display: flex;
    align-content: center;
    justify-content: center;
    padding: var(--space-6) var(--space-4);
    font-family: 'font-secondary';
    text-transform: uppercase;
    font-weight: 700;
    font-size: var(--text-lg);
    transform: rotate(2deg);
    text-align: center;
}

.wlr-anchor:nth-of-type(2) {
    transform: rotate(-1deg);
}

.wlr-anchor:nth-of-type(3) {
    transform: rotate(1deg);
}

.wlr-anchor:hover {
    background-color: var(--primary);
    color: white;
}

.wlr-block {
    display: grid;
    gap: var(--space-8);
}

.wlr-item {
    display: grid;
    gap: var(--space-6);
}

.wlr-item__link {
    background: var(--neutral-bg);
    clip-path: polygon(2% 0, 99% 1%, 98% 100%, 1% 99%);
    display: inherit;
    height: 100%;
    gap: var(--space-4);
    padding: var(--space-4);
    padding-bottom: var(--space-7);
    text-align: center;
    transition: all 0.2s ease-in-out;
}

.wlr-item__link:hover {
    background-color: var(--accent);
    color: white;
}

.wlr-item__link:hover .wlr-item__poster {
    background-color: var(--accent);
}

.wlr-item > * {
    margin-block: 0;
}

.wlr-item__poster {
    background-color: var(--neutral-bg);
    aspect-ratio: 1;
    object-fit: contain;
    padding: var(--space-2);
    display: block;
    transition: all 0.2s ease-in-out;
    width: 100%;
}

.wlr-item__links {
    display: flex;
    flex-wrap: wrap;
    gap: 0 var(--space-4);
}

.wlr-item.simple .wlr-item__title {
    font-size: var(--text-md);
}


/* -------------------------------------------------------------------------- */
/* 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
*/

.disclosure {
    border: 1px solid var(--neutral-light);
    display: block;
    overflow: hidden;
    text-decoration: none;
    background-color: var(--neutral-bg);
    margin-top: -1px
}
.disclosure[open=""] {
    background-color: white;
    outline-color: var(--white);
}
.disclosure-summary {
    cursor: pointer;
    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(--primary);
}



/* -------------------------------------------------------------------------- */
/* 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(--neutral-dark);
    color: var(--accent);
    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 {
    font-family: 'font-typewriter', sans-serif;
    font-size: var(--text-md);
    font-weight: 400;
    color: var(--primary);
    line-height: 2;
    max-width: 40ch;
}

.quote strong,
.quote em {
    font-weight: 400;
    color: var(--primary);
}

.quote__author {
    margin-top: var(--space-2);
    font-size: var(--text-sm);
    text-transform: uppercase;
    letter-spacing: var(--space-1);
}


/* -------------------------------------------------------------------------- */
/* MARK: Footer CTA
*/

.footer-cta {
    background-color: var(--primary-dark);
    color: var(--white);
    padding: var(--space-8) var(--gutter);
    position: relative;
}



.footer-cta::before,
.footer-cta::after {
    content: '';
    top: -1px; left: 0; right: 0; bottom: -1px;
    position: absolute;
}

.footer-cta::before {
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0 0);
    background-color: var(--white);
    z-index: 3;
    bottom: auto;
    height: var(--space-6);
}

.footer-cta::after {
    clip-path: polygon(0 100%, 100% 0, 100% 100%, 0 100%);
    background-color: var(--neutral-dark);
    top: auto;
    height: var(--space-6);
}

.footer-cta__inner {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-4);
    justify-content: space-between;
    position: relative;
    z-index: 2;
}

.footer-cta__title span {
    position: relative;
    z-index: 1;
    display: inline-block;
    transform: rotate(-3deg);
}

.footer-cta__title span::after {
    content: '';
    position: absolute;
    left: -0.5rem; right: -0.5rem; bottom: -0.5rem;
    height: 50%;
    background-color: var(--primary);
    z-index: -1;
    transform: rotate(2deg);
}


/* -------------------------------------------------------------------------- */
/* MARK: Cards
*/

.cards {
    --auto-grid-min-size: 14rem;
    --auto-grid-max-columns: 4;
    --auto-grid-gap: var(--space-4);
    display: grid;
}


.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: Footer
*/

.footer {
    background-color: var(--neutral-dark);
    color: var(--neutral-mid);
    padding: 0 var(--gutter);
}

.footer__inner {
    display: grid;
    gap: var(--space-6);
}

.footer h3 {
    color: var(--accent);
    font-size: var(--text-md);
    margin: 0 0 var(--space-1) 0;
    text-transform: uppercase;
}

.footer__contact .search-form {
    gap: var(--space-2);
}

.footer__contact .search-form__text {
    width: 100%;
}

.footer__nav a,
.footer__contact a {
    text-decoration: none;
}

.footer__nav.variant-inline ul {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
}

.footer-courtesy {
    display: flex;
    flex-wrap: wrap;
    column-gap: var(--space-2);
}


.footer__contact {
    background-color: #272725;
    clip-path: polygon(0 0, 100% 0, 100% 93%, 0 100%);
}

.footer__contact h3 {
    color: white;
}

.footer__logo {
    display: inline-block;
    max-width: 18.125rem;
}

.footer__logo svg {
    fill: white;
}

.footer__logo .logo-light { fill: var(--primary-mid); }
.footer__logo .logo-dark { fill: var(--primary-light); }

.footer__social {
    display: flex;
    gap: var(--space-1);
    margin-top: var(--space-1);
}

.footer__social svg {
    fill: var(--accent);
    width: var(--space-6);
}


/* -------------------------------------------------------------------------- */
/* MARK: Copyright
*/

.copyright {
    padding-block: var(--space-3);
}

.copyright a {
    text-decoration: none;
}

#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-results {
    gap: var(--space-1);
}

.search-modal {
    cursor: zoom-out;
    display: none;
    position: fixed;
    z-index: 1000;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    overflow: auto;
    background-color: rgba(0,0,0,0.8);
}

.search-modal-content {
    cursor: default;
    background-color: var(--neutral-bg);
    /* 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 {
    display: flex;
    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(--neutral-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);
    margin-top: var(--space-8);
}
.dev-notice li p {
    margin: var(--space-1) 0 0 0;
}

.portal {
    --auto-grid-min-size: 14rem;
    --auto-grid-max-columns: 4;
    --auto-grid-gap: var(--space-4);
    display: grid;


}

.portal-large {
    --auto-grid-max-columns: 2;
    --auto-grid-gap: var(--space-4);
}

.portal-block-heading {
    margin-bottom: var(--space-6);
}

.portal-block-lede > * {
    max-width: var(--max-narrow);
}

.portal-item {
    background-color: var(--neutral-light);
    /* border-radius: var(--radius-xs); */
    clip-path: polygon(0 0, 100% 0%, 99% 100%, 1% 98.5%);
    display: grid;
    line-height: 1.1;
    grid-template-areas: 'stackem';
    outline: .125rem solid transparent;
    overflow: hidden;
    padding: 0;
    position: relative;
    text-decoration: none;
    transition: transform 0.3s ease-in-out;
    transform: rotate(-1.5deg);
    width: 100%;
    z-index: 1;
    min-height: 18rem;
    max-height: 40rem;
}

.portal-item > * {
    grid-area: stackem;
}

.portal-item .btn:hover {
    background-color: var(--neutral);
}

.portal-item:nth-child(2n + 1) {
    transform: rotate(3deg);
}

.portal-item:hover {
    background-color: var(--primary);
    transform: rotate(0deg) !important;
    z-index: 2;
}

.portal-item:hover * {
    color: white
}

.portal-item:focus {
    outline: .25rem solid var(--neutral-dark);
}
.portal-lede {
    margin-top: var(--space-2);
    line-height: 1.5;
    text-wrap: balance;
}
.portal-copy {
    padding: var(--space-6);
    height: 100%;
    display: flex;
    flex-direction: column;
    position: relative;
    z-index: 2;
}
.portal-label {
    background-color: white;
    color: var(--neutral);
    margin-top: auto;
    margin-left: auto;
    text-align: right;
}
.portal-item:hover .portal-label {
    background-color: var(--neutral-dark);
}
.portal-img-wrap {
    position: absolute;
    left: 0; right: 0; top: 0; bottom: 0;
    width: 100%;
    height: 100%;
}

.portal-img {
    filter: contrast(10) saturate(0) brightness(2) opacity(0.5);
    mix-blend-mode: soft-light;
    txransition: all 0.3s ease-in-out;
    object-fit: cover;
    width: 100%;
    height: 100%;
}

.portal-item:hover .portal-img {
    mix-blend-mode: multiply;
}
.portal-item:hover .portal-img-wrap {
    background-color: transparent;
}

.portal-meta {
    display: flex;
    justify-content: space-between;
}

/* -------------------------------------------------------------------------- */
/* MARK: Forms
*/

.uniform__potty {
    position: absolute;
    left: -9999px;
}

.uniform__captcha {
    max-width: 60%;
}

.uniform-errors {
    padding: var(--space-3);
    margin-bottom: var(--space-6);
    position: relative;
}


.rtbform label {
    display: block;
    line-height: 1.2;
    margin-bottom: var(--space-1);
}

.rtbform {
    display: grid;
    gap: var(--space-4);
    position: relative;
}

.rtbform > h3 {
    margin: var(--space-6) 0 0 0;
}
.rtbform > h3:first-of-type {
    margin: 0;
}

.rtbform input:not([type="submit"]),
.rtbform textarea {
    -webkit-appearance: none;
    appearance: none;
    background: var(--neutral-light);
    border-radius: 0;
    border: 1px solid transparent;
    display: block;
    font-family: 'font-primary';
    font-weight: 400;
    font-size: var(--text-base);
    height: auto;
    line-height: 1;
    margin: 0;
    padding: var(--space-2);
    width: 100%;
    box-shadow: none;
}
.rtbform textarea {
    min-height: var(--space-10);
}

.rtbform input::placeholder,
.rtbform textarea::placeholder {
    color: var(--neutral-mid);
}

.rtbform input:not([type="submit"]):focus,
.rtbform textarea:focus {
    background-color: var(--accent-light);
    outline: 2px solid var(--accent);
}

.rtbform input[type="submit"] {
    display: block;
    max-width: 50%;
}

.footer__form {
    gap: var(--space-2);
    padding-bottom: var(--space-2);
}

.footer__form input[type="email"] {
    background: var(--neutral);
    padding: var(--space-1)
}

.footer__form-title {
    color: var(--neutral);
    font-size: var(--text-lg);
    margin: 0;
    transform: rotate(-1deg);
}

.footer__form-body {
    display: flex;
    gap: var(--space-2);
    align-items: center;
}

.footer__form label {
    font-size: var(--text-md);
    text-transform: uppercase;
    font-family: 'font-secondary';

}



/* -------------------------------------------------------------------------- */
/* 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; }