/* @override 
	https://demo.drup.ch/themes/custom/stable9plus/css/global.css?* */


	
/* +P
  __      ____
 /\ \    /\  _`\  
 \_\ \___\ \ \L\ \
/\___  __\\ \ ,__/
\/__/\ \_/ \ \ \/ 
    \ \_\   \ \_\ 
     \/_/    \/_/ 
     Yeah! 2022 plusproduit.com
     
     stable9plus subtheme 22.07.12
*/
	
	
/* à 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;
}
#page {
    position: relative;
}

/* @group LARGEUR */

.max-width,
.max-width-child > div,
.max-width-nopad,
.max-width-nopad-child > div {
    width: 100%;
    max-width: 1140px;
    margin-left: auto;
    margin-right: auto;
}
/* permet à bootstrap de gérer les pad en resp pour le header
  >>>>>>> gouttières !
  override bs5 pour homogénéiser les gouttières, corriger .row aussi
*/
.container,
.container-fluid,
.col-pad,
.row > *,
.max-width,
.max-width-child > div,
.row-wrapper > * > *,
.row-wrapper-view-content .view-content > *,
.row-wrapper-infinite .views-infinite-scroll-content-wrapper > * {
    padding-left: 15px;
    padding-right: 15px;
}

/* classe pour les vues qui utilisent des col pour les rows
   + pour une views-row qui utilise des cols
   + pour views infinite scroll
 */
.row, 
.row-wrapper > *,
.row-wrapper-view-content .view-content,
.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;
}
.row-wrapper > .contextual {
    display: block;
}

/* @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 */

/* video embed bs5 : classes du parent => ratio ratio-16x9 */

/* class .p-fh pour un vrai vh 100 sur mobile > à activer dans global.js */


.p-pady {
    position: relative;
    padding-top: 6vh;
    padding-bottom: 6vh;
}
.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;
}

/* @group OVERRIDE */

.user-login-form {
    max-width: 480px;
}
.dropbutton-wrapper,
.dropbutton-wrapper.open {
    max-width: 250px;
    margin: 1em auto;
}

/* @end */

/* @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 CKEDITOR EMBED IMG */

/* 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%;
}

/* @end */


/* @group NAVBAR */

/* 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-vertical .fixed-top {
    top: 39px;
}

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

/* @end */


/* @group OFF-CANVAS */

#p-offcanvas {
    z-index: 1499;
    position: fixed;
    left: 100%;
    top: 0;
    bottom: 0;
	
	width: 100%;
}
.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;
}

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

/* @end */

/* @group MULTILEVEL NAV - P-NAV */

.p-nav ul.nav {
    flex-direction: column;
}
.p-nav ul.nav > li {
    margin-bottom: .4em;
}
.p-nav-parent {
    overflow: hidden;
    position: relative;
}

.p-nav .nav-link {
    padding: .3em 0 .4em;
    line-height: 1.2;
}
.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);
    
    transition: max-height .3s;
}

/* 3ème niveau */
.p-nav ul.menu ul.menu {
    background-color: transparent;
    list-style-type: square;
    padding: 0 0 0 1.3rem;
}

/* toggle */
.p-nav-open > ul.menu {
    max-height: 1000px;
    transition: max-height 2s;
}
button.p-nav-toggle {
    position: absolute;
    right: .4em;
    top: .3em;
    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: #fafafa;
    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 */

/* @group ICON BUTTONS - P-BTN */
/* fond transparent par défaut, ajouter p-btn-bg pour avoir un fond */

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

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

.p-btn span {
    overflow: hidden;
    text-indent: -200px;
    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-bg {
    background-color: #333;
}
.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;
}
.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-on {
    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-on .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-wrapper {
    opacity: 0.9;
    background: #eee;
	color: #333;
	font-size: 14px;
    z-index: 3800;
    position: fixed;
    bottom: 100px;
    right: 0;
    width: 300px;
    margin: 15px 15px 40px;
    padding: 1rem;
    border: 0 none;
    border-radius: 1rem;
	cursor: help;
	box-shadow: 0px 3px 5px rgba(0,0,0,0.3);
    
    transition: right 1s 3s;
}
.alert-wrapper .placeholder {
    background: transparent;
}
.p-loaded .alert-wrapper {
    right: -300px;
}
.p-loaded .alert-wrapper:hover {
	right: 0;
	transition-delay: 0s;
}

/* @end */


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

.block-local-tasks-block .nav-item > a {
    display: inline-block;
    text-transform: uppercase;
    text-decoration: none;
    font-weight: 700;
    letter-spacing: .05em;
    font-size: 13px;
    padding: .8em 0.5em 1.2em;
    color: #777;
    border-radius: .25rem .25rem 0 0;
}
.block-local-tasks-block .nav-item > a.is-active {
    display: none;
}
.block-local-tasks-block .nav-item > a:hover {
    color: #222;
    background-color: rgba(255, 255, 255, 0.8);
}

/* @end */


/* @group MAINTENANCE */

.maintenance-page {
    padding: 15vh 15px;
}

.maintenance-page header,
.maintenance-page main {
    background-color: #fafafa;
    text-align: center;
    box-shadow: 0 5px 20px rgba(0, 0, 0, 0.4);
    padding: 15px;
    margin: 0 auto;
    max-width: 580px;
}

/* @end */