/*! tailwindcss v4.1.8 | MIT License | https://tailwindcss.com */
@layer theme, base, components, utilities;
@layer theme {
  :root, :host {
    --rf-font-sans: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji",
      "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
    --rf-font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono",
      "Courier New", monospace;
    --rf-default-font-family: var(--rf-font-sans);
    --rf-default-mono-font-family: var(--rf-font-mono);
  }
}
@layer base {
  *, ::after, ::before, ::backdrop, ::file-selector-button {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    border: 0 solid;
  }
  html, :host {
    line-height: 1.5;
    -webkit-text-size-adjust: 100%;
    tab-size: 4;
    font-family: var(--rf-default-font-family, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");
    font-feature-settings: var(--rf-default-font-feature-settings, normal);
    font-variation-settings: var(--rf-default-font-variation-settings, normal);
    -webkit-tap-highlight-color: transparent;
  }
  hr {
    height: 0;
    color: inherit;
    border-top-width: 1px;
  }
  abbr:where([title]) {
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted;
  }
  h1, h2, h3, h4, h5, h6 {
    font-size: inherit;
    font-weight: inherit;
  }
  a {
    color: inherit;
    -webkit-text-decoration: inherit;
    text-decoration: inherit;
  }
  b, strong {
    font-weight: bolder;
  }
  code, kbd, samp, pre {
    font-family: var(--rf-default-mono-font-family, ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);
    font-feature-settings: var(--rf-default-mono-font-feature-settings, normal);
    font-variation-settings: var(--rf-default-mono-font-variation-settings, normal);
    font-size: 1em;
  }
  small {
    font-size: 80%;
  }
  sub, sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline;
  }
  sub {
    bottom: -0.25em;
  }
  sup {
    top: -0.5em;
  }
  table {
    text-indent: 0;
    border-color: inherit;
    border-collapse: collapse;
  }
  :-moz-focusring {
    outline: auto;
  }
  progress {
    vertical-align: baseline;
  }
  summary {
    display: list-item;
  }
  ol, ul, menu {
    list-style: none;
  }
  img, svg, video, canvas, audio, iframe, embed, object {
    display: block;
    vertical-align: middle;
  }
  img, video {
    max-width: 100%;
    height: auto;
  }
  button, input, select, optgroup, textarea, ::file-selector-button {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    border-radius: 0;
    background-color: transparent;
    opacity: 1;
  }
  :where(select:is([multiple], [size])) optgroup {
    font-weight: bolder;
  }
  :where(select:is([multiple], [size])) optgroup option {
    padding-inline-start: 20px;
  }
  ::file-selector-button {
    margin-inline-end: 4px;
  }
  ::placeholder {
    opacity: 1;
  }
  @supports (not (-webkit-appearance: -apple-pay-button))  or (contain-intrinsic-size: 1px) {
    ::placeholder {
      color: currentcolor;
      @supports (color: color-mix(in lab, red, red)) {
        color: color-mix(in oklab, currentcolor 50%, transparent);
      }
    }
  }
  textarea {
    resize: vertical;
  }
  ::-webkit-search-decoration {
    -webkit-appearance: none;
  }
  ::-webkit-date-and-time-value {
    min-height: 1lh;
    text-align: inherit;
  }
  ::-webkit-datetime-edit {
    display: inline-flex;
  }
  ::-webkit-datetime-edit-fields-wrapper {
    padding: 0;
  }
  ::-webkit-datetime-edit, ::-webkit-datetime-edit-year-field, ::-webkit-datetime-edit-month-field, ::-webkit-datetime-edit-day-field, ::-webkit-datetime-edit-hour-field, ::-webkit-datetime-edit-minute-field, ::-webkit-datetime-edit-second-field, ::-webkit-datetime-edit-millisecond-field, ::-webkit-datetime-edit-meridiem-field {
    padding-block: 0;
  }
  :-moz-ui-invalid {
    box-shadow: none;
  }
  button, input:where([type="button"], [type="reset"], [type="submit"]), ::file-selector-button {
    appearance: button;
  }
  ::-webkit-inner-spin-button, ::-webkit-outer-spin-button {
    height: auto;
  }
  [hidden]:where(:not([hidden="until-found"])) {
    display: none !important;
  }
}
@layer utilities {
  .rf\:h-lvh {
    height: 100lvh;
  }
}

:root {
	--text-width: 700px;
	/* font-sizes */
	--font-size-title: 28px;
	--font-size-text: 23px;
	--font-size-item-title: 21px;
	--font-size-item-text: 23px;
	--font-size-buttons: 21px;
	/* fonts */
	--font-family-title: 'Maven Pro';
	--font-family-text: 'Zilla Slab';
	--font-family-item-title: 'Maven Pro';
	--font-family-item-text: 'Zilla Slab';
	--font-family-buttons: 'Maven Pro';
	/* weights */
	--font-weight-title: 500;
	--font-weight-text: 400;
	--font-weight-item-title: 500;
	--font-weight-item-text: 500;
	--font-weight-buttons: 500;
	/* radius */
	--border-radius-modal: 12px;
	--border-radius-item: 12px;
	--border-radius-button: 12px;
	/* buttons */
	--button-text-color: #fff;
	--button-background-color: #7b9d20;
	--button-border-color: rgba(0,0,0,0);
	--hover-button-text-color: #fff;
	--hover-button-background-color: #617e13;
	--hover-button-border-color: rgba(0,0,0,0);
	/* secondary buttons */
	--button-secondary-text-color: #7b9d20;
	--button-secondary-background-color: #fff;
	--button-secondary-border-color: #7b9d20;
	--hover-button-secondary-text-color: #617e13;
	--hover-button-secondary-background-color: #fff;
	--hover-button-secondary-border-color: #617e13;
	/* disabled buttons */
	--disabled-button-text-color: #242e08;
	--disabled-button-background-color: #f8f8f8;
	--disabled-button-border-color: rgba(0,0,0,0);
	/* modals */
	--modal-background-color: #fff;
	--modal-text-color: initial;
	--modal-content-width: 700px;



	/* replace */
	--primary-color: #7b9d20;
	--secondary-color: #7b9d20;
	--disabled-input-background-color: #f8f8f8;
	--item-card-background-color: #f8f8f8;
	--item-card-border-color: #f8f8f8;
	--background-color: #fff;
	--foreground-color: #000;
}

rf2k-sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

/*******************************************************************************
*	buttons
*******************************************************************************/

.rf2k-button-primary,
.rf2k-button-secondary {
	margin-top: calc(var(--font-size-text) * 0.41625);
	margin-bottom: calc(var(--font-size-text) * 0.41625);
	margin-right: calc(var(--font-size-text) * 0.24975);
	transition: background-color 0.2s;
	cursor: pointer;
    padding:
		calc(var(--font-size-text) * 0.5)
		calc(var(--font-size-text) * 0.7)
		calc(var(--font-size-text) * 0.5)
		calc(var(--font-size-text) * 0.7);
    border-radius: var(--border-radius-button);
    font-size: var(--font-size-buttons);
	font-family: var(--font-family-buttons);
	font-weight: var(--font-weight-buttons);
}
.rf2k-button-primary {
	color: var(--button-text-color);
	background-color: var(--button-background-color);
	border: 1px solid var(--button-border-color);
}
.rf2k-button-primary:hover {
	color: var(--hover-button-text-color);
	background-color: var(--hover-button-background-color);
	border: 1px solid var(--hover-button-border-color);
}
.rf2k-button-secondary {
	color: var(--button-secondary-text-color);
	background-color: var(--button-secondary-background-color);
	border: 1px solid var(--button-secondary-border-color);
}
.rf2k-button-secondary:hover {
	color: var(--hover-button-secondary-text-color);
	background-color: var(--hover-button-secondary-background-color);
	border: 1px solid var(--hover-button-secondary-border-color);
}
.rf2k-button-primary:disabled,
.rf2k-button-secondary:disabled {
	color: var(--disabled-button-text-color);
	background-color: var(--disabled-button-background-color);
	border: 1px solid var(--disabled-button-border-color);
	cursor: initial;
}

/*******************************************************************************
*	modal
*******************************************************************************/

#rf2k-modal {
	display: block;
	position: fixed;
	z-index: 999;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	overflow: auto;
	background-color: rgb(0,0,0);
	background-color: rgba(0,0,0,0.4);
}
#rf2k-modal.closed {
	display: none;
}
#rf2k-modal-content {
	position: relative;
	box-sizing: border-box;
	margin: calc(var(--font-size-text) * 0.5) auto;
	padding-top: calc(var(--font-size-text) * 1.875);
	padding-right: calc(var(--font-size-text) * 1.5);
	padding-bottom: calc(var(--font-size-text) * 1.125);
	padding-left: calc(var(--font-size-text) * 1.5);
	width: var(--modal-content-width);
	border: 1px solid #888;
	border-radius: var(--border-radius-modal);
	background-color: var(--modal-background-color);
	color: var(--modal-text-color);
	max-width: calc(100% - (var(--font-size-text) * 1));
	box-shadow: 0 calc(var(--font-size-text) * 0.1665) calc(var(--font-size-text) * 0.333) 0 rgba(0,0,0,0.2), 0 calc(var(--font-size-text) * 0.24975) calc(var(--font-size-text) * 0.83325) 0 rgba(0,0,0,0.19);
	animation-name: animatetop;
	animation-duration: 0.4s;
}
#rf2k-modal-title {
	font-size: var(--font-size-title);
	font-family: var(--font-family-title);
	font-weight: var(--font-weight-title);
	margin-bottom: var(--font-size-text);
}
#rf2k-modal-footer {
	text-align: center;
}
@keyframes animatetop {
	from {top: -300px; opacity: 0}
	to {top: 0; opacity: 1}
  }
#rf2k-modal p {
	font-size: var(--font-size-text);
	font-family: var(--font-family-text);
	font-weight: var(--font-weight-text);
	margin: 0;
	margin-bottom: calc(var(--font-size-text) * 0.6);
}

/*******************************************************************************
*	sections
*******************************************************************************/

.rf2k-exams-section {
    margin-top: calc(var(--font-size-text) * 7.5);
    margin-bottom: calc(var(--font-size-text) * 7.5);
}
.rf2k-category-section {
	margin-top: calc(var(--font-size-text) * 3.5);
}
p.rf2k-exams-section-description {
	max-width: var(--text-width);
	font-size: var(--font-size-text);
	font-family: var(--font-family-text);
	font-weight: var(--font-weight-text);
}
.rf2k-checkout-section {
    margin-top: calc(var(--font-size-text) * 7.5);
    margin-bottom: calc(var(--font-size-text) * 7.5);
}
#checkout .rf2k-checkout-section-title {
	margin-top: calc(var(--font-size-text) * 3.75);
}
p.rf2k-checkout-section-description {
	font-size: var(--font-size-text);
	font-family: var(--font-family-text);
	font-weight: var(--font-weight-text);
}

/*******************************************************************************
*	question/answer items
*******************************************************************************/

.rf2k-exams-items-container {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	grid-auto-rows: auto;
	grid-gap: var(--font-size-text);
}
@media (max-width: 960px) {
	.rf2k-exams-items-container {
		grid-template-columns: repeat(2, 1fr);
	}
}
@media (max-width: 720px) {
	.rf2k-exams-items-container {
		grid-template-columns: repeat(1, 1fr);
	}
}
.rf2k-exams-item {
	cursor: pointer;
	background-color: #f8f8f8;
	border: 1px solid #f8f8f8;
	border-radius: var(--border-radius-item);
    padding: calc(var(--font-size-text) * 0.2916) calc(var(--font-size-text) * 0.58275);
    margin-top: calc(var(--font-size-text) * 0.41625);
    margin-bottom: calc(var(--font-size-text) * 0.41625);
	transition: box-shadow 0.2s;
	display: flex;
    justify-content: center;
    align-items: center;
	min-height: calc(var(--font-size-text) * 4.9995);
}
.rf2k-exams-item.rf2k-category {
	background-color: var(--primary-color);
	border: 1px solid var(--primary-color);
	color: white;
}
.rf2k-exams-item:hover {
	box-shadow: 0 calc(var(--font-size-text) * 0.41625) calc(var(--font-size-text) * 0.83325) rgba(0,0,0,0.19), 0 calc(var(--font-size-text) * 0.24975) calc(var(--font-size-text) * 0.24975) rgba(0,0,0,0.23);
}
.rf2k-item-select-title {
	font-size: var(--font-size-item-title);
	font-family: var(--font-family-item-title);
	font-weight: var(--font-weight-item-title);
	text-align: center;
}
.rf2k-item-select-body {
	font-size: var(--font-size-item-text);
	font-family: var(--font-family-item-text);
	font-weight: var(--font-weight-item-text);
	text-align: center;
}
.rf2k-cart-item .rf2k-item-select-title {
	text-align: left;
}
.rf2k-cart-item .rf2k-item-select-body {
	text-align: left;
}

/*******************************************************************************
*	checkout
*******************************************************************************/

.rf2k-hidden {
	display: none;
}
#rf2k-checkout-outer-container {
	max-width: var(--text-width);
}
.rf2k-checkout-items-container,
.rf2k-checkout-files-container,
.rf2k-checkout-consent-container {
	margin: 0 0 24px 0;
}
.rf2k-cart-item,
.rf2k-checkout-exam-items,
.rf2k-checkout-download-items {
	background-color: var(--item-card-background-color);
	border: 1px solid var(--item-card-border-color);
	border-radius: var(--border-radius-item);
    padding:
		calc(var(--font-size-text) * 0.5)
		calc(var(--font-size-text) * 0.7)
		calc(var(--font-size-text) * 0.5)
		calc(var(--font-size-text) * 0.7);
    margin-top: calc(var(--font-size-text) * 0.41625);
    margin-bottom: calc(var(--font-size-text) * 0.41625);
	font-size: var(--font-size-item-title);
	font-family: var(--font-family-item-title);
	font-weight: var(--font-weight-item-title);
}
.rf2k-checkout-description {
	font-size: var(--font-size-text);
	font-family: var(--font-family-text);
	font-weight: var(--font-weight-text);
	margin-top: calc(var(--font-size-text) * 0.41625);
    margin-bottom: calc(var(--font-size-text) * 0.41625);
    margin-right: calc(var(--font-size-text) * 0.24975);
	padding-left: calc(var(--font-size-text) * 1.5);
}
.rf2k-checkout-description label {
	display: inline-block;
}
input[type="checkbox"] {
	margin-left: calc(var(--font-size-text) * -1.35);
    float: left;
    margin-top: calc(var(--font-size-text) * 0.5625);
	transform: scale(2) translate(2px, -1px);
}
ul.rf2k-checkout-items-container {
	padding-left: 0;
}

