/* ─────────────────────────────────────────────────────────────
   Coxinha Run — Frontend CSS
   Palette:
     --crp-primary   #E8921B  (golden orange)
     --crp-secondary #FFD000  (yellow)
     --crp-dark      #3D1A00  (deep brown)
     --crp-accent    #FF6B2B  (warm orange)
     --crp-light     #FFF5E6  (cream)
     --crp-white     #FFFFFF
     --crp-danger    #E53935
     --crp-success   #43A047
───────────────────────────────────────────────────────────── */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
	--crp-primary:    #E8921B;
	--crp-primary-d:  #C47510;
	--crp-secondary:  #FFD000;
	--crp-dark:       #3D1A00;
	--crp-dark-mid:   #5C2D00;
	--crp-accent:     #FF6B2B;
	--crp-light:      #FFF5E6;
	--crp-cream:      #FFF8EE;
	--crp-white:      #FFFFFF;
	--crp-danger:     #E53935;
	--crp-success:    #43A047;
	--crp-muted:      #9E7B5A;
	--crp-border:     #F0D5B0;
	--crp-radius:     12px;
	--crp-radius-lg:  20px;
	--crp-shadow:     0 4px 20px rgba(61,26,0,.12);
	--crp-shadow-lg:  0 8px 40px rgba(61,26,0,.2);
	--crp-font:       'Segoe UI', system-ui, -apple-system, sans-serif;
}

body.crp-page {
	font-family: var(--crp-font);
	background: var(--crp-cream);
	color: var(--crp-dark);
	min-height: 100vh;
	line-height: 1.6;
}

.crp-container {
	max-width: 960px;
	margin: 0 auto;
	padding: 24px 16px 48px;
}

/* ── Navigation ──────────────────────────────────────────── */
.crp-nav {
	display: flex;
	align-items: center;
	gap: 16px;
	background: var(--crp-dark);
	padding: 0 20px;
	height: 80px;    /* altura para logo grande */
	position: sticky;
	top: 0;
	z-index: 100;
	box-shadow: 0 2px 12px rgba(0,0,0,.3);
}

.crp-nav-brand {
	display: flex;
	align-items: center;
	text-decoration: none;
	white-space: nowrap;
}

.crp-nav-logo {
	height: 72px;   /* logo bem grande e visível */
	width: auto;
	display: block;
}

.crp-nav-links {
	display: flex;
	align-items: center;
	gap: 4px;
	margin-left: auto;
}

.crp-nav-links a {
	color: rgba(255,255,255,.8);
	text-decoration: none;
	padding: 6px 14px;
	border-radius: 8px;
	font-size: .9rem;
	font-weight: 500;
	transition: background .15s, color .15s;
}

.crp-nav-links a:hover,
.crp-nav-links a.active {
	background: rgba(255,255,255,.12);
	color: var(--crp-secondary);
}

.crp-nav-logout {
	color: rgba(255,120,80,.9) !important;
}

.crp-nav-toggle {
	display: none;
	margin-left: auto;
	background: none;
	border: 1px solid rgba(255,255,255,.3);
	color: #fff;
	padding: 6px 12px;
	border-radius: 6px;
	cursor: pointer;
	font-size: 1.1rem;
}

/* ── Buttons ─────────────────────────────────────────────── */
.crp-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	padding: 10px 24px;
	border-radius: var(--crp-radius);
	font-size: 1rem;
	font-weight: 700;
	text-decoration: none;
	cursor: pointer;
	border: 2px solid transparent;
	transition: transform .1s, box-shadow .15s, background .15s;
	white-space: nowrap;
}

.crp-btn:active { transform: translateY(1px); }

.crp-btn-primary {
	background: var(--crp-primary);
	color: var(--crp-white);
	border-color: var(--crp-primary-d);
	box-shadow: 0 4px 0 var(--crp-primary-d);
}
.crp-btn-primary:hover {
	background: #F5A030;
	box-shadow: 0 6px 0 var(--crp-primary-d);
	transform: translateY(-1px);
}
.crp-btn-primary:active {
	box-shadow: 0 1px 0 var(--crp-primary-d);
}

.crp-btn-secondary {
	background: var(--crp-secondary);
	color: var(--crp-dark);
	border-color: #C9A500;
	box-shadow: 0 4px 0 #C9A500;
}
.crp-btn-secondary:hover {
	background: #FFE033;
	box-shadow: 0 6px 0 #C9A500;
	transform: translateY(-1px);
}

.crp-btn-outline {
	background: transparent;
	color: var(--crp-primary);
	border-color: var(--crp-primary);
}
.crp-btn-outline:hover {
	background: var(--crp-primary);
	color: var(--crp-white);
}

.crp-btn-ghost {
	background: transparent;
	color: var(--crp-muted);
	border-color: var(--crp-border);
}
.crp-btn-ghost:hover {
	background: var(--crp-light);
	color: var(--crp-dark);
}

.crp-btn-full { width: 100%; }

.crp-btn-large {
	padding: 14px 36px;
	font-size: 1.15rem;
}

.crp-btn-small {
	padding: 5px 14px;
	font-size: .85rem;
}

.crp-btn-play {
	font-size: 1.1rem;
	padding: 12px 32px;
	animation: crp-pulse 2s ease-in-out infinite;
}

@keyframes crp-pulse {
	0%, 100% { box-shadow: 0 4px 0 var(--crp-primary-d); }
	50% { box-shadow: 0 4px 20px rgba(232,146,27,.6); }
}

/* ── Cards ───────────────────────────────────────────────── */
.crp-card {
	background: var(--crp-white);
	border-radius: var(--crp-radius-lg);
	padding: 28px;
	box-shadow: var(--crp-shadow);
	border: 1px solid var(--crp-border);
}

/* ── Forms ───────────────────────────────────────────────── */
.crp-form {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.crp-field {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.crp-field label {
	font-weight: 600;
	font-size: .9rem;
	color: var(--crp-dark-mid);
}

.crp-field small {
	font-size: .8rem;
	color: var(--crp-muted);
}

.crp-field input {
	padding: 12px 16px;
	border: 2px solid var(--crp-border);
	border-radius: var(--crp-radius);
	font-size: 1rem;
	font-family: var(--crp-font);
	color: var(--crp-dark);
	background: var(--crp-white);
	transition: border-color .2s, box-shadow .2s;
	width: 100%;
}

.crp-field input:focus {
	outline: none;
	border-color: var(--crp-primary);
	box-shadow: 0 0 0 3px rgba(232,146,27,.2);
}

.crp-input-with-status {
	position: relative;
}

.crp-input-with-status input {
	padding-right: 44px;
}

.crp-nick-indicator {
	position: absolute;
	right: 14px;
	top: 50%;
	transform: translateY(-50%);
	font-size: 1.2rem;
}

/* ── Messages ────────────────────────────────────────────── */
.crp-messages {
	padding: 12px 16px;
	border-radius: var(--crp-radius);
	font-size: .9rem;
	font-weight: 500;
	display: none;
}

.crp-messages.crp-msg-error {
	display: block;
	background: #FFEBEE;
	border: 1px solid #FFCDD2;
	color: var(--crp-danger);
}

.crp-messages.crp-msg-success {
	display: block;
	background: #E8F5E9;
	border: 1px solid #C8E6C9;
	color: var(--crp-success);
}

/* ── Tables ──────────────────────────────────────────────── */
.crp-table {
	width: 100%;
	border-collapse: collapse;
	font-size: .9rem;
}

.crp-table th,
.crp-table td {
	padding: 10px 14px;
	text-align: left;
	border-bottom: 1px solid var(--crp-border);
}

.crp-table th {
	background: var(--crp-light);
	font-weight: 700;
	color: var(--crp-dark-mid);
	font-size: .8rem;
	text-transform: uppercase;
	letter-spacing: .5px;
}

.crp-table tr:last-child td { border-bottom: none; }

.crp-table tr:hover td { background: rgba(232,146,27,.04); }

.crp-score-cell {
	font-weight: 700;
	color: var(--crp-primary);
	font-size: 1rem;
}

/* ── Badges ──────────────────────────────────────────────── */
.crp-badge {
	display: inline-block;
	padding: 2px 10px;
	border-radius: 100px;
	font-size: .78rem;
	font-weight: 700;
}

.crp-badge-success {
	background: #E8F5E9;
	color: var(--crp-success);
}

.crp-badge-danger {
	background: #FFEBEE;
	color: var(--crp-danger);
}

/* ── Login Page ──────────────────────────────────────────── */
.crp-login-page {
	background: linear-gradient(135deg, var(--crp-dark) 0%, var(--crp-dark-mid) 100%);
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 100vh;
	padding: 20px;
}

.crp-login-wrapper {
	width: 100%;
	max-width: 440px;
}

.crp-login-box {
	background: var(--crp-white);
	border-radius: var(--crp-radius-lg);
	padding: 40px;
	box-shadow: var(--crp-shadow-lg);
}

.crp-login-logo {
	text-align: center;
	margin-bottom: 28px;
}

.crp-login-logo img {
	height: 80px;
	width: auto;
	margin-bottom: 8px;
}

.crp-logo-text {
	font-size: 1.6rem;
	color: var(--crp-dark);
	font-weight: 900;
}

.crp-login-logo p {
	color: var(--crp-muted);
	font-size: .9rem;
	margin-top: 4px;
}

.crp-login-footer {
	text-align: center;
	margin-top: 20px;
	font-size: .85rem;
	color: var(--crp-muted);
}

.crp-login-footer a {
	color: var(--crp-primary);
	text-decoration: none;
	font-weight: 600;
}

.crp-login-footer a:hover { text-decoration: underline; }
.crp-sep { margin: 0 8px; }

/* ── Dashboard ───────────────────────────────────────────── */
.crp-dashboard-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	margin-bottom: 28px;
	flex-wrap: wrap;
}

.crp-dashboard-greeting h2 {
	font-size: 1.6rem;
	color: var(--crp-dark);
}

.crp-nickname {
	color: var(--crp-primary);
}

.crp-no-access-msg {
	color: var(--crp-muted);
	font-size: .9rem;
	margin-top: 4px;
}

.crp-stats-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 16px;
	margin-bottom: 24px;
}

.crp-stat-card {
	background: var(--crp-white);
	border-radius: var(--crp-radius-lg);
	padding: 20px;
	display: flex;
	align-items: center;
	gap: 16px;
	box-shadow: var(--crp-shadow);
	border: 1px solid var(--crp-border);
	transition: transform .15s, box-shadow .15s;
}

.crp-stat-card:hover {
	transform: translateY(-2px);
	box-shadow: var(--crp-shadow-lg);
}

.crp-stat-icon {
	font-size: 2rem;
	line-height: 1;
}

.crp-stat-info {
	display: flex;
	flex-direction: column;
}

.crp-stat-label {
	font-size: .78rem;
	color: var(--crp-muted);
	text-transform: uppercase;
	letter-spacing: .5px;
	font-weight: 600;
}

.crp-stat-value {
	font-size: 1.5rem;
	font-weight: 900;
	color: var(--crp-dark);
	line-height: 1.2;
}

.crp-dashboard-nav-cards {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 12px;
	margin-bottom: 28px;
}

.crp-nav-card {
	background: var(--crp-white);
	border: 2px solid var(--crp-border);
	border-radius: var(--crp-radius-lg);
	padding: 20px;
	text-align: center;
	text-decoration: none;
	color: var(--crp-dark);
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	font-size: 1.4rem;
	transition: border-color .15s, background .15s;
}

.crp-nav-card strong {
	font-size: .9rem;
	font-weight: 700;
}

.crp-nav-card:hover {
	border-color: var(--crp-primary);
	background: var(--crp-light);
	color: var(--crp-dark);
}

/* Dashboard logo ao lado do texto */
.crp-greeting-row {
	display: flex;
	align-items: center;
	gap: 14px;
	flex-wrap: wrap;
}
.crp-dash-logo-img { height: 48px; width: auto; flex-shrink: 0; }

/* Nickname card */
.crp-nickname-card {
	max-width: 500px;
	margin: 40px auto;
	text-align: center;
}

.crp-card-icon {
	font-size: 3rem;
	margin-bottom: 8px;
}

.crp-nickname-card h2 {
	font-size: 1.5rem;
	margin-bottom: 8px;
}

.crp-nickname-card p {
	color: var(--crp-muted);
	margin-bottom: 24px;
}

/* Recent scores */
.crp-recent-scores h3 {
	font-size: 1.1rem;
	margin-bottom: 16px;
	color: var(--crp-dark);
}

/* ── Ranking Page ────────────────────────────────────────── */
.crp-ranking-header {
	text-align: center;
	margin-bottom: 28px;
}

.crp-ranking-header h1 {
	font-size: 2rem;
	font-weight: 900;
}

.crp-ranking-subtitle {
	color: var(--crp-muted);
	font-size: .9rem;
	margin-top: 4px;
}

.crp-my-position {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	background: var(--crp-primary);
	color: var(--crp-white);
	padding: 10px 24px;
	border-radius: 100px;
	margin-top: 12px;
	font-size: .9rem;
	font-weight: 600;
	flex-wrap: wrap;
	justify-content: center;
}

.crp-my-pos-rank { font-size: 1.2rem; font-weight: 900; }
.crp-my-pos-score { opacity: .85; }

.crp-ranking-table-wrap {
	background: var(--crp-white);
	border-radius: var(--crp-radius-lg);
	overflow: hidden;
	box-shadow: var(--crp-shadow);
	border: 1px solid var(--crp-border);
	margin-bottom: 24px;
}

.crp-ranking-table th,
.crp-ranking-table td {
	padding: 14px 16px;
}

.crp-col-pos { width: 80px; text-align: center; }
.crp-col-score { text-align: right; font-weight: 700; color: var(--crp-primary); }

.crp-rank-gold   { background: linear-gradient(90deg, rgba(255,215,0,.15) 0%, transparent 60%); }
.crp-rank-silver { background: linear-gradient(90deg, rgba(192,192,192,.15) 0%, transparent 60%); }
.crp-rank-bronze { background: linear-gradient(90deg, rgba(205,127,50,.12) 0%, transparent 60%); }
.crp-rank-top10  { background: rgba(232,146,27,.04); }
.crp-rank-me     { outline: 2px solid var(--crp-primary); outline-offset: -2px; }

.crp-pos-num { font-weight: 700; color: var(--crp-muted); }

.crp-you-tag {
	display: inline-block;
	background: var(--crp-primary);
	color: #fff;
	font-size: .7rem;
	font-weight: 700;
	padding: 1px 8px;
	border-radius: 100px;
	margin-left: 6px;
	vertical-align: middle;
}

.crp-ranking-cta {
	text-align: center;
	padding: 32px;
	background: var(--crp-white);
	border-radius: var(--crp-radius-lg);
	border: 2px dashed var(--crp-border);
}

.crp-ranking-cta h3 { font-size: 1.2rem; margin-bottom: 8px; }
.crp-ranking-cta p  { color: var(--crp-muted); margin-bottom: 16px; }

/* ── Account Page ────────────────────────────────────────── */
.crp-account-page h1 {
	font-size: 1.8rem;
	margin-bottom: 24px;
}

.crp-account-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 20px;
	margin-bottom: 24px;
}

.crp-account-card h2 {
	font-size: 1rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .5px;
	color: var(--crp-muted);
	margin-bottom: 16px;
	padding-bottom: 12px;
	border-bottom: 2px solid var(--crp-border);
}

.crp-dl {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 8px 16px;
	font-size: .9rem;
}

.crp-dl dt {
	color: var(--crp-muted);
	font-weight: 600;
	white-space: nowrap;
}

.crp-dl dd { font-weight: 500; }

.crp-card-action { margin-top: 20px; }

.crp-link-inline {
	color: var(--crp-primary);
	font-size: .85rem;
	margin-left: 8px;
}

.crp-account-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
}

/* ── No access ───────────────────────────────────────────── */
.crp-no-access-card {
	text-align: center;
	max-width: 480px;
	margin: 60px auto;
}

.crp-no-access-card h2 { font-size: 1.4rem; margin: 12px 0 8px; }
.crp-no-access-card p { color: var(--crp-muted); margin-bottom: 24px; }

/* ── Login tabs ──────────────────────────────────────────── */
.crp-login-logo {
	text-align: center;
	margin-bottom: 20px;
}

.crp-login-logo img {
	height: 64px;
	width: auto;
}

.crp-login-tabs {
	display: flex;
	border-bottom: 2px solid var(--crp-border);
	margin-bottom: 20px;
	gap: 0;
}

.crp-tab-btn {
	flex: 1;
	background: none;
	border: none;
	padding: 10px 16px;
	font-size: .95rem;
	font-weight: 700;
	color: var(--crp-muted);
	cursor: pointer;
	border-bottom: 3px solid transparent;
	margin-bottom: -2px;
	transition: color .15s, border-color .15s;
}

.crp-tab-btn.active {
	color: var(--crp-primary);
	border-bottom-color: var(--crp-primary);
}

.crp-tab-panel[hidden] { display: none; }

.crp-register-info {
	text-align: center;
	padding: 8px 0;
}

.crp-register-icon { font-size: 3rem; margin-bottom: 8px; }

.crp-register-info h3 {
	font-size: 1.2rem;
	margin-bottom: 8px;
	color: var(--crp-dark);
}

.crp-register-info p {
	color: var(--crp-muted);
	font-size: .9rem;
	margin-bottom: 20px;
}

.crp-register-note {
	margin-top: 14px !important;
	font-size: .78rem !important;
	color: var(--crp-muted) !important;
}

/* ── Ranking: Apoio column ───────────────────────────────── */
.crp-col-apoio {
	text-align: right;
	font-weight: 700;
	color: var(--crp-success);
	font-size: .85rem;
}

/* ── Empty state ─────────────────────────────────────────── */
.crp-empty {
	text-align: center;
	color: var(--crp-muted);
	padding: 32px !important;
	font-style: italic;
}

/* ── Loading spinner ─────────────────────────────────────── */
.crp-loading-spinner {
	text-align: center;
	padding: 24px;
	color: var(--crp-muted);
	font-size: .9rem;
}

/* ── Responsive ──────────────────────────────────────────── */
@media (max-width: 640px) {
	.crp-nav-links {
		display: none;
		flex-direction: column;
		position: absolute;
		top: 60px;
		left: 0;
		right: 0;
		background: var(--crp-dark);
		padding: 12px;
		gap: 4px;
		z-index: 99;
	}

	.crp-nav-links.is-open { display: flex; }
	.crp-nav-toggle { display: block; }

	.crp-nav-links a {
		display: block;
		padding: 10px 16px;
	}

	.crp-dashboard-header {
		flex-direction: column;
		align-items: flex-start;
	}

	.crp-login-box { padding: 24px 20px; }

	.crp-stats-grid {
		grid-template-columns: 1fr 1fr;
	}

	.crp-my-position { flex-direction: column; gap: 4px; }

	.crp-account-actions { flex-direction: column; }
	.crp-account-actions .crp-btn { text-align: center; }
}
