:root{
	--bg: #f4f5f7;
	--surface: #ffffff;
	--surface-2: #fafafa;
	--text: #16181d;
	--muted: #5f6470;
	--border: #d9dce3;

	--accent: #e61e73;
	--accent-dark: #b80f56;
	--accent-light: #ffdeeb;

	--black: #0d0f14;
	--black-soft: #1a1d24;
	--white: #ffffff;

	--shadow: 0 10px 24px rgba(0,0,0,.10);
	--radius: 16px;
	--radius-lg: 22px;
	--radius-xl: 24px;
}

*{
	box-sizing: border-box;
}

html, body{
	margin: 0;
	padding: 0;
}

body{
	font-family: 'Inter', Arial, Helvetica, sans-serif;
	background: linear-gradient(180deg, #f7f8fa 0%, #eff1f4 100%);
	color: var(--text);
}

a{
	text-decoration: none;
	color: inherit;
}

img{
	max-width: 100%;
	height: auto;
	display: block;
}

/* =========================================================
   SHARED LAYOUT
========================================================= */

.page{
	max-width: 1240px;
	margin: 0 auto;
	padding: 18px;
}

.panel{
	background: var(--surface);
	border: 1px solid var(--border);
	border-radius: 18px;
	overflow: hidden;
	box-shadow: 0 6px 14px rgba(0,0,0,.05);
}

.panel-header{
	padding: 14px 16px;
	background: linear-gradient(135deg, var(--black) 0%, #262b36 100%);
	border-bottom: 4px solid var(--accent);
}

.panel-header h2{
	margin: 0;
	color: #fff;
	font-size: 17px;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: .06em;
	font-family: 'Bebas Neue', Arial, sans-serif;
}

.panel-body{
	padding: 14px;
	background: linear-gradient(180deg, #fff 0%, #fcfcfd 100%);
}

/* =========================================================
   SHARED HEADER / NAV
========================================================= */

.site-header{
	background: linear-gradient(135deg, var(--black) 0%, var(--black-soft) 100%);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow);
	overflow: hidden;
	margin-bottom: 18px;
	border: 1px solid #222631;
}

.header-top{
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding: 20px 24px;
	background:
		radial-gradient(circle at top right, rgba(230,30,115,.35), transparent 35%),
		linear-gradient(135deg, var(--black) 0%, #161922 100%);
}

.brand{
	display: flex;
	align-items: center;
	gap: 16px;
}

.brand-badge{
	width: 72px;
	height: 72px;
	border-radius: 20px;
	background: linear-gradient(135deg, var(--accent) 0%, var(--accent-dark) 100%);
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	font-size: 26px;
	font-weight: 800;
	box-shadow: 0 10px 24px rgba(230,30,115,.35);
	border: 2px solid rgba(255,255,255,.14);
	font-family: 'Bebas Neue', Arial, sans-serif;
	letter-spacing: 1px;
}

.brand-copy h1{
	margin: 0;
	color: #fff;
	font-size: 31px;
	line-height: 1.05;
	letter-spacing: .02em;
	text-transform: uppercase;
	font-family: 'Bebas Neue', Arial, sans-serif;
}

.brand-copy p{
	margin: 7px 0 0;
	color: rgba(255,255,255,.74);
	font-size: 14px;
	font-weight: bold;
	letter-spacing: .06em;
	text-transform: uppercase;
}

.header-links{
	color: rgba(255,255,255,.8);
	font-size: 13px;
	font-weight: bold;
}

.header-links a{
	color: #fff;
}

.nav{
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	padding: 14px 18px 18px;
	background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,0));
}

.nav a{
	padding: 10px 16px;
	border-radius: 999px;
	background: rgba(255,255,255,.08);
	color: #fff;
	font-weight: 700;
	font-size: 14px;
	border: 1px solid rgba(255,255,255,.12);
	transition: .18s ease;
	text-transform: uppercase;
	letter-spacing: .04em;
}

.nav a:hover,
.nav a.active{
	background: linear-gradient(135deg, var(--accent), var(--accent-dark));
	border-color: transparent;
	transform: translateY(-1px);
	box-shadow: 0 8px 18px rgba(230,30,115,.25);
}

/* =========================================================
   HOMEPAGE
========================================================= */

.main-shell{
	background: var(--surface);
	border: 1px solid var(--border);
	border-radius: var(--radius-lg);
	padding: 18px;
	box-shadow: var(--shadow);
}

.home-grid{
	display: grid;
	grid-template-columns: 250px 1fr 290px;
	gap: 18px;
	align-items: start;
}

/* Left column logo tile */
.logo-tile{
	background: linear-gradient(135deg, var(--black) 0%, #222631 100%);
	border-radius: 18px;
	padding: 18px;
	text-align: center;
	margin-bottom: 14px;
	color: #fff;
	box-shadow: 0 10px 20px rgba(0,0,0,.12);
	border: 1px solid #242936;
}

.logo-mark{
	width: 138px;
	height: 138px;
	margin: 0 auto 12px;
	border-radius: 28px;
	background: linear-gradient(135deg, var(--accent) 0%, #ff5aa0 100%);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 42px;
	font-weight: 900;
	box-shadow: 0 12px 28px rgba(230,30,115,.28);
	border: 3px solid rgba(255,255,255,.16);
}

.logo-tile strong{
	display: block;
	font-size: 16px;
	text-transform: uppercase;
	letter-spacing: .05em;
}

.logo-tile span{
	display: block;
	margin-top: 4px;
	font-size: 12px;
	color: rgba(255,255,255,.72);
	text-transform: uppercase;
	letter-spacing: .08em;
}

/* Standings */
.division-title{
	margin-top: 12px;
	padding: 9px 10px;
	background: linear-gradient(135deg, var(--accent), var(--accent-dark));
	color: #fff;
	font-size: 12px;
	font-weight: 800;
	text-align: center;
	text-transform: uppercase;
	letter-spacing: .08em;
	border-radius: 10px 10px 0 0;
	font-family: 'Inter', Arial, sans-serif;
}

.data-table{
	width: 100%;
	border-collapse: collapse;
	font-size: 13px;
	border: 1px solid var(--border);
	border-top: none;
	border-radius: 0 0 12px 12px;
	overflow: hidden;
}

.data-table th{
	background: #f3f5f8;
	color: var(--black-soft);
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: .05em;
	padding: 9px 8px;
	text-align: left;
	border-bottom: 1px solid var(--border);
}

.data-table td{
	padding: 9px 8px;
	border-bottom: 1px solid #eceef2;
	font-weight: 600;
}

.data-table tbody tr:nth-child(even){
	background: #fafbfc;
}

.data-table tbody tr:hover{
	background: #fff2f8;
}

/* News */
.news-item{
	position: relative;
	background: #fff;
	border: 1px solid var(--border);
	border-left: 5px solid var(--accent);
	border-radius: 14px;
	padding: 14px 14px 14px 16px;
	margin-bottom: 12px;
	box-shadow: 0 4px 10px rgba(0,0,0,.04);
}

.news-item:last-child{
	margin-bottom: 0;
}

.news-date{
	display: inline-block;
	margin-bottom: 8px;
	padding: 4px 10px;
	border-radius: 999px;
	background: var(--accent-light);
	color: var(--accent-dark);
	font-size: 11px;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: .05em;
}

.news-item h3{
	margin: 0 0 7px;
	font-size: 18px;
	line-height: 1.2;
}

.news-item p{
	margin: 0;
	color: var(--muted);
	font-size: 14px;
	line-height: 1.65;
}

/* Games */
.day-block{
	margin-bottom: 14px;
	border: 1px solid var(--border);
	border-radius: 14px;
	overflow: hidden;
	background: #fff;
	box-shadow: 0 4px 10px rgba(0,0,0,.04);
}

.day-block:last-child{
	margin-bottom: 0;
}

.day-title{
	padding: 10px 12px;
	background: linear-gradient(135deg, var(--black) 0%, #2a2f39 100%);
	color: #fff;
	font-size: 12px;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: .08em;
	border-left: 5px solid var(--accent);
}

.games-table{
	width: 100%;
	border-collapse: collapse;
	font-size: 13px;
}

.games-table td{
	padding: 9px 8px;
	border-bottom: 1px solid #eceef2;
	font-weight: 600;
}

.games-table tr:nth-child(even){
	background: #fafbfc;
}

.time{
	width: 58px;
	color: var(--accent-dark);
	font-weight: 800;
	vertical-align: top;
	background: #fff7fa;
}

.score{
	width: 34px;
	text-align: right;
	font-weight: 800;
	color: var(--black-soft);
}

/* Footer */
.site-footer{
	display: flex;
	justify-content: space-between;
	gap: 16px;
	padding: 18px 6px 4px;
	color: var(--muted);
	font-size: 12px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .04em;
}

.site-footer a{
	color: var(--accent-dark);
}

.form-group{
	margin-bottom: 16px;
}

label{
	display: block;
	margin-bottom: 7px;
	font-size: 13px;
	font-weight: 700;
	color: var(--black-soft);
	text-transform: uppercase;
	letter-spacing: .05em;
}

input[type="text"],
input[type="email"],
input[type="password"]{
	width: 100%;
	height: 48px;
	padding: 0 14px;
	border: 1px solid var(--border);
	border-radius: 12px;
	background: #fff;
	font: inherit;
	color: var(--text);
	transition: .18s ease;
}

input:focus{
	outline: none;
	border-color: var(--accent);
	box-shadow: 0 0 0 4px rgba(230,30,115,.12);
}

.form-row{
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 14px;
	margin: 8px 0 20px;
}

.checkbox{
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 14px;
	color: var(--muted);
}

.checkbox input{
	accent-color: var(--accent);
}

.btn{
	display: inline-flex;
	padding: 0px 20px;
	align-items: center;
	justify-content: center;
	height: 50px;
	border: 0;
	border-radius: 14px;
	font: inherit;
	font-weight: 800;
	cursor: pointer;
	transition: .18s ease;
}

.btn.full {
	width: 100%;
}

.btn-primary{
	background: linear-gradient(135deg, var(--accent), var(--accent-dark));
	color: #fff;
	box-shadow: 0 10px 22px rgba(230,30,115,.22);
	text-transform: uppercase;
	letter-spacing: .06em;
}

.btn-primary:hover{
	transform: translateY(-1px);
	box-shadow: 0 14px 26px rgba(230,30,115,.28);
}

.error-message{
	margin-bottom: 16px;
	padding: 12px 14px;
	border-radius: 12px;
	background: #fff1f5;
	border: 1px solid #f4bfd3;
	color: #8d1d4a;
	font-size: 14px;
	font-weight: 600;
}

.success-message{
	margin-bottom: 16px;
	padding: 12px 14px;
	border-radius: 12px;
	background: #eefaf3;
	border: 1px solid #bfe8cf;
	color: #1f7a4d;
	font-size: 14px;
	font-weight: 600;
}

/* ===== ADMIN SUBNAV ===== */

.admin-subnav{
	margin-top: -10px; /* tucks nicely under nav */
	margin-bottom: 20px;
}

.admin-subnav-inner{
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 10px 14px;
	border-radius: 14px;
	background: linear-gradient(180deg, #1a1d24, #12141a);
	border: 1px solid #2a2f39;
	box-shadow: 0 6px 14px rgba(0,0,0,.10);
	flex-wrap: wrap;
	color: var(--text);
}

.admin-label{
	font-size: 11px;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: .08em;
	color: rgba(255,255,255,.55);
	margin-right: 6px;
}

.admin-subnav a{
	padding: 7px 12px;
	border-radius: 999px;
	font-size: 12px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .05em;
	color: #fff;
	background: rgba(255,255,255,.06);
	border: 1px solid rgba(255,255,255,.10);
	transition: .18s ease;
}

.admin-subnav a:hover,
.admin-subnav a.active {
	background: linear-gradient(135deg, var(--accent), var(--accent-dark));
	border-color: transparent;
	transform: translateY(-1px);
	box-shadow: 0 6px 14px rgba(230,30,115,.25);
}

.admin-subnav a.logout{
	margin-left: auto;
	background: rgba(230,30,115,.12);
	border-color: rgba(230,30,115,.35);
}

.admin-subnav a.logout:hover{
	background: linear-gradient(135deg, var(--accent), var(--accent-dark));
}

.admin-user{
	margin-left: auto;
	display: flex;
	align-items: center;
	gap: 10px;
}

.admin-username{
	font-size: 12px;
	font-weight: 700;
	color: rgba(255,255,255,.75);
	background: rgba(255,255,255,.06);
	border: 1px solid rgba(255,255,255,.10);
	padding: 6px 12px;
	border-radius: 999px;
}

/* ===== FORM SELECT (MATCH INPUT STYLE) ===== */

select{
	height: 48px;
	padding: 0 40px 0 14px; /* right padding for arrow */
	border: 1px solid var(--border);
	border-radius: 12px;
	background-color: #fff;

	font: inherit;
	color: var(--text);

	transition: .18s ease;
	cursor: pointer;
}

select.full {
	width: 100%;
}

/* focus state (same as inputs) */
select:focus{
	outline: none;
	border-color: var(--accent);
	box-shadow: 0 0 0 4px rgba(230,30,115,.12);
}

/* hover (optional but nice) */
select:hover{
	border-color: var(--accent);
}

.footer-credit{
	color: var(--accent);
	font-weight: 700;
	margin-left: 6px;
}

/* ===== SCHEDULE / GAME MANAGEMENT ===== */

.schedule-panel{
	margin-bottom: 20px;
}

.table-wrap{
	overflow-x: auto;
}

.manage-table{
	width: 100%;
	border-collapse: separate;
	border-spacing: 0;
	font-size: 14px;
	min-width: 960px;
	border: 1px solid var(--border);
	border-radius: 14px;
	overflow: hidden;
	background: #fff;
}

.manage-table thead th{
	padding: 12px 12px;
	background: #f3f5f8;
	color: var(--black-soft);
	font-size: 12px;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: .06em;
	border-bottom: 1px solid var(--border);
	border-right: 1px solid var(--border);
	white-space: nowrap;
}

.manage-table thead th:last-child{
	border-right: 0;
}

.manage-table tbody td{
	padding: 10px 12px;
	border-bottom: 1px solid #eceef2;
	border-right: 1px solid #eceef2;
	vertical-align: middle;
	background: #fff;
}

.manage-table tbody td:last-child{
	border-right: 0;
}

.manage-table tbody tr:nth-child(even):not(.add-row){
	background: #fafbfc;
}

.manage-table tbody tr:nth-child(even):not(.add-row) td{
	background: #fafbfc;
}

.manage-table tbody tr:hover:not(.add-row) td{
	background: #fff2f8;
}

.manage-table tbody tr:last-child td{
	border-bottom: 0;
}

.manage-table .actions-col{
	width: 90px;
	text-align: center;
	white-space: nowrap;
}

/* Add row */
.add-row td{
	background: #fff8fb;
	border-bottom: 2px solid var(--accent-light);
}

.add-row input[type="text"],
.add-row input[type="date"],
.add-row select{
	width: 100%;
	height: 40px;
	padding: 0 12px;
	border: 1px solid var(--border);
	border-radius: 10px;
	background: #fff;
	font: inherit;
	color: var(--text);
	transition: .18s ease;
}

.add-row input[type="text"]:focus,
.add-row input[type="date"]:focus,
.add-row select:focus{
	outline: none;
	border-color: var(--accent);
	box-shadow: 0 0 0 4px rgba(230,30,115,.12);
}

.add-row input[type="text"]{
	min-width: 70px;
	text-align: center;
}

.add-row select{
	padding-right: 40px;
	cursor: pointer;
}

/* Buttons / links */
.btn-table{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 56px;
	height: 40px;
	padding: 0 14px;
	border-radius: 10px;
	font-size: 13px;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: .05em;
	text-decoration: none;
	transition: .18s ease;
}

.btn-table-add{
	background: linear-gradient(135deg, var(--accent), var(--accent-dark));
	color: #fff;
	box-shadow: 0 8px 18px rgba(230,30,115,.22);
}

.btn-table-add:hover{
	transform: translateY(-1px);
	box-shadow: 0 10px 22px rgba(230,30,115,.28);
}

.table-link{
	color: var(--accent-dark);
	font-weight: 800;
	text-transform: uppercase;
	font-size: 12px;
	letter-spacing: .05em;
}

.table-link:hover{
	color: var(--accent);
	text-decoration: underline;
}

/* Mobile */
@media (max-width: 760px){
	.manage-table{
		font-size: 13px;
	}

	.manage-table thead th,
	.manage-table tbody td{
		padding: 9px 10px;
	}
}

/* =========================================================
   RESPONSIVE
========================================================= */

@media (max-width: 1080px){
	.home-grid{
		grid-template-columns: 1fr;
	}
}

@media (max-width: 760px){
	.header-top{
		flex-direction: column;
		align-items: flex-start;
	}

	.brand-copy h1{
		font-size: 25px;
	}

	.site-footer{
		flex-direction: column;
	}
}

@media (max-width: 560px){
	.form-row{
		flex-direction: column;
		align-items: flex-start;
	}
}