/*custom css for Cassiopea color Ateliercas2 - OPTIMISED version*/

/*creation de 2 override pour chaque langage pr modif footer copyright*/

/* importation https://web-eau.net/en/development/joomla-overrides/offcanvas-menu 
et modification offcanvas-menu.php*/

/*changer les couleurs principales dans color_alternative.css/min/gz)
/*les couleurs oof-canvas sont definies inline offcanvas-menu.php */

/* 1. Google Fonts Import */
@import url('https://fonts.googleapis.com/css2?family=Open+Sans:wght@300;400;600;800&display=swap');

/* 1.1 Base Typography */
body {
    font-family: 'Open Sans', sans-serif;
    font-weight: 300;
}

/* 2. Header Styles */
.container-header {
    background: #fff;
    box-shadow: 0 3px 3px rgba(0,0,0,0.05);
}

.container-headerabove,
.container-abovetop {
    background-color: var(--cassiopeia-color-primary);
}

.container-abovetop {
    display: flex;
    width: 100%;
    max-width: 1320px;
    margin: 0 auto;
    padding: 1em 1em 0 1em;
}

.container-topbar {
    display: flex;
    justify-content: flex-end;
    width: 100%;
    max-width: 1320px;
    margin: 0 auto;
    padding-bottom: 1em;
    background-color: var(--cassiopeia-color-primary);
}

div.mod-languages a {
    font-weight: 800;
    font-size: 0.9em;
}

div.mod-languages ul li.lang-active {
    background: none;
    color: var(--cassiopeia-color-link);
}

.container-header .container-nav {
    padding-top: 1.5em;
}

.container-header .navbar-brand a {
    text-decoration: none;
    font-family: 'Open Sans', sans-serif;
    color: var(--cassiopeia-color-link);
    font-size: 24px;
    font-weight: 800;
}

.container-header .navbar-brand a:hover {
    color: var(--cassiopeia-color-primary);
}

.container-header .site-description {
    color: var(--cassiopeia-color-primary);
    font-weight: 400;
}

.container-header .mod-menu {
    justify-content: flex-end;
}

/* 3. Menu Styles */
.metismenu.mod-menu .metismenu-item {
    color: #212529;
    text-transform: uppercase;
    font-weight: 600;
    font-size: 0.9em;
}

.metismenu.mod-menu .metismenu-item:hover,
.metismenu.mod-menu .metismenu-item:focus {
    color: var(--link-hover-color);
}

.metismenu.mod-menu .metismenu-item.current > a,
.metismenu.mod-menu .metismenu-item.current > button {
    text-decoration: underline;
}
/* 3.1. Article Grid Layout & Portfolio */

.container-art-container {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0 2em;
  margin-top: 20px;
}

.container-art-container > * {
  min-width: 0;
}

.grid-item-full { grid-column: 1 / span 4; }
.grid-item-left { grid-column: 1 / span 2; }
.grid-item-right { grid-column: 3 / span 2; }
.grid-item-right-inner { grid-column: 1 / span 4; }
.grid-item-3  { grid-column: 1 ; }
.grid-item-4  { grid-column: 2 /span 3; }
.grid-item-full,
.grid-item-left,
.grid-item-right,
.grid-item-right-inner,
.grid-item-3,
.grid-item-4 {
  display: grid;
  gap: 0 1em;
}
/* 4. Social Icons */
.fa.fa-linkedin:before {
    color: #fff;
    font-size: 1em;
}

/* 5. Footer */
.footer {
    background: var(--cassiopeia-color-primary);
    text-align: center;
    padding: 1em 0;
}

.footer .grid-child {
    justify-content: center;
}

/* 6. Article Elements */
.linedivider {
    margin-top: 0.1em;
    border-bottom: 1px solid #ccc;
}
.image-container {
  padding: 0 0 10px 0;
  width: 350px;
  height: 100%;
  object-fit: cover;
}
.image-container-small {
  padding: 0 0 10px 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.image-container-bottom {
  display: none;
}

/* 7. Offcanvas Menu */
.container-header .navbar-toggler {
    color: #000000;
}

.navbar-toggler {
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
    background-color: transparent;
}

/* Close button (white SVG) */
.btn-close {
    --btn-close-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23ffffff'%3e%3cpath d='M.293.293a1 1 0 0 1 1.414 0L8 6.586 14.293.293a1 1 0 1 1 1.414 1.414L9.414 8l6.293 6.293a1 1 0 0 1-1.414 1.414L8 9.414l-6.293 6.293a1 1 0 0 1-1.414-1.414L6.586 8 .293 1.707a1 1 0 0 1 0-1.414z'/%3e%3c/svg%3e");
}
.offcanvas {
  width: 80vw !important; 80% of viewport width */
}

/* 8. Responsive Styles */
@media screen and (max-width: 767px) {
    body {
        font-weight: 400 !important;
        display: flex !important;
        flex-wrap: wrap;
    }
    .container-header {
        position: sticky !important;
        top: auto !important;
    }
    .container-abovetop {
        justify-content: center;
    }
    .fa.fa-linkedin:before {
        font-size: 1.5em;
    }

    .metismenu.mod-menu .metismenu-item {
        font-weight: 800;
        font-size: 0.9em;
    }
	  /* Article grid: stack items vertically */
	
	.container-art-container {
		grid-template-columns: minmax(0, 1fr);
		gap: .5em 0;
	}
	.grid-item-full,
	.grid-item-left,
	.grid-item-right,
	.grid-item-right-inner,
	.grid-item-3,
	.grid-item-4 {
		grid-column: 1 !important;
		margin: 1em 0;
		width: 100%;
	}
}
