@font-face {
	font-family: MontMd;
	src: url('fonts/Montserrat-Medium.ttf') format('truetype');
	font-weight: normal;
	font-style: normal;
}

@font-face {
	font-family: MontBd;
	src: url('fonts/Montserrat-Bold.ttf') format('truetype');
	font-weight: bold;
	font-style: normal;
}

@import url(https://fonts.googleapis.com/css?family=Quicksand);

html {
	--scrollbarBG: #343a40;
	--thumbBG: #666;
}

body,
html,
.all {
	margin: 0;
	padding: 0;
}

body,
a,
a:active,
a:visited,
a:link {
	font-family: MontMd;
	font-size: 13px;
	text-decoration: none;
}

a,
a:active,
a:visited,
a:link {
	cursor: pointer;
	font-weight: bold;
}

p {
	margin: 0;
	padding: 0;
}

.pddInner {
	padding: 0 20px;
}

hr {
	width: 100%;
	height: 2px;
	padding: 0;
	margin: 20px auto;
	border: 0;
	background: transparent url('../imgs/separator.png') no-repeat center top;
}

h1 {
	display: block;
	text-shadow: 1px 1px 0 rgba(255, 255, 255, 0.3);
	font-weight: normal;
	padding: 0;
	width: 80%;
	margin: 24px auto 16px;
}

h1 a {
	float: right;
	display: block;
}

h2 {
	text-shadow: 1px 1px 0 rgba(255, 255, 255, 0.3);
	font-weight: normal;
	padding: 0;
	margin: 30px 0 20px 20px;
}

p.cbold {
	font-weight: bold;
	text-align: center;
	width: 100%;
	padding: 10px 0;
	text-transform: uppercase;
}

.rmsg {
	display: table;
	width: 348px;
	margin: 0 auto 20px auto;
	padding: 10px;
	background: #108c00;
	border-radius: 5px;
	text-align: center;
	color: #fff;
	font-size: 14px;
	box-sizing: border-box;
}

.rmsg.error {
	background-color: #b30000 !important;
}

.rmsg.warn {
	background-color: #fa713b !important;
	color: #000 !important;
}

.accept-rules-label {
	display: table;
	width: 348px;
	margin: 0 auto 16px;
	padding: 10px 14px;
	box-sizing: border-box;
	cursor: pointer;
	font-size: 13px;
	color: #000;
	background: #fa713b;
	border: 2px solid #f16c13;
	border-radius: 5px;
	text-align: left;
	user-select: none;
}

.accept-rules-label input[type="checkbox"] {
	margin-right: 8px;
	vertical-align: middle;
	cursor: pointer;
	width: 15px;
	height: 15px;
}

.accept-rules-label b {
	vertical-align: middle;
}

#alerta {
	visibility: hidden;
	position: fixed;
	display: table;
	z-index: 1001;
	margin: 0 auto;
	padding: 25px 30px;
	color: #5a5a5a;
	font-size: 15px;
	background: #f7f7f7;
	border-radius: 6px;
}

#alerta .ok {
	display: table;
	width: 100%;
}

#alerta .ok>div {
	font-size: 12px;
	font-weight: bold;
	cursor: pointer;
	display: table;
	float: right;
	margin: 15px 0 0 0;
	padding: 5px 0;
	text-align: center;
	width: 60px;
	text-transform: uppercase;
	color: #fff;
	background: #ac0f0f;
	border: 1px solid #ac0f0f;
	box-shadow: 0 1px 0 rgba(255, 255, 255, 0.2) inset;
	border-radius: 4px;
}

#alerta .ok>div:hover {
	background: #d21818;
	border-color: #d21818;
}

#alerta .ok.sucesso>div {
	background: #0dbb00;
	border: 1px solid #0dbb00;
}

#alerta .ok.sucesso>div:hover {
	background: #0a8c00;
	border: 1px solid #0a8c00;
}

#backblack {
	height: 100%;
	width: 100%;
	position: fixed;
	top: 0;
	left: 0;
	background: #000;
	opacity: 0.8;
	z-index: 1000;
}

input.default.sucesso {
	background: #0dbb00 !important;
	border-color: #0dbb00 !important;
	color: #fff !important;
}

body {
	background: url('../imgs/bg-top.jpg') no-repeat center top;
	background-color: #210d02;
	color: #000;
	scrollbar-width: thin;
	scrollbar-color: var(--thumbBG) var(--scrollbarBG);
}

a,
a:active,
a:visited,
a:link {
	color: #f04200;
}

body::-webkit-scrollbar {
	width: 11px;
}

body::-webkit-scrollbar-track {
	background: var(--scrollbarBG);
}

body::-webkit-scrollbar-thumb {
	background-color: var(--thumbBG);
	border-radius: 6px;
	border: 3px solid var(--scrollbarBG);
}

a:hover {
	color: #2d2d2d;
}

a:active {
	color: #ffe745;
}

h1 {
	font-family: MontBd;
	font-size: 26px;
	color: #353535;
}

h1 a {
	font-family: MontMd !important;
	font-size: 15px !important;
	padding: 17px 0 0;
}

h2 {
	font-family: MontMd;
	font-size: 23px;
	color: #353535;
}

.langs {
	z-index: 2;
	position: absolute;
	width: 140px;
	height: 34px;
}

.langs .bg {
	opacity: 0.3;
	width: 138px;
	height: 34px;
	border-radius: 4px;
}

.langs .links {
	position: absolute;
	left: 4px;
	top: 4px;
	display: table;
}

.langs a {
	float: left;
	display: block;
	width: 42px;
	height: 26px;
	margin: 0 2px 0 0;
	background: transparent url('../imgs/langs.png') no-repeat;
}

.langs a.en {
	background-position: 0 0;
	border-radius: 3px 0 0 3px;
}

.langs a.pt {
	background-position: -44px 0;
}

.langs a.es {
	background-position: -88px 0;
	border-radius: 0 3px 3px 0;
}

.langs a.en:hover {
	background-position: 0 -28px;
}

.langs a.pt:hover {
	background-position: -44px -28px;
}

.langs a.es:hover {
	background-position: -88px -28px;
}

.langs a:active {
	opacity: 0.6;
}

.langs {
	top: 40px;
	right: 25%;
}

.langs .bg {
	background: #000;
}

main a.default,
a.default,
span.default,
input.default,
.rankings_options>div a {
	transition: background-color 0.25s ease, border-color 0.25s ease, color 0.25s ease;
	cursor: pointer;
	display: block;
	text-align: center;
	font-weight: bold;
	font-size: 12px;
	text-transform: uppercase;
	padding: 6px 0 5px 0;
	width: 178px;
	margin: 0 0 1px;
	border-radius: 3px;
	box-shadow: 0px 1px 0px rgba(255, 255, 255, 0.2) inset;
	font-family: Tahoma;
}

article .ucp a.default,
.ucp a.default,
.ucp span.default,
.ucp input.default {
	padding: 9px 0 10px 0;
}

article a.default:active,
a.default:active,
input.default:active,
span.default:active {
	opacity: 0.7;
}

a.default.dbig,
input.default.dbig {
	font-size: 16px;
	padding: 12px 35px 13px 35px;
	display: table;
	width: auto !important;
}

main a.default,
a.default,
span.default,
input.default,
.rankings_options>div a {
	background-color: #2a2a2a;
	border: 1px solid #1f1f1f;
	color: rgba(255, 255, 255, 0.8) !important;
}

main a.default:hover,
a.default:hover,
input.default:hover,
span.default:hover,
.rankings_options>div a:hover {
	background-color: #5a5a5a;
	border-color: #5a5a5a;
	color: #fff !important;
}

nav {
	position: absolute;
	left: 0;
	top: -84px;
	z-index: 3;
	width: 1010px;
	height: 84px;
	line-height: 49px;
	padding: 35px 0 0 0;
	display: table;
	background: transparent url('../imgs/menu.png') no-repeat;
}

nav div {
	display: table;
	margin: 0 auto;
}

nav a {
	float: left;
	display: table;
	padding: 0 12px;
	font-family: Calibri, Arial !important;
	font-size: 16px !important;
	font-weight: bold;
	text-transform: uppercase;
	color: #fff !important;
	text-shadow: 1px 1px 2px #000;
	background: transparent;
	transition: background 0.4s, text-shadow 0.4s;
}

nav a:hover {
	text-shadow: 0 0 10px #fff;
	background: rgba(255, 255, 255, 0.1);
}

nav a:active {
	text-shadow: 0 0 10px #000;
	background: #000;
}

.banner {
	height: 52vh;
	width: 100%;
}

.box {
	margin: 0 0 23px 0;
}

.box .title {
	font-family: Calibri, Arial;
	font-size: 16px;
	font-weight: bold;
	text-transform: uppercase;
	border-bottom: 4px solid #cb3800;
	position: relative;
	z-index: 2;
	width: 200px;
	margin: 0px 0 15px 0;
}

.box .ctt {
	padding: 0 10px;
}

.box.support a:hover {
	opacity: 0.7;
}

.box.support a:active {
	opacity: 1;
}

a.donateBanner {
	width: 180px;
	height: 83px;
	display: block;
	border-radius: 5px;
	transition: opacity 0.4s;
}

.pt a.donateBanner {
	background: transparent url('../imgs/donateb_PT.jpg') no-repeat center center;
	background-size: cover;
}

.en a.donateBanner {
	background: transparent url('../imgs/donateb_EN.jpg') no-repeat center center;
	background-size: cover;
}

.es a.donateBanner {
	background: transparent url('../imgs/donateb_ES.jpg') no-repeat center center;
	background-size: cover;
}

a.donateBanner:hover {
	opacity: 0.8;
}

a.donateBanner:active {
	opacity: 1;
}

a.supportBanner {
	width: 180px;
	height: 83px;
	display: block;
	border-radius: 5px;
	transition: opacity 0.4s;
}

.pt a.supportBanner {
	background: transparent url('../imgs/supportb_PT.jpg') no-repeat center center;
	background-size: cover;
}

.en a.supportBanner {
	background: transparent url('../imgs/supportb_EN.jpg') no-repeat center center;
	background-size: cover;
}

.es a.supportBanner {
	background: transparent url('../imgs/supportb_ES.jpg') no-repeat center center;
	background-size: cover;
}

a.supportBanner:hover {
	opacity: 0.8;
}

a.supportBanner:active {
	opacity: 1;
}

main {
	background-color: #FFF;
	position: relative;
	margin: 0 auto;
	max-width: 1010px;
	box-sizing: border-box;
	border-radius: 10px;
}

.main {
	font-size: 14px;
}

.slider {
	background-color: rgba(0, 0, 0, 0.4);
	box-sizing: border-box;
	border-radius: 10px;
	overflow: hidden;
	border: 2px solid rgba(0, 0, 0, 0.4);
}

.carousel-indicators {
	left: auto;
}

.carousel-indicators button {
	border-radius: 50%;
	width: 10px !important;
	height: 10px !important;
	background-color: rgba(20, 13, 11) !important;
	border: 2px solid #fff !important;
}

.carousel-control-prev,
.carousel-control-next,
.carousel-control-prev:visited,
.carousel-control-next:visited {
	opacity: 0.3;
}

.carousel-control-prev:hover,
.carousel-control-next:hover {
	opacity: 1.0;
}

.carousel-fade .carousel-item {
	opacity: 0;
	transition-duration: .6s;
	transition-property: opacity;
}

.carousel-fade .carousel-item.active,
.carousel-fade .carousel-item-next.carousel-item-left,
.carousel-fade .carousel-item-prev.carousel-item-right {
	opacity: 1;
}

.carousel-fade .active.carousel-item-left,
.carousel-fade .active.carousel-item-right {
	opacity: 0;
}

.carousel-fade .carousel-item-next,
.carousel-fade .carousel-item-prev,
.carousel-fade .carousel-item.active,
.carousel-fade .active.carousel-item-left,
.carousel-fade .active.carousel-item-prev {
	transform: translateX(0);
	transform: translate3d(0, 0, 0);
}

.news .title,
.newsPage .title {
	color: #f04200;
	font-size: 16px;
	font-weight: bold;
	overflow: hidden;
}

.news .title:hover,
.newsPage .title:hover {
	color: rgba(0, 0, 0, 0.8);
}

.news .text,
.newsPage .text {
	color: rgba(0, 0, 0, 0.8);
	font-size: 11px;
	min-height: 42px;
	overflow: hidden;
}

.news .date,
.newsPage .date {
	color: rgba(0, 0, 0, 0.6);
	font-weight: bold;
}

.news img {
	border-radius: 5px;
}

.news img:hover {
	opacity: 0.7;
}

.newsPage .list-group-item {
	border: 0;
	border-bottom: 1px solid rgba(255,255,255,0.1);
}


#modal {
	position: fixed;
	z-index: 2000;
	width: 380px;
	max-width: calc(100vw - 32px);
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	padding: 28px 30px 24px;
	box-sizing: border-box;
	text-align: center;
	background: #fff;
	color: #000;
	border-radius: 12px;
	box-shadow: 0 8px 40px rgba(0,0,0,0.45);
}

#modal h1 {
	text-align: center;
	width: 100%;
	margin: 0 0 8px;
	font-size: 20px !important;
	color: #000;
}

#modal p, #modal br { display: none; }

#modal .modal-desc {
	font-size: 13px;
	color: #555;
	margin: 0 0 18px;
}

#modal .g-recaptcha,
#modal > div[id^="recaptcha"] {
	margin: 0 auto 16px !important;
	display: table !important;
}

.indexRank {
	width: 100%;
	margin: 0 auto;
	font-size: 11px;
}

.indexRank div {
	width: 100%;
	height: 24px;
	line-height: 24px;
	background: transparent url('../imgs/separator.png') no-repeat center bottom;
	display: flex;
	align-items: center;
	gap: 4px;
	overflow: hidden;
}

.indexRank div .rank-name {
	flex: 1;
	min-width: 0;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.indexRank div .float-end {
	flex-shrink: 0;
	white-space: nowrap;
}

.faceIndex {
	width: 100%;
	overflow: hidden;
	background: transparent;
	text-align: center;
}

.faceIndex .fb-page,
.faceIndex .fb-page span,
.faceIndex .fb-page iframe {
	max-width: 100% !important;
}

.fb-page-name, 
.fb-page-link {
	color: #1877f2 !important;
}

.fb-page-name:hover,
.fb-page-link:hover {
	color: #1a1a1a !important;
}

.loginarea {
	position: relative;
}

.loginarea .error {
	margin: 0 auto 10px auto;
	padding: 4px;
	background: #b30000;
	border-radius: 4px;
	text-align: center;
	color: #fff;
	font-size: 11px;
}

.loginarea .loader {
	opacity: 0.8;
	width: 80px;
	height: 80px;
	background: #000 url('../imgs/nm/loader.gif') no-repeat center center;
	position: absolute;
	left: 49px;
	top: 16px;
	border-radius: 40px;
}

.loginarea .ess {
	display: block;
	padding: 6px 0 6px 0px;
}

.loginarea .ess a {
	font-size: 10px;
}

/* ── Login form: sidebar desktop ── */
.loginarea { position: relative; }
.loginarea form { width: 100%; }

.loginarea .error {
	margin: 0 0 8px;
	padding: 6px 10px;
	background: #b30000;
	border-radius: 4px;
	text-align: center;
	color: #fff;
	font-size: 11px;
}

.loginarea .loader {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 36px;
	height: 36px;
	background: transparent url('../imgs/nm/loader.gif') no-repeat center center;
	background-size: contain;
	opacity: 0.8;
	z-index: 2;
}

.login-inputs { display: none; }

.fieldsBox {
	position: relative;
	background: #b9b9b9;
	width: 178px;
	padding: 1px;
	border-radius: 5px;
}

.fieldsBox .inpt {
	outline: none;
	background: #f3f3f3;
	color: #000;
	font-size: 12px;
	border: 0;
	padding: 0 10px 0 28px;
	margin: 0;
	width: 176px;
	height: 28px;
	line-height: 28px;
	border-radius: 4px 4px 0 0;
	box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.1) inset;
}

.fieldsBox .inpt.pass {
	border-radius: 0 0 4px 4px;
	margin: 1px 0 0 0;
	padding: 0 70px 0 28px;
	width: 176px;
}

.fieldsBox .acc_icon {
	position: absolute;
	width: 11px;
	height: 11px;
}

.fieldsBox .acc_icon.user {
	left: 10px;
	top: 10px;
	background: transparent url('../imgs/login-icons.png') no-repeat 0 0;
}

.fieldsBox .acc_icon.pass {
	left: 10px;
	top: 39px;
	background: transparent url('../imgs/login-icons.png') no-repeat 0 -13px;
}

.fieldsBox .gologin {
	position: absolute;
	right: 0px;
	bottom: 1px;
	width: 60px;
	height: 28px;
	line-height: 24px;
	padding: 0;
	margin: 0;
	box-sizing: border-box;
	border: 0;
	font-size: 12px;
	font-family: Arial;
	text-transform: none;
	border-radius: 4px 0 4px 4px;
}

.loginarea .ess {
	display: block;
	padding: 4px 0;
	text-align: center;
}

.loginarea .ess a { font-size: 10px; }

.anpc {
	width: 100%;
	text-align: center;
	height: auto;
	line-height: 1.6;
	font-size: 10px;
	border-radius: 3px;
	padding: 3px 6px;
	margin-top: 2px;
	box-sizing: border-box;
}

.anpc a { font-size: 10px; }

.anpc, .logged { background: #ccc; color: #000; }

.logged {
	font-size: 11px;
	width: 100%;
	line-height: 1.6;
	padding: 4px 10px;
	box-sizing: border-box;
	text-align: center;
	margin: 0 0 10px;
	border-radius: 3px;
	background: #ccc;
	color: #000;
}

.logged span { font-weight: bold; font-size: 12px; }

.anpc,
.logged {
	background: #ccc;
	color: #000;
}

.sstatus {
	width: 180px;
	background: #efefef;
	padding: 9px 15px;
	border-radius: 8px;
	box-sizing: border-box;
}

.sstatus>div {
	font-size: 11px;
	font-weight: bold;
	width: 150px;
	height: 22px;
	line-height: 22px;
	box-sizing: border-box;
	color: #454545;
	padding: 0 9px;
	border-top: 1px solid #dedede;
}

.sstatus>div:first-child {
	border: 0;
}

.sstatus>div>div {
	float: right;
}

.sstatus>div>div.on,
.sstatus>div>span {
	color: #0e7a0b;
}

.sstatus>div>div.off {
	color: #b70000;
}

table.default {
	border-radius: 4px;
	box-shadow: 0 0 5px rgba(0, 0, 0, 0.3);
	width: 100%;
	background: 0;
	overflow: hidden;
}

table.default tr td:first-child {
	border: 0;
}

table.default tr td {
	font-size: 12px;
	padding: 6px 8px;
	border-left: 1px solid rgba(0, 0, 0, 0.1);
	background: rgba(0, 0, 0, 0.1);
}

table.default tr.two td {
	background: #fff;
}

table.default tr td.foco {
	font-weight: bold;
	color: #000;
	background: rgba(0, 0, 0, 0.2);
}

table.default tr.two td.foco {
	background: rgba(0, 0, 0, 0.1);
}

table.default tr th {
	font-weight: bold;
	text-align: center;
	background: rgba(0, 0, 0, 0.8);
	color: #fff;
	padding: 10px 0;
}

table.default tr.ctype2,
table.default tr.ctype2 td {
	padding: 0;
	margin: 0;
	height: 2px;
	background: rgba(0, 0, 0, 0.1);
}

table.default .pos {
	width: 25px;
	text-align: center;
}

.rulesbox {
	height: 260px;
	box-sizing: border-box;
	overflow: auto;
	margin: 0 auto 20px;
	padding: 20px;
	width: calc(100% - 20px);
	border: 2px solid rgba(0, 0, 0, 0.2);
	background: rgba(0, 0, 0, 0.1);
}

.rulesbox h1 {
	padding-top: 0;
	width: auto;
	height: auto;
	margin: 0;
	padding: 0 0 20px 20px;
	font-size: 20px;
}

.formpadrao,
.formpadrao>div,
.formpadrao .camp input,
.formpadrao .camp select {
	border-radius: 3px;
}

.formpadrao {
	display: table;
	margin: 0 auto 2px auto;
	padding: 2px;
}

.formpadrao>div {
	display: table;
}

.formpadrao .desc {
	width: 140px;
	padding: 0 10px;
	font-weight: bold;
	text-align: right;
}

.formpadrao .desc,
.formpadrao .camp,
.formpadrao .camp2 {
	float: left;
	height: 40px;
	line-height: 40px;
}

.formpadrao .camp input[type="text"],
.formpadrao .camp input[type="password"],
.formpadrao .camp input[type="file"] {
	border: 0;
	width: 200px;
	margin: 5px 5px 0 0;
	height: 30px;
	line-height: 30px;
	padding: 0 5px;
	box-shadow: 1px 1px 1px rgba(0, 0, 0, 0.4) inset;
}

.formpadrao .camp select {
	border: 0;
	width: 201px;
	margin: 5px 5px 0 0;
	padding: 6px 5px 5px;
	box-shadow: 1px 1px 1px rgba(0, 0, 0, 0.4) inset;
}

.formpadrao textarea {
	border: 0;
	resize: vertical;
	height: 300px;
	width: 200px;
	margin: 0 4px 10px 0;
	padding: 5px;
}

.formpadrao.tdate .camp input {
	text-align: center;
	padding: 0 9px;
}

.formpadrao.errorc,
.formpadrao.errorc .desc,
.formpadrao.errorc .camp {
	border-color: #c70000;
}

.formpadrao.errorc>div {
	background: #c70000;
}

.formpadrao.errorc .desc {
	color: #fff;
}

.formpadrao>div {
	background: #1c1c1c;
}

.formpadrao .desc {
	color: #fff;
}

.formpadrao .camp input[type="text"],
.formpadrao .camp input[type="password"],
.formpadrao .camp input[type="file"],
.formpadrao .camp select,
.formpadrao textarea {
	background: #fff;
}

.formpadrao .camp input[type="text"]:focus,
.formpadrao .camp input[type="password"]:focus,
.formpadrao .camp select:hover,
.formpadrao textarea:focus {
	background: #fffbd5;
}

label.captcha {
	position: relative;
}

label.captcha img.captchaImage {
	position: absolute;
	left: 8px;
	opacity: 0.8;
	border-radius: 3px;
}

label.captcha a {
	position: absolute;
	right: 12px;
	top: 12px;
}

label.captcha a,
label.captcha a img {
	width: 23px;
	height: 23px;
}

label.captcha a:hover {
	opacity: 0.7;
}

label.captcha a:active {
	opacity: 1;
}

.rankings_options {
	cursor: pointer;
	transition: background 0.5s, border-color 0.5s, color 0.5s;
	position: absolute;
	top: 20px;
	right: 28px;
	background: #f5f5f5;
	border: 1px solid rgba(0, 0, 0, 0.2);
	height: 34px;
	line-height: 34px;
	padding: 0 26px 0 10px;
	border-radius: 5px;
	text-transform: uppercase;
	font-size: 12px;
	font-weight: bold;
	color: rgba(0, 0, 0, 0.6);
}

.rankings_options .rankings_arrow {
	transition: opacity 0.5s;
	position: absolute;
	top: 15px;
	right: 10px;
	display: block;
	width: 10px;
	height: 6px;
	background: transparent url('../imgs/nm/rankings_arrow.png') no-repeat;
	opacity: 0.6;
}

.rankings_options:hover {
	background: rgba(0, 0, 0, 0.2);
	border-color: rgba(0, 0, 0, 0.4);
	color: rgba(0, 0, 0, 0.8);
}

.rankings_options:hover .rankings_arrow {
	opacity: 0.8;
}

.rankings_options>div {
	opacity: 0;
	transition: opacity 0.5s;
	width: 0px;
	height: 0px;
	overflow: hidden;
	position: absolute;
	top: 35px;
	right: 0;
	border-radius: 6px;
	box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.2);
}

.rankings_options>div a {
	line-height: normal;
	width: 150px !important;
	font-size: 10px !important;
	padding: 5px 0 !important;
}

.rankings_options:hover>div {
	width: auto !important;
	height: auto !important;
	opacity: 1;
	padding: 10px;
	background: #f5f5f5;
	border: 1px solid #dddddd;
	border-right: 0;
	border-bottom: 0;
}

.castled {
	width: 400px;
	margin: 0 auto;
}

.castled,
.castled>div {
	display: table;
}

.castled .ct {
	font-size: 16px;
	font-weight: bold;
	padding: 10px 0 10px 30px;
}

.castled .imgc {
	width: 200px;
	height: 113px;
	border: 1px solid rgba(0, 0, 0, 0.4);
	float: left;
	border-radius: 6px;
}

.castled .imgc span {
	display: block;
	width: 200px;
	height: 113px;
	background: rgba(0, 0, 0, 0.6) url('../imgs/nm/castles.jpg') no-repeat;
	border-radius: 5px;
}

.castled .ci {
	float: left;
	width: 188px;
	padding: 2px 0 0 10px;
}

.castled .ci .co {
	font-weight: bold;
}

.castled .ci .cc {
	margin-bottom: 8px;
}

.castled .nwar {
	padding: 5px 0 10px 0;
}

.castled .imgc.aden span {
	background-position: left top;
}

.castled .imgc.goddard span {
	background-position: -200px top;
}

.castled .imgc.giran span {
	background-position: -400px top;
}

.castled .imgc.oren span {
	background-position: -600px top;
}

.castled .imgc.dion span {
	background-position: -800px top;
}

.castled .imgc.gludio span {
	background-position: -1000px top;
}

.castled .imgc.innadril span {
	background-position: -1200px top;
}

.castled .imgc.rune span {
	background-position: -1400px top;
}

.castled .imgc.schuttgart span {
	background-position: -1600px top;
}

.horMenu {
	display: table;
	margin: 20px auto;
}

.horMenu a {
	float: left;
	padding: 10px 15px;
	border-bottom: 2px solid rgba(0, 0, 0, 0.5);
	margin: 0 0 0 10px;
	text-transform: uppercase;
	font-size: 12px;
	color: rgba(0, 0, 0, 0.6) !important;
}

.horMenu a:first-child {
	margin: 0;
}

.horMenu a:hover {
	border-color: #000 !important;
	color: #000 !important;
}

.horMenu a.act {
	cursor: default;
	border-color: #000 !important;
	color: #000 !important;
	text-shadow: 0 0 5px rgba(255, 255, 255, 0.6);
}

.horMenu a:active {
	opacity: 0.6;
}

footer {
	font-size: 14px;
	font-weight: bold;
	color: #fff;
}

footer .atualstudio {
	opacity: 0.3;
}

footer a.atualstudio:hover {
	opacity: 1;
}

#fanback {
	background: transparent url("../imgs/nm/fanbg.png") repeat;
	display: none;
	height: 100%;
	top: 0;
	left: 0;
	position: fixed;
	width: 100%;
	z-index: 99999;
}

#fan-exit {
	height: 100%;
	width: 100%;
}

#fanbox {
	background: #fff;
	border-left: 3px solid #1877f2;
	border-radius: 8px;
	box-sizing: border-box;
	left: 50%;
	padding: 20px;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 370px;
	max-width: calc(100vw - 30px);
}

#fanclose {
	color: #999;
	cursor: pointer;
	font-size: 22px;
	line-height: 1;
	position: absolute;
	right: 12px;
	top: 8px;
}

#fanclose:hover {
	color: #333;
}

#soon-glow {
	font-family: 'Quicksand', sans-serif;
	color: #000;
	background: transparent;
	text-transform: lowercase;
}

#soon-glow .soon-label {
	color: #000;
	text-shadow: 0 0 .25rem rgba(0, 0, 0, .75);
}

#soon-glow .soon-ring-progress {
	color: #000;
	background-color: rgba(0, 0, 0, .15);
}

#soon-glow>.soon-group {
	margin-bottom: -.5em;
}

.soon[data-face*="glow"] .soon-separator,
.soon[data-face*="glow"] .soon-slot-inner {
	text-shadow: 0 0 .125em rgba(0, 0, 0, .75);
}

.overlay ul {
	margin: 0;
	padding: 0;
	text-decoration: none;
	list-style: none;
}

.overlay li {
	padding: 0;
	margin: 0;
}

.mobile-menu-button .button {
	position: fixed;
	left: 12px;
	top: 12px;
	width: 44px;
	height: 44px;
	min-width: 44px;
	min-height: 44px;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	background: rgba(0,0,0,0.85);
	border: 1px solid rgba(255,255,255,0.2);
	border-radius: 8px;
	cursor: pointer;
	z-index: 999;
	padding: 0;
	margin: 0;
	box-sizing: border-box;
	-webkit-appearance: none;
	appearance: none;
	outline: none;
}

.mobile-menu-button .button:hover,
.mobile-menu-button .button:active,
.mobile-menu-button .button:focus {
	width: 44px;
	height: 44px;
	background: rgba(0,0,0,0.95);
	border: 1px solid rgba(255,255,255,0.2);
	border-radius: 8px;
	outline: none;
}

.mobile-menu-button a {
	color: #fff;
}

.btn-open:after {
	content: "\f0c9";
	font-family: "FontAwesome";
	font-size: 18px;
	transition: all 0.2s linear;
}

.btn-close:after {
	content: "\f00d";
	font-family: "FontAwesome";
	font-size: 18px;
	transition: all 0.2s linear;
}

.overlay {
	display: none;
	position: fixed;
	top: 0;
	height: 100%;
	width: 100%;
	background: #1a1a1a;
	overflow: auto;
	z-index: 99;
}

.wrap {
	color: #e9e9e9;
	text-align: center;
	max-width: 92%;
	margin: 0 auto;
	padding-top: 75px;
	padding-bottom: 40px;
}

.wrap ul.wrap-nav {
	border-bottom: 1px solid #575757;
	text-transform: capitalize;
	padding: 16px 0 16px;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 0;
}

.wrap ul.wrap-nav li {
	font-size: 18px;
	display: inline-block;
	vertical-align: top;
	width: 48%;
	position: relative;
	text-align: center;
}

.wrap ul.wrap-nav li a {
	color: #f16c13;
	display: block;
	padding: 10px 0 6px;
	text-decoration: none;
	transition: color 0.2s linear;
	font-size: 15px;
	font-weight: bold;
}

.wrap ul.wrap-nav li a:hover {
	color: #f0f0f0;
}

.wrap ul.wrap-nav ul {
	padding: 8px 0 12px;
}

.wrap ul.wrap-nav ul li {
	display: block;
	font-size: 13px;
	width: 100%;
	color: #e9e9e9;
}

.wrap ul.wrap-nav ul li a {
	color: #bbb;
	font-size: 13px;
	padding: 5px 0;
}

.wrap ul.wrap-nav ul li a:hover {
	color: #f16c13;
}

.wrap .logo img {
	width: 200px;
	opacity: 0.7;
}

@media only screen and (max-width:767px) {
	body {
		background-size: cover;
		background: url('../imgs/bg-mobile.png') no-repeat center top, url('../imgs/bg-bot.jpg') no-repeat center bottom;
		background-color: #210d02;
	}

	nav {
		max-width: 100%;
	}

	.banner {
		height: 346px;
	}

	.langs {
		right: 5%;
	}

	.faceIndex {
		max-width: 100%
	}
}

@media only screen and (min-width:767px) and (max-width:1366px) {
	.banner {
		height: 510px;
	}

	.langs {
		right: 10%;
	}
}

/* ============================================================
   MOBILE RESPONSIVE - Breakpoint Bootstrap LG (< 992px)
   ============================================================ */

@media only screen and (max-width: 991px) {

	/* --- Sidebar direita (server status, discord, donate) --- */
	.right {
		padding: 0 10px;
		margin-bottom: 16px;
	}

	.right .box {
		margin-bottom: 12px;
	}

	.right .sstatus {
		width: 100%;
		box-sizing: border-box;
	}

	.right a.donateBanner,
	.right a.supportBanner {
		width: 100%;
		max-width: 360px;
		height: 83px;
		display: block;
		background-size: cover;
		background-repeat: no-repeat;
		background-position: center center;
	}

	.right .galleryBox > div {
		display: flex;
		flex-wrap: wrap;
		gap: 4px;
	}

	.right .galleryBox > div a {
		flex: 1 1 calc(33.33% - 4px);
		min-width: 80px;
	}

	.right .galleryBox > div a img {
		width: 100%;
		height: auto;
	}

	/* Discord iframe responsivo */
	.right iframe[src*="discord"] {
		width: 100% !important;
		max-width: 100%;
		height: 240px;
	}

	/* --- Botões default --- */
	main a.default,
	a.default,
	span.default,
	input.default {
		max-width: 100%;
		box-sizing: border-box;
	}

	/* --- IndexRank (Top PvP/Pk mini) --- */
	.indexRank {
		width: 100%;
		box-sizing: border-box;
	}

	/* --- Formulário padrão (register, ucp, etc) --- */
	/* Mantém layout igual ao desktop: label à esquerda, input à direita */
	.formpadrao {
		max-width: 100%;
		overflow-x: auto;
	}

	/* --- Tabelas responsivas ---
	   NÃO mudar display:table (quebra renderização das células).
	   A estratégia correta é: .pddInner rola, table transborda. */
	table.default {
		width: auto;       /* Remove width:100% para poder transbordar o container */
		min-width: 100%;   /* Mas preenche o container quando o conteúdo for menor */
		overflow: visible; /* Permite o pai (.pddInner) rolar horizontalmente */
	}

	table.default td,
	table.default th {
		width: auto !important; /* Ignora style="width:300px" inline */
		font-size: 12px;
	}

	/* Container scrollável para tabelas e conteúdo largo */
	.pddInner {
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		padding: 0 4px; /* Reduz de 20px para não cortar espaço útil */
	}

	/* --- Alert centrado no mobile --- */
	#alerta {
		position: fixed;
		left: 50% !important;
		top: 50% !important;
		transform: translate(-50%, -50%);
		max-width: calc(100vw - 30px);
		width: auto;
		box-sizing: border-box;
		word-break: break-word;
	}

	/* --- Modal captcha --- */
	#modal {
		width: calc(100vw - 30px);
		left: 15px !important;
		top: 50% !important;
		transform: translateY(-50%);
		height: auto;
		padding-bottom: 20px;
	}

	/* --- Castle siege cards --- */
	.castled {
		width: 100%;
	}

	.castled .imgc {
		width: 100%;
		height: auto;
	}

	.castled .imgc span {
		width: 100%;
		height: 100px;
		background-size: 400%;
	}

	.castled .ci {
		width: 100%;
		padding: 6px 0 0 0;
	}

	/* --- Rankings options (dropdown) --- */
	.rankings_options {
		position: relative;
		top: auto;
		right: auto;
		display: block;
		width: 100%;
		margin-bottom: 10px;
		box-sizing: border-box;
	}

	/* --- H1/H2 mobile --- */
	h1 {
		width: 100%;
		font-size: 20px;
		margin-left: 0;
		margin-right: 0;
	}

	h2 {
		margin-left: 0; /* Remove o margin-left: 20px que desalinha no mobile */
		font-size: 18px;
	}

	/* --- rulesbox no mobile --- */
	.rulesbox {
		width: 100%;
		box-sizing: border-box;
	}

	/* --- accept-rules no mobile --- */

	.accept-rules-label {
		width: 100%;
		box-sizing: border-box;
	}

	/* --- reCAPTCHA no mobile --- */
	.g-recaptcha {
		transform: scale(0.85);
		transform-origin: left center;
	}

	/* --- Padding do main-content no mobile ---
	   Bootstrap p-3 = 16px. Reduz para 8px para ganhar espaço horizontal. */
	.main-content.p-3 {
		padding: 8px !important;
	}

	/* --- Corrige alinhamento do container no mobile ---
	   Garante que main não ultrapasse os limites da tela. */
	main {
		border-radius: 0;
		margin-top: 0;
	}
}

/* ============================================================
   FORMULÁRIO - Telas pequenas (iPhone e similares ≤ 480px)
   Escala desc + input proporcionalmente, mantém label à esquerda
   ============================================================ */
@media only screen and (max-width: 480px) {

	.pddInner { padding: 0 6px; }

	.formpadrao .desc {
		width: 90px;
		font-size: 12px;
		padding: 0 6px;
	}

	.formpadrao .camp input[type="text"],
	.formpadrao .camp input[type="password"],
	.formpadrao .camp input[type="file"] {
		width: 165px;
	}

	.formpadrao .camp select {
		width: 166px;
	}

	.rmsg {
		width: 271px;
		box-sizing: border-box;
	}

	.accept-rules-label {
		width: 271px;
		box-sizing: border-box;
	}

	.g-recaptcha {
		transform: scale(0.82);
		transform-origin: center center;
	}

}

/* ============================================================
   MOBILE OVERLAY - Login, Rankings e navegação completa
   ============================================================ */

/* User section no overlay */
.mob-user-section {
	background: rgba(255,255,255,0.05);
	border-radius: 8px;
	padding: 16px;
	margin-bottom: 20px;
	text-align: left;
}

.mob-user-title {
	font-size: 12px;
	font-weight: bold;
	text-transform: uppercase;
	color: #888;
	letter-spacing: 1px;
	margin-bottom: 10px;
}

.mob-fields {
	display: flex;
	flex-direction: column;
	gap: 6px;
	margin-bottom: 10px;
}

.mob-inpt {
	background: rgba(255,255,255,0.1);
	border: 1px solid rgba(255,255,255,0.2);
	border-radius: 5px;
	color: #fff;
	font-size: 14px;
	height: 40px;
	line-height: 40px;
	padding: 0 12px;
	width: 100%;
	box-sizing: border-box;
	outline: none;
}

.mob-inpt::placeholder {
	color: rgba(255,255,255,0.4);
}

.mob-inpt:focus {
	border-color: rgba(255,255,255,0.5);
	background: rgba(255,255,255,0.15);
}

.mob-btn-login {
	width: 100%;
	height: 40px;
	background: #cb3800;
	border: none;
	border-radius: 5px;
	color: #fff;
	font-size: 13px;
	font-weight: bold;
	text-transform: uppercase;
	cursor: pointer;
	transition: background 0.3s;
	margin-bottom: 10px;
}

.mob-btn-login:hover {
	background: #e04200;
}

.mob-login-error {
	background: #b30000;
	color: #fff;
	font-size: 11px;
	border-radius: 4px;
	padding: 5px 8px;
	margin-bottom: 8px;
	text-align: center;
}

.mob-links-row {
	text-align: center;
	font-size: 11px;
}

.mob-links-row a {
	color: #f16c13 !important;
	font-weight: bold;
}

.mob-links-row span {
	color: #666;
	margin: 0 6px;
}

/* Usuário logado no overlay */
.mob-logged-info {
	font-size: 14px;
	color: #ccc;
	margin-bottom: 12px;
	text-align: center;
}

.mob-logged-info strong {
	color: #fff;
	display: block;
	font-size: 16px;
	margin-top: 4px;
}

.mob-user-actions {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.mob-action-btn {
	display: block;
	text-align: center;
	background: rgba(255,255,255,0.08);
	border: 1px solid rgba(255,255,255,0.15);
	border-radius: 5px;
	color: #e9e9e9 !important;
	font-size: 12px;
	font-weight: bold;
	padding: 9px 0;
	text-transform: uppercase;
	transition: background 0.2s;
}

.mob-action-btn:hover {
	background: rgba(255,255,255,0.15);
	color: #fff !important;
}

.mob-action-btn.mob-logout {
	background: rgba(172, 15, 15, 0.3);
	border-color: rgba(172, 15, 15, 0.5);
	color: #ff9999 !important;
}

.mob-action-btn.mob-logout:hover {
	background: rgba(172, 15, 15, 0.5);
}

/* Idioma no overlay */
.mob-lang-wrap {
	text-align: center;
	padding: 20px 0 10px;
}

.mob-lang-wrap .langs {
	position: relative;
	top: auto;
	right: auto;
	display: inline-block;
}