/* @override 
	https://rdg.drup.ch/themes/barrio5st/css/utilities.css?* */


	
	
/* +P
  __      ____
 /\ \    /\  _`\  
 \_\ \___\ \ \L\ \
/\___  __\\ \ ,__/
\/__/\ \_/ \ \ \/ 
    \ \_\   \ \_\ 
     \/_/    \/_/ 
     Yeah! 2021 plusproduit.com
     
     Barrio 5 subtheme CDN 06.02.21
*/
	
	
/* à mettre dans un bloc pour seven si images blanches avec fond transparent
    <style>
    .image-preview { background-color: #ccc; }
    </style>
*/

/*::-webkit-scrollbar {
    -webkit-appearance: none;
    width: 17px;
}

::-webkit-scrollbar-thumb {
    border-radius: 8px;
    background-color: rgba(0,0,0,.5);
    box-shadow: 0 0 1px rgba(255,255,255,.5);
}*/

#page-wrapper {
    position: relative;
    overflow: hidden;
}

/* @group LARGEUR */

.header .container-fluid,
.featured-top .container-fluid,
#main,
.site-footer .container-fluid,
.max-width,
.max-width-child > div,
.max-width-child-nopad > div,
.max-width-nopad {
    width: 100%;
    max-width: 1140px;
    margin-left: auto;
    margin-right: auto;
}
/* permet à bootstrap de gérer les pad en resp pour le header */
#main,
.max-width,
.max-width-child > div {
    padding-left: 15px;
    padding-right: 15px;
}

/* @end */



/* @group HELPERS */

/* Bootstrap*/
/* min-vh-100, vh-100 || w- 
   w-25, w-50, w-75, w-100, w-auto || h-
   float-left/right
   d-flex, justify-content-center/end/between/around, align-items-center/stretch */

/* class .fh pour un vrai vh 100 sur mobile > global.js */

.p-pady {
    position: relative;
    padding-top: 8vh;
    padding-bottom: 8vh;
}
.p-padx {
    padding-left: 5vw;
    padding-right: 5vw;
}
@media (max-width:767.98px) {
    .p-padx {
        padding-left: 15px;
        padding-right: 15px;
    }
}
.p-bg-cover {
    background-size: cover;
    background-position: center center;
}

/* classe pour les vues qui utilisent des col pour les rows
   + pour une views-row qui utlisent des cols
   + pour views infinite scroll
 */
.row-wrapper > .view-content,
.row-wrapper > .views-row-inner,
.row-wrapper-infinite .views-infinite-scroll-content-wrapper {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-right: -15px;
    margin-left: -15px;
}

/* @end */

/* @group CURSOR */

.p-cursor-link {
    cursor: pointer;
}
.p-cursor-zoomin {
    cursor: zoom-in;
}
.p-cursor-scroll {
    cursor: s-resize;
}
.p-cursor-close {
    cursor: e-resize;
}

/* @end */

/* @group OVERRIDE */

/* force les blocs à prendre toute la largeur */
.region .block,
.text-formatted {
    flex-grow: 1;
    width: 100%;
}
.user-login-form {
    max-width: 480px;
}
.dropbutton-wrapper,
.dropbutton-wrapper.open {
    max-width: 250px;
    margin: 1em auto;
}
.site-footer__top .nav {
    flex-direction: column;
}
.site-footer .navbar-brand {
    margin: 0;
}

/* image embed ckeditor */
.align-center {
    margin-bottom: 1rem;
}
@media (min-width:767px) {
    .align-left,
    .align-right {
        width: 47%;
    }
    .align-right {
        margin: 0 0 1rem 3%;
    }
    .align-left {
        margin: 0 3% 1rem 0;
    }
}

/* media avec caption */
.caption {
    width: 100%;
}

/* annule le style bs des listes pour les champs multiples */
.list-group {
    display: block;
    list-style-type: disc;
    padding-left: 1.4rem;
}
.list-group-item {
    display: list-item;
    background: transparent;
    border: 0 none;
}

/* @end */


/* @group NAVBAR */

.nav-link {
    outline: 0 none;
}
/* header form - zone à droite navbar  - anti row */
#navbar-main .navbar-form {
    padding-left: 15px;
}
.navbar-toggler {
    /* js > remplacé par un p-btn p-incon-burger */
    margin-right: 13px;
}

/* sticky-top ne marche pas > utiliser affix mais moins fluide que fixed-top */
.fixed-top,
.affix {
  z-index: 399;
  position: fixed;
  left: 0;
  right: 0;
  top: 0;
}
.affix,
[data-toggle="affix"] {
    z-index: 398;
}

.toolbar-fixed .fixed-top,
.toolbar-fixed.scrolled.scrollup .fixed-top,
.toolbar-fixed .affix,
.toolbar-fixed.scrolled.scrollup .affix,
.toolbar-vertical .fixed-top {
    top: 39px;
}

.toolbar-tray-open.toolbar-horizontal .fixed-top,
.toolbar-tray-open.toolbar-horizontal.scrolled.scrollup .fixed-top,
.toolbar-tray-open.toolbar-horizontal .affix,
.toolbar-tray-open.toolbar-horizontal.scrolled.scrollup .affix {
    top: 79px;
}

/* dropdown */

.dropdown-item.active,
.dropdown-item:active,
.dropdown-item:focus,
.dropdown-item:hover {
    background-color: transparent;
}

/* anim triangle */
.dropdown-toggle::after {
    transition: transform 0.15s linear; 
}
.show.dropdown .dropdown-toggle::after {
    transform: translateY(2px);
}

/* @end */

/* @group PAGINATION */

.pagination {
    margin: 1rem 0;
}

/* reset pagination */
.page-link,
.page-item:first-child .page-link,
.page-item:last-child .page-link {
    background-color: transparent;
    border-radius: 0;
}
a.page-link:hover,
.page-item:first-child a.page-link:hover,
.page-item:last-child a.page-link:hover,
.page-item.active .page-link {
    background-color: rgba(255, 255, 255, 0.2);
    border-color: inherit;
}

/* @end */

/* @group OFF-CANVAS */

#p-offcanvas {
    z-index: 1499;
    position: fixed;
    left: 100%;
    top: 0;
    bottom: 0;
}
.p-offcanvas-overflow {
    height: 100vh;
    overflow: auto;
}
.p-offcanvas-content {
    overflow: hidden;
}
#p-offcanvas-cover {
    z-index: 1498;
    position: fixed;
    left: 0;
    right: 0;
    top: 100%;
    bottom: 0;
    opacity: 0;
    
    transition: top 0s .5s, opacity .5s;
}
.p-offcanvas-on #p-offcanvas-cover {
    opacity: 1;
    top: 0;
    
    transition: top 0s, opacity .5s;
}

#p-offcanvas .dropdown-menu {
    /* empêche l'absolute appliqué par script */
    position: static!important;
    transform: translate3d(0,0,0)!important;
}

/* Off-canvas btn */
#p-offcanvasbtn {
    position: fixed;
    right: 0;
    top: 5px;
    margin: 0px 12px 0 0;
    z-index: 1499;
}
.toolbar-fixed #p-offcanvasbtn {
    top: 39px;
}
.toolbar-tray-open #p-offcanvasbtn {
    top: 79px;
}


/* @group p-nav */

.p-nav ul.nav > li {
    margin-bottom: .4em;
}
.p-nav-parent {
    overflow: hidden;
    position: relative;
}
.p-nav-parent > .nav-link {
    margin-right: 2rem;
}
/* 2ème niveau */
.p-nav ul.menu {
    max-height: 0;
    padding: 0 0 0 1rem;
    list-style-type: none;
    background-color: rgba(255, 255, 255, .1);
}
.p-nav-parent ul.menu .nav-link {
    font-size: 1.2rem;
    line-height: 1.5;
}
/* 3ème niveau */
.p-nav ul.menu ul.menu {
    background-color: transparent;
    list-style-type: square;
    padding: 0 0 0 1.3rem;
}
.p-nav-parent ul.menu ul.menu .nav-link {
    font-size: 1rem;
    line-height: 1.8;
}

/* toggle */
.p-nav-open > ul.menu {
    max-height: 1000px;
    transition: max-height 2s;
}
button.p-nav-toggle {
    position: absolute;
    right: 0;
    top: 0;
    font-size: 1rem;
    line-height: 1;
    height: 2rem;
    width: 2rem;
    text-align: center;
    background-color: rgba(255, 255, 255, 0.1);
    border: 0 none;
    color: #fff;
    outline: 0 none;
}
button.p-nav-toggle:hover {
    background-color: rgba(255, 255, 255, .2);
}
.p-nav-open > .p-nav-toggle {
    transform: rotate(180deg);
}

/* @end */

/* @end */

/* @group ICON BUTTONS */

.p-btn {
    position: relative;
    z-index: 1;
    border-radius: 9%;
    border: 0 none;
    padding: 0;
    background: transparent;

    width: 50px;
    height: 50px;
}
.p-btn:focus {
    outline: 0 none;
}

.p-btn span {
    /*overflow: hidden;*/
    text-indent: -100px;
    opacity: 0;
}

.p-btn span,
.p-btn::before,
.p-btn::after {
    content: "";
    display: block;
    border-radius: 2px;
    position: absolute;
    top: 47%;
    left: 10%;
    height: 6%;
    width: 80%;

    background: #333;
}
.p-loaded .p-btn span,
.p-loaded .p-btn::before,
.p-loaded .p-btn::after {
    transition: .35s linear;
}
/* bg neg */
.bg-neg .p-btn {
    /*background-color: #fafafa;*/
}
.bg-neg .p-btn span,
.bg-neg .p-btn::before,
.bg-neg .p-btn::after {
    background-color: #fafafa;
}

/* ^^ Arrow ^^^^^ */
.p-icon-arrow {
    transition: .35s;
}
.p-icon-arrow::before,
.p-icon-arrow::after {
    width: 60%;
}

.p-icon-arrow::before {
    transform: rotate(45deg);
    left: 40%;
}

.p-icon-arrow::after {
    transform: rotate(-45deg);
    left: 1%;
}

/* arrow orientation */
.p-icon-n {
    transform: rotate(0deg);
}

.p-icon-e {
    transform: rotate(90deg);
}

.p-icon-s {
    transform: rotate(180deg);
}

.p-icon-w {
    transform: rotate(270deg);
}


/* burger ---------- */

.p-icon-burger::before {
    top: 24%;
}

.p-icon-burger span {
    opacity: 1;
}

.p-icon-burger::after {
    top: 70%;
}

.p-icon-burger:hover::before {
    top: 15%;
}
.p-icon-burger:hover::after {
    top: 79%;
}

/* close ------------- */
.p-icon-close::before {
    transform: rotate(-45deg);
}

.p-icon-close::after {
    transform: rotate(45deg);
}

/* + plus ++++++++++++ */
.p-icon-plus::after {
    transform: rotate(90deg);
}

/* - moins ------------ */
.p-icon-minus::after {
    transform: rotate(0deg);
}

/* @end */

/* @group MODAL */

.p-modal-link a * {
    pointer-events: none
}

/* voile */
.p-modal {
    position: fixed;
    overflow: hidden;
    width: 100%;
    height: 100vh;
    left: 0;
    z-index: 1999;
    perspective: 100vh;

    bottom: -100vh;
    opacity: 0;
    
    transition: bottom 0s .5s, opacity .3s linear .1s;
}
.p-modal-open {
    opacity: 1;
    bottom: 0;

    transition: bottom 0s 0s, opacity .2s linear 0s;
}

/* fenêtre */
.p-modal-inner {
    position: relative;
    margin-left: auto;
    margin-right: auto;

    opacity: 0;
    transition: .5s linear .1s;
}
.p-modal-open .p-modal-inner {
    opacity: 1;
    transition: .5s ease-out .2s;
}
.p-modal-overflow {
    overflow: auto;
}

/* btn close xxxxxxxxxxx */
.p-modal-close {
    position: absolute;
    right: 0;
    top: 0;
    margin: 3px 20px 0 0;
    z-index: 2000;
}

/* @end */

/* @group ACCORDION */
.p-accordion .group-title {
    position: relative;
    padding: 1rem 55px 1rem 15px;
}
.p-accordion .group-title > * {
    margin: 0;
    padding: 0;
}
.p-accordion .group-rows {
    overflow: hidden;
}
.p-accordion .p-btn {
    position: absolute;
    right: 15px;
    top: 8px;
    width: 40px;
    height: 40px;
}

/* @end */

/* @group TABS */

.p-tabs {
    position: relative;
    display: flex;
}

.p-tabs .view-content {
    display: flex;
    position: relative;
}

.p-tabs .group-title {
    position: relative;
    text-align: center;
    display: flex;
    align-items: center;
    z-index: 1;
    top: 1px;
}

.p-tabs .group-rows {
    display: none;
    position: absolute;
    left: 0;
    right: 0;
}
.p-tabs-open .group-rows {
    display: block;
}

/* @end */

/* @group ALERTS */

/* Alerts classic - default colors */
.alert {
    opacity: 0.9;
    z-index: 3800;
    position: fixed;
    bottom: 0;
    right: 0;
    max-width: 440px;
    margin: 15px 15px 40px;
    padding-top: 1rem;
    border: 0 none;
    
    font-family: sans-serif;
    font-size: 16px;
    line-height: 1.2;
}
.alert hr {
    margin-top: 1em;
    margin-bottom: 1em;
}
.alert::before {
    float: left;
    margin-right: 5px;
    margin-top: -10px;
    margin-bottom: 15px;
}
.alert a {
    color: #fafafa;
    text-decoration: underline;
}
.alert a:hover {
    color: #fafafa;
}

/* @end */


/* @group NAV TABS */
nav.tabs {
    position: fixed;
    bottom: -1px;
    right: 15px;
    z-index: 3801;
    margin-bottom: 0;
    background: rgba(255, 255, 255, 0.95);
    border-top-left-radius: .25rem;
    border-top-right-radius: .25rem;
    border: 1px solid #aaa;
}

.nav-tabs > li > a {
    text-transform: uppercase;
    font-weight: 700;
    letter-spacing: .05em;
    font-size: 13px;
    padding: 0.6em 0.5em;
    color: #777;
}
.nav-tabs > li > a:hover {
    color: #222;
    background-color: rgba(255, 255, 255, 0.8);
}
.nav-tabs.primary .active {
    display: none;
}

/* @end */


/* @group MAINTENANCE */

.maintenance-page {
    background-color: #333;
    min-height: 100vh;
}
.maintenance-page #header {
    text-align: center;
}
.maintenance-page #page {
    background-color: #fafafa;
    text-align: center;
    margin: 15vh auto;
    padding: 2rem 0;
    max-width: 580px;
    box-shadow: 0 10px 15px rgba(0, 0, 0, 0.4);
}

/* @end */