/* CSS May 7, 2026 */
@import url('https://fonts.googleapis.com/css?family=Libre+Franklin:200,400,500,800|Montserrat:300,400,600');
:root {

  /* --<system>-<role>-<variant>-<state> */
  /* Spacing Values - based on a 24px rhythm unit for 16px font size and 24px line height*/
  --sp-2x: 4.5rem;  /* 72px */
  --sp-xl: 3rem; /* 48px */
  --sp-lg: 2.25rem; /* 36px */
  --sp-md: 1.5rem; /* 24px */
  --sp-sm: 1.125rem; /* 18px */
  --sp-xs: 0.625rem; /* 10px */
  --sp-2xs: 0.4rem; /* 6px */
  --sp-3xs: 0.25rem; /* 4px */
  --sp-4xs: 0.1rem; /* 2px */

	/* Main color palette */
  --color-brand-primary: #082f44;
  --color-brand-secondary: rgb(76,157,234);
  --color-brand-accent: #d4d6d7;
  --color-neutral-900: #1c1a17;
	--color-neutral-800: #252729;
	--color-neutral-700: #3e4144;
	--color-neutral-600: #716e69;
	--color-neutral-500: #868e95;
	--color-neutral-400: #c6cacc;
	--color-neutral-300: #d4d6d7;
	--color-neutral-200: #ececec;
	--color-neutral-100: #f9f9f9;
	--color-neutral-000: #ffffff;

  --box-shadow: 0 4px 10px 0px rgba(29,34,40,.15);

  /* Typography */
  --color-text-primary: rgb(28, 26, 23);
  --color-text-primary-rev: var(--color-neutral-000);
  --color-text-secondary: #004d71;
  --color-text-primary-inverted: var(--color-neutral-000);

  --type-font-primary: 'Libre Franklin', Arial, sans-serif;
	--type-font-secondary: 'Montserrat', Helvetica, sans-serif;

  --type-weight-extrabold: 800; /* Open Sans only */
  --type-weight-bold: 700;
  --type-weight-semibold: 600;
  --type-weight-medium: 500;
  --type-weight-regular: 400;
  --type-weight-light: 300; /* Open Sans only */

  --type-size-900: 2rem; /* 32px */
  --type-size-800: 1.75rem; /*28px*/
  --type-size-700: 1.5rem; /* 24px */
  --type-size-600: 1.25rem; /* 20px */
  --type-size-500: 1.125rem; /* 18px */
  --type-size-400: 1rem; /* 16px */
  --type-size-300: 0.875rem; /* 14px */ 
  --type-size-200: 0.75rem; /* 12px */
  --type-size-100: 0.625rem; /* 10px */

  --type-height-900: 1.15;
  --type-height-800: 1.2;
  --type-height-700: 1.25;
  --type-height-600: 1.3;
  --type-height-500: 1.35;
  --type-height-400: 1.45;
  --type-height-300: 1.5;
  --type-height-200: 1.55;
  --type-height-100: 1.6;

  /* Shared sizing for dense data UI: form controls and table rows */
  --data-font-size: var(--type-size-300);
  --data-font-weight: var(--type-weight-regular);
  --data-line-height: 1.2;

  /* Shared sizing for buttons, inputs and select controls */
  --control-font-size: var(--data-font-size);
  --control-font-weight: var(--data-font-weight);
  --control-height: 2rem;
  --control-line-height: var(--data-line-height);
  --control-padding-x: var(--sp-xs);
  --control-padding-y: 0;
  --control-radius: var(--sp-2xs);
  --control-border-width: 2px;

	--header-bg: var(--color-neutral-000);
  --header-text: var(--color-neutral-000);
  --header-height: 60px;

  --nav-main-text-color: var(--color-neutral-000);
  --nav-main-fill-color: var(--color-brand-primary);
  --nav-main-button-fill-color: var(--nav-main-fill-color);
  --nav-main-button-hover-color: rgb(255 255 255 / 0.8);
  --nav-main-button-hover-text-color: var(--color-brand-primary);
  --nav-main-button-active-color: rgb(255 255 255 / 1);
  --nav-main-button-active-text-color: var(--color-brand-primary);
  --nav-main-text-color-vertical: var(--color-neutral-100);
  --nav-main-button-hover-color-vertical: #073954;
  --nav-main-subnav-fill-color: #040404;
  --nav-main-subnav-hover-color: #212121;
  --nav-main-subnav-active-color: #212121;

  --footer-bg: #1c1a17;
  --footer-text: var(--color-neutral-000);

	/* Primary actions, progress callouts and accents for buttons and links */
	--status-color-info: #3699f7;
	--status-color-info-hover: var(--status-color-info-shade);
	--status-color-info-shade: #163b7a;
	--status-color-info-tint: #e4f0fe;
	--status-color-progress: #2FC61E;
	--status-color-progress-shade: #25ae15;
	--status-color-progress-tint: #e4f8e1;
	--status-color-warning: #cf9f0d;
	--status-color-warning-shade: #50504f;
	--status-color-warning-tint: #f4f4f4;
	--status-color-error: #ED1C24;  
	--status-color-error-shade: #ce2430;
	--status-color-error-tint: #ffebeb;

	--color-progress: #2FC61E;
	--color-progress-shade: #25ae15;
	--color-progress-tint: #e4f8e1;
  --color-action-primary-hover: #0f5ab8;
  --color-action-primary-rev: #ffffff;
  --color-action-primary-rev-hover: #88b5ee;

  --color-action-fill: #2FC61E;
  --color-action-hover: #25ae15;
  --color-action-text: var(--color-neutral-000);

  --graph-measure-color-01-rgb: 23 58 221;   /* Deep Royal Blue */
  --graph-measure-color-02-rgb: 220 38 38;   /* Fire Engine */
  --graph-measure-color-03-rgb: 130 246 68;  /* Limeade */
  --graph-measure-color-04-rgb: 255 140 0;   /* Tangerine */
  --graph-measure-color-05-rgb: 109 215 237; /* Bright Sky */
  --graph-measure-color-06-rgb: 245 206 68;  /* Schoolbus */
  --graph-measure-color-07-rgb: 26 141 55;   /* Pine Green */
  --graph-measure-color-08-rgb: 234 63 177;  /* Bubblegum */
  --graph-measure-color-09-rgb: 137 60 187;  /* Purple Haze */
  --graph-measure-color-10-rgb: 108 130 46;  /* Olive */
  --graph-measure-color-11-rgb: 48 58 112;   /* Twilight */
  --graph-measure-color-12-rgb: 209 167 126; /* Sand */
  --graph-measure-color-13-rgb: 190 189 23;  /* Periwinkle */
  --graph-measure-color-14-rgb: 152 31 39;   /* Crimson */
  --graph-measure-color-15-rgb: 84 145 243;  /* Noon */
  --graph-measure-color-16-rgb: 142 112 46;  /* Khaki */

  --graph-measure-color-01: rgb(var(--graph-measure-color-01-rgb));
  --graph-measure-color-02: rgb(var(--graph-measure-color-02-rgb));
  --graph-measure-color-03: rgb(var(--graph-measure-color-03-rgb));
  --graph-measure-color-04: rgb(var(--graph-measure-color-04-rgb));
  --graph-measure-color-05: rgb(var(--graph-measure-color-05-rgb));
  --graph-measure-color-06: rgb(var(--graph-measure-color-06-rgb));
  --graph-measure-color-07: rgb(var(--graph-measure-color-07-rgb));
  --graph-measure-color-08: rgb(var(--graph-measure-color-08-rgb));
  --graph-measure-color-09: rgb(var(--graph-measure-color-09-rgb));
  --graph-measure-color-10: rgb(var(--graph-measure-color-10-rgb));
  --graph-measure-color-11: rgb(var(--graph-measure-color-11-rgb));
  --graph-measure-color-12: rgb(var(--graph-measure-color-12-rgb));
  --graph-measure-color-13: rgb(var(--graph-measure-color-13-rgb));
  --graph-measure-color-14: rgb(var(--graph-measure-color-14-rgb));
  --graph-measure-color-15: rgb(var(--graph-measure-color-15-rgb));
  --graph-measure-color-16: rgb(var(--graph-measure-color-16-rgb));

  --table-border-top: var(--status-color-info);
  --table-row-header: var(--color-brand-primary);
  --table-border-bottom: var(--color-neutral-300);
  --table-row-banded: var(--color-neutral-100);
  --admin-sidebar-w: 200px;

}

@font-face {
  font-family: "Open Sans"; src: url("/fonts/open-sans/open-sans_variable.ttf") format("truetype");
  font-weight: 300 800; font-stretch: 75% 100%; font-style: normal; font-display: swap;
}

@font-face {
  font-family: "Open Sans";
  src: url("/fonts/open-sans/open-sans-italic_variable.ttf") format("truetype");
  font-weight: 300 800; font-stretch: 75% 100%; font-style: italic; font-display: swap;
}

@font-face {
  font-family: "Arimo"; src: url("/fonts/arimo/arimo_variable.ttf") format("truetype");
  font-weight: 400 700; font-style: normal; font-display: swap;
}

@font-face {
  font-family: "Arimo"; src: url("/fonts/arimo/arimo-italic_variable") format("truetype");
  font-weight: 400 700; font-style: italic; font-display: swap;
}

/* =============================================== */
/* LIGHTWEIGHT CUSTOM RESET */
/* =============================================== */
*, *::before, *::after { box-sizing: border-box; } /* Box-sizing reset */
body, h1, h2, h3, h4, p, figure, blockquote, dl, dd { margin: 0; } /* Remove default margin */
ul[role="list"], ol[role="list"], nav ul, footer ul { list-style: none; } /* Remove list styles */
body { min-height: 100vh; text-rendering: optimizeSpeed; line-height: 1.5; } /* Set core body defaults */
ul, ol, nav ul { padding: 0; } /* Remove default padding from lists */
.font-primary { font-family: var(--type-font-primary); }
.font-secondary { font-family: var(--type-font-secondary); }
#pageContainer ul { padding-left: var(--sp-md);}
section { margin: 0; }
img { max-width: 100%; display: block; } /* Images: easier to work with */
input, button, textarea, select { font: inherit; } /* Inherit fonts for form controls */
label { font-size: var( --type-size-300); font-weight: var(--type-weight-bold); line-height: var(--type-height-200); color: var(--color-neutral-600); }

/* Remove focus and active outline/color changes site-wide */
:focus { outline: none; }
:focus-visible { outline: none; }
*:active { outline: none; }


/* =============================================================================== */
/* TYPE STYLING                                                                    */
/* =============================================================================== */

body { color: var(--color-text-primary); font-family: var(--type-font-primary); font-size: 16px; line-height: 1.5rem; }
h2,h3,h4,h5,h6 { margin: 0; padding: 0; }
h1, h2 { font-family: var(--type-font-primary); }
h3, h4, h5, h6, a, button { font-family: var(--type-font-secondary); }
h1 { 
  font-size: var(--type-size-900); font-weight: var(--type-weight-medium); margin: 1.25rem 0 0.4rem; color: var(--color-neutral-800);
}
h2 { 
  font-size: var(--type-size-700); font-weight: var(--type-weight-medium);  margin: 1.1rem 0 0rem; color: var(--color-action-primary-hover); line-height: var(--type-height-800);
}
h3 { 
  color: var(--color-text-primary); font-size: var(--type-size-600); font-weight: var(--type-weight-semibold);  margin-top: var(--sp-3xs); line-height: var(--type-height-700);
}
h4 { 
  font-size: var(--type-size-500); font-weight: var(--type-weight-semibold); margin-top: var(--sp-xs); color: var(--color-action-hover); line-height: var(--type-height-300);
}
h5 { font-size: var(--type-size-500);  line-height: 1.3rem; }
p { line-height: var(--type-height-500); margin-top: var(--sp-2xs); }
p.small-note { font-size: var(--type-size-300);}
sup { font-size: 0.8em; padding-left: 0.4em; } /* relative to the parent font size */
code { color: var(--color-brand-secondary); font-size: var(--type-size-400); font-weight: var(--type-weight-medium); }
.text-align--center { text-align: center; }


/* =============================================================================== */
/* BUTTON & LINK STYLING                                                           */
/* =============================================================================== */
button,
a.button,
input[type=button],
input[type=submit] { 
  display: inline-flex; align-items: center; justify-content: center;
  width: fit-content; max-width: 100%; height: var(--control-height); min-height: var(--control-height); margin: var(--sp-xs) 0; padding: var(--control-padding-y) var(--type-size-500); line-height: var(--control-line-height);
  appearance: none; -moz-appearance: none; -webkit-appearance: none;
  border-width: var(--control-border-width); border-style: solid; border-color: var(--color-action-fill); border-radius: var(--control-radius);
  background-color: var(--color-action-fill); background-size: 20px; background-repeat: no-repeat;
  color: var(--color-action-text); font-size: var(--control-font-size); font-weight: var(--type-weight-medium); text-decoration: none; cursor: pointer;
  transition: background .2s ease, color .2s ease, border-color .2s ease;
}

a,
a:visited {
  color: var(--color-action-fill); font-size: inherit; font-weight: var(--type-weight-semibold); text-decoration: none;
}

a:hover {
  color: var(--color-action-hover); text-decoration-line: underline; text-decoration-thickness: 0.1em; text-underline-offset: 0.16em;
}

a.button,
a.button:visited {
  margin-block: 0; line-height: 1.2; color: var(--color-action-text); text-decoration: none;
}

/* correct button spacing inside CSS grid */
#pageContainer > a.button {
  justify-self: start; align-self: start;
}

button:hover,
a.button:hover,
input[type=button]:hover,
input[type=submit]:hover { 
  background-color: var(--color-action-hover);
  border-color: var(--color-action-hover);
  color: var(--color-action-text);
  text-decoration: none;
}

button:disabled,
a.button:disabled,
button[disabled],
input[disabled=disabled] { 
  background-color: rgb(150,150,150);
  cursor: pointer; 
}

button.btn-secondary,
a.button.btn-secondary,
a.button.btn-secondary:visited,
input[type=button].btn-secondary { 
  background-color: var(--color-action-text);
  color: var(--color-action-fill);
}

button.btn-secondary:hover,
a.button.btn-secondary:hover,
input[type=button].btn-secondary:hover { 
  border-color: var(--color-action-hover);
  color: var(--color-action-hover);
  text-decoration: none;
}

.section-grid > button,
.section-grid > a.button,
.section-grid > input[type="submit"],
.section-grid > input[type="button"] {
  align-self: end;
  justify-self: start;
  margin: var(--sp-xs) 0 0;
}

nav#pageNav a.button { border-radius: 50%; width: 35px;
  height: 35px; background-color: var(--color-action-primary-rev);
  color: var(--color-action-fill); border-color: var(--color-action-fill);
}

button.expanding,
button.expanding::after {
  color: var(--color-action-fill);
}

button.expanding {
  background-color: var(--color-action-text);
}

button.expanding::after {
  content: "\0020\25BE";
  margin-left: var(--sp-3xs);
}

button.expanding:hover,
button.expanding:hover::after {
  background-color: var(--color-action-text);
  border-color: var(--color-action-hover);
  color: var(--color-action-hover);
}

.button-group { display: flex; flex-direction: row; flex-wrap: wrap; align-items: center; gap: var(--sp-xs); margin-top: 0; }
.button-group button,
.button-group .button { width: auto; margin-block: 0; }
.form-actions .button-group + .button-group { margin-top: var(--sp-xs); }
.button-group--center { justify-content: center; }
.button-group--right { justify-content: flex-end; }

.button--icon-download::before { content: ""; width: 16px; height: 16px; display: inline-block;
  background: url("../img/icons/download_rev.svg") no-repeat center / contain; margin-right: 0.5rem; }


/* =============================================================================== */
/* LAYOUT                                                                          */
/* =============================================================================== */
html {  height: 100%; font-family: var(--type-font-primary); font-size: 16px; font-weight: 300; color: var(--color-neutral-500) }

body.site {
  display: grid; gap: 0; background-color: var(--color-neutral-000);
  color: var(--color-text-primary); font-family: var(--type-font-primary); font-size: var(--type-size-500); line-height: var(--sp-lg);
  min-height: 100vh;
  grid-template-columns: 1.5rem minmax(0, 1fr) 1.5rem;
  grid-template-rows: auto auto 1fr auto;
  grid-template-areas:
    "header header header"
    "nav    nav    nav"
    "main   main   main"
    "footer footer footer";
}

body.site.admin {
  grid-template-columns: 1.5rem minmax(0, 1fr) 1.5rem;
  grid-template-rows: auto auto 1fr auto;
  grid-template-areas:
    "header header header"
    "nav    nav    nav"
    "main   main   main"
    "footer footer footer";
}
/* prevent auto height rows */
body.site > #pageContainer {
  align-content: start;
  grid-auto-rows: max-content;
  min-height: 0;
}

/* Top Level Sections */
body.site > header { grid-area: header; }
body.site > #mainNav { grid-area: nav; }
body.site > #pageContainer { grid-area: main; padding-bottom: var(--sp-2x); }
body.site > footer { grid-area: footer; }
/* each top-level section spans full page width */
body.site > header, body.site > #mainNav, body.site > #pageContainer, body.site > footer { grid-column: 1/-1; }

/* let each section inherit the same column structure */
body.site > header, body.site > #mainNav, body.site > #pageContainer, body.site > footer { display: grid; grid-template-columns: subgrid; }

/* default pageContainer sits inside the gutters */
#headerContainer, #mainNav .nav-menu__list, #pageContainer > *, #footer-info, .footer-follow, footer > .footer-list { grid-column: 2 / 3; }

/* pageContainer Section grid setup */
#pageContainer > * + * { margin-top: var(--sp-sm); }
form > :not(input[type="hidden"]) + :not(input[type="hidden"]) { margin-top: var(--sp-sm); }
.section-grid { --grid-cols: 1; display: grid; grid-template-columns: repeat(var(--grid-cols), 1fr); gap: var(--sp-sm) var(--sp-xl); }
.section-grid > * { grid-column: var(--item-span, span 1);}
.form-field,
.form-field--stack {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--sp-2xs);
  width: 100%;
}
/* for table headers and other areas where labels need to stack over a checkmark */
.form-check-stack {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-3xs);
}

.form-field--cluster {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-2xs);
  width: 100%;
}

.form-font--compact { font-size: 0.7em; }

/* optional utility classes */
.grid-full { grid-column: 1 / -1; } /* force content to bleed to left and right edges */
.grid-center { grid-column: 2 / 6; }

.section-flex { display: flex; width: 100%; flex-direction: column; align-items: center; gap: var(--sp-3xs) var(--sp-xl); margin: 0.5rem 0; }
/* FLEX Items */
.section-flex.stack { display: flex; flex-direction: column; align-items: flex-start; gap: var(--sp-4xs, 4px); margin: 0.5rem 0; }
.cluster { display: flex; flex-direction: row; align-items: center; gap: var(--sp-xs, 4px); margin: 0.5rem 0; }
.cluster--wide { gap: var(--sp-md); }
.cluster--tight { gap: var(--sp-3xs); flex: 1 0 25%; }

/* =============================================================================== */
/* HEADER & NAVIGATION                                                             */
/* =============================================================================== */
header { z-index: auto; position: sticky; top: 0; display: grid; padding: 0 1rem; justify-content: space-between; align-items: center; width: 100%; height: var(--header-height); background: var(--color-brand-primary);
  background: var(--header-bg); box-shadow: 0px 5px 5px rgba(0,0,0,0.2);  }
#headerContainer { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-sm); min-width: 0; padding-left: calc(44px + var(--sp-xs)); }
header a#site-logo, nav#mainNav a { margin: 0;} /* clear the base margins for links across the site */
header a#site-logo { margin: 0; } /* override the site margins for links */
#site-logo { display: inline-flex; align-items: center; min-width: 0; }
#site-logo > img { max-width: 100%; margin: 0; padding-left: 0; height: 30px; display: flex; }
header a, nav#mainNav a, nav#mainNav button { color: var(--nav-main-text-color); text-decoration: none; border: none; }
header a:hover { color: var(--color-action-primary-rev-hover); }
#myaccount { display: flex; align-items: center; justify-content: flex-end; margin-left: auto; min-width: 44px; }
#myaccount a { display: inline-flex; align-items: center; gap: var(--sp-2xs); color: var(--header-text); font-size: 0; font-weight: var(--type-weight-medium); text-decoration: none; white-space: nowrap; }
#myaccount a::before {
  content: "";
  display: inline-block;
  width: 1.65rem;
  height: 1.65rem;
  flex: 0 0 auto;
  background-color: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 21a8 8 0 0 0-16 0'/%3E%3Ccircle cx='12' cy='7' r='4'/%3E%3C/svg%3E") center / contain no-repeat;
	  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 21a8 8 0 0 0-16 0'/%3E%3Ccircle cx='12' cy='7' r='4'/%3E%3C/svg%3E") center / contain no-repeat;
}

/* Header compatibility for templates without #headerContainer / #site-logo wrappers */
body.site > header > a {
  grid-column: 2 / 3;
  display: inline-flex;
  align-items: center;
  justify-self: start;
  align-self: center;
  min-width: 0;
  margin: 0;
  padding-left: calc(44px + var(--sp-xs));
}
body.site > header > a > img.site-logo {
  display: block;
  height: 30px;
  max-width: 100%;
  margin: 0;
}
body.site > header > #myaccount {
  grid-column: 2 / 3;
  justify-self: end;
  align-self: center;
}

/* Account menu compatibility for templates using #acct-title / #acct-menu */
#myaccount {
  position: relative;
  color: var(--header-text);
}
#myaccount .acct-title {
  position: relative;
  z-index: 150;
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--sp-2xs);
  color: var(--header-text);
  cursor: pointer;
}
#myaccount #myAccntIcon {
  display: block;
  width: 1.65rem;
  height: 1.65rem;
}
#myaccount .acct-title .username {
  display: none;
  color: var(--color-text-primary);
  font-weight: var(--type-weight-medium);
  white-space: nowrap;
}
#myaccount a,
#myaccount #rememberMeLabel {
  color: var(--header-text);
}
#acct-signin {
  position: absolute;
  top: calc(100% + var(--sp-2xs));
  right: 0;
  z-index: 160;
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2xs) var(--sp-xs);
  width: min(calc(100vw - 2rem), 22rem);
  padding: var(--sp-xs);
  background: var(--color-neutral-800);
  color: var(--color-neutral-000);
  box-shadow: 0 12px 24px rgba(0,0,0,0.18);
}
#acct-signin > * {
  flex: 1 1 40%;
  margin: 0;
}
#acct-signin > div:first-of-type {
  flex-basis: 100%;
}
#acct-signin input[type="text"],
#acct-signin input[type="password"] {
  width: 100%;
  max-width: none;
}
#myAccntAuthLogin,
#myAccntAuthPsswd {
  text-transform: lowercase;
}
#acct-signin .forgot {
  display: inline-block;
}
#acct-signin a {
  font-size: var(--type-size-400);
}
#acct-signin a::before {
  content: none;
}
#acct-menu {
  display: none;
  position: fixed;
  top: var(--header-height);
  right: 1rem;
  bottom: 0;
  z-index: 160;
  width: min(100vw, 22rem);
  height: auto;
  max-height: calc(100vh - var(--header-height));
  background: var(--color-neutral-800);
  overflow-y: auto;
  box-shadow: 0 12px 24px rgba(0,0,0,0.18);
}
#acct-menu ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
#acct-menu li {
  margin: 0;
  padding: 0;
  border-top: 1px solid rgba(255,255,255,0.12);
}
#acct-menu li:first-child {
  border-top: none;
}
#acct-menu a {
  display: block;
  padding: var(--sp-xs) var(--sp-sm);
  color: var(--color-neutral-000);
  font-size: var(--type-size-400);
  text-decoration: none;
}
#acct-menu a::before {
  content: none;
}
#acct-menu a:hover {
  background: var(--color-neutral-700);
  text-decoration: none;
}


/* =============================================================================== */
/* NAVIGATION                                                                      */
/* =============================================================================== */
#mainNav { 
  --nav-toggle-height: 46px; position: relative; z-index: 105; width: 100%; min-height: 0; height: 0; background: transparent; font-family: var(--type-font-secondary); font-weight: var(--type-weight-medium); font-size: var(--type-size-400); color: var(--nav-main-text-color);
}

#mainNav .nav-menu__list {
  position: fixed; top: var(--header-height); bottom: 0; left: 0; margin: 0; padding: 0; list-style: none;
  grid-column: auto; width: min(82vw, 320px); max-width: 320px; background-color: var(--nav-main-fill-color);
  transform: translateX(-100%); transition: transform 0.2s ease; overflow-y: auto; box-shadow: 0 12px 24px rgba(0,0,0,0.18);
}
#mainNav .nav-menu__link { 
  appearance: none; display: block; width: 100%; min-height: 2.35rem; margin: 0; padding: var(--sp-3xs) var(--sp-xs); border: none; border-bottom: 1px solid rgba(255,255,255,0.1); border-radius: 0; box-sizing: border-box; color: inherit; background-color: transparent; font: inherit; font-weight: var(--type-weight-medium); text-align: left; text-decoration: none; white-space: nowrap; cursor: pointer; transition: background-color 0.3s ease; font-size: var(--type-size-300);
}
#mainNav .nav-menu__item--top { display: none; text-align: center; background-color: transparent; }
#mainNav .nav-menu__link--sub { background-color: var(--nav-main-subnav-fill-color); }
#mainNav .nav-menu__item--top:hover > .nav-menu__link--top {
  background-color: var(--nav-main-button-hover-color);
  color: var(--nav-main-button-hover-text-color);
}
#mainNav.nav-menu--vertical .nav-menu__item--top:hover > .nav-menu__link--top {
  background-color: var(--nav-main-button-hover-color-vertical);
  color: var(--nav-main-text-color-vertical);
}
#mainNav .nav-menu__sublist { border-left: 3px solid rgba(0,0,0,0.1); display: none; }
#mainNav .nav-menu__item--sub:hover > .nav-menu__link--sub { background-color: var(--nav-main-subnav-hover-color); }
#mainNav .nav-menu__item--sub.current > .nav-menu__link--sub,
#mainNav .nav-menu__item--sub .nav-menu__link--current { background-color: var(--nav-main-subnav-active-color); color: var(--nav-main-text-color-vertical); }
#mainNav .nav-menu__link--current,
#mainNav .nav-menu__item--top.current > .nav-menu__link--top {
  background-color: var(--nav-main-button-active-color);
  color: var(--nav-main-button-active-text-color);
}

/* hide checkbox */
#mainNav .nav-check { 
  position: absolute; width: 1px; height: 1px; margin: -1px; padding: 0; border: 0; overflow: hidden; clip: rect(0 0 0 0); clip-path: inset(50%); white-space: nowrap; }
/* hamburger */
#mainNav .nav-burger { 
  display: flex; align-items: center; justify-content: flex-start; position: fixed; top: 0; left: 1.5rem; z-index: 120; cursor: pointer; width: 44px; min-width: 44px; min-height: var(--header-height); padding: 0; box-sizing: border-box; }
#mainNav .nav-burger::before { 
  content: ""; display: block; height: 2px; width: 22px; background: var(--header-text); box-shadow: 0 6px 0 var(--header-text), 0 12px 0 var(--header-text); }
/* open mobile menu */
#mainNav .nav-check:checked ~ .nav-menu__list { transform: translateX(0); }
#mainNav .nav-check:checked ~ .nav-menu__list .nav-menu__item--top { display: block; text-align: left; }

@media screen and (min-width: 1000px) {
  #mainNav { position: sticky; top: 0; height: auto; min-height: var(--nav-toggle-height); background: var(--nav-main-fill-color); box-shadow: var(--box-shadow); }
  #mainNav .nav-menu__list { grid-column: 2 / 8; position: static; width: 100%; max-width: none; transform: none; transition: none; overflow: visible; box-shadow: none; }
  #mainNav .nav-check, #mainNav .nav-burger { display: none; }
  #mainNav .nav-menu__item--top { display: block; }

  #mainNav.nav-menu--horizontal .nav-menu__list { display: flex; justify-content: start; align-items: stretch; gap: 1.5rem; background-color: transparent; }
  #mainNav.nav-menu--horizontal .nav-menu__item--top { display: flex; align-items: center; text-align: center; }
  #mainNav.nav-menu--horizontal .nav-menu__link--top { display: flex; align-items: center; min-height: 48px; width: auto; text-align: center; }

  #mainNav.nav-menu--vertical { overflow: auto; grid-column: 1 / 2; }
  #mainNav.nav-menu--vertical .nav-menu__list { display: block; color: var(--nav-main-text-color-vertical); }
  #mainNav.nav-menu--vertical .nav-menu__list .nav-menu__item:hover { background-color: var(--nav-main-button-hover-color-vertical); }
  #mainNav.nav-menu--vertical .nav-menu__item--top.is-open > .nav-menu__link--top {
    background-color: var(--nav-main-button-hover-color-vertical);
    color: var(--nav-main-text-color-vertical);
  }
  #mainNav.nav-menu--vertical .nav-menu__item--top.is-open > .nav-menu__sublist { display: block; }
}

/* =============================================================================== */
/* PAGE NAVIGATION                                                                 */
/* =============================================================================== */
nav#pageNav { 
  display: flex; flex-direction: column; align-items: center; justify-content: center; width: 100%; height: auto; padding: var(--sp-sm); background: var(--status-color-info); font-weight: var(--type-weight-semibold); gap: var(--sp-2xs);  
}
nav#pageNav, nav#pageNav a { color: var(--color-neutral-000); }
#pageNav > * { text-align: center; display: flex; gap: var(--sp-md); align-items: center; padding: 0; margin: 0;  }


/* =============================================================================== */
/* PAGE MESSAGING                                                                  */
/* =============================================================================== */

.pageMessage { 
  margin: var(--sp-2xs) 0; padding: 0; list-style: none; font-size: var(--type-size-400); line-height: var(--type-height-900); }
#pageContainer ul.pageMessage,
#pageContainer ul.connectBorder,
#pageContainer form ul,
#pageContainer form ol { padding-left: 0;
}

.pageMessage li { 
  display: grid; grid-template-columns: 1.25rem 1fr; gap: 0.5rem; align-items: start; padding: 0.75rem 1rem; border-left: 3px solid var(--message-border, currentColor);
  background-color: var(--message-bg, #fff); color: var(--message-text, inherit);
}
.pageMessage li::before { 
  content: ""; width: 1.25rem; height: 1.25rem; display: block; background-repeat: no-repeat; background-position: center; background-size: contain; }

.pageMessage__content {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--sp-xs);
}

.pageMessage li.pageMessage--info { 
  --message-bg: var(--status-color-info-tint); --message-border: var(--status-color-info); --message-text: var(--status-color-info-shade); }
.pageMessage li.pageMessage--info::before { background-image: url("../img/icons/icon_notify_info.svg"); }

.pageMessage li.pageMessage--progress { 
  --message-bg: var(--status-color-progress-tint); --message-border: var(--status-color-progress); --message-text: var(--status-color-progress-shade); }
.pageMessage li.pageMessage--progress::before { background-image: url("../img/icons/icon_notify_progress.svg"); }

.pageMessage li.pageMessage--warning { 
  --message-bg: var(--status-color-warning-tint); --message-border: var(--status-color-warning); --message-text: var(--status-color-warning-shade); }
.pageMessage li.pageMessage--warning::before { background-image: url("../img/icons/icon_notify_warning.svg"); }

.pageMessage li.pageMessage--error { 
  --message-bg: var(--status-color-error-tint); --message-border: var(--status-color-error); --message-text: var(--status-color-error-shade); }
.pageMessage li.pageMessage--error::before { background-image: url("../img/icons/icon_notify_error.svg"); }

.connectBorder {
  margin: var(--sp-2xs) 0;
  border-left: 3px solid var(--color-neutral-300);
  list-style: none;
}

.connectBorder:not(.pageMessage) > :not(table):not(.tableBody):not(.section-grid) {
  margin-left: var(--sp-xs);
  margin-right: var(--sp-xs);
}

.connectBorder > table,
.connectBorder > .tableBody,
.connectBorder > .section-grid {
  margin-left: 0;
  margin-right: 0;
  margin-top: 0;
  margin-bottom: 0;
}

.connectBorder:not(.pageMessage) > * + * {
  margin-top: var(--sp-xs);
}

.connectBorder:not(.pageMessage) > li {
  padding: var(--sp-xs);
  margin-left: 0;
  margin-right: 0;
}


/* =============================================================================== */
/* FORMS                                                                           */
/* =============================================================================== */
	input[type="text"], input[type="tel"],
  input[type="url"], input[type="email"],
  input[type="password"], input[type="number"],
  input[type="date"], input[type="datetime-local"],
  select, textarea {
		width: 100%;
    max-width: 240px;
    min-height: var(--control-height);
    padding: var(--control-padding-y) var(--control-padding-x);
    border: var(--control-border-width) solid var(--color-neutral-300);
    border-radius: var(--control-radius);
    background-color: var(--color-neutral-000);
    box-shadow: inset 2px 0.2rem 0.3rem #f2f2f2;
    color: var(--color-text-primary);
    font: inherit; font-size: var(--control-font-size); font-weight: var(--control-font-weight); line-height: var(--control-line-height);
  }

  input[type="text"], input[type="tel"],
  input[type="url"], input[type="email"],
  input[type="password"], input[type="number"],
  input[type="date"], input[type="datetime-local"],
  select {
    height: var(--control-height);
  }

  textarea {
    padding-block: var(--sp-xs);
  }

  select {
    appearance: none;
    -moz-appearance: none;
    -webkit-appearance: none;

    padding-right: 2.5rem;
    background-image:
      linear-gradient(45deg, transparent 50%, var(--color-neutral-800) 50%),
      linear-gradient(135deg, var(--color-neutral-800) 50%, transparent 50%),
      linear-gradient(to left, var(--color-neutral-000) 0 2rem, transparent 2rem);
    background-position:
      calc(100% - 1.15rem) 50%,
      calc(100% - 0.75rem) 50%,
      right center;
    background-size:
      0.4rem 0.4rem,
      0.4rem 0.4rem,
      2rem 100%;
    background-repeat: no-repeat;
  }


input[type=checkbox] { margin-right: 0.3rem; }
input:focus, select:focus, textarea:focus { outline: none; border-color: var(--status-color-info); border-width: 2px; }
input:disabled { box-shadow: none; border-width: 1px; border-color: var(--color-neutral-200); }
input[readonly],
textarea[readonly] {
  border-style: dotted;
  caret-color: transparent;
  cursor: default;
  box-shadow: none;
}


/* =============================================================================== */
/* FOOTER                                                                          */
/* =============================================================================== */
footer { background-color: var(--footer-bg); height: auto; font-size: var(--type-size-400); padding: 0.5rem 2rem 3rem; }
body.site.admin footer {  padding: 0.5rem 2rem 1rem; }
footer, footer a, footer a:visited { color: var(--footer-text); }
footer h3 { color: var(--color-brand-primary); font-weight: var(--type-weight-semibold); }
#footer-info { flex-direction: column; align-items: baseline; display: flex; flex-direction: row; gap: 1rem; flex-wrap: wrap; margin: 2rem 0 0; }
#footer-info a:hover  { text-decoration: underline }
#footer-info .site-logo { margin: 0; width: 330px; max-width: 80%; }
#footer-info p { margin: 0; }
.footer-follow {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 1rem;
  margin: 2rem 0 0;
}
.footer-follow p { margin: 0; }
footer ul { color: #000; padding-left: 0; }
footer a { text-decoration: none; }
footer > ul > li { line-height: 1.6rem; }
footer > ul > li > ul { padding: 0 0 0.5rem 2rem; }
footer > ul > li > ul > li { line-height: 1.4rem; }

/* =============================================================================== */
/* FILTER BAR                                                                      */
/* =============================================================================== */
.filter-bar { display: flex; flex-wrap: wrap; align-items: center; gap: var(--sp-sm); margin-block: var(--sp-sm); }

.filter-bar__controls { display: flex; flex-wrap: wrap; align-items: end; gap: var(--sp-xs); width: 100%; }

.filter-bar input[type="text"],
.filter-bar input[type="date"] { max-width: 24rem; }

.filter-bar .check-field { display: inline-flex; align-items: center; gap: var(--sp-3xs); white-space: nowrap; font-weight: var(--type-weight-semibold); }

.filter-bar .form-field,
.filter-bar .form-field--cluster { width: auto; flex: 0 1 auto; }

.filter-bar__search { flex: 1 1 16rem; }

.filter-bar__actions,
.filter-bar .button-group { display: flex; flex-wrap: wrap; align-items: center; gap: var(--sp-xs); }

.filter-bar .button-group { flex-basis: 100%; margin-top: var(--sp-xs); }

.filter-bar--inline .filter-bar__controls { flex-wrap: nowrap; align-items: end; gap: var(--sp-2xs); }
.filter-bar--inline .filter-bar__controls > .form-field { flex: 0 0 auto; min-width: 0; }
.filter-bar--inline .filter-bar__search { flex: 0 1 24rem; max-width: 24rem; }
.filter-bar--inline .filter-bar__controls > .form-field:not(.filter-bar__search) { max-width: 16rem; }

.filter-bar--inline .filter-bar__actions,
.filter-bar--inline .button-group { flex: 0 0 auto; flex-basis: auto; align-items: end; margin-top: 0; gap: var(--sp-2xs); }

.filter-bar--inline .filter-bar__actions button,
.filter-bar--inline .filter-bar__actions .button,
.filter-bar--inline .button-group button,
.filter-bar--inline .button-group .button { margin-block: 0; }

.filter-bar--inline input,
.filter-bar--inline select { width: 100%; max-width: none; min-height: var(--control-height); }

.pagination-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-md);
  margin-top: var(--sp-md);
}

@media screen and (max-width: 760px) {
  .filter-bar--inline .filter-bar__controls {
    flex-wrap: wrap;
  }

  .filter-bar--inline .form-field,
  .filter-bar--inline .filter-bar__search {
    flex: 1 1 100%;
    max-width: none;
  }
}

/* =============================================================================== */
/* SPECIAL CLASSES                                                                 */
/* =============================================================================== */
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0 0 0 0); clip-path: inset(50%); white-space: nowrap; border: 0; }
.hiddenMobile { display: none} /* HIDE all elements that should not appear on mobile devices */
#totop { min-height: 20px; position: fixed; bottom: 75px; right: 15px; z-index: 5; width: 40px; }

/* =============== BREADCRUMB MENU ================================ */
nav#breadcrumb { font-size: var(--type-size-400); font-weight: 400; padding: var(--sp-3xs) 0 var(--sp-sm); }
nav#breadcrumb ul { margin: 0 auto; padding-left: 0; line-height: 1.3rem; width: 100%; display: flex; gap: 0 var(--sp-3xs); background: var(--color-neutral-100); padding: 0.5rem .8rem;
  border-left: 3px solid var(--color-neutral-300); }
nav#breadcrumb ul li { display: inline-block; width: auto; }
nav#breadcrumb ul:nth-child(1) li { padding-left: 0; }
nav#breadcrumb a { cursor: pointer; }
nav#breadcrumb a, nav#breadcrumb a.visited { color: var(--color-action-fill); text-decoration: none; }
nav#breadcrumn a:hover { color: var(--color-action-primary-hover)}
nav#breadcrumb ul li::after { content: '\00A0\203A\00A0'}
nav#breadcrumb ul li:last-of-type::after { content: '';}

/* =============================================================================== */
/* TABLES                                                                          */
/* =============================================================================== */
/* Data tables: mobile-first */
table { width: 100%; border-collapse: collapse; border-bottom: 3px solid var(--table-border-bottom); font-size: var(--data-font-size); font-weight: var(--data-font-weight); line-height: var(--data-line-height);}
table thead { display: none; }
table,
table tbody,
table tr,
table td { display: block; width: 100%;
}
table tr { padding: 1rem 0; border-bottom: 2px solid var(--color-neutral-300); }
table td { display: grid; grid-template-columns: 8rem 1fr; gap: 1rem; padding: 0.35rem 0; }
table td .table-col-align--center { text-align: center; } 
table td::before { content: attr(data-label); font-weight: var(--type-weight-semibold); }
.table--banded tbody tr:nth-child(even) { background-color: var(--color-neutral-200); }
.table-row--section { padding: 0; border-bottom: none; }
.table-row--section th {
  display: block;
  width: 100%;
  padding: var(--sp-3xs) var(--sp-xs);
  background: var(--color-neutral-300);
  color: var(--table-row-header);
  font-weight: var(--type-weight-medium);
  text-align: left;
}

/* Table column width utilities */
.col-w-5 { width: 5%; }
.col-w-10 { width: 10%; }
.col-w-15 { width: 15%; }
.col-w-20 { width: 20%; }
.col-w-25 { width: 25%; }
.col-w-30 { width: 30%; }
.col-w-40 { width: 40%; }
.col-w-50 { width: 50%; }

/* =============== TABLES ================================ */
.tableBody { max-width: none; border: none; }
.tableRow { border-top: 1px solid var(--color-neutral-300); }
.tableRow { margin-top: 0.7rem; } .tableRow:first-of-type { margin-top: 0; }
.tableRow, .tableCell { display: inline-block;}
.tableRowHeader { display: none; }
.tableRow, .secondaryHeader, form { margin-top: 0; width: 100%; }
.tableCell { display: block; line-height: 1.7rem; }
.tableCell span:nth-child(1) { font-weight: var(--type-weight-semibold); }
.table-group .tableBody { 
	border-top: 3px solid var(--table-border-top); border-bottom: 3px solid var(--table-border-bottom);
	background: var(--color-neutral-200);
}

/* =============================================================================== */
/* SUPPORT KNOWLEDGEBASE TROUBLESHOOT NEW TICKETS                                  */
/* =============================================================================== */

.numeric-nav {
  --step-size: 2.5rem;
  position: relative;
  width: 100%;
  padding: var(--sp-md) 0 var(--sp-xl);
  color: var(--color-text-primary);
  font-family: var(--type-font-primary);
  font-size: var(--type-size-400);
}
.numeric-nav::before {
  content: "";
  position: absolute;
  top: calc(var(--sp-md) + (var(--step-size) / 2));
  left: calc(var(--step-size) / 2);
  right: calc(var(--step-size) / 2);
  height: 2px;
  background: var(--color-neutral-300);
  z-index: 0;
}
.numeric-nav > ol {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(4, var(--step-size));
  justify-content: space-between;
  gap: 0;
  width: 100%;
  margin: 0;
  padding: 0;
  list-style: none;
}
.numeric-nav > ol > li {
  display: flex;
  justify-content: center;
  width: var(--step-size);
  margin: 0;
  padding: 0;
  list-style: none;
}
.numeric-nav .numeric-nav-item {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-xs);
  width: var(--step-size);
  height: auto;
  min-width: var(--step-size);
  margin: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: var(--color-text-primary);
  font-weight: var(--type-weight-regular);
  text-align: center;
  text-decoration: none;
  overflow: visible;
}
.numeric-nav .numeric-nav-number {
  display: inline-flex;
  flex: 0 0 var(--step-size);
  align-items: center;
  justify-content: center;
  width: var(--step-size);
  height: var(--step-size);
  border: 2px solid var(--color-neutral-200);
  border-radius: 50%;
  background: var(--color-neutral-200);
  color: var(--color-text-primary);
  font-weight: var(--type-weight-bold);
  line-height: 1;
  transition: background-color .2s ease, border-color .2s ease, color .2s ease;
}
.numeric-nav .numeric-nav-label {
  max-width: 9rem;
  color: var(--color-text-primary);
  font-size: var(--type-size-300);
  line-height: var(--type-height-300);
  white-space: normal;
}
.numeric-nav .numeric-nav-item.active .numeric-nav-number,
.numeric-nav .numeric-nav-item[aria-current="step"] .numeric-nav-number {
  border-color: var(--status-color-info);
  background: var(--status-color-info);
  color: var(--color-text-primary-rev);
}
.numeric-nav .numeric-nav-item:hover {
  color: var(--color-text-primary);
  text-decoration: none;
}
.numeric-nav .numeric-nav-item:hover .numeric-nav-number {
  border-color: var(--status-color-info-hover);
  background: var(--status-color-info-hover);
  color: var(--color-text-primary-rev);
}
.numeric-nav .numeric-nav-item:focus-visible .numeric-nav-number {
  outline: 3px solid var(--status-color-info-tint);
  outline-offset: 2px;
}

.content-card {
  display: flex;
  flex-direction: column;
  gap: var(--sp-xs);
  min-height: 100%;
  padding: var(--sp-md);
  border: 2px solid var(--color-neutral-300);
  border-radius: var(--sp-2xs);
  background: var(--color-neutral-000);
  box-shadow: var(--box-shadow);
}

.content-card .content-card__media {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 7rem;
}

.content-card .content-card__media img {
  display: block;
  max-width: 100%;
  max-height: 7rem;
  object-fit: contain;
}

.content-card .content-card__body {
  display: flex;
  flex: 1 1 auto;
  flex-direction: column;
  gap: var(--sp-xs);
}

.content-card p {
  margin: 0;
  color: var(--color-text-primary);
  font-size: var(--type-size-400);
  line-height: var(--type-height-500);
}

.content-card ul {
  margin: 0;
  padding-left: var(--sp-sm);
  color: var(--color-text-primary);
  font-size: var(--type-size-400);
  line-height: var(--type-height-500);
}

.content-card .content-card__action {
  margin-top: auto;
  align-self: flex-start;
}

/* =============================================================================== */
/*                  LARGER SCREENS ONLY                                            */
/* =============================================================================== */

@media screen and (min-width: 1000px) {
  body.site { gap: 0 3rem; grid-template-columns: 3rem repeat(6, 1fr) 3rem; }
  body.site.admin {
  column-gap: 0;
  grid-template-columns: var(--admin-sidebar-w) 3rem repeat(6, 1fr) 3rem;
  grid-template-areas:
    "header header header header header header header header header"
    "nav    .      main   main   main   main   main   main   main"
    "footer footer footer footer footer footer footer footer footer";
}
  /* Designate the column structure of tags */
  body.site.admin > header,
  body.site.admin > footer { grid-column: 1 / -1; column-gap: 3rem; grid-template-columns: 3rem repeat(6, minmax(0, 1fr)) 3rem; }
  body.site.admin > #mainNav { grid-column: 1 / 2; }
  body.site.admin > #pageContainer { grid-column: 3 / -1; }
  body.site.admin #headerContainer,
  body.site.admin #footer-info,
  body.site.admin .footer-follow,
  body.site.admin footer > .footer-list { grid-column: 2 / 8; }
  /* in admin layout, main content spans the 6 content columns beside the sidebar */
  body.site.admin > #pageContainer > * { grid-column: var(--page-col, 1 / 7); }
  /* nav content fills the sidebar column */
  body.site.admin #mainNav .nav-menu__list { grid-column: 1 / -1; }

  #headerContainer, body.site > header > a, body.site > header > #myaccount, #mainNav .nav-menu__list, #pageContainer > *, #footer-info, .footer-follow, footer > .footer-list { grid-column: 2 / 8; }
  
  #headerContainer {display: flex; justify-content: space-between; align-items: center; padding-left: 0; }
  body.site > header > a { padding-left: 0; }
  header {	z-index: 300; grid-row: 1; position: relative; box-shadow: none; padding: 0; height: 70px; border-bottom: 2px solid var(--color-brand-accent); }
  #site-logo > img,
  body.site > header > a > img.site-logo { max-width: none; margin: 0; height: 2.2rem; }
  footer .disclaimer {  display: flex; gap: 1rem; }
  footer ul { grid-column: span 2; }

  .section-flex { display: flex; width: 100%; flex-direction: row; flex-wrap: wrap; gap: var(--sp-lg); }

  .grid-col-2 { --grid-cols: 2; }
  .grid-col-3 { --grid-cols: 3; }
  .grid-col-4 { --grid-cols: 4; }
  .grid-col-5 { --grid-cols: 5; }
  .grid-col-6 { --grid-cols: 6; }

  /* default child placement */
  .section-grid > * { grid-column: var(--item-span, span 1); }

  /* item span utilities */
  .col-span-2 { --item-span: span 2; }
  .col-span-3 { --item-span: span 3; }
  .col-span-4 { --item-span: span 4; }

  .hiddenDesktop { display: none; } /* REVEAL all elements that were hidden on mobile devices */


/* =============================================================================== */
/* DESKTOP ---- TABLES                                                             */
/* =============================================================================== */
  /* Data tables */
  table {
    display: table; table-layout: fixed; width: 100%; max-width: none; font-size: var(--data-font-size);
    margin: 0.5rem 0 0.8rem; border: none; border-top: 3px solid var(--table-border-top); border-bottom: 3px solid var(--table-border-bottom); border-collapse: collapse;
  }

  table thead { display: table-header-group; background: var(--table-row-header); color: var(--color-neutral-000); font-weight: 400; }
  table tbody { display: table-row-group; }
  table tr { display: table-row; width: auto; padding: 0; border-bottom: none; }

  table th,
  table td { display: table-cell; padding: var(--sp-xs) var(--sp-xs); font-weight: inherit; }
  table th:not([class*="col-w-"]),
  table td:not([class*="col-w-"]) { width: auto; }
  /* Set table cell alignment default to left */
  table th:not(.text-align--center),
  table td:not(.text-align--center) { text-align: left; }
  table td::before { content: none; }
  table td,
  table td a { overflow-wrap: anywhere; word-break: normal; } /* wrap text even if it is a long url */
  table .table-row--section th {
    display: table-cell;
    padding: var(--sp-3xs) var(--sp-xs);
    background: var(--color-neutral-300);
    color: var(--table-row-header);
    font-weight: var(--type-weight-medium);
  }

  /* =============== TABLES ================================ */
	.tableRowHeader { display: table-header-group; font-weight: var(--type-weight-medium); background: var(--table-row-header); color: var(--color-neutral-000); }
	.tableRowHeader.secondary { background: var(--color-neutral-300); color: var(--color-neutral-800); }
	.tableBody { max-width: none; border: none; margin: 0.5rem 0 0.8rem; border-bottom: 2px solid var(--color-neutral-300); }
	.tableRow { display: table-row; }
	.tableRowHeader > *, .tableRow > * { display: table-cell; width: 5%; }
  .tableRowHeader > * { padding: var(--sp-3xs) var(--sp-sm); }
  .tableRow > * { padding: var(--sp-3xs) var(--sp-sm); }
	.tableRowHeader > *:nth-child(1) *, .tableRow > *:nth-child(1) *  { font-size: inherit; }
	.tableCell span:nth-child(1) { font-weight: inherit; } /* remove bold headings used in mobile view */
	.tableCell { display: table-cell; padding: 0.3rem 1rem; }
	textarea { width: 100%; max-width: none; min-height: 110px; }
  
/* =============================================================================== */
/* BUTTONS                                                                         */
/* =============================================================================== */
  .button-group { flex-direction: row; }

  /* =============== CUSTOMER MENUS ================================ */
  #myaccount { cursor: pointer; }
  #myaccount a { font-size: var(--type-size-400); }
  #myaccount #myAccntReg a { color: var(--color-neutral-800); } /* Register link */
  #myaccount .acct-title .username { display: inline-block; } /* Makes username visible on desktops */
  #acct-menu {
    position: fixed;
    top: 70px;
    right: 3rem;
    bottom: auto;
    z-index: 310;
    width: 18rem;
    max-height: calc(100vh - 70px);
  }
}

@media screen and (-webkit-min-device-pixel-ratio: 0) and (min-resolution: 0.001dpcm) and (min-width: 1400px) {
  body {
    grid-template-columns: 1fr repeat(6, 180px) 1fr;
    /* grid-gap: 0 3rem; */
  }
}
