msos/css/layout/_header.css

256 lines
5.8 KiB
CSS

/* ==========================================================================
Header Styles
========================================================================== */
/**
* Ta datoteka vsebuje stile za glavo (header) spletne strani.
*
* 1. Glavni kontejner za glavo
* 2. Vsebina glave (logotip, namizna navigacija)
* 3. Gumbi in akcije v glavi (vključno z izbiro jezika)
* 4. Stili za mobilno glavo in navigacijo
*/
/* 1. Glavni kontejner za glavo */
.dropdown-header-navigation {
position: absolute;
width: 100%;
height: 80px;
background: #FFFFFF;
border-bottom: 1px solid #F2F4F7;
display: flex;
justify-content: center;
align-items: center;
z-index: 1000;
}
/* 2. Vsebina glave (logotip, namizna navigacija) */
.header-content {
display: flex;
align-items: center;
gap: 40px;
}
.logo-link .logo-img {
height: 32px;
width: auto;
}
.navigation.desktop-nav {
display: flex;
gap: 32px;
}
.navigation a {
text-decoration: none;
color: #667085;
font-weight: 600;
font-size: 16px;
padding: 4px 0;
}
/* 3. Gumbi in akcije v glavi */
.navigation-actions {
display: flex;
align-items: center;
gap: 24px;
}
/* Stili za izbiro jezika */
.language-selector {
position: relative;
cursor: pointer;
}
.current-lang {
display: flex;
align-items: center;
gap: 8px;
color: #646E82;
padding: 8px; /* Dodan enakomeren padding za lažji klik */
border-radius: 6px; /* Rahlo zaobljeni robovi za lepši videz */
transition: background-color 0.2s ease-in-out;
}
.current-lang:hover {
background-color: #F9FAFB; /* Svetlo ozadje ob prehodu z miško */
}
.current-lang span {
font-weight: 600;
}
.current-lang .fa-chevron-down {
transition: transform 0.3s ease-in-out; /* Animacija puščice */
}
.lang-dropdown {
display: block; /* Meni je vedno v DOM-u, vidnost nadzorujemo drugače */
position: absolute;
top: calc(100% + 8px); /* Postavi se pod sprožilec z majhnim odmikom */
right: 0;
background-color: #FFFFFF;
border: 1px solid #EAECF0;
border-radius: 8px;
box-shadow: 0 8px 16px rgba(0,0,0,0.08);
padding: 8px;
z-index: 1001;
min-width: 180px;
/* Tranzicije za gladek prikaz in izginotje */
opacity: 0;
visibility: hidden;
transform: translateY(10px);
transition: opacity 0.3s ease, transform 0.3s ease, visibility 0.3s;
}
/* Stanje, ko je menjalnik jezika odprt (aktiven) */
.language-selector.active .lang-dropdown {
opacity: 1;
visibility: visible;
transform: translateY(0);
}
.language-selector.active .current-lang .fa-chevron-down {
transform: rotate(180deg); /* Zasuka puščico navzgor */
}
.lang-dropdown a {
display: block;
padding: 10px 12px;
color: #344054;
text-decoration: none;
font-weight: 500;
font-size: 16px;
white-space: nowrap;
border-radius: 6px;
}
.lang-dropdown a:hover {
background-color: #F9FAFB;
}
/* 4. Skrivanje mobilnih elementov na namizju */
.mobile-menu-icon {
display: none;
}
.mobile-nav-panel {
display: none;
}
/* ==========================================================================
Mobile Header Styles
========================================================================== */
@media (max-width: 768px) {
.dropdown-header-navigation {
position: fixed;
top: 0;
left: 0;
right: 0;
height: 60px;
box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.06);
border-bottom: none;
z-index: 1002; /* Biti mora nad panelom, ki ima 1001 */
}
/* Skrij namizne elemente */
.navigation.desktop-nav {
display: none;
}
.dropdown-header-navigation .container > .navigation-actions {
display: none;
}
/* Prikaži mobilno ikono */
.mobile-menu-icon {
display: block;
font-size: 24px;
color: #101828;
cursor: pointer;
z-index: 1002;
}
.mobile-menu-icon .fa-times {
display: none;
}
body.nav-open .mobile-menu-icon .fa-bars {
display: none;
}
body.nav-open .mobile-menu-icon .fa-times {
display: block;
}
/* Stiliziraj mobilni panel */
.mobile-nav-panel {
display: flex;
flex-direction: column;
align-items: center;
justify-content: flex-start;
gap: 48px;
position: fixed;
top: 60px; /* Začne se pod glavo */
left: 0;
width: 100%;
height: calc(100vh - 60px);
background: #FFFFFF;
padding: 40px 24px;
box-sizing: border-box;
transform: translateX(100%);
transition: transform 0.3s ease-in-out;
z-index: 1001; /* Pod glavo, a nad vsebino strani */
overflow-y: auto;
}
/* Logika za odpiranje panela */
body.nav-open .mobile-nav-panel {
transform: translateX(0);
}
.mobile-nav-panel .navigation.mobile-nav {
display: flex;
flex-direction: column;
align-items: center;
gap: 24px;
}
.mobile-nav-panel .navigation a {
font-size: 20px;
color: #101828;
}
.mobile-nav-panel .navigation-actions {
display: flex; /* Mora biti flex za prikaz vsebine */
flex-direction: column;
align-items: center;
gap: 16px;
width: 100%;
}
.mobile-nav-panel .navigation-actions .btn {
width: 100%;
max-width: 300px;
}
.mobile-nav-panel .language-selector {
margin-top: 16px;
text-align: center; /* Poskrbi za poravnavo dropdown menija */
}
/* Na mobilnih napravah dropdown meni potrebuje malo drugačno pozicijo */
.mobile-nav-panel .lang-dropdown {
left: 50%;
transform: translateX(-50%); /* Centriranje menija pod ikono */
right: auto;
/* Tranzicije so podedovane iz namizne različice */
}
}