/**
 * Padel Kompet — Styles publics
 *
 * Palette inspirée de PadelKompet : violet principal, vert accent, gris neutres.
 * Compatible Divi — !important utilisé dans la section Auth pour contrer les overrides Divi.
 */

:root {
	--pk-primary: #7C5CFC;
	--pk-primary-dark: #5A3FD6;
	--pk-primary-light: #B8A5FF;
	--pk-accent: #A8E86C;
	--pk-accent-dark: #7BC42E;
	--pk-success: #22C55E;
	--pk-warning: #F59E0B;
	--pk-danger: #EF4444;
	--pk-info: #3B82F6;
	--pk-text: #1A1A2E;
	--pk-text-light: #6B7280;
	--pk-bg: #F8F9FA;
	--pk-bg-card: #FFFFFF;
	--pk-border: #E5E7EB;
	--pk-radius: 12px;
	--pk-radius-sm: 8px;
	--pk-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
	--pk-shadow-hover: 0 4px 16px rgba(124, 92, 252, 0.15);
	--pk-transition: 0.2s ease;
}

/* === LAYOUT === */

.pk-tournament-list,
.pk-live-scores,
.pk-standings,
.pk-score-entry,
.pk-registration-form {
	max-width: 1200px;
	margin: 0 auto;
	padding: 2rem 1rem;
	font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
	color: var(--pk-text);
}

/* === FILTRES === */

.pk-filters {
	margin-bottom: 2rem;
}

.pk-filter-form {
	display: flex;
	gap: 1rem;
	flex-wrap: wrap;
	align-items: center;
}

.pk-filter-select {
	padding: 0.6rem 1rem;
	border: 1px solid var(--pk-border);
	border-radius: var(--pk-radius-sm);
	background: var(--pk-bg-card);
	font-size: 0.9rem;
	color: var(--pk-text);
	cursor: pointer;
	transition: border-color var(--pk-transition);
}

.pk-filter-select:focus {
	border-color: var(--pk-primary);
	outline: none;
}

/* === GRILLE TOURNOIS === */

.pk-tournament-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
	gap: 1.5rem;
}

.pk-tournament-card {
	background: var(--pk-bg-card);
	border: 1px solid var(--pk-border);
	border-radius: var(--pk-radius);
	padding: 1.5rem;
	box-shadow: var(--pk-shadow);
	transition: box-shadow var(--pk-transition), transform var(--pk-transition);
}

.pk-tournament-card:hover {
	box-shadow: var(--pk-shadow-hover);
	transform: translateY(-2px);
}

.pk-card-header {
	display: flex;
	gap: 0.5rem;
	flex-wrap: wrap;
	margin-bottom: 0.75rem;
}

.pk-card-title {
	font-size: 1.15rem;
	font-weight: 700;
	margin: 0 0 0.75rem;
	line-height: 1.3;
}

.pk-card-title a {
	color: var(--pk-text);
	text-decoration: none;
	transition: color var(--pk-transition);
}

.pk-card-title a:hover {
	color: var(--pk-primary);
}

.pk-card-meta {
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
	margin-bottom: 1rem;
	font-size: 0.9rem;
	color: var(--pk-text-light);
}

/* === BADGES === */

.pk-badge {
	display: inline-block;
	padding: 0.2rem 0.6rem;
	border-radius: 20px;
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.03em;
}

.pk-badge-inscriptions {
	background: rgba(124, 92, 252, 0.12);
	color: var(--pk-primary);
}

.pk-badge-en_cours {
	background: rgba(34, 197, 94, 0.12);
	color: var(--pk-success);
}

.pk-badge-termine {
	background: rgba(107, 114, 128, 0.12);
	color: var(--pk-text-light);
}

.pk-badge-brouillon {
	background: rgba(245, 158, 11, 0.12);
	color: var(--pk-warning);
}

.pk-badge-level {
	background: rgba(168, 232, 108, 0.2);
	color: var(--pk-accent-dark);
}

.pk-badge-gender {
	background: rgba(59, 130, 246, 0.1);
	color: var(--pk-info);
}

/* === BOUTONS === */

.pk-btn {
	display: inline-block;
	padding: 0.6rem 1.2rem;
	border: none;
	border-radius: var(--pk-radius-sm);
	font-size: 0.9rem;
	font-weight: 600;
	cursor: pointer;
	text-decoration: none;
	text-align: center;
	transition: all var(--pk-transition);
	line-height: 1.4;
}

.pk-btn-primary {
	background: var(--pk-primary);
	color: #fff;
}

.pk-btn-primary:hover {
	background: var(--pk-primary-dark);
	color: #fff;
}

.pk-btn-large {
	padding: 0.8rem 2rem;
	font-size: 1rem;
}

.pk-btn-filter {
	background: var(--pk-bg);
	color: var(--pk-text);
	border: 1px solid var(--pk-border);
}

.pk-btn-filter:hover {
	background: var(--pk-primary);
	color: #fff;
	border-color: var(--pk-primary);
}

.pk-btn-score {
	background: var(--pk-success);
	color: #fff;
}

.pk-btn-score:hover {
	background: #16A34A;
}

.pk-btn-forfait {
	background: var(--pk-danger);
	color: #fff;
}

.pk-btn-forfait:hover {
	background: #DC2626;
}

/* === FORMULAIRES === */

.pk-form-group {
	margin-bottom: 1.25rem;
}

.pk-form-group label {
	display: block;
	margin-bottom: 0.4rem;
	font-weight: 600;
	font-size: 0.9rem;
	color: var(--pk-text);
}

.pk-input,
.pk-textarea {
	width: 100%;
	padding: 0.7rem 1rem;
	border: 1px solid var(--pk-border);
	border-radius: var(--pk-radius-sm);
	font-size: 0.95rem;
	color: var(--pk-text);
	background: var(--pk-bg-card);
	transition: border-color var(--pk-transition);
}

.pk-input:focus,
.pk-textarea:focus {
	border-color: var(--pk-primary);
	outline: none;
	box-shadow: 0 0 0 3px rgba(124, 92, 252, 0.1);
}

/* === LIVE SCORES === */

.pk-live-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 1.5rem;
}

.pk-live-header h3 {
	font-size: 1.3rem;
	margin: 0;
}

.pk-live-indicator {
	display: flex;
	align-items: center;
	gap: 0.4rem;
	padding: 0.3rem 0.8rem;
	background: rgba(239, 68, 68, 0.1);
	border-radius: 20px;
	font-size: 0.8rem;
	font-weight: 700;
	color: var(--pk-danger);
	animation: pk-pulse 2s infinite;
}

@keyframes pk-pulse {
	0%, 100% { opacity: 1; }
	50% { opacity: 0.5; }
}

/* === MATCH SCORE CARDS === */

.pk-match-score-card {
	background: var(--pk-bg-card);
	border: 1px solid var(--pk-border);
	border-radius: var(--pk-radius);
	padding: 1.25rem;
	margin-bottom: 1rem;
	transition: border-color var(--pk-transition);
}

.pk-match-score-card[data-statut="en_cours"] {
	border-left: 4px solid var(--pk-success);
}

.pk-match-score-card[data-statut="termine"],
.pk-match-score-card[data-statut="forfait"] {
	opacity: 0.7;
}

.pk-match-header {
	display: flex;
	gap: 0.5rem;
	align-items: center;
	margin-bottom: 0.75rem;
	font-size: 0.85rem;
}

.pk-match-teams {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 1rem;
	margin-bottom: 1rem;
	font-weight: 600;
	font-size: 1.05rem;
}

.pk-vs {
	color: var(--pk-text-light);
	font-weight: 400;
	font-size: 0.85rem;
}

.pk-score-inputs {
	display: flex;
	gap: 1rem;
	align-items: flex-end;
	flex-wrap: wrap;
}

.pk-set-score {
	display: flex;
	align-items: center;
	gap: 0.3rem;
}

.pk-set-score label {
	font-size: 0.8rem;
	color: var(--pk-text-light);
	margin-right: 0.3rem;
}

.pk-score-input {
	width: 50px;
	padding: 0.4rem;
	text-align: center;
	border: 2px solid var(--pk-border);
	border-radius: var(--pk-radius-sm);
	font-size: 1.1rem;
	font-weight: 700;
	transition: border-color var(--pk-transition);
}

.pk-score-input:focus {
	border-color: var(--pk-primary);
	outline: none;
}

.pk-final-score {
	display: flex;
	gap: 0.75rem;
	justify-content: center;
}

.pk-set-result {
	padding: 0.3rem 0.6rem;
	background: var(--pk-bg);
	border-radius: var(--pk-radius-sm);
	font-weight: 700;
	font-size: 1rem;
}

/* === STANDINGS TABLE === */

.pk-pool-group {
	margin-bottom: 2rem;
}

.pk-group-title {
	font-size: 1.1rem;
	font-weight: 700;
	color: var(--pk-primary);
	margin-bottom: 0.75rem;
}

.pk-standings-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.9rem;
}

.pk-standings-table th {
	background: var(--pk-bg);
	padding: 0.6rem 0.75rem;
	text-align: left;
	font-weight: 600;
	font-size: 0.8rem;
	text-transform: uppercase;
	color: var(--pk-text-light);
	border-bottom: 2px solid var(--pk-border);
}

.pk-standings-table td {
	padding: 0.6rem 0.75rem;
	border-bottom: 1px solid var(--pk-border);
}

.pk-standings-table tr.pk-qualified {
	background: rgba(168, 232, 108, 0.08);
}

.pk-standings-table tr:hover {
	background: rgba(124, 92, 252, 0.04);
}

/* === NOTICES === */

.pk-notice {
	padding: 1rem 1.5rem;
	border-radius: var(--pk-radius-sm);
	margin-bottom: 1rem;
}

.pk-notice p {
	margin: 0 0 0.5rem;
}

.pk-notice-info {
	background: rgba(59, 130, 246, 0.08);
	border-left: 4px solid var(--pk-info);
}

.pk-notice-success {
	background: rgba(34, 197, 94, 0.08);
	border-left: 4px solid var(--pk-success);
}

.pk-notice-warning {
	background: rgba(245, 158, 11, 0.08);
	border-left: 4px solid var(--pk-warning);
}

/* === PAGINATION === */

.pk-pagination {
	display: flex;
	gap: 0.5rem;
	justify-content: center;
	margin-top: 2rem;
}

.pk-page-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border-radius: var(--pk-radius-sm);
	text-decoration: none;
	color: var(--pk-text);
	background: var(--pk-bg-card);
	border: 1px solid var(--pk-border);
	font-weight: 600;
	transition: all var(--pk-transition);
}

.pk-page-link.active,
.pk-page-link:hover {
	background: var(--pk-primary);
	color: #fff;
	border-color: var(--pk-primary);
}

/* === LOADING === */

.pk-loading {
	text-align: center;
	padding: 2rem;
	color: var(--pk-text-light);
}

.pk-form-message {
	margin-top: 1rem;
	padding: 0.75rem 1rem;
	border-radius: var(--pk-radius-sm);
	font-size: 0.9rem;
}

.pk-form-message.success {
	background: rgba(34, 197, 94, 0.1);
	color: var(--pk-success);
}

.pk-form-message.error {
	background: rgba(239, 68, 68, 0.1);
	color: var(--pk-danger);
}

/* === DASHBOARDS === */

.pk-dashboard {
	max-width: 1100px;
	margin: 0 auto;
	padding: 2rem 1rem;
}

.pk-dash-header {
	display: flex;
	align-items: center;
	gap: 1.25rem;
	margin-bottom: 2rem;
	flex-wrap: wrap;
}

.pk-dash-avatar img {
	border-radius: 50%;
	border: 3px solid var(--pk-primary-light);
}

.pk-dash-user-info h2 {
	margin: 0 0 0.25rem;
	font-size: 1.5rem;
}

.pk-dash-user-info .pk-badge {
	margin-right: 0.5rem;
}

.pk-dash-club {
	font-size: 0.9rem;
	color: var(--pk-text-light);
}

.pk-dash-actions {
	margin-left: auto;
}

/* Stats grid */
.pk-dash-stats-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1rem;
	margin-bottom: 2rem;
}

.pk-stat-card {
	background: var(--pk-bg-card);
	border: 1px solid var(--pk-border);
	border-radius: var(--pk-radius);
	padding: 1.25rem;
	text-align: center;
	box-shadow: var(--pk-shadow);
}

.pk-stat-card.pk-stat-highlight {
	border-color: var(--pk-primary);
	background: rgba(124, 92, 252, 0.04);
}

.pk-stat-value {
	display: block;
	font-size: 2rem;
	font-weight: 800;
	color: var(--pk-primary);
	line-height: 1.2;
}

.pk-stat-highlight .pk-stat-value {
	color: var(--pk-success);
}

.pk-stat-label {
	display: block;
	font-size: 0.8rem;
	color: var(--pk-text-light);
	margin-top: 0.3rem;
	text-transform: uppercase;
	letter-spacing: 0.03em;
}

/* Sections */
.pk-dash-section {
	margin-bottom: 2.5rem;
}

.pk-dash-section h3 {
	font-size: 1.15rem;
	font-weight: 700;
	margin-bottom: 1rem;
	padding-bottom: 0.5rem;
	border-bottom: 2px solid var(--pk-border);
}

.pk-dash-urgent h3 {
	color: var(--pk-success);
	border-bottom-color: var(--pk-success);
}

/* Match list dans les dashboards */
.pk-dash-match-list {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}

.pk-dash-match-card {
	display: flex;
	justify-content: space-between;
	align-items: center;
	background: var(--pk-bg-card);
	border: 1px solid var(--pk-border);
	border-radius: var(--pk-radius-sm);
	padding: 1rem 1.25rem;
	transition: box-shadow var(--pk-transition);
}

.pk-dash-match-card:hover {
	box-shadow: var(--pk-shadow-hover);
}

.pk-dash-match-info {
	display: flex;
	flex-direction: column;
	gap: 0.2rem;
}

.pk-dash-match-tournament {
	font-size: 0.8rem;
	color: var(--pk-text-light);
}

.pk-dash-match-meta {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	font-size: 0.85rem;
	color: var(--pk-text-light);
}

/* Tournament list dans dashboard joueur */
.pk-dash-tournament-list {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 1rem;
}

.pk-dash-tournament-list .pk-tournament-card {
	padding: 1.25rem;
}

.pk-dash-tournament-list .pk-card-title {
	font-size: 1rem;
	margin-bottom: 0.5rem;
}

/* État vide */
.pk-dash-empty {
	text-align: center;
	padding: 3rem 2rem;
	background: var(--pk-bg-card);
	border: 2px dashed var(--pk-border);
	border-radius: var(--pk-radius);
}

.pk-dash-empty p {
	color: var(--pk-text-light);
	font-size: 1.05rem;
	margin-bottom: 1rem;
}

/* Login card */
.pk-dashboard-login {
	display: flex;
	justify-content: center;
	padding: 3rem 1rem;
}

.pk-login-card {
	background: var(--pk-bg-card);
	border: 1px solid var(--pk-border);
	border-radius: var(--pk-radius);
	padding: 3rem;
	text-align: center;
	max-width: 420px;
	box-shadow: var(--pk-shadow);
}

.pk-login-card h2 {
	margin: 0 0 0.5rem;
	color: var(--pk-primary);
}

.pk-login-card p {
	color: var(--pk-text-light);
	margin-bottom: 1.5rem;
}

/* === AUTH PAGE — SPLIT SCREEN LAYOUT === */

/* Container split plein écran */
.pk-auth-split {
	display: flex !important;
	min-height: 100vh !important;
	width: 100vw !important;
	margin-left: calc(-50vw + 50%) !important;
	overflow: hidden !important;
}

/* ——— PANNEAU GAUCHE : HERO ——— */
.pk-auth-hero {
	flex: 0 0 50% !important;
	background: linear-gradient(135deg, #1A1A2E 0%, #16162A 40%, #201A3A 100%) !important;
	color: #fff !important;
	display: flex !important;
	flex-direction: column !important;
	justify-content: center !important;
	padding: 4rem 3.5rem !important;
	position: relative !important;
	overflow: hidden !important;
}

.pk-auth-hero-content {
	position: relative !important;
	z-index: 2 !important;
}

.pk-auth-hero-badge {
	display: inline-block !important;
	background: rgba(124, 92, 252, 0.15) !important;
	color: var(--pk-primary-light) !important;
	padding: 0.4rem 1rem !important;
	border-radius: 20px !important;
	font-size: 0.85rem !important;
	font-weight: 500 !important;
	margin-bottom: 2rem !important;
	letter-spacing: 0.02em !important;
}

.pk-auth-hero-title {
	font-size: 3.5rem !important;
	font-weight: 800 !important;
	line-height: 1.1 !important;
	margin: 0 0 1.5rem !important;
	color: #fff !important;
}

.pk-auth-hero-title span {
	background: linear-gradient(135deg, var(--pk-primary) 0%, var(--pk-accent) 100%) !important;
	-webkit-background-clip: text !important;
	-webkit-text-fill-color: transparent !important;
	background-clip: text !important;
}

.pk-auth-hero-sub {
	color: rgba(255, 255, 255, 0.6) !important;
	font-size: 1.1rem !important;
	line-height: 1.6 !important;
	max-width: 400px !important;
	margin: 0 0 2.5rem !important;
}

/* Stats flottantes */
.pk-auth-hero-stats {
	display: flex !important;
	gap: 2rem !important;
}

.pk-auth-hero-stat {
	display: flex !important;
	flex-direction: column !important;
}

.pk-auth-hero-stat-value {
	font-size: 1.8rem !important;
	font-weight: 700 !important;
	color: #fff !important;
}

.pk-auth-hero-stat-label {
	font-size: 0.8rem !important;
	color: rgba(255, 255, 255, 0.5) !important;
	text-transform: uppercase !important;
	letter-spacing: 0.05em !important;
}

/* Cercles décoratifs */
.pk-auth-hero-decor {
	position: absolute !important;
	top: 0 !important;
	left: 0 !important;
	right: 0 !important;
	bottom: 0 !important;
	pointer-events: none !important;
	z-index: 1 !important;
}

.pk-auth-hero-circle {
	position: absolute !important;
	border-radius: 50% !important;
	border: 1px solid rgba(124, 92, 252, 0.12) !important;
}

.pk-auth-hero-circle-1 {
	width: 500px !important;
	height: 500px !important;
	top: -150px !important;
	right: -100px !important;
}

.pk-auth-hero-circle-2 {
	width: 350px !important;
	height: 350px !important;
	top: -80px !important;
	right: -30px !important;
	border-color: rgba(168, 232, 108, 0.08) !important;
}

.pk-auth-hero-circle-3 {
	width: 200px !important;
	height: 200px !important;
	bottom: 60px !important;
	left: -60px !important;
	border-color: rgba(124, 92, 252, 0.1) !important;
}

/* ——— PANNEAU DROIT : FORMULAIRE ——— */
.pk-auth-form-side {
	flex: 0 0 50% !important;
	background: #fff !important;
	display: flex !important;
	flex-direction: column !important;
}

/* Top bar (logo + lien) */
.pk-auth-topbar {
	display: flex !important;
	align-items: center !important;
	justify-content: space-between !important;
	padding: 1.5rem 3rem !important;
}

.pk-auth-logo {
	display: flex !important;
	align-items: center !important;
	gap: 0.5rem !important;
}

.pk-auth-logo-icon {
	font-size: 1.5rem !important;
}

.pk-auth-logo-text {
	font-size: 1.25rem !important;
	font-weight: 700 !important;
	color: var(--pk-text) !important;
}

.pk-auth-topbar-link {
	background: none !important;
	border: none !important;
	color: var(--pk-primary) !important;
	font-size: 0.95rem !important;
	font-weight: 600 !important;
	cursor: pointer !important;
	display: flex !important;
	align-items: center !important;
	gap: 0.4rem !important;
	transition: var(--pk-transition) !important;
}

.pk-auth-topbar-link:hover {
	color: var(--pk-primary-dark) !important;
}

/* Zone formulaire centrée */
.pk-auth-form-inner {
	flex: 1 !important;
	display: flex !important;
	flex-direction: column !important;
	justify-content: center !important;
	padding: 0 3rem 2rem !important;
	max-width: 440px !important;
	margin: 0 auto !important;
	width: 100% !important;
}

.pk-auth-form-inner.pk-auth-logged-in {
	text-align: center !important;
	align-items: center !important;
}

.pk-auth-form-title {
	font-size: 2rem !important;
	font-weight: 700 !important;
	color: var(--pk-text) !important;
	margin: 0 0 1.5rem !important;
}

.pk-auth-subtitle {
	color: var(--pk-text-light) !important;
	font-size: 0.95rem !important;
	margin: 0.5rem 0 0 !important;
}

.pk-auth-avatar {
	margin-bottom: 1rem !important;
}

.pk-auth-avatar img {
	border-radius: 50% !important;
	box-shadow: 0 4px 16px rgba(124, 92, 252, 0.2) !important;
}

.pk-auth-actions {
	display: flex !important;
	flex-direction: column !important;
	gap: 0.75rem !important;
	margin-top: 1.5rem !important;
	width: 100% !important;
	max-width: 320px !important;
}

/* Auth panels */
.pk-auth-panel {
	display: none !important;
}

.pk-auth-panel-active {
	display: block !important;
}

/* Auth form fields */
.pk-auth-form {
	display: flex !important;
	flex-direction: column !important;
	gap: 0.9rem !important;
}

.pk-auth-field input,
.pk-auth-field select {
	width: 100% !important;
	padding: 0.85rem 1rem !important;
	border: 1.5px solid #E5E7EB !important;
	border-radius: 28px !important;
	font-size: 0.95rem !important;
	color: var(--pk-text) !important;
	background: #fff !important;
	transition: var(--pk-transition) !important;
	box-sizing: border-box !important;
	outline: none !important;
}

.pk-auth-field input::placeholder {
	color: #B0B7C3 !important;
}

.pk-auth-field input:focus,
.pk-auth-field select:focus {
	border-color: var(--pk-primary) !important;
	box-shadow: 0 0 0 3px rgba(124, 92, 252, 0.08) !important;
}

.pk-auth-field-row {
	display: grid !important;
	grid-template-columns: 1fr 1fr !important;
	gap: 0.75rem !important;
}

/* Password toggle */
.pk-auth-password-wrap {
	position: relative !important;
}

.pk-auth-password-wrap input {
	padding-right: 3rem !important;
}

.pk-auth-toggle-pass {
	position: absolute !important;
	right: 12px !important;
	top: 50% !important;
	transform: translateY(-50%) !important;
	background: none !important;
	border: none !important;
	cursor: pointer !important;
	color: #B0B7C3 !important;
	padding: 4px !important;
	display: flex !important;
	align-items: center !important;
}

.pk-auth-toggle-pass:hover {
	color: var(--pk-primary) !important;
}

/* Password strength */
.pk-auth-password-strength {
	height: 3px !important;
	border-radius: 2px !important;
	margin-top: 0.35rem !important;
	background: #F3F4F6 !important;
	overflow: hidden !important;
}

.pk-auth-password-strength .pk-strength-bar {
	height: 100% !important;
	border-radius: 2px !important;
	transition: width 0.3s ease, background-color 0.3s ease !important;
}

/* Forgot password */
.pk-auth-forgot-row {
	text-align: left !important;
	margin-top: -0.25rem !important;
}

.pk-auth-forgot {
	color: var(--pk-primary) !important;
	text-decoration: none !important;
	font-size: 0.9rem !important;
	font-weight: 500 !important;
}

.pk-auth-forgot:hover {
	text-decoration: underline !important;
}

/* Options */
.pk-auth-options {
	font-size: 0.9rem !important;
}

.pk-auth-checkbox {
	display: flex !important;
	align-items: flex-start !important;
	gap: 0.5rem !important;
	cursor: pointer !important;
	line-height: 1.4 !important;
}

.pk-auth-checkbox input[type="checkbox"] {
	width: auto !important;
	margin: 3px 0 0 !important;
	flex-shrink: 0 !important;
}

.pk-auth-checkbox a {
	color: var(--pk-primary) !important;
}

/* Divider */
.pk-auth-divider {
	display: flex !important;
	align-items: center !important;
	gap: 1rem !important;
	margin: 1.25rem 0 !important;
	color: #B0B7C3 !important;
	font-size: 0.85rem !important;
}

.pk-auth-divider::before,
.pk-auth-divider::after {
	content: '';
	flex: 1 !important;
	height: 1px !important;
	background: #E5E7EB !important;
}

/* Google button */
.pk-btn-google {
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 0.75rem !important;
	padding: 0.8rem 1rem !important;
	background: #fff !important;
	border: 1.5px solid #E5E7EB !important;
	border-radius: 28px !important;
	font-size: 0.95rem !important;
	font-weight: 500 !important;
	color: var(--pk-text) !important;
	cursor: pointer !important;
	transition: var(--pk-transition) !important;
}

.pk-btn-google:hover {
	background: #FAFAFA !important;
	border-color: #D1D5DB !important;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06) !important;
}

/* Auth messages */
.pk-auth-message {
	padding: 0.75rem 1rem !important;
	border-radius: 12px !important;
	font-size: 0.9rem !important;
	margin-bottom: 1rem !important;
}

.pk-auth-message-error {
	background: #FEF2F2 !important;
	color: var(--pk-danger) !important;
	border: 1px solid #FECACA !important;
}

.pk-auth-message-success {
	background: #F0FDF4 !important;
	color: var(--pk-success) !important;
	border: 1px solid #BBF7D0 !important;
}

/* Conditional fields */
.pk-auth-conditional {
	transition: var(--pk-transition) !important;
}

/* Footer */
.pk-auth-footer {
	text-align: center !important;
	padding: 1.5rem 0 0 !important;
	margin-top: 2rem !important;
	color: #B0B7C3 !important;
	font-size: 0.8rem !important;
}

/* ——— BUTTONS ——— */
.pk-btn {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	padding: 0.7rem 1.5rem !important;
	border-radius: 28px !important;
	font-size: 0.95rem !important;
	font-weight: 600 !important;
	cursor: pointer !important;
	transition: var(--pk-transition) !important;
	text-decoration: none !important;
	border: none !important;
}

.pk-btn-lg {
	padding: 0.9rem 1.5rem !important;
	font-size: 1rem !important;
}

.pk-btn-primary {
	background: var(--pk-primary) !important;
	color: #fff !important;
}

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

.pk-btn-gradient {
	background: linear-gradient(135deg, var(--pk-primary) 0%, #9B6DFF 50%, var(--pk-accent) 100%) !important;
	color: #fff !important;
	border: none !important;
	box-shadow: 0 4px 16px rgba(124, 92, 252, 0.3) !important;
}

.pk-btn-gradient:hover {
	box-shadow: 0 6px 24px rgba(124, 92, 252, 0.45) !important;
	transform: translateY(-1px) !important;
}

.pk-btn-outline {
	background: transparent !important;
	color: var(--pk-primary) !important;
	border: 2px solid var(--pk-primary) !important;
}

.pk-btn-outline:hover {
	background: var(--pk-primary) !important;
	color: #fff !important;
}

.pk-btn-full {
	width: 100% !important;
}

/* === RESPONSIVE === */

@media (max-width: 981px) {
	.pk-tournament-grid {
		grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)) !important;
	}

	.pk-score-inputs {
		flex-direction: column !important;
		align-items: stretch !important;
	}

	.pk-set-score {
		justify-content: center !important;
	}

	.pk-dash-stats-grid {
		grid-template-columns: repeat(2, 1fr) !important;
	}

	.pk-dash-header {
		flex-direction: column !important;
		text-align: center !important;
	}

	.pk-dash-actions {
		margin-left: 0 !important;
	}

	.pk-dash-match-card {
		flex-direction: column !important;
		gap: 0.75rem !important;
		align-items: flex-start !important;
	}

	.pk-standings-table {
		display: block !important;
		overflow-x: auto !important;
	}

	/* Auth split → stacked */
	.pk-auth-split {
		flex-direction: column !important;
		min-height: auto !important;
	}

	.pk-auth-hero {
		flex: none !important;
		padding: 2.5rem 2rem !important;
		min-height: 300px !important;
	}

	.pk-auth-hero-title {
		font-size: 2.5rem !important;
	}

	.pk-auth-hero-stats {
		gap: 1.5rem !important;
	}

	.pk-auth-form-side {
		flex: none !important;
	}

	.pk-auth-topbar {
		padding: 1.25rem 1.5rem !important;
	}

	.pk-auth-form-inner {
		padding: 0 1.5rem 2rem !important;
	}
}

@media (max-width: 768px) {
	.pk-tournament-grid {
		grid-template-columns: 1fr !important;
	}

	.pk-filter-form {
		flex-direction: column !important;
	}

	.pk-filter-select {
		width: 100% !important;
	}

	.pk-match-teams {
		flex-direction: column !important;
		gap: 0.3rem !important;
		font-size: 0.95rem !important;
	}

	.pk-standings-table {
		font-size: 0.8rem !important;
	}

	.pk-standings-table th,
	.pk-standings-table td {
		padding: 0.4rem !important;
	}

	.pk-dash-stats-grid {
		grid-template-columns: repeat(2, 1fr) !important;
		gap: 0.75rem !important;
	}

	.pk-stat-value {
		font-size: 1.5rem !important;
	}

	.pk-dash-tournament-list {
		grid-template-columns: 1fr !important;
	}

	.pk-dash-match-meta {
		flex-wrap: wrap !important;
		gap: 0.5rem !important;
	}

	/* Auth mobile small */
	.pk-auth-hero {
		padding: 2rem 1.25rem !important;
		min-height: 220px !important;
	}

	.pk-auth-hero-title {
		font-size: 2rem !important;
	}

	.pk-auth-hero-sub {
		font-size: 0.95rem !important;
	}

	.pk-auth-hero-stats {
		flex-wrap: wrap !important;
		gap: 1rem !important;
	}

	.pk-auth-topbar {
		padding: 1rem !important;
	}

	.pk-auth-form-inner {
		padding: 0 1rem 1.5rem !important;
	}

	.pk-auth-form-title {
		font-size: 1.5rem !important;
	}

	.pk-auth-field-row {
		grid-template-columns: 1fr !important;
	}
}
