/* Ruleta Asistida — Frontend CSS — Olympia Brand */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;600;700;800;900&display=swap');

:root {
	--ol-dark:   #112131;
	--ol-navy:   #003366;
	--ol-blue:   #00AEEF;
	--ol-yellow: #FFD100;
	--ol-white:  #ffffff;
}

#ra-sandbox-bar {
	background: var(--ol-yellow);
	color: var(--ol-dark);
	text-align: center;
	padding: 8px;
	font-weight: 700;
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: 1px;
	margin-bottom: 16px;
	border-radius: 10px;
	font-family: 'Montserrat', sans-serif;
}

#ra-wrapper {
	max-width: 460px;
	margin: 40px auto;
	font-family: 'Montserrat', sans-serif;
}

.ra-card {
	background: var(--ol-dark);
	border-radius: 24px;
	padding: 36px 28px;
	box-shadow: 0 24px 64px rgba(0,0,0,0.45);
	border: 1px solid rgba(0,174,239,0.2);
	animation: ra-slidein 0.45s cubic-bezier(.34,1.56,.64,1);
}
@keyframes ra-slidein {
	from { transform: translateY(40px) scale(0.95); opacity: 0; }
	to   { transform: translateY(0)    scale(1);    opacity: 1; }
}

/* Header */
.ra-header { text-align: center; margin-bottom: 24px; }
.ra-logo   { font-size: 48px; display: block; margin-bottom: 8px; }
.ra-header h2 {
	margin: 0 0 6px;
	font-size: 22px;
	font-weight: 800;
	color: var(--ol-white);
	text-transform: uppercase;
	letter-spacing: 0.5px;
}
.ra-header p { margin: 0; color: var(--ol-blue); font-size: 13px; font-weight: 500; }

/* Formulario */
.ra-field { margin-bottom: 16px; }
.ra-field label {
	display: block;
	font-size: 12px;
	font-weight: 700;
	color: var(--ol-blue);
	text-transform: uppercase;
	letter-spacing: 0.5px;
	margin-bottom: 6px;
}
.ra-opcional { font-weight: 400; color: rgba(255,255,255,0.3); text-transform: none; letter-spacing: 0; }

.ra-field input {
	width: 100%;
	padding: 12px 16px;
	background: rgba(255,255,255,0.05);
	border: 1.5px solid rgba(0,174,239,0.3);
	border-radius: 10px;
	font-size: 15px;
	color: var(--ol-white);
	box-sizing: border-box;
	font-family: 'Montserrat', sans-serif;
	transition: border-color 0.2s;
}
.ra-field input::placeholder { color: rgba(255,255,255,0.25); }
.ra-field input:focus {
	outline: none;
	border-color: var(--ol-blue);
	background: rgba(0,174,239,0.06);
}
#ra-codigo {
	letter-spacing: 3px;
	font-family: 'Montserrat', monospace;
	font-size: 18px;
	font-weight: 700;
	text-transform: uppercase;
	text-align: center;
}

/* Error */
.ra-msg-error {
	padding: 10px 14px;
	border-radius: 8px;
	font-size: 13px;
	margin-bottom: 12px;
	background: rgba(185,28,28,0.15);
	color: #fca5a5;
	border: 1px solid rgba(185,28,28,0.3);
	font-weight: 600;
}

/* Botón principal */
.ra-btn {
	display: block;
	width: 100%;
	padding: 16px;
	background: var(--ol-yellow);
	color: var(--ol-dark);
	border: none;
	border-radius: 50px;
	font-size: 15px;
	font-weight: 800;
	font-family: 'Montserrat', sans-serif;
	letter-spacing: 1.5px;
	text-transform: uppercase;
	cursor: pointer;
	margin-top: 8px;
	transition: transform 0.2s, box-shadow 0.2s, background 0.2s;
	box-shadow: 0 6px 20px rgba(255,209,0,0.3);
}
.ra-btn:hover:not(:disabled) {
	background: #F2C600;
	transform: translateY(-2px);
	box-shadow: 0 10px 28px rgba(255,209,0,0.45);
}
.ra-btn:disabled { opacity: 0.5; cursor: not-allowed; transform: none; }

/* Rueda */
.ra-wheel-container {
	position: relative;
	text-align: center;
	margin: 4px 0 20px;
}
.ra-pointer {
	font-size: 28px;
	color: var(--ol-yellow);
	line-height: 1;
	margin-bottom: -4px;
	filter: drop-shadow(0 2px 6px rgba(0,0,0,0.4));
}
#ra-canvas {
	display: block;
	margin: 0 auto;
	border-radius: 50%;
	box-shadow:
		0 0 0 4px var(--ol-navy),
		0 0 0 8px var(--ol-blue),
		0 12px 40px rgba(0,0,0,0.5);
	max-width: 100%;
}

.ra-btn-girar {
	margin-top: 20px;
}

/* Resultado */
.ra-resultado {
	text-align: center;
	margin-top: 20px;
	animation: ra-fadein 0.5s ease;
}
@keyframes ra-fadein { from { opacity: 0; } to { opacity: 1; } }

.ra-resultado-icono   { font-size: 64px; margin-bottom: 10px; }
.ra-resultado-titulo  {
	font-size: 22px;
	font-weight: 800;
	color: var(--ol-white);
	margin: 0 0 8px;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}
.ra-resultado-mensaje { font-size: 14px; color: var(--ol-blue); margin: 0 0 16px; font-weight: 500; line-height: 1.5; }
.ra-resultado-nota    { font-size: 11px; color: rgba(255,255,255,0.35); margin: 0; }
.ra-sandbox-note      {
	background: var(--ol-yellow);
	color: var(--ol-dark);
	padding: 6px 12px;
	border-radius: 20px;
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 1px;
	margin-bottom: 12px;
	display: inline-block;
}

/* Responsive */
@media (max-width: 520px) {
	#ra-wrapper { margin: 16px; }
	.ra-card    { padding: 24px 16px; }
	#ra-canvas  { width: 300px !important; height: 300px !important; }
}
