/* CSS Document */
/* Documento creado por Estudio Adumbro */
/* http://www.adumbro.es */

/* FONTS *****************/
@font-face {
    font-family: 'Montserrat';
    src: url('/css/font/Montserrat-Light.woff2') format('woff2'),
        url('/css/font/Montserrat-Light.woff') format('woff');
    font-weight: 300;
    font-style: normal;
}

@font-face {
    font-family: 'Montserrat';
    src: url('/css/font/Montserrat-Medium.woff2') format('woff2'),
        url('/css/font/Montserrat-Medium.woff') format('woff');
    font-weight: 500;
    font-style: normal;
}

@font-face {
    font-family: 'Montserrat';
    src: url('/css/font/Montserrat-Italic.woff2') format('woff2'),
        url('/css/font/Montserrat-Italic.woff') format('woff');
    font-weight: normal;
    font-style: italic;
}

@font-face {
    font-family: 'Montserrat';
    src: url('/css/font/Montserrat-Regular.woff2') format('woff2'),
        url('/css/font/Montserrat-Regular.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}

/* GENERAL *****************/
* {
	margin: 0px;
	padding: 0px;
    box-sizing: border-box;
}
html {
    user-select: none;
	background-color: #28282d;
    min-height: 100%;
    overflow-y: scroll;
}
body {
	font-family: 'Montserrat', sans-serif;
	color: #e6e6eb; 
	font-size: 14px;
    min-height: 100%;
    /*
    -moz-user-select: none; -webkit-user-select: none; -ms-user-select:none; -o-user-select:none; user-select:none;
    */
}

html, body {
    overscroll-behavior-y: contain; /* disable pull to refresh, keeps glow effects */
}

a {color: #b9007c; cursor: pointer;}
a.link {color: #b9007c; text-decoration: underline; padding: 0 2px;}
a.link:hover {color: #fff; background-color: #b9007c; text-decoration: none;}
a.link.blue {color: #0090B4;}
a.link.blue:hover {background-color: #0090B4; color: #fff;}

button, label.button {outline: none; border: none; cursor: pointer; font-family: 'Montserrat'; font-weight: normal; font-style: normal;}
button.magenta, label.button.magenta {background-color: #b9007c;}
button.blue, label.button.blue {background-color: #0090B4;}
button.icon, label.button.icon {overflow: hidden; -webkit-border-radius: 50%; -moz-border-radius: 50%; border-radius: 50%;}
button.icon span, label.button.icon span {display: none;}
button.icon::before, label.button.icon::before {display: block; content: ''; width: 100%; height: 100%; position: absolute; top: 0; left: 0; background-color: transparent; background-repeat: no-repeat; background-position: center center; background-size: 60% auto; cursor: pointer; -webkit-border-radius: 50%; -moz-border-radius: 50%; border-radius: 50%;}
button.icon:hover::before, button.icon:active::before, label.button.icon:hover::before, label.button.icon:active::before {background-color: rgba(0,0,0,0.2);}
button.shadow, label.button.shadow {-webkit-box-shadow: 0px 4px 10px 0px rgba(0,0,0,0.5); -moz-box-shadow: 0px 4px 10px 0px rgba(0,0,0,0.5); box-shadow: 0px 4px 10px 0px rgba(0,0,0,0.5);}

button.new {
    display: block; width: 100%; height: auto; min-height: 70px; position: relative;
    background-color: #e8bd3e; border-radius: 10px; padding: 10px; font-size: 20px; color: #323237; text-align: left; text-transform: uppercase;
}
button.new:hover, button.new:active {background-color: #fff;}
button.new::after {display: block; content: ''; width: 70px; height: 100%; position: absolute; top: 0; right: 0; border-left: 2px solid #323237; background-image: url(img/ico_plus_b.svg); background-color: transparent; background-repeat: no-repeat; background-position: center center; background-size: 50% auto;}

img {border: 0px;}
.clear {
	display: block;
	clear: both;
}

h1, h2, h3, h4, h5, h6, strong {font-family: 'Montserrat'; font-weight: 500; font-style: normal;}
em {font-family: 'Montserrat'; font-weight: normal; font-style: italic;}
.spotlight {color: #e8bd3e !important;}

.noscroll {overflow: hidden;}

div.loader span {display: none;}
div.loader {
    display: block; margin: 0 auto;
    border: 3px solid rgba(0,0,0,.2); border-top: 3px solid #0090B4;
    border-radius: 50%;
    width: 30px;
    height: 30px;
    animation: spin 1s linear infinite;
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}
    
@keyframes pulse {
  0% {transform: scale(0.8);}
  70% {transform: scale(1);}
  100% {transform: scale(0.8);}
}

@keyframes jump {
  0% {transform: scale(1);}
  70% {transform: scale(1.2);}
  100% {transform: scale(1);}
}

button.pulse {animation: pulse 2s infinite;}
button.jump {animation: jump 2s infinite;}

/* HEADER *****************/
body > header {
    display: block; width: 100%; height: 50px;
    position: fixed; top: 0; left: 0; z-index: 100;
    background-color: #28282d; background-color: rgba(40,40,45,.9);
}
body > header h1 span {display: none;}
body > header h1 {display: block; width: 92px; height: 42px; margin: 5px 0 0 5px; background: transparent url('img/logo_jjiffy_w.svg') no-repeat top center; background-size: cover;}
body > header.back h1 {margin: 5px auto 0 auto;}
body > header h1 a {display: block; width: 100%; height: 100%; cursor: pointer;}
body > header div.back {
    display: none; width: 50px; height: 50px;
    position: absolute; top: 0px; left: 0px;
    cursor: pointer; z-index: 100;
}
body > header.back  div.back {display: block;}
body > header div.back a span {display: none;}
body > header div.back a {
    display: block; width: 100%; height: 100%;
    background-image: url('img/ico_back.svg'); background-color: transparent; background-repeat: no-repeat; background-position: center center; background-size: 60% auto;
}
body > header div.back a:hover {background-color: rgba(0,0,0,0.4);}
body > header div.back a:active {background-color: rgba(0,0,0,0.8);}
/* white */
body > header.white {background-color: #fff; background-color: rgba(255,255,255,.9);}
body > header.white h1 {background: transparent url('img/logo_jjiffy_b.svg') no-repeat top center;}

/* MENU PRINCIPAL **************/
body > header nav h2, body > header nav input[type="checkbox"] {display: none;}
body > header nav { display: block; width: 50px; height: 50px; position: absolute; top: 0px; right: 0px;}
body > header nav > label {
    display: block; width: 100%; height: 100%; position: relative;
    cursor: pointer; z-index: 100;
    background-image: url('img/ico_menu.svg'); background-color: transparent; background-repeat: no-repeat; background-position: center center; background-size: 60% auto;
}
body > header nav > label span {display: none;}
body > header nav > input#chk_menu:checked + label {background-color: rgba(0,0,0,0.4); background-image: url('img/ico_menu_close.svg');}
body > header nav > ul {
    display: block; z-index: -1; width: 190px; height: auto;
    position: fixed; top: 40px; right: 0; 
    background-color: #28282d; background-color: rgba(40,40,45,.9);
    -webkit-box-shadow: 0px 4px 10px 0px rgba(0,0,0,0.5); -moz-box-shadow: 0px 4px 10px 0px rgba(0,0,0,0.5); box-shadow: 0px 4px 10px 0px rgba(0,0,0,0.5);
    list-style: none;
    transition: all .5s ease; visibility: hidden; opacity: 0;
}
body > header nav > input#chk_menu:checked ~ ul {visibility: visible; opacity: 1; top: 50px; z-index: 90;}
body > header nav ul li {display: block; width: 100%; height: auto; border-bottom: 1px solid rgba(0,0,0,.2); position: relative;}
body > header nav ul li:last-child {border-bottom: none;}
body > header nav ul li a, body > header nav ul li label {
    display: block; width: auto; height: auto; padding: 10px;
    color: #fff; font-family: 'Montserrat'; font-weight: 300; font-style: normal; font-size: 16px; text-decoration: none;
    background-color: transparent; cursor: pointer;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
body > header nav ul li a:hover, body > header nav ul li a:active, body > header nav ul li label:hover {background-color: rgba(0,0,0,0.3);}
body > header nav ul li label {padding: 10px 5px 10px 30px; background-image: url('img/ico_back.svg'); background-repeat: no-repeat; background-position: center left 5px; background-size: auto 50%;}
body > header nav ul li.highlight {background-color: rgba(0,0,0,0.2);}
body > header nav ul > li.highlight a {color: #e8bd3e; text-align: right; text-transform: uppercase;}
body > header nav ul li > ul > li.highlight a {color: #e8bd3e; text-align: left; text-transform: none;}
body > header nav ul li > ul > li.highlight a.show_qr_reader {color: #0090B4;}
body > header nav ul li > input[type="checkbox"]:checked + label {background-color: rgba(0,0,0,0.4); color: rgba(255,255,255,0.3); background-image: url('img/ico_forward.svg');}
body > header nav ul li ul {
    display: block; z-index: -1; width: 180px; height: auto; max-height: 50vh; overflow-x: hidden; overflow-y: auto; 
    position: absolute; top: 0; left: -160px;
    background-color: #28282d; background-color: rgba(40,40,45,.9);
    -webkit-box-shadow: 0px 4px 10px 0px rgba(0,0,0,0.5); -moz-box-shadow: 0px 4px 10px 0px rgba(0,0,0,0.5); box-shadow: 0px 4px 10px 0px rgba(0,0,0,0.5);
    transition: all .5s ease; visibility: hidden; opacity: 0; 
}
body > header nav ul li > input[type="checkbox"]:checked ~ ul {visibility: visible; opacity: 1; left: -180px; z-index: 90;}
/* white */
body > header.white nav > label {background-image: url('img/ico_menu_b.svg');}
body > header.white nav > input#chk_menu:checked + label {background-image: url('img/ico_menu_close_b.svg');}

/* FORM *****************/
div.columns {display: flex; flex-direction: row; flex-wrap: wrap; justify-content: space-between; align-items: flex-start;}
div.columns .w30 {display: block; width: 30%;}
div.columns .w40 {display: block; width: 40%;}
div.columns .w50 {display: block; width: 50%;}
div.columns .w60 {display: block; width: 60%;}
div.columns .w70 {display: block; width: 70%;}
div.form {display: block;}
div.columns div.form {width: 50%; padding-left: 1%;}
div.columns div.form:first-child {border-right: 1px solid #46464b; padding-right: 1%; padding-left: 0;}
div.columns div.form.white:first-child {border-right: 1px solid #ccc;}
@media screen and (max-width: 700px) {
    div.columns {display: block;}
    div.columns > div {width: 100% !important;}
    div.columns div.form {padding-left: 0;}
    div.columns div.form:first-child {border-right: 0 !important; padding-right: 0;}
}
div.form div.row {display: block; padding-bottom: 10px; text-align: center; position: relative;}
.space {margin-top: 10px; padding-top: 10px;}
.division {padding-top: 10px; border-top: 1px solid #46464b;}
div.form div.left {text-align: left;}
div.form div.right {text-align: right;}
div.form div.row p {display: block; height: auto; width: 100%; margin-bottom: 20px; font-size: 18px; line-height: 20px; color: #fff; text-align: center;}
div.form div.row p.note {color: #b4b4b9; font-size: 13px; line-height: 15px; text-align: left; margin: 4px 2px;}
div.form div.row p.note strong, div.form div.row p.note em {color: #e6e6eb;}
div.form div.row label,
div.form div.row div.lbl {display: block; font-size: 14px; padding: 2px 2px 4px 2px; text-transform: uppercase; color: #fff; text-align: left;}
div.form.white div.row label, div.form.white div.row div.lbl {color: #222;}
div.form div.row div.lbl.center {text-align: center;}
div.form div.row label p.note, div.form div.row div.lbl p.note {text-transform: none;}
div.form div.row input[type="text"],
div.form div.row input[type="email"],
div.form div.row input[type="password"],
div.form div.row textarea {
    display: block; width: 100%; padding: .3em; border: 2px solid #1e1e23; font-size: 20px; text-align: center; box-sizing: border-box;
    appearance: none; -moz-appearance: none; -webkit-appearance: none; border-radius: 0; -moz-border-radius: 0; -webkit-border-radius: 0;
    background-color: #1e1e23; color: #fff;
    font-family: 'Montserrat'; font-weight: normal; font-style: normal;
}
div.form div.row textarea {text-align: left; resize: vertical;}
div.form.white div.row input[type="text"],
div.form.white div.row input[type="email"],
div.form.white div.row input[type="password"],
div.form.white div.row textarea {border: 2px solid #eee; background-color: #eee; color: #222;}
div.form div.row input[type="text"]::placeholder,
div.form div.row input[type="email"]::placeholder,
div.form div.row input[type="password"]::placeholder,
div.form div.row textarea::placeholder {color: #46464b;}
div.form.white div.row input[type="text"]::placeholder,
div.form.white div.row input[type="email"]::placeholder,
div.form.white div.row input[type="password"]::placeholder,
div.form.white div.row textarea::placeholder {color: #ccc;}
div.form div.row.highlight label {color: #b9007c;}
div.form div.row.highlight input[type="text"],
div.form div.row.highlight input[type="email"],
div.form div.row.highlight input[type="password"],
div.form div.row.highlight textarea {border: 2px solid #b9007c;}
div.form div.row div.chk {display: block; position: relative;}
div.form div.row div.chk label {
    display: inline-block; text-transform: none; padding: 5px 60px 5px 2px; color: #828287; font-size: 16px; cursor: pointer;
    -webkit-transition: .4s; transition: .4s;
}
div.form div.row div.chk label::before {
    display: block; content: ""; width: 56px; height: 28px; position: absolute; top: 1px; right: 0; border-radius: 15px;
    background-color: #828287; background-image: url('img/ico_ko.svg'); background-repeat: no-repeat; background-position: right 2px center; background-size: auto 100%;
    -webkit-transition: .4s; transition: .4s;
}
div.form div.row div.chk label::after {
    display: block; content: ""; width: 24px; height: 24px; position: absolute; top: 3px; right: 30px; border-radius: 13px;
    background-color: #fff;
    -webkit-transition: .4s; transition: .4s;
}
div.form div.row div.chk input:checked ~ label::after {-webkit-transform: translateX(28px); -ms-transform: translateX(28px); transform: translateX(28px);}
div.form div.row div.chk input:checked ~ label::before {background-color: #0090B4; background-image: url('img/ico_ok.svg'); background-position: left 2px center;}
div.form div.row div.chk input:checked ~ label {color: #fff;}
div.form div.row div.chk input:disabled ~ label::before {background-color: #e6e6eb;}
div.form div.row div.chk input {display: none;}
div.form div.row div.chk2 {display: block; position: relative;}
div.form div.row div.chk2 label {display: inline-block; text-transform: none; padding-left: 3em; color: #828287; font-size: 16px; cursor: pointer;}
div.form div.row div.chk2 label::before {
    display: block; content: ""; width: 2.3em; height: 2.3em; position: absolute; top: 2px; left: 0; background-color: #1e1e23; 
}
div.form div.row div.chk2 label::after {
    display: block; content: ""; width: 2.3em; height: 2.3em; position: absolute; top: 2px; left: 0;
    background-color: transparent; background-image: url('img/ico_ko.svg'); background-repeat: no-repeat; background-position: center center; background-size: auto 100%;
    opacity: .1;
}
div.form div.row div.chk2 input:checked ~ label::before {background-color: #0090B4;}
div.form div.row div.chk2 input:checked ~ label::after {background-image: url('img/ico_ok.svg'); opacity: 1;}
div.form div.row div.chk2 input:checked ~ label {color: #fff;}
div.form div.row div.chk2 input {display: none;}
div.form div.row button:not(.icon) {display: inline-block; vertical-align: middle; width: auto; height: 30px; border-radius: 15px; margin: 0 5px; border: 2px solid #fff; padding: 0 2%; background-color: transparent; text-transform: uppercase; text-decoration: none; font-size: 16px; color: #fff; text-align: center; cursor: pointer;}
div.form.white div.row button:not(.icon) {border: 2px solid #222; color: #222;}
div.form div.row button.blue:not(.icon) {border: 2px solid #0090B4; color: #0090B4;}
div.form div.row button:not(.icon):hover {background-color: #e8bd3e; color: #28282d; border-color: #e8bd3e;}
div.form div.row button:not(.icon):active {background-color: #0090B4; color: #fff; border-color: #0090B4;}
div.form div.row button:not(.icon):disabled {background-color: transparent; color: #46464b; border-color: #46464b; cursor: not-allowed;}
div.form div.row button.black:not(.icon):hover {background-color: #141419; color: #fff; border-color: #141419;}
div.form div.row button:not(.icon).big {height: 40px; font-size: 18px; border-radius: 20px; padding: 0 5%;}
div.form div.row div.lblbtn {display: inline-block; text-transform: none; padding: 5px 10px; color: #fff; font-size: 18px; cursor: pointer; vertical-align: middle;}
div.form div.row a {display: inline-block; text-decoration: none; font-size: 16px; color: #e8bd3e;}
div.form div.row a.btn {padding: 0 10px; border-radius: 20px;}
div.form div.row a:hover, div.form div.row a:active {background-color: #fff; color: #28282d;}
div.form div.especial {padding: 10px 10px 0 10px; background-color: #1e1e23; border: 1px solid #e8bd3e;}
/* range */
div.form div.row div.range {display: block; width: 100%;}
div.form div.row div.range div.val {
    display: flex; flex-direction: row; flex-wrap: nowrap; justify-content: space-between; align-items: center;
    width: 100%; padding: 1%;
    background-color: #1e1e23;
    font-size: 20px; text-align: center;
    color: #fff; border-radius: 20px;
}
div.form div.row div.range div.val button {
    display: block; padding: 0; margin: 0; width: 24px; height: 24px; border-radius: 50%; overflow: hidden;
    font-size: 20px; line-height: 20px; text-align: center; position: relative; background-color: transparent; border: 2px solid #fff;
    color: #fff; -webkit-appearance: none;
}
div.form div.row div.range div.val button:hover {background-color: #e8bd3e;; border: 2px solid #e8bd3e; color: #28282d;}
div.form div.row div.range div.val button:active {background-color: #0090B4; border: 2px solid #0090B4; color: #fff;}
div.form div.row div.range div.val button:disabled {background-color: transparent; border: 2px solid #46464b; color: #46464b; cursor: not-allowed;}
div.form div.row div.range div.val div {display: block; width: 50%; text-align: center;}
div.form div.row div.range div.ctrl {display: block; width: 100%; margin: 0 auto; position: relative; background-color: transparent;}
div.form div.row div.range div.rule {position: absolute; z-index: 0; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 96%; padding: 0 4px; box-sizing: border-box; display: flex; flex-direction: row; flex-wrap: nowrap; justify-content: space-between; align-items: center;}
div.form div.row div.range div.rule span {display: block; width: 4px; height: 4px; background-color: #46464b; border-radius: 2px;}
div.form div.row div.range div.rule span.x {background-color: #0090B4;}
div.form div.row div.range input[type="range"]:disabled {visibility: hidden;}
div.form div.row div.range input[type="range"] {
    display: block; width: 96%; height: 10px; margin: 6px auto;
    position: relative; z-index: 100;
    -webkit-appearance: none; background: transparent; outline: none;
}
div.form div.row div.range input[type="range"]::-webkit-slider-thumb{
    -webkit-appearance: none; appearance: none;
    width: 12px; height: 12px; border-radius: 50%;
    background: #0090B4; cursor: pointer;
}
div.form div.row div.range input[type="range"]::-moz-range-thumb {
    -webkit-appearance: none; appearance: none;
    width: 12px; height: 12px; border-radius: 50%;
    background: #0090B4; cursor: pointer;
}
div.form div.row div.range input[type="range"]:hover::-webkit-slider-thumb {background-color: #0090B4;}
div.form div.row div.range input[type="range"]:hover::-moz-range-thumb {background-color: #0090B4;}
div.form div.row div.range input[type="range"]:focus {outline: none;}
div.form div.row div.range.disable div.val button,
div.form div.row div.range.disable div.ctrl {display: none;}
div.form div.row div.range.disable div.val div {width: 100%; cursor: not-allowed; color: #828287;}

div.form div.row div.password_eval {display: block; position: relative; width: 100%; height: 2px; margin-top: 2px;}
div.form div.row div.password_eval span {
    display: block; width: 0; height: 2px;
    position: absolute; top: 0; left: 0; background-color: #b9007c;
    transition: 1s ease; -webkit-transition: 1s ease;
}

/* PAGE TABS *****************/
div#page_tabs {text-align: center; position: relative;}
div#page_tabs > section {text-align: left; padding: 10px 0;}
div#page_tabs > section > h1 {display: none;}
div#page_tabs > section, div#page_tabs > input {display: none;}
div#page_tabs > label {display: inline-block; padding: 6px 3vw 10px 3vw; margin-bottom: 10px; background-color: transparent; color: #828287; border-bottom: 1px solid #646469; font-size: 20px; line-height: 18px; text-transform: uppercase; cursor: pointer; vertical-align: baseline;}
div#page_tabs > label:hover {color: #b4b4b9; border-bottom: 1px solid #b4b4b9;}
div#page_tabs > input:checked + label {color: #fff; border-bottom: 1px solid #fff;}
div#page_tabs > input:checked + label:hover {}
div#page_tabs > input#ptab0:checked ~ #pcontent0,
div#page_tabs > input#ptab1:checked ~ #pcontent1,
div#page_tabs > input#ptab2:checked ~ #pcontent2,
div#page_tabs > input#ptab3:checked ~ #pcontent3,
div#page_tabs > input#ptab4:checked ~ #pcontent4 {display: block;}

div.no_items, div.loading  {display: block; margin: 3% 2%; font-size: 18px; color: rgba(255,255,255,.15); text-align: center;}
div.no_items p, div.loading p {margin: 1% 0;}

/* QR READER *************************/
article#qr_reader div.content {background: #646469 url('img/ico_forbidden_mobile.svg') no-repeat top 15vh center; background-size: 20vh auto;}
article#qr_reader canvas#canvas {display: block; width: 100%; min-height: 50vh;}

/* BROWSER *************************/
article#browser {font-size: 1vw;}
@media (max-width: 1500px) { article#browser {font-size: 1.5vw;} }
@media (max-width: 1000px) { article#browser {font-size: 2vw;} }
@media (max-width: 500px) { article#browser {font-size: 2.5vw;} }

article#browser.loader div.loader {display: block;}
article#browser div.loader {display: none; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);}
article#browser header button.back span {display: none;}
article#browser header button.back {
    display: none; width: 50px; height: 50px;
    position: absolute; top: 0; left: 0;
    background-color: transparent; background-repeat: no-repeat; background-position: center center; background-size: 60% auto;
    background-image: url('img/ico_back_b.svg');
    border: none; outline: none !important;
    cursor: pointer;
}
article#browser header button.back:hover, article#browser header button.back2:active {background-color: #fff;}

article#browser header button.selection {
    display: inline-block; width: auto; height: auto; border-radius: 30px;
    position: absolute; top: 12px; right: 15px;
    background-color: #333; background-repeat: no-repeat; background-position: center center; background-size: 60% auto;
    color: #fff; font-size: 14px; text-transform: uppercase; padding: 5px 20px;
    border-radius: 30px; border: none; outline: none !important;
    cursor: pointer;
    visibility: hidden;
}
article#browser header button.selection.show {visibility: visible;}
article#browser header button.selection:active {background-color: #0090B4;}
article#browser.rolls header button.selection {display: none;}

article#browser.rolls div.rolls_lst {display: block;}
article#browser div.rolls_lst {display: none;}
article#browser div.rolls_lst ol {
    display: flex; flex-direction: row; flex-wrap: wrap; justify-content: flex-start; align-items: flex-start; align-content: flex-start;
    list-style: none;
    padding: 1vw; 
}
article#browser div.rolls_lst ol li {display: block; width: 24.5vw; height: 12vw; position: relative; box-sizing: border-box;}
@media (max-width: 1500px) {article#browser div.rolls_lst ol li {width: 48vw; height: 20vw;}}
@media (max-width: 1000px) {article#browser div.rolls_lst ol li {width: 100vw; height: 32vw;}}
article#browser div.rolls_lst ol li img {display: none;}
article#browser div.rolls_lst ol li a {display: block; width: 100%; height: 100%; color: #fff; border-radius: 10px;}
article#browser div.rolls_lst ol li a:hover {background-color: #3c3c41;}
article#browser div.rolls_lst ol li a:active {background-color: #0090B4;}
article#browser div.rolls_lst ol li div.roll {
    display: block; width: 80%; height: 64%; position: relative; top: 11%; left: 16%; border-bottom-right-radius: 10px; border-top-right-radius: 10px;
    background-repeat: no-repeat; background-color: transparent; background-position: center center; background-size: cover;
   
}
article#browser div.rolls_lst ol li div.label {
    display: block; width: 100%; height: auto; position: absolute; bottom: 6%; left: 0; text-align: center; font-size: 1.2em;
}
article#browser div.rolls_lst ol li div.stats {
    display: block; width: 18%; height: 70%; background-color: #1e1e23; border-radius: 5px;
    position: absolute; top: 8%; left: 4%;
    -webkit-box-shadow: 0px 5px 15px -5px rgba(0,0,0,0.8);
    -moz-box-shadow: 0px 5px 15px -5px rgba(0,0,0,0.8);
    box-shadow: 0px 5px 15px -5px rgba(0,0,0,0.8);
}
article#browser div.rolls_lst ol li div.stats dl {
    display: block; width: 100%; height: auto; position: absolute; bottom: 0; left: 0; padding: 5%;
    font-size: .5em; font-family: 'Montserrat'; font-weight: 300; font-style: normal; color: #fff; text-align: center;
}
@media (max-width: 1000px) {article#browser div.rolls_lst ol li div.stats dl {font-size: .7em;}}
article#browser div.rolls_lst ol li div.stats dl dt {display: block; padding-top: 10%; text-transform: uppercase; text-transform: uppercase; overflow: hidden;}
article#browser div.rolls_lst ol li div.stats dl dd {display: block; padding-bottom: 10%; color: #fff; color: rgba(255,255,255,0.5); overflow: hidden;}
article#browser div.rolls_lst ol li div.stats dl dd strong {display: block; font-family: 'Montserrat'; font-weight: 300; font-style: normal; color: #fff; font-size: 2em;}
@media (max-width: 1500px) {article#browser div.rolls_lst ol li div.stats {width: 15%;}}
@media (max-width: 1000px) {article#browser div.rolls_lst ol li div.stats {width: 12%;}}

article#browser div.rolls_lst div.no_items {display: none;}
article#browser div.rolls_lst ol:empty ~ div.no_items {display: block;}

article#browser.exposures div.exposures_lst {display: block;}
article#browser div.exposures_lst {display: none;}
article#browser.exposures header button.close {display: none;}
article#browser.exposures header button.back {display: block;}
article#browser div.exposures_lst div.header {
    display: flex; flex-direction: row; flex-wrap: nowrap; justify-content: space-between; align-items: center;
    width: 100%; padding: .5vw;
    background-color: #3c3c41; color: #fff; font-size: 
}
article#browser div.exposures_lst div.header div.info {display: inline-block; font-size: 14px;}
article#browser div.exposures_lst div.header div.info span.title {font-weight: 500; color: #e8bd3e;}
article#browser div.exposures_lst div.header button.selected_all {display: inline-block; border-radius: 15px; margin: 0 5px; border: 1px solid #fff; padding: 0 1vw; background-color: transparent; text-transform: uppercase; text-decoration: none; font-size: 12px; color: #fff; text-align: center; cursor: pointer;}
article#browser div.exposures_lst div.header button.selected_all:hover {background-color: #e8bd3e; color: #28282d; border-color: #e8bd3e;}
article#browser div.exposures_lst div.header button.selected_all:active {background-color: #0090B4; color: #fff; border-color: #0090B4;}
article#browser div.exposures_lst ol {
    display: flex; flex-direction: row; flex-wrap: wrap; justify-content: flex-start; align-items: flex-start; align-content: flex-start;
    list-style: none;
    padding: 1vw;
}
article#browser div.exposures_lst ol li {display: block; width: 9.8vw; height: 9.8vw; position: relative;}
article#browser div.exposures_lst ol li img, article#browser div.exposures_lst ol li input[type="checkbox"], section#browser ol li label span {display: none;}
article#browser div.exposures_lst ol li label {
    display: block; width: 9vw; height: 9vw; position: relative; top: .5vw; left: .5vw; border-radius: 1vw; border: .3vw solid #3c3c41;
    background-color: transparent; background-repeat: no-repeat; background-position: center center; background-size: cover;
    cursor: pointer;
}
article#browser div.exposures_lst ol li label span {display: none;}
article#browser div.exposures_lst ol li label::after {
    display: block; content: ""; width: 2vw; height: 1vw; border-left: .5vw solid #fff; border-bottom: .5vw solid #fff;
    -webkit-box-shadow: -0.3vw 0.3vw 0.2vw 0px rgba(0,0,0,0.3); -moz-box-shadow: -0.3vw 0.3vw 0.2vw 0px rgba(0,0,0,0.3); box-shadow: -0.3vw 0.3vw 0.2vw 0px rgba(0,0,0,0.3);
    position: absolute; bottom: 1.8vw; left: 1.3vw;
    transition: all .5s ease-out; opacity: 0; transform: rotate(-40deg) scale(1.5);
}
article#browser div.exposures_lst ol li label::before {
    display: block; content: ""; width: 2.6vw; height: 2.6vw; border-radius: .7vw; background-color: rgba(0,144,180,.8);
    position: absolute; bottom: .8vw; left: .8vw;
    transition: all .2s ease-out; opacity: 0; transform: scale(.1);
}
article#browser div.exposures_lst ol li input[type="checkbox"]:checked + label {border: .3vw solid #0090B4;}
article#browser div.exposures_lst ol li input[type="checkbox"]:checked + label::before {opacity: 1; transform: scale(1);}
article#browser div.exposures_lst ol li input[type="checkbox"]:checked + label::after {opacity: 1; transform: rotate(-40deg) scale(1);}

/* MODAL *****************/
section.modal {
    display: none; width: 100%; height: 100%; overflow-y: auto; box-sizing: border-box; padding-top: 50px;
    position: fixed; top: 0; left: 0; z-index: 300;
    background-color: #46464b; background-color: rgba(70,70,75,.95); background-repeat: no-repeat; background-size: cover;
    
    /*overflow: auto;*/
    overscroll-behavior-y: contain;
    /* overflow-y: scroll; has to be scroll, not auto */
    /*-webkit-overflow-scrolling: touch;*/
}
section.modal header {
    display: block; width: 100%; height: 50px;
    position: fixed; top: 0; left: 0; z-index: 100;
    background-color: #e8bd3e;
}
section.modal header h1 {display: block; font-size: 25px; width: 100%; text-align: center; color: #28282d; padding-top: 10px; text-transform: uppercase;}
section.modal div.container article div.content h2 {font-family: 'Montserrat'; font-weight: 300; font-style: normal; text-transform: uppercase; color: #fff; font-size: 28px; line-height: 28px; padding-bottom: 2vh; margin-bottom: 3vh; text-align: center; position: relative;}
section.modal div.container article div.content h2:not(.no_underline)::before {display: block; content:""; width: 20%; height: 2px; background-color: #b4b4b9; position: absolute; bottom: 0; left: 50%; transform: translateX(-50%);}
section.modal div.container article div.content h2.no_underline {margin-bottom: 0;}

section.modal button.close span {display: none;}
section.modal button.close {
    display: block; width: 50px; height: 50px;
    position: absolute; top: 0; left: 0;
    background-color: transparent; background-repeat: no-repeat; background-position: center center; background-size: 60% auto;
    background-image: url('img/ico_back_b.svg');
    border: none; outline: none !important;
    cursor: pointer;
}
section.modal button.close:hover, section.modal button.close:active {background-color: #fff;}
article#fullimage button.close {background-image: url('img/ico_back.svg');}
article#fullimage button.close:hover, article#fullimage button.close:active {background-color: #000;}

section.modal div.container {display: block; width: 100%; height: 100%; position: relative;}
section.modal div.container > article {display: none;}
section.modal div.container article div.content {
    display: block; width: 500px; height: auto;
    position: relative; top: 10vh; left: 50%; transform: translateX(-50%);
    background-color: #28282d; padding: 2%;
    -webkit-box-shadow: 0px 30px 20px -20px rgba(0,0,0,0.5);
    -moz-box-shadow: 0px 30px 20px -20px rgba(0,0,0,0.5);
    box-shadow: 0px 30px 20px -20px rgba(0,0,0,0.5);
}

@media screen and (max-width: 500px) {section.modal div.container article div.content {width: 98%;}}

/* win tabs */
div.win_tabs {text-align: center;}
div.win_tabs > div.wtabcont {text-align: left;}
div.win_tabs > input[type="radio"],
div.win_tabs > div.wtabcont {display: none; margin-top: 2vh;}
div.win_tabs > label {display: inline-block; padding: 10px 20px 8px 20px; margin-bottom: 10px; background-color: #1e1e23; color: #828287; font-size: 18px; line-height: 16px; text-transform: uppercase; cursor: pointer; vertical-align: baseline;}
div.win_tabs > label.first {border-top-left-radius: 20px; border-bottom-left-radius: 20px;}
div.win_tabs > label.last {border-top-right-radius: 20px; border-bottom-right-radius: 20px;}
div.win_tabs > label:hover {color: #28282d; background-color: #e8bd3e;}
div.win_tabs > input:checked + label {color: #fff; background-color: #0090B4;}
div.win_tabs > input:checked + label:hover {}
div.win_tabs > input.wtab1:checked ~ .wtabcont.wtab1,
div.win_tabs > input.wtab2:checked ~ .wtabcont.wtab2,
div.win_tabs > input.wtab3:checked ~ .wtabcont.wtab3,
div.win_tabs > input.wtab4:checked ~ .wtabcont.wtab4 {display: block;}

/* show more */
div.show_more {position: relative;}
div.show_more > input[type="checkbox"] {display: none;}
div.show_more > label {display: inline-block; padding: .1em 1em; margin-top: 5px; color: #fff; background: #28282d; border-radius: 1.5em; font-size: .8em; text-transform: uppercase; cursor: pointer;}
div.show_more > label:hover, div.show_more > label:active {background-color: #b9007c;}
div.show_more input[type="checkbox"]:checked ~ label {display: none;}
div.show_more > div.showmore_cnt {display: block; position: relative; overflow: hidden; height: auto; max-height: 2.5em; transition: max-height 3s ease;}
div.show_more input[type="checkbox"]:checked ~ div.showmore_cnt {max-height: 50em;}
div.show_more > div.showmore_cnt::after {display: block; content: ""; width: 100%; height: 100%; position: absolute; bottom: 0; left: 0; z-index: 100;}
div.show_more input[type="checkbox"]:checked ~ div.showmore_cnt::after {display: none;}

div.header_tabs div.show_more > div.showmore_cnt::after {background: linear-gradient(to bottom, rgba(100,100,105,0) 0%, rgba(100,100,105,1) 100%);}

/* GENERAL MESSAGE *****************/
section#message.modal {background-color: #e8bd3e; background-color: rgba(232,189,62,0.95); color: #28282d; text-align: center; z-index: 400;}
section#message.modal header {background-color: #fff;}
section#message.modal button.close:hover, section#message.modal button.close:active {background-color: #e8bd3e;}
section#message.modal div.container > article {width: 90%; position: relative; top: 50%; left: 50%; transform: translate(-50%, -50%);}
article#msg {padding-top: 20vh; background: transparent url('img/ico_msg.svg') no-repeat top center; background-size: auto 16vh;}
article#msg h1 {display: block; padding-bottom: 3vh; font-size: 6vh; line-height: 6vh;}
article#msg div.message {display: block; padding-bottom: 2vh; font-size: 3.5vh;}
article#msg div.message p {display: block; padding-bottom: .5em;}
article#msg div.details {display: block; padding-bottom: 2vh; font-size: 2.5vh; text-align: right; color: #333;}
article#msg div.details label {display: inline-block; margin-bottom: 1vh; padding: 0 1vh 0 4vh; position: relative; color: #333; cursor: pointer; text-transform: uppercase;}
article#msg div.details label::before {display: block; content: ""; width: 3vh; height: 3vh; position: absolute; top: 0; left: 0; border-radius: 1.5vh; background-color: #333; background-image: url('img/ico_plus.svg'); background-repeat: no-repeat; background-position: center center; background-size: 50% auto;}
article#msg div.details label:hover {color: #fff;}
article#msg div.details label:hover::before {background-color: #fff; background-image: url('img/ico_plus_b.svg');}
article#msg div.details > div {display: none; text-align: center;}
article#msg div.details > div ul {display: inline-block;}
article#msg div.details > div ul li {text-align: left;}
article#msg div.details > div ul li em {color: #222;}
article#msg div.details > div div#list_errors {display: block; width: 100%; height: auto; position: relative; overflow-y: hidden; overflow-x: auto;}
article#msg div.details > div div#list_errors ul {display: flex; flex-direction: row; flex-wrap: nowrap; justify-content: flex-start; align-items: stretch; list-style: none; width: auto; height: auto; font-size: 2vh; color: #fff; text-align: center; padding-bottom: 1vh;}
article#msg div.details > div div#list_errors ul li {display: block; height: auto; width: auto; margin: 0 .2vw; background-color: #28282d; flex: 0 0 auto; max-width: 25rem;}
article#msg div.details > div div#list_errors ul li::after {display: block; content: ""; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-color: transparent; z-index: 1;}
article#msg div.details > div div#list_errors ul li img {display: block; height: auto; width: auto; max-height: 15vh; max-width: 100%; margin: 0 auto; padding: .2vw;}
article#msg div.details > div div#list_errors ul li span {display: block; width: 100%; height: auto; padding: .2vw; position: relative; text-align: center;}
article#msg div.details > div div#list_errors ul li span::after {content: ""; position: absolute; bottom: 100%; left: 50%; transform: translateX(-50%); border-width: 2.5vh; border-style: solid; border-color: transparent transparent #28282d transparent;}
article#msg div.details input[type='checkbox'] {display: none;}
article#msg div.details input[type='checkbox']:checked ~ div {display: block;}
article#msg div.details input[type='checkbox']:checked ~ label::before {background-image: url('img/ico_minus.svg');}
article#msg div.details input[type='checkbox']:checked ~ label:hover::before {background-image: url('img/ico_minus_b.svg');}
article#msg div.buttons {display: block; margin-top: 2vh;}
article#msg button {display: block; font-size: 3vh; margin: 0 auto; border: .4vh solid #28282d; padding: 2vh 4vw; border-radius: 4vh; font-size: 3vh; cursor: pointer; background-color: #fff; background-color: transparent; color: #28282d; text-transform: uppercase;}
article#msg button.cancel {margin: 2vh auto 0 auto; font-size: 2.5vh; background-color: transparent; border: none; color: #28282d;}
article#msg button:hover {background-color: #28282d; color: #fff;}
article#msg button:active {background-color: #0090B4; border: .4vh solid #0090B4; color: #fff;}

/* FLASH MESSAGES *****************/
div#flash {
    display: inline-block; height: auto; width: auto;
    position: fixed; left: 50%; transform: translateX(-50%);
    opacity: 0; z-index: 450;
    text-align: center; font-size: 18px; color: #fff;
    padding: 5px 10px; background-color: #1e1e23; border-radius: 20px;
    visibility: visible;
}
div#flash.top {top: 50px; bottom: auto;}
div#flash.bottom {bottom: 50px; top: auto;}
div#flash.hidden {visibility: hidden;}

/* COOKIES BOX *****************/
div#cookies_box {
    display: block; width: 30%; height: auto; max-height: 90%; overflow-y: auto; font-size: .8em;
    position: fixed; left: 1em; bottom: 1em; z-index: 430;
    padding: 1em; background-color: #e8bd3e; background-color: rgba(232, 189, 62, .9); color: #1e1e23;
    border-radius: 1em;
    -webkit-box-shadow: 0px 0px 2em 0px rgba(0,0,0,0.5);
    -moz-box-shadow: 0px 0px 2em 0px rgba(0,0,0,0.5);
    box-shadow: 0px 0px 2em 0px rgba(0,0,0,0.5);
}
div#cookies_box p {padding-bottom: 1em;}
div#cookies_box div.row {padding: 0 !important;}
div#cookies_box div.row button {font-size: 1rem; height: auto; border-radius: 3em; padding: 0 .5rem; margin: 0 .5rem; border-width: .12rem;}
@media (max-width: 600px) {
    div#cookies_box {width: 90%; left: 50%; bottom: auto; top: calc(50px + 2rem); transform: translateX(-50%);}
    body.index div#cookies_box {}
}

/* SERVER MESSAGES *****************/
div#server_message {display: none;}

/* PAGE LOADER *****************/
div#page_loader {display: block; width: 100vw; height: 100%; position: fixed; top: 0; left: 0; z-index: 500; box-sizing: border-box; background: #28282d url('img/logo_jjiffy_wb.svg') no-repeat top 25vh center; background-size: 300px auto; background-color: rgba(40,40,45,.95);}
div#page_loader div.loader {display: block; margin: 80vh auto 0 auto; border: 3px solid rgba(0,0,0,.2); border-top: 3px solid #0090B4;}

/* LOG */
div#log {display: none; width: 100%; background-color: #000; color: #fff; padding: 5px; font-size: 14px; position: fixed; top: 5px; left: 5px; z-index: 550;} 