@charset "utf-8";

* { margin: 0; padding: 0; position: relative; min-width: 0; box-sizing: border-box; font-family: 'Poppins', Sans-serif, Arial, Helvetica, Verdana; line-height: 140%; font-size: 1.0rem; }
html  { scroll-behavior: smooth; font-size: 100%; height: 100%; min-height: 100%; }
body  { height: 100%; min-height: 100dvh; background-color: #fff; }
input, select, textarea { box-sizing: border-box; border: 1px solid #888; color: #444; padding: 10px; width: 100%; border-radius: var(--border-radius); }
textarea { height: 80px; background-color: transparent; border-radius: var(--border-radius); }
input.small { padding: 5px 10px; font-size: 0.9rem; }
select.small { padding: 5px 10px; font-size: 0.9rem; }
textarea.small { padding: 5px 10px; font-size: 0.9rem; }
input[type=submit] { border: none; }
button { appearance: none; -moz-appearance: none; -moz-appearance: none; border: none; }
a, span, label, strong { color: inherit; font-size: inherit; font-weight: inherit; }
strong { font-weight: bold; }
ul { margin: 15px 20px; }
ol { margin: 15px 20px; }
img, iframe, article { max-width: 100%; }
h1, h2, h3, h4, h5, h6 { line-height: 120%; text-wrap: balance; }
p  { line-height: 140%; }

blockquote         { margin: 10px; padding: 15px 15px 15px 40px; background-color: #fff; border-style: solid; border-color: #ddd #ddd #ddd #222; border-width: 1px 1px 1px 10px; font-family: Georgia, serif; overflow: hidden; clear: both; min-height: 50px; }
blockquote::before { font-family: "Times New Roman"; position: absolute; top: 25px; left: 10px; color: #999; content: '\201C'; font-size: 3rem; margin: 0; }
blockquote p       { display: inline; font-size: 1.2rem; font-style: italic; color: #777; margin: 0px!important; }

table                     { width: 100%; border-collapse: separate; border-spacing: 0; background-color: #fff; border: 1px solid #ccc; overflow: hidden; border-radius: var(--border-radius); }
table tr:nth-child(2n) td { background-color: #eee; }
table thead tr th         { border-bottom: 2px solid #0008; }
table td, table th        { vertical-align:top; padding: 10px; font-size: 0.85rem; border-right: 1px solid #ccc; color: #000C; }
table tr td:last-child, table tr th:last-child { border-right: none; }
table th                  { font-weight: 600; text-transform: none; font-size: 0.9rem; text-align: left; color: #000D; }

section, article, header, footer { width: 100%; }

.ronin-hidden   { display: none!important; }
.display-none   { display: none!important; }
.cursor-pointer { cursor: pointer; }
.block          { display: block; }
.noselect       { -webkit-touch-callout: none; -webkit-user-select: none; -khtml-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; }

.center-container { display:block; margin: 0 auto; }
.left-content     { text-align: left!important; }
.center-content   { text-align: center!important; }
.right-content    { text-align: right!important; }

.italic { font-style: italic; }
.line   { background-color: #ccc; height: 1px; width: 100px; margin: 15px auto; }

.border           { border: 1px solid #ccc; }
.border-top       { border-top: 1px solid #ccc; }
.border-right     { border-right: 1px solid #ccc; }
.border-bottom    { border-bottom: 1px solid #ccc; }
.border-left      { border-left: 1px solid #ccc; }

.absolute-left    { position: absolute; top: 0; left: 0; }
.absolute-right   { position: absolute; top: 0; left: initial; right: 0; }

.full-width       { width: 100%; }
.flex-row         { display: flex; flex-direction: row; flex-wrap: wrap; margin: 0; padding: 0; gap: 15px; }
.flex-row > *     { flex: 0 0 auto; }
.flex-row > li    { list-style-type: none; }

.alert         { padding: 15px; margin-bottom: 20px; width: 100%; box-sizing: border-box; color: #222; background-color: #eee; border: 1px solid #444; }
.alert.success { color: #3c763d; background-color: #dff0d8; border-color: #d6e9c6; }
.alert.info    { color: #31708f; background-color: #d9edf7; border-color: #bce8f1; }
.alert.warning { color: #8a6d3b; background-color: #fcf8e3; border-color: #faebcc; }
.alert.danger  { color: #a94442; background-color: #f2dede; border-color: #ebccd1; }
.alert p       { margin:0; font-size: 0.9rem; }

.margin-top-5   { margin-top:  5px!important; }
.margin-top-10  { margin-top: 10px!important; }
.margin-top-15  { margin-top: 15px!important; }
.margin-top-20  { margin-top: 20px!important; }
.margin-top-25  { margin-top: 25px!important; }
.margin-top-30  { margin-top: 30px!important; }
.margin-top-40  { margin-top: 40px!important; }
.margin-top-50  { margin-top: 50px!important; }
.margin-top-100 { margin-top:100px!important; }

.margin-bottom-5   { margin-bottom:  5px!important; }
.margin-bottom-10  { margin-bottom: 10px!important; }
.margin-bottom-15  { margin-bottom: 15px!important; }
.margin-bottom-20  { margin-bottom: 20px!important; }
.margin-bottom-25  { margin-bottom: 25px!important; }
.margin-bottom-30  { margin-bottom: 30px!important; }
.margin-bottom-40  { margin-bottom: 40px!important; }
.margin-bottom-50  { margin-bottom: 50px!important; }
.margin-bottom-100 { margin-bottom:100px!important; }

.max-width-100  { max-width:  100px!important; }
.max-width-200  { max-width:  200px!important; }
.max-width-300  { max-width:  300px!important; }
.max-width-400  { max-width:  400px!important; }
.max-width-500  { max-width:  500px!important; }
.max-width-600  { max-width:  600px!important; }
.max-width-700  { max-width:  700px!important; }
.max-width-800  { max-width:  800px!important; }
.max-width-900  { max-width:  900px!important; }
.max-width-1000 { max-width: 1000px!important; }

.rotate-45  { -ms-transform:  rotate(45deg); -webkit-transform:  rotate(45deg); transform:  rotate(45deg);  }
.rotate-90  { -ms-transform:  rotate(90deg); -webkit-transform:  rotate(90deg); transform:  rotate(90deg);  }
.rotate-135 { -ms-transform: rotate(135deg); -webkit-transform: rotate(135deg); transform: rotate(135deg); }
.rotate-180 { -ms-transform: rotate(180deg); -webkit-transform: rotate(180deg); transform: rotate(180deg); }
.rotate-225 { -ms-transform: rotate(225deg); -webkit-transform: rotate(225deg); transform: rotate(225deg); }
.rotate-270 { -ms-transform: rotate(270deg); -webkit-transform: rotate(270deg); transform: rotate(270deg); }
.rotate-315 { -ms-transform: rotate(315deg); -webkit-transform: rotate(315deg); transform: rotate(315deg); }

.grid-1  { display: grid; grid-template-columns: repeat( 1, 1fr); grid-gap: 25px; }
.grid-2  { display: grid; grid-template-columns: repeat( 2, 1fr); grid-gap: 25px; }
.grid-3  { display: grid; grid-template-columns: repeat( 3, 1fr); grid-gap: 25px; }
.grid-4  { display: grid; grid-template-columns: repeat( 4, 1fr); grid-gap: 25px; }
.grid-5  { display: grid; grid-template-columns: repeat( 5, 1fr); grid-gap: 25px; }
.grid-6  { display: grid; grid-template-columns: repeat( 6, 1fr); grid-gap: 25px; }
.grid-7  { display: grid; grid-template-columns: repeat( 7, 1fr); grid-gap: 25px; }
.grid-8  { display: grid; grid-template-columns: repeat( 8, 1fr); grid-gap: 25px; }
.grid-9  { display: grid; grid-template-columns: repeat( 9, 1fr); grid-gap: 25px; }
.grid-10 { display: grid; grid-template-columns: repeat(10, 1fr); grid-gap: 25px; }
.grid-11 { display: grid; grid-template-columns: repeat(11, 1fr); grid-gap: 25px; }
.grid-12 { display: grid; grid-template-columns: repeat(12, 1fr); grid-gap: 25px; }

.cover-bg         { background-repeat: no-repeat; background-position: center center; background-size: cover; }
.cover-bg::before { background-repeat: no-repeat; background-position: center center; background-size: cover; }
.cover-bg::after  { background-repeat: no-repeat; background-position: center center; background-size: cover; }

.bg-w-10   { background-color: rgba(255,255,255,0.1); }
.bg-w-20   { background-color: rgba(255,255,255,0.2); }
.bg-w-30   { background-color: rgba(255,255,255,0.3); }
.bg-w-40   { background-color: rgba(255,255,255,0.4); }
.bg-w-50   { background-color: rgba(255,255,255,0.5); }
.bg-w-60   { background-color: rgba(255,255,255,0.6); }
.bg-w-70   { background-color: rgba(255,255,255,0.7); }
.bg-w-80   { background-color: rgba(255,255,255,0.8); }
.bg-w-90   { background-color: rgba(255,255,255,0.9); }
.bg-w-100  { background-color: rgba(255,255,255,1.0); }

.bg-b-10   { background-color: rgba(0,0,0,0.1); }
.bg-b-20   { background-color: rgba(0,0,0,0.2); }
.bg-b-30   { background-color: rgba(0,0,0,0.3); }
.bg-b-40   { background-color: rgba(0,0,0,0.4); }
.bg-b-50   { background-color: rgba(0,0,0,0.5); }
.bg-b-60   { background-color: rgba(0,0,0,0.6); }
.bg-b-70   { background-color: rgba(0,0,0,0.7); }
.bg-b-80   { background-color: rgba(0,0,0,0.8); }
.bg-b-90   { background-color: rgba(0,0,0,0.9); }
.bg-b-100  { background-color: rgba(0,0,0,1.0); }

.before::before   { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
.after::after   { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; }

/*============================================================================*/

#ronin_page   { min-height: 100%; max-width: 100vw; display: grid; grid-template-rows: auto 1fr auto; }

#ronin_header { max-width: 100%; z-index: 90; }
#ronin_header .items { display: grid; gap: 10px; grid-template-columns: 0 200px 1fr 50px 50px auto 50px; height: var(--header-height); }
#ronin_header .items .item { display: flex; justify-content: center; align-items: center; }
#ronin_header .items .item:nth-child(2) { justify-content: flex-start; }
#ronin_header .items .item:nth-child(3) { justify-content: flex-start; }
#ronin_header .items .item:nth-child(4) { justify-content: center; overflow: hidden; }
#ronin_header .item .home-link { display: block; line-height: 0; height: var(--header-height); max-width: 120px; margin: 0 auto; }
#ronin_header .item .home-link img { max-height: var(--header-height); height: 100%; object-fit: contain; }
#ronin_header .header-menu-icon { cursor: pointer; }

#ronin_body { max-width: 100%; background-color: #eee; }
#ronin_body.rb-left-column { display: grid; grid-template-columns: 280px 1fr; gap: 0; }
#ronin_body.rb-left-column .ronin-body-left { z-index: 80; }
#ronin_body.rb-left-column .ronin-body-left.visible { box-shadow: 0 0 5px 0 #0004; }
#ronin_body_left { background-color: #fff; }
#ronin_body_main { background-color: transparente; }

#ronin_body_left.rbl-category { background-color: transparent; }
#ronin_body_left.rbl-category .left-filters-container { position: sticky; top: 70px; }

#ronin_footer { max-width: 100%; background-color: #ddd; padding: 25px 0; }
#ronin_footer * { color: #000; }

.nav.menu { list-style-type: none; margin: 5px 0 0 0; display: flex; align-items: center; height: 50px; justify-content: center; }
#ronin_header:not(.modal) .ronin-content { padding: 0 10px 0 0; }
#ronin_header:not(.modal) .nav.menu { flex-wrap: nowrap; }
.nav.menu > li { display: inline-block; }
.nav.menu > li > span, .nav.menu > li > a { user-select: none; transition: all 0.5s; display: block; padding: 5px 15px 8px; text-decoration: none; transition: all 0.3s; font-size: 0.9rem; text-transform: none; }
.nav.menu > li > span:hover, .nav.menu > li > a:hover { transition: all 0.5s; color: var(--color-05); }
.nav.menu > li > span:hover + .icono, .nav.menu > li > a:hover + .icono { transition: all 0.5s; color: var(--color-05); user-select: none; }
.nav.menu > li > span { cursor: context-menu; }
.nav.menu > li.current > span, .nav.menu > li.current > a { font-weight: 700; }
.nav.menu > li.active > span, .nav.menu > li.active > a { font-weight: 700; }
.nav.menu > li.parent span, .nav.menu > li.parent a { display: inline-block; vertical-align: top; padding-right: 0; cursor: pointer; }
.nav.menu > li.parent .icono { transition: all 0.5s; display: inline-block; font-size: 1.4rem; vertical-align: top; margin: 0 0 0 -3px; padding: 5px 5px 0px; opacity: 0.5; cursor: pointer; }
.nav.menu ul.submenu { list-style-type: none; margin: 0; transition: opacity 0.5s, transform 0s; opacity: 0; transform: translate(0,-1000px); position: absolute; top: 42px; left: 0; background-color: #fff; z-index: 10; }
#ronin_header .nav.menu ul.submenu { padding: 20px 10px; border-radius: var(--border-radius); overflow: hidden; width: 670px; left: 0; display: grid; grid-template-columns: 1fr 1fr 1fr; box-shadow: 0 5px 5px 0 #0004; border: 1px solid #0002; }
#ronin_header .nav.menu ul.submenu > li:not(:last-child) { border-right: 1px solid #0004; }
.nav.menu > li ul.submenu.visible { transition: opacity 0.5s, transform 0s; opacity: 1; transform: translate(0,0); transform: scale(1,1) translate(0,0); z-index: 110; }
.nav.menu ul.submenu > li { display: inline-block; min-width: 200px; }
.nav.menu ul.submenu > li > a { display: block; color: var(--color-06); padding: 0 20px 10px 20px; text-decoration: none; transition: all 0.3s; font-size: 0.9rem; text-transform: none; }
.nav.menu ul.submenu > li > a:hover { color: var(--color-05); }

.nav.menu .item-submenu { list-style-type: none; margin: 0; }
.nav.menu .item-submenu a { text-decoration: none; font-size: 0.8rem; color: #000D; padding: 5px 20px; }
.nav.menu .item-submenu > li.current a { color: #000; font-weight: 500; }
.nav.menu .item-submenu > li:hover { background-color: #f2f2f2; }

#ronin_header.modal { background-color: transparent; }
#ronin_header.modal + #ronin_body { padding-top: 70px; }
#ronin_header.modal + #ronin_body::before { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 70px; background-color: #fff; box-shadow: 0 5px 10px 0 #0002; }
#ronin_header.modal .quitamiedos { display: block; width: 100%; }
#ronin_header.modal .ronin-content { height: 100%; max-height: 100%; border-radius: 0; opacity: 1!important; transition: transform 0.2s ease-out; transform: translate(0,0); margin: 0 auto 0 0; max-width: 450px; }
#ronin_header.modal .ronin-content.unfit { transition: transform 0s; transform: translate(-100%,0); }
#ronin_header.modal .item-right { overflow: auto; }
#ronin_header.modal .item-user { height: 50px; justify-content: flex-start; margin: 0 auto; width: 100%; max-width: 300px; padding: 15px; border-top: 1px solid #ddd; }
#ronin_header.modal .item-user a { width: 100%; text-decoration: none; }
#ronin_header.modal #main_menu { display: block!important; width: 100%; margin-bottom: 25px; border-bottom: 1px solid #0008; }
#ronin_header.modal .header-menu-icon { display: none; }
#ronin_header.modal .items { display: grid; grid-template-columns: 1fr; gap: 10px 0; }
#ronin_header.modal .nav.menu { display: block; height: auto; max-width: 300px; width: 300px; margin-left: auto; margin-right: auto; }
#ronin_header.modal .nav.menu > li { display: block; }
#ronin_header.modal .nav.menu > li:not(.parent) { border-bottom: 1px solid #ddd; }
#ronin_header.modal .nav.menu > li:not(.parent):last-child { border-bottom: none; }
#ronin_header.modal .nav.menu > li > a { padding: 15px; }
#ronin_header.modal .nav.menu > li > a:hover { background-color: #eee; }
#ronin_header.modal .nav.menu > li.parent a { display: block; }
#ronin_header.modal .nav.menu > li.parent > a { border-bottom: 1px solid #ddd; }
#ronin_header.modal .nav.menu > li.parent .icono { display: block; position: absolute; top: 0px; right: 10px; z-index: 50; margin: 0; cursor: pointer; }
#ronin_header.modal .nav.menu > li.parent .icono:hover { background-color: #ddd; }
#ronin_header.modal .nav.menu > li ul.submenu { margin: 0; opacity: 0; transition: max-height 0.1s ease-out; max-height: 0; transform: translate(0,0); overflow: hidden; position: relative; top: 0; left: 0; box-shadow: none; }
#ronin_header.modal .nav.menu > li ul.submenu.visible { opacity: 1; max-height: 2000px; transition: max-height 0.5s ease-out; }
#ronin_header.modal .nav.menu > li ul.submenu > li { display: block; }
#ronin_header.modal .nav.menu > li ul.submenu > li:last-child { border-bottom: none; }
#ronin_header.modal .nav.menu > li ul.submenu > li a { padding: 10px 15px 10px 30px; }
#ronin_header.modal .nav.menu ul.submenu > li > a:hover { background-color: #f2f2f2; }
#ronin_header.modal .close-seccion-modal-out { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
#ronin_header.modal .nav.menu ul.submenu > li:not(:last-child) { border-right: none; }
#ronin_header.modal .nav.menu ul.submenu > li { margin: 10px 0; }
#ronin_header.modal .nav.menu ul.submenu > li a { display: block; }
#ronin_header.modal .nav.menu ul.submenu { padding: 0; }

.left-menu-container { height: 100%; overflow: auto; max-height: calc(100vh - 140px); position: sticky; top: 70px; }
.left-menu-container .nav.menu { margin: 0; display: flex; align-items: flex-start; justify-content: flex-start; flex-direction: row; flex-wrap: wrap; }
.left-menu-container .nav.menu > li { flex: 0 0 100%; margin: 15px 0 0; }
.left-menu-container .nav.menu > li:last-child { padding-bottom: 25px; }
.left-menu-container .nav.menu > li > span, .left-menu-container .nav.menu > li > a { font-size: 0.9rem; text-transform: uppercase; font-weight: 600; color: var(--color-05); }
.left-menu-container .nav.menu > li.parent .icono { position: absolute; top: 0; right: 15px; }
.left-menu-container .nav.menu > li.parent .icono:not(.abierto) { transform: rotate(-90deg); }
.left-menu-container .nav.menu ul.submenu { transition: opacity 0.5s, max-height 0.5s!important; max-height: 0!important; opacity: 0!important; transform: translate(0,0); padding: 0 30px; overflow: hidden; position: relative; top: 0; left: 0; z-index: 0; box-shadow: none; }
.left-menu-container .nav.menu ul.submenu.visible { transition: opacity 1.8s, max-height 1.8s!important; max-height: 1000px!important; opacity: 1!important; }
.left-menu-container .nav.menu > li:hover ul.submenu { transform: none; }
.left-menu-container .nav.menu ul.submenu::before { content: ''; position: absolute; top: 0; left: 30px; width: 3px; height: 100%; background-color: #0001; border-radius: 20px; }
.left-menu-container .nav.menu ul.submenu li { width: 100%; }
.left-menu-container .nav.menu ul.submenu li a { font-weight: 500; }
.left-menu-container .nav.menu ul.submenu li:not(.current) a { opacity: 0.5; }

#ronin_body.rb-left-column .ronin-body-left.visible .left-menu-icon { transition: all 0.5s; opacity: 0; }
.left-menu-icon { transition: all 0.5s; position: fixed; left: -10px; top: calc(50% - 20px); cursor: pointer; user-select: none; width: 40px; height: 40px; display: flex; justify-content: center; align-items: center; border-radius: 50%; background-color: #fff; z-index: 25; box-shadow: 0 0 5px 0 #0004; }
.left-menu-icon > span { display: block; margin-left: 5px; }
.left-filters-icon { position: fixed; right: -10px; top: calc(50% - 20px); cursor: pointer; user-select: none; width: 40px; height: 40px; display: flex; justify-content: center; align-items: center; border-radius: 50%; background-color: #fff; z-index: 25; box-shadow: 0 0 5px 0 #0004; }
.left-filters-icon > span { display: block; margin-left: 5px; }

.ronin-section   { width: 100%; max-width: 100vw; margin:0 auto; padding: 12.5px 0; }
.ronin-container { max-width: var(--max-width); margin: 0 auto; }
.ronin-content   { max-width: var(--max-width); margin: 0 auto; padding: 0 var(--padding); transition: padding 0.3s; }
body:not([class*='login']) .ronin-view { padding: 0 0 12.5px; }
.ronin-view .ronin-section:first-child { padding: 25px 0 12.5px; }

.title         { font-size: 1.4rem; line-height: 120%; font-weight: 500; margin: 0 auto 15px; color: #484f57; text-align: left; }
.subtitle      { font-size: 1.2rem; line-height: 120%; font-weight: 500; margin: 0 auto 15px; color: #000; text-align: left; }
.description   { font-size: 0.9rem; line-height: 140%; font-weight: normal; color: #000A; text-align: left; }
.description p { font-size: 0.9rem; line-height: 140%; font-weight: normal; margin: 0 auto 15px; color: #000A; text-align: left; }
.button        { text-align: center; margin: 0; }
.image         { background-repeat: no-repeat; background-position: center center; background-size: cover; }
.image::before { background-repeat: no-repeat; background-position: center center; background-size: cover; }
.image::after  { background-repeat: no-repeat; background-position: center center; background-size: cover; }

.only-modal { display: none; }
.ronin-section.modal .only-modal { display: block; }

.items-01 { display: grid; gap: 50px; grid-template-columns: 1fr 1fr; margin: 50px 0; }
.items-01 .item-image { padding-top: 70%; background-color: #ccc; }
.items-01 .item-title { color: #000; }
.items-01 .item-description { color: #000; }
.items-01 .item-bottom { padding: 50px; }

.ronin-section.top { background-color: #e8e8e8; border-bottom: 1px solid #ddd; padding: 40px 0 25px!important; margin-bottom: 25px; }

.ronin-section.rs-formulario.modal .form-items { max-height: calc(100vh - 100px); overflow: auto; }
.ronin-section.rs-formulario .form-items { display: grid; gap: 25px; }
.ronin-section.rs-formulario .form-items label { display: block; }
.ronin-section.rs-formulario .form-items input:not([type="submit"]) { background-color: transparent; padding: 20px; font-size: 1.1rem; }
.ronin-section.rs-formulario .form-items input[type='submit'] { width: auto; }
.ronin-section.rs-formulario .form-items input[type='submit']:hover { background-color: #000; transition: all 0.3s; color: #fff; }
.ronin-section.rs-formulario .form-item.enviar { margin: 25px 0 0; }

input#acepto_input[type='checkbox'] { position: absolute; top: 5px; left: 0; z-index: 25; cursor: pointer; width: 15px; opacity: 0; }
input#acepto_input[type='checkbox'] + label { position: absolute; top: 0; margin-top: 0px; padding: 0 0 0 30px; left: 0; z-index: 25; cursor: pointer; }
input#acepto_input[type='checkbox'] + label::before { content: ''; display: block; position: absolute; top: 0px; left: 0; width: 20px; height: 20px; border: 1px solid #000; }
input#acepto_input[type='checkbox'] + label::after { content: ''; display: block; opacity: 0; transition: all 0.3s; position: absolute; top: 3px; left: 3px; width: 13px; height: 8px; border-width: 0 0 2px 2px; border-style: solid; border-color: #000; -ms-transform: rotate(315deg); -webkit-transform: rotate(315deg); transform: rotate(315deg); }
input#acepto_input[type='checkbox']:checked + label::after { opacity: 1; transition: all 0.3s; }

.modal { transition: all 0; position: fixed!important; margin: 0!important; padding: 0!important; display: flex; flex-direction: column; justify-content: center; align-items: center; top: 0; left: 0; width: 100%; height: 100%; overflow: hidden; z-index: 99999; }
.modal .close-modal { position: sticky; top: 0; right: 10px; z-index: 999; width: 100%; padding: 10px; background-color: #fff; display: flex!important; justify-content: flex-end; align-items: center; cursor: pointer; }
.modal > .ronin-container { background-color: rgba(0,0,0,0.75); max-width: 100vw; width: 100%; height: 100%; display: flex; justify-content: center; align-items: flex-start; }
.modal > .ronin-container .shadow-close { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
.modal > .ronin-container > .ronin-content { transition: top 0.5s, opacity 0.5s; opacity: 0; top: -50px; margin: 50px auto 25px; padding: 0; width: 100%; max-width: 600px; max-height: calc(100vh - 100px); height: auto; overflow: auto; background-color: #fff; border-radius: var(--border-radius); }
.modal > .ronin-container > .ronin-content.visible { transition: top 0.5s, opacity 0.5s; opacity: 1; top: 0; }

body #ronin_header { position: sticky; top: 0; left: 0; padding: 0; background-color: #fff; box-shadow: 0 0 10px 0 #0004; }
body.inicio #ronin_header.visible:not(.top-hidden) .header-menu-icon .contenedor:hover { background-color: rgba(0,0,0,0.5); }

.waitting { transition: all 0.5s; opacity: 0; z-index: 0; display: flex; justify-content: center; align-items: center;position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(255,255,255,0.7); }
.waitting.visible { transition: all 0.5s; opacity: 1; z-index: 99; }
.waitting .puntos { display: inline-block; width: 15px; height: 15px; border-radius: 50%; background-color: rgba(0,0,0,0.5); }
.waitting .puntos { animation: esperando 1s infinite; transition: all 0.3; box-shadow: -25px 0 0 rgba(0,0,0,0.2), 25px 0 0 rgba(0,0,0,0.2); }

@keyframes esperando {
    0%   { background-color: rgba(0,0,0,0.5); box-shadow: -25px 0 0 rgba(0,0,0,0.2), 25px 0 0 rgba(0,0,0,0.2); }
    33%  { background-color: rgba(0,0,0,0.2); box-shadow: -25px 0 0 rgba(0,0,0,0.2), 25px 0 0 rgba(0,0,0,0.5); }
    66%  { background-color: rgba(0,0,0,0.2); box-shadow: -25px 0 0 rgba(0,0,0,0.5), 25px 0 0 rgba(0,0,0,0.2); }
    100% { background-color: rgba(0,0,0,0.5); box-shadow: -25px 0 0 rgba(0,0,0,0.2), 25px 0 0 rgba(0,0,0,0.2); }
}

/*============================================================================*/

@keyframes raiTopFadeIn {
    0% { opacity: 0; transform: translate(0,-50px); }
    80% { opacity: 1; transform: translate(0,0); }
    100% { opacity: 1; }
}
@keyframes raiBottomFadeIn {
    0% { opacity: 0; transform: translate(0,50px); }
    80% { opacity: 1; transform: translate(0,0); }
    100% { opacity: 1; }
}
@keyframes raiLeftFadeIn {
    0% { opacity: 0; transform: translate(-50px,0); }
    80% { opacity: 1; transform: translate(0,0); }
    100% { opacity: 1; }
}
@keyframes raiRightFadeIn {
    0% { opacity: 0; transform: translate(50px,0); }
    80% { opacity: 1; transform: translate(0,0); }
    100% { opacity: 1; }
}
*[class*='rai-'] { opacity: 0; }
.rai-bottom.item-on { animation: raiBottomFadeIn 2s; opacity: 1; animation-fill-mode: both; }
.rai-top.item-on { animation: raiTopFadeIn 2s; opacity: 1; animation-fill-mode: both; }
.rai-left.item-on { animation: raiLeftFadeIn 2s; opacity: 1; animation-fill-mode: both; }
.rai-right.item-on { animation: raiRightFadeIn 2s; opacity: 1; animation-fill-mode: both; }

@keyframes float {
    0% { transform: translatey(0px); }
    50% { transform: translatey(-20px); }
    100% { transform: translatey(0px); }
}
@keyframes floater {
    0% { transform: translateY(-5px); transition: ease 0.5s; }
    50% { transform: translateY(5px); transition: ease 0.5s; }
    100% { transform: translateY(-5px); transition: ease 0.5s; }
}

.ancla-seccion { position: absolute; top: -70px; }
.ronin-up-container { position: absolute; bottom: 15px; right: 15px; width: 1px; height: calc(100% - (100vh + 150px)); display: flex; align-items: flex-end; justify-content: flex-end; z-index: 75; }
.ronin-up-container .ronin-up { transition: all 0.5s; position: sticky; bottom: 15px; right: 0; width: 50px; min-width: 50px; max-width: 50px; height: 50px; cursor: pointer; border-radius: 50%; background-color: #f7b924; display: flex; justify-content: center; align-items: center; }
.ronin-up-container .ronin-up:hover { box-shadow: 0 0 5px 0 #000a; }
.ronin-up-container .ronin-up > span { transition: all 0.5s; color: #000; }
.ronin-up-container .ronin-up:hover > span { transition: all 0.5s; transform: scale(1.3); }

/*============================================================================*/

@media screen and (max-width:575.98px){
    .ronin-xs-hidden { display:none!important; }
    .ronin-md-down { display:block!important; }
    #ronin_header .items { gap: 0; grid-template-columns: 50px 1fr 0 0 50px 50px 50px; }
    #ronin_body.rb-left-column.rblc-category { grid-template-columns: 1fr 0; }
    #ronin_body.rb-left-column .ronin-body-left { transition: all 0.3s; grid-area: 1 / 1 / 2 / 2; z-index: 20; left: -100%; }
    #ronin_body.rb-left-column .ronin-body-left.visible { transition: all 0.3s; left: 0; }
    #ronin_body.rb-left-column .rbl-category { left: initial; right: -100%; order: 2; max-width: 280px; position: fixed; }
    #ronin_body.rb-left-column .rbl-category.visible { left: initial; right: 0; }
    #ronin_body.rb-left-column .ronin-body-main { grid-area: 1 / 1 / 2 / 3; }
    #ronin_header .nav.menu ul.submenu { grid-template-columns: 1fr; border-radius: 0; border: 0; max-width: 100%; }
}
@media screen and (min-width:576px) and (max-width:767.98px){
    .ronin-sm-hidden { display:none!important; }
    .ronin-md-down { display:block!important; }
    #ronin_header .items { gap: 0; grid-template-columns: 50px 1fr 0 50px 50px 50px 50px; }
    #ronin_body.rb-left-column .ronin-body-left { transition: all 0.3s; grid-area: 1 / 1 / 2 / 2; z-index: 20; left: -100%; }
    #ronin_body.rb-left-column .ronin-body-left.visible { transition: all 0.3s; left: 0; }
    #ronin_body.rb-left-column .rbl-category { left: initial; right: -100%; order: 2; max-width: 280px; position: fixed; }
    #ronin_body.rb-left-column .rbl-category.visible { left: initial; right: 0; }
    #ronin_body.rb-left-column .ronin-body-main { grid-area: 1 / 1 / 2 / 3; }
    #ronin_header .nav.menu ul.submenu { grid-template-columns: 1fr; border-radius: 0; border: 0; max-width: 100%; }
}
@media screen and (min-width:768px) and (max-width:991.98px){
    .ronin-md-hidden { display:none!important; }
    .ronin-md-down { display:block!important; }
    #ronin_header .items { gap: 0; grid-template-columns: 50px 1fr 0 50px 50px 50px 50px; }
    #ronin_body.rb-left-column .ronin-body-left { transition: all 0.3s; grid-area: 1 / 1 / 2 / 2; z-index: 20; left: -100%; }
    #ronin_body.rb-left-column .ronin-body-left.visible { transition: all 0.3s; left: 0; }
    #ronin_body.rb-left-column .rbl-category { left: initial; right: -100%; order: 2; max-width: 280px; position: fixed; }
    #ronin_body.rb-left-column .rbl-category.visible { left: initial; right: 0; }
    #ronin_body.rb-left-column .ronin-body-main { grid-area: 1 / 1 / 2 / 3; }
    #ronin_header .nav.menu ul.submenu { grid-template-columns: 1fr; border-radius: 0; border: 0; max-width: 100%; }
}
@media screen and (min-width:992px) and (max-width:1199.98px){
    #ronin_header .items { gap: 0; grid-template-columns: 50px 1fr 0 50px 50px 50px 50px; }
    .ronin-lg-hidden { display:none!important; }
    .left-menu-icon { display: none; }
    .left-filters-icon { display: none; }
    #ronin_header .nav.menu ul.submenu { grid-template-columns: 1fr; border-radius: 0; border: 0; max-width: 100%; }
}
@media screen and (min-width:1200px){
    .ronin-xl-hidden { display:none!important; }
    .left-menu-icon { display: none; }
    .left-filters-icon { display: none; }
}