* {
	margin: 0px;
	padding: 0px;
	list-style: none;
	border: none;
	text-decoration: none;
	font-family: 'Poppins', sans-serif;
}
body{
	background-repeat:no-repeat;
	background-size:cover;
	background-position: center center;
	background-attachment:fixed;
}
.container{
	width:100%;
	max-width:1000px;
}
@font-face {
    font-family: 'Edwardian-Script-ITC';
    src: url('/fonts/EdwardianScriptITC.eot');
    src: url('/fonts/EdwardianScriptITC.eot?#iefix') format('embedded-opentype'),
        url('/fonts/EdwardianScriptITC.woff2') format('woff2'),
        url('/fonts/EdwardianScriptITC.woff') format('woff'),
        url('/fonts/EdwardianScriptITC.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}


/*** ### Header ### ***/
header{
	position:relative;
}
header .main-image{
	position:relative;
}
header .main-image img{
	width:100%;
}
header .main-text{
	position:absolute;
	bottom:10%;
	left:5%;
	right:5%;
}
header h1{
    font-family: 'Edwardian-Script-ITC';
	margin:0px;
	padding:0px;
	color:var(--color-heading);
	font-size:70px;
}
header .main-text .top-flower{
	position:absolute;
	bottom:0px;
	right:0px;
	width:20%;
	max-width:177px;
}

header .main-text a {
    text-decoration: none;
    font-family: 'Edwardian-Script-ITC';
	margin:0px;
	padding:0px;
	color:var(--color-heading);
	font-size:70px;
}

@media (max-width:1000px){
	header h1{
		font-size:7vw;
	}

	header .main-text a {
	    font-size:7vw;
	}
}
/*** ### Middle Content ### ***/
.middle-content{
	position:relative;
	background-size:100% 100%;
	padding:0px 7%;
	min-height: 65vh;
	overflow-wrap: break-word;
}
.middle-content p{
	padding:15px 0px;
	margin:0px;
	color:#000000;
	font-size:16px;
	font-weight:400;
	text-align:center;
}
.middle-content .pagination{
	position:relative;
	padding-bottom:15px;
}
.middle-content .pagination-main ul{
	margin:0px;
	padding:0px;
	text-align:center;
}
.middle-content .pagination-main ul li{
	position:relative;
	display:inline-block;
	vertical-align:middle;
	color:#000000;
	font-size:17px;
	font-weight:400;
	margin:0px 5px;
	padding:0px;
}
.middle-content .pagination-main ul li:first-child{
	font-weight:600;
}
.middle-content .pagination-main ul li a{
	color:#000000;
	text-decoration:none;
	outline:none;
	border:none;
}
.middle-content .main-table {
	position: relative;
	padding: 20px 0px;
}
.middle-content .main-table table {
	border-collapse: collapse;
	margin: 0 auto;
	padding: 0;
	width: 90%;
	--bs-table-bg: transparent;
	background-color: transparent !important;
}
.middle-content .main-table table tr {
	background: transparent !important;
	--bs-table-bg: transparent;
	border-bottom: 1px solid rgba(0,0,0,0.15);
}
.middle-content .main-table table th {
	text-align: left;
	font-size: 18px;
	color: var(--color-secondary);
	font-weight: 700;
	padding: 10px 20px;
	border-bottom: 2px solid var(--color-secondary);
	background: transparent !important;
}
.middle-content .main-table table tr td{
	vertical-align: top;
	font-size: 16px;
	color: #000000;
	font-weight: 400;
	padding: 14px 20px;
	word-break: break-word;
	background: transparent !important;
	--bs-table-bg: transparent;
}
.middle-content .main-table table tr td:first-child{
	font-size: 18px;
	width: 30%;
	font-weight: 600;
	text-align: left;
}
@media screen and (max-width: 600px) {
	.middle-content input[type=text], input[type=password] {
		font-size: 16px;
	}

	[role=form-error] {
		width: 100% !important;
	}

	button:not(.btn-search) {
		width: 100% !important;
	}

	.middle-content .main-table table {
		border: 0;
	}

	.middle-content .main-table table thead {
		border: none;
		clip: rect(0 0 0 0);
		height: 1px;
		margin: -1px;
		overflow: hidden;
		padding: 0;
		position: absolute;
		width: 1px;
	}

	.middle-content .main-table table tr {
		border-bottom: 1px solid #000000;
		display: block;
		margin-bottom: 1em;
		padding: 8px 0;
	}

	.middle-content .main-table table td {
		display: block;
		padding: 2px 0 2px 0;
	}

	.middle-content .main-table table tr td:first-child {
		font-size: 18px;
		width: auto;
		font-weight: 600;
		text-align: left;
	}

	.middle-content .main-table table td::before {
		content: attr(data-label);
		display: block;
		font-weight: 700;
		font-size: 11px;
		text-transform: uppercase;
		letter-spacing: 0.05em;
		color: var(--color-secondary);
		margin-bottom: 2px;
	}

	.middle-content .main-table table table td:last-child {
		border-bottom: 0;
	}

	.side-images {
		display: none;
	}
}

/*** ### Footer ### ***/
footer{
	position:relative;
}
footer .main-image{
	position:relative;
}
footer .main-image img{
	width:100%;
}
footer .main-text{
	position:absolute;
	top:0%;
	left:5%;
	right:5%;
}
footer .main-text .bottom-flower{
	position:absolute;
	top:0px;
	left:0px;
	width:15%;
	max-width:129px;
}
	
/* Form Buttons */

input[type=button], input[type=submit], input[type=reset] {
  background-color: red;
  border: none;
  color: white;
  padding: 1px 25px;
  text-decoration: none;
  margin: 4px 2px;
  cursor: pointer;
}

.button {
	background-color: red;
	width: 200px;
	border: none;
	color: white;
	padding: 1px 25px;
	text-decoration: none;
	text-align: center;
}

/* Bottom advertisements */

.bottom-adverts {
	text-align: center;
}

.bottom-adverts img {
	text-align: center;
	margin: 7px;
}

/* List Image (The images on the main page that link to the lists) */

.list-image {
	width: 25%;
	height: auto;
	margin: 20px;
}

.list-image-label {
	display: none;
}

/* Side Images (Used on login and register) */

.side-images {
	float: right;
}

/* Input boxes on forms */

.input-box {
	display: block;
	margin: 10px;
	font-size: 16px;
}

.input-box input {
	margin: 0 auto;
}

.middle-content input[type=text], input[type=password] {
	font-size: 16px;
	width: 50%;
}

[role=form-error] {
	width: 50% !important;
}

button {
	width: 50% !important;
}

/* General */

.center-content {
	text-align: center;
}

/* Signature */

.cursive-font {
	font-family: 'Brush Script MT';
	font-size: 24px !important;
	display: block;
	padding:15px 0px;
	margin:0px;
	color:#000000;
	font-size:16px;
	font-weight:400;
	text-align:center;
}

/* Form Validation */

[role=form-error] {
	display: block;
	background-color: #FF0000;
	color: #fff !important;
	text-align: center !important;
	margin: auto;
}

button {
  background-color: var(--color-primary);
  border: 1px solid #000;
  color: #fff;
  padding: 15px 32px;
  text-align: center;
  text-decoration: none;
  display: inline-block;
  font-size: 16px;
  margin: 4px 2px;
  cursor: pointer;
}

form {
	display: block;
	margin:0px;
	color:#000000;
	font-size:16px;
	font-weight:400;
	text-align:center;
}

.paragraph {
	display: block;
	padding:15px 0px;
	margin:0px;
	color:#000000;
	font-size:16px;
	font-weight:400;
	text-align:center;
}

textarea {
	width: 100%;
}

.small-font {
	display: block;
	font-size: 10px !important;
}

h4 {
	text-align: center;
}

/* Selected page color and decoration */
.selected-page {
	text-decoration: underline;
}

.selected-page a {
	color: #FF0000 !important;
}

/* Christmas Nav */

.xmas-nav {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
    padding: 18px 0 10px;
    border-top: 2px dashed var(--color-primary);
    margin-top: 16px;
}

.xmas-nav-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 20px;
    border-radius: 50px;
    font-size: 14px;
    font-weight: 600;
    text-decoration: none !important;
    cursor: pointer;
    transition: transform 0.15s, box-shadow 0.15s;
    background: var(--color-primary);
    color: #fff !important;
    border: 2px solid var(--color-primary);
    box-shadow: 0 2px 6px rgba(0,0,0,0.18);
    width: auto !important;
    line-height: 1.4;
}

.xmas-nav-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.22);
    background: var(--color-primary-dark);
    border-color: var(--color-primary-dark);
}

.xmas-nav-btn--green {
    background: var(--color-accent-green);
    border-color: var(--color-accent-green);
}

.xmas-nav-btn--green:hover {
    background: var(--color-accent-green-dark);
    border-color: var(--color-accent-green-dark);
}

.xmas-nav-btn--gold {
    background: #b8860b;
    border-color: #b8860b;
}

.xmas-nav-btn--gold:hover {
    background: #9a700a;
    border-color: #9a700a;
}

.xmas-nav-btn--outline {
    background: transparent;
    color: var(--color-secondary) !important;
    border-color: var(--color-secondary);
    box-shadow: none;
}

.xmas-nav-btn--outline:hover {
    background: rgba(139,0,0,0.08);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.12);
}

/* Header Main */

.middle-content h1 {
	text-align: center;
}

/* Icon Area */

.icon-area img {
	margin: 5px;
}

/* Parent Dashboard Header */

.parent-header {
    text-align: center;
    padding: 4px 0 22px;
    margin-bottom: 4px;
    border-bottom: 2px dashed var(--color-primary);
    display: flow-root;
}

.parent-header__divider {
    font-size: 18px;
    letter-spacing: 6px;
    color: var(--color-secondary);
    margin-bottom: 10px;
}

.parent-header__title {
    font-family: 'Edwardian-Script-ITC', cursive;
    font-size: 42px;
    color: var(--color-secondary);
    margin: 0 0 10px;
    line-height: 1.2;
}

.parent-header__text {
    font-size: 15px;
    color: #333;
    max-width: 480px;
    margin: 0 auto 18px !important;
    line-height: 1.6;
    padding: 0 !important;
}

.parent-header__icons {
    display: flex;
    justify-content: center;
    gap: 28px;
    flex-wrap: wrap;
}

.parent-icon-link {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    text-decoration: none !important;
    color: var(--color-secondary) !important;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    transition: transform 0.15s, opacity 0.15s;
}

.parent-icon-link img {
    width: 40px;
    height: 40px;
    object-fit: contain;
    display: block;
    border-radius: 8px;
    padding: 4px;
    background: rgba(139,0,0,0.06);
    border: 1.5px solid rgba(139,0,0,0.15);
    transition: background 0.15s, border-color 0.15s;
}

.parent-icon-link:hover {
    transform: translateY(-3px);
    opacity: 0.85;
}

.parent-icon-link:hover img {
    background: rgba(139,0,0,0.12);
    border-color: rgba(139,0,0,0.35);
}

.btn-xmas-green {
    background-color: var(--color-accent-green) !important;
    border-color: var(--color-accent-green) !important;
    color: #fff !important;
}

.btn-xmas-green:hover {
    background-color: var(--color-accent-green-dark) !important;
    border-color: var(--color-accent-green-dark) !important;
}

.btn-xmas-remove {
    background-color: var(--color-secondary) !important;
    border-color: var(--color-secondary) !important;
    color: #fff !important;
}

.btn-xmas-remove:hover {
    background-color: #6b0000 !important;
    border-color: #6b0000 !important;
}

/* Themed Form Section (change password, etc.) */

.xmas-form-section {
    max-width: 420px;
    margin: 22px auto 0;
    text-align: center;
}

.xmas-field {
    margin-bottom: 16px;
}

.xmas-label {
    display: block;
    font-weight: 700;
    color: var(--color-secondary);
    margin-bottom: 4px;
    font-size: 15px;
}

.xmas-input {
    width: 100% !important;
    margin: 4px auto 0 !important;
}

.xmas-submit {
    width: auto !important;
    padding: 8px 32px !important;
    font-size: 15px !important;
}

/* Admin Panel */

.admin-section {
    margin: 22px 0;
    padding-bottom: 18px;
    border-bottom: 2px dashed var(--color-primary);
}

.admin-section:last-child {
    border-bottom: none;
}

.admin-section__title {
    font-family: 'Edwardian-Script-ITC', cursive;
    font-size: 30px;
    color: var(--color-secondary);
    font-weight: normal;
    margin: 0 0 12px;
}

.admin-section .form-select,
.admin-section .ts-wrapper {
    max-width: 480px;
    margin: 0 auto;
}

/* Tom Select theme overrides */
.ts-wrapper .ts-control {
    border: 1.5px solid rgba(139,0,0,0.3) !important;
    border-radius: 6px !important;
    background: rgba(255,255,255,0.7) !important;
    font-size: 15px !important;
}

.ts-wrapper.focus .ts-control {
    border-color: var(--color-secondary) !important;
    box-shadow: 0 0 0 3px rgba(139,0,0,0.12) !important;
}

.ts-dropdown {
    border-color: rgba(139,0,0,0.25) !important;
    border-radius: 6px !important;
}

.ts-dropdown .option.selected,
.ts-dropdown .option:hover {
    background: rgba(139,0,0,0.08) !important;
    color: var(--color-secondary) !important;
}

.ts-dropdown .option.active {
    background: var(--color-primary) !important;
    color: #fff !important;
}

/* Credits Empty / Payment */

.credits-empty {
    text-align: center;
    padding: 10px 0 18px;
}

.credits-empty__icon {
    font-size: 48px;
    line-height: 1;
    margin-bottom: 10px;
}

.credits-empty__title {
    font-family: 'Edwardian-Script-ITC', cursive;
    font-size: 30px;
    color: var(--color-secondary);
    font-weight: normal;
    margin: 0 0 8px;
}

.credits-empty__text {
    font-size: 15px;
    color: #333;
    margin: 0 0 18px !important;
    padding: 0 !important;
}

.credits-empty__purchase {
    max-width: 480px;
    margin: 0 auto 18px;
    padding: 18px 20px;
    background: rgba(255,255,255,0.4);
    border: 2px dashed var(--color-primary);
    border-radius: 10px;
}

.credits-empty__purchase-label {
    font-size: 15px;
    color: var(--color-secondary);
    font-weight: 600;
    margin: 0 0 14px !important;
    padding: 0 !important;
}

.credits-empty__charity {
    display: inline-block;
    margin: 0 auto 12px;
    padding: 12px 20px;
    background: rgba(45,106,45,0.1);
    border: 1.5px solid var(--color-accent-green);
    border-radius: 8px;
    color: var(--color-accent-green-dark);
    font-size: 14px;
    line-height: 1.6;
}

.credits-empty__refund {
    font-size: 13px;
    color: #666;
    margin: 10px 0 16px !important;
    padding: 0 !important;
}

/* Parent Dashboard Content */

#parent-dashboard-content h4 {
    font-family: 'Edwardian-Script-ITC', cursive;
    font-size: 30px;
    color: var(--color-secondary);
    font-weight: normal;
    margin: 18px 0 10px;
}

#parent-dashboard-content hr {
    border: none;
    border-top: 2px dashed var(--color-primary);
    opacity: 1;
    margin: 18px 0;
}

/* Parent Toast */

.parent-toast {
    position: fixed;
    bottom: 30px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 9999;
    padding: 14px 32px;
    background: var(--color-accent-green);
    color: #fff;
    font-weight: 700;
    font-size: 16px;
    border-radius: 50px;
    box-shadow: 0 4px 20px rgba(0,0,0,0.35);
    white-space: nowrap;
}

/* Can't Find Box */

.cant-find-box {
    display: block;
    margin-top: 14px;
    margin-bottom: 24px;
    padding: 14px 24px;
    background: rgba(139,0,0,0.06);
    border: 2px dashed var(--color-primary);
    border-radius: 10px;
    text-align: center;
}

.cant-find-box__text {
    font-size: 15px;
    color: #333;
    margin: 4px 0 !important;
    padding: 0 !important;
}

.cant-find-box__link {
    color: var(--color-secondary) !important;
    font-weight: 700;
    text-decoration: underline !important;
}

/* Not Found Box */

.not-found-box {
    text-align: center;
    margin: 24px auto;
    padding: 24px 20px;
    max-width: 480px;
    background: rgba(255,255,255,0.45);
    border: 2px dashed var(--color-primary);
    border-radius: 12px;
}

.not-found-box__emoji {
    font-size: 48px;
    line-height: 1;
    margin-bottom: 12px;
}

.not-found-box__title {
    font-size: 17px;
    color: var(--color-secondary);
    font-weight: 600;
    margin: 0 0 8px !important;
    padding: 0 !important;
}

.not-found-box__sub {
    font-size: 15px;
    color: #333;
    margin: 0 !important;
    padding: 0 !important;
}

.not-found-box__link {
    color: var(--color-secondary) !important;
    font-weight: 700;
    text-decoration: underline !important;
}

/* Pagination */

.pagination .page-link {
	background-color: transparent !important;
	border-color: rgba(0,0,0,0.6) !important;
	color: #000 !important;
	font-weight: 600;
}

.pagination .page-item.active .page-link {
	background-color: var(--color-primary) !important;
	border-color: var(--color-primary) !important;
	color: #fff !important;
}

.pagination .page-link:hover {
	background-color: rgba(201,32,31,0.1) !important;
}

/* Override Bootstrap primary color to match site theme */

.btn-primary {
	background-color: var(--color-primary) !important;
	border-color: var(--color-primary) !important;
}

.btn-primary:hover {
	background-color: var(--color-primary-dark) !important;
	border-color: var(--color-primary-dark) !important;
}

/* Success */

.success {
	display: block;
	background-color: #00d023;
	color: #000 !important;
	text-align: center !important;
	margin: auto;
}