/**
    * Master CSS file for the "domovbystre.cz" website.
    * @author: Halva Jindřich
    * @date: 07/2025
    *
*/

/*******************************************************************DEFAULT*/

* {
    box-sizing: border-box !important;
    scrollbar-width: thin;    
}

:root {
    --font-default: 'Open Sans', sans-serif;
    --color-dark: #000000;
    --color-light: #ffffff;
    --color-main-red: #b11728;
    --color-gray: #b2adac;
    --color-dark-gray: #6c6c6c;
    --color-accent-main: var(--color-main-red);
    --color-text: var(--color-dark);
    --color-headlines: var(--color-accent-main);
    --color-link: var(--color-accent-main);
    --color-headlines: var(--color-accent-main);
    --color--succ-bg: #64BAAA;
    --color--succ: #ffffff;
    --color--err-bg: #951200;
    --color--err: #ffffff;
    --content-space: var(--content-padding);
    --block-space: 1.5rem;
    --page-max-width: 2000px;
    --content-padding: 6.5rem;
    --menu-padding: 5.9rem;
  }

html {
    scroll-behavior: smooth;
    font-size: 17px;
    font-family: var(--font-default);
    line-height: 1.5;
    color: var(--color-text);
}
  
textarea,
input {
    font-family: var(--font-default);
}

img {
    max-width: 100%;
}

strong,
b {
  font-weight: bold;
}

em {
  font-style: italic;
}

sub {
  vertical-align: sub;
  font-size: smaller;
}

sup {
  vertical-align: super;
  font-size: smaller;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  display: block;
  font-family: var(--font-default);
  color: var(--color-headlines);
  font-weight: 600;
  margin-block-start: .5em;
  margin-block-end: .5em;
  margin-inline-start: 0px;
  margin-inline-end: 0px;
  line-height: 1.1;
}

h1 {
  font-size: 3rem;
}

h2 {
  font-size: 2.5rem;
}

h3 {
  font-size: 2.2rem;
}

h4 {
  font-size: 2rem;
}

h5 {
  font-size: 1.6rem;
}

h6 {
  font-size: 1.2rem;
}

p {
    display: block;
    font-size: 1rem;
    margin-block-start: .5em;
    margin-block-end: .5em;
    margin-inline-start: 0px;
    margin-inline-end: 0px;
    line-height: 1.5;
}
  
ul {
    display: block;
    list-style-type: none;
    margin-block-start: 1em;
    margin-block-end: 1em;
    margin-inline-start: 0px;
    margin-inline-end: 0px;
    padding-inline-start: 2em;
}

ol {
    display: block;
    list-style-type: decimal;
    margin-block-start: 1em;
    margin-block-end: 1em;
    margin-inline-start: 0px;
    margin-inline-end: 0px;
    padding-inline-start: 2em;
}
  
li {
    margin-block-start: 1em;
    margin-block-end: 1em;
    line-height: 1.2;
}
  
ul li {
    position: relative;
}

.disc {
    list-style-type:disc;
}
  
a {
    color: var(--color-link);
    text-decoration: none;
}

.height-auto {
    height: auto;
}

.content-width {
    max-width: var(--page-max-width);
    margin-left: auto;
    margin-right: auto;
}
  
.content-margin {
    margin-left: var(--content-space);
    margin-right: var(--content-space);
}
  
.content-margin--left {
    margin-left: var(--content-space);
}
  
.content-margin--right {
    margin-right: var(--content-space);
}
  
.content-padding {
    padding-left: var(--content-space);
    padding-right: var(--content-space);
}
  
.content-padding--left {
    padding-left: var(--content-space);
}

.content-padding--right {
    padding-right: var(--content-space);
}
  
.content-padding--double {
    padding-left: calc(2 * var(--content-space));
    padding-right: calc(2 * var(--content-space));
}
  
.block-margin {
    margin-top: var(--block-space);
    margin-bottom: var(--block-space);
}
  
.block-margin--top {
    margin-top: var(--block-space);
}
  
.block-margin--bottom {
    margin-bottom: var(--block-space);
}
  
.block-margin--double {
    margin-top: calc(2 * var(--block-space));
    margin-bottom: calc(2 * var(--block-space));
}

.block-padding {
    padding: var(--block-space);
}
  
.block-padding--top {
    padding-top: var(--block-space);
}
  
.block-padding--bottom {
    padding-bottom: var(--block-space);
}
  
.page--error {
    margin: 5rem 0;
}
  
.page--error__headline {
    font-size: 2rem;
    text-align: center;
}
  
.page--error__subheadline {
    font-size: 1.5rem;
    font-weight: 300;
    text-align: center;
}

.page-title {
    border-bottom: var(--color-main-red) 4px solid;
    padding-bottom: .2em;
    margin-bottom: 3rem;
    width: max-content;
}

.page-title-sluzby {
    color: var(--color-gray);
    margin-block-start: 0;
    margin-block-end: 0;
}

.page {
    min-height: 100vh;
}

/**************************************************************************BODY*/

body {
    position: relative;
    min-width: 320px;
    margin: auto;
    box-shadow: 0px 3px 10px rgba(0,0,0,0.2);
    background-color: var(--color-light);
}

/*******************************************************************HEADER_PANEL*/

header {
    position: relative;
    width: 100%;
    height: auto;
    z-index: 1000;
    box-shadow: 0px 0px 10px rgba(0,0,0,0.25);
}

.sub-button-div {
    padding: 10px var(--menu-padding);
    display: flex;
    align-items: center;
    justify-content: flex-end;
}

.sub-button {
    display: flex;
    align-items: center;
}

.fb-icon {
    color: #ffffffdf;
    font-size: 1.7em;
    margin-right: 0.5em;
    transition: all 0.2s ease;
}

.fb-icon:hover {
    color: var(--color-light);
    text-shadow: 1px 2px 5px rgba(0,0,0,0.3);
}

.header-menu__red {
    background-color: var(--color-main-red);
    background-image: url(../img/header_bg.png);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.header-menu__cnt {
    background-color: var(--color-light);
    position: relative;
}

.main-logo{
    width: 300px;
    height: auto;
    position: absolute;
    top: -15px;
    left: 1.8rem;
    transition: all 0.2s ease;
}

.main-logo:hover {
    transform: scale(1.05);
}

.menu-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: end;
    align-items: center;
    padding: 45px var(--menu-padding) 10px;
}

.submenu-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: start;
    align-items: center;
    padding: 0px var(--menu-padding) 10px;
}

.menu-item {
    position: relative;
    margin: 0 1px;
    padding: 7px 12px;
    border-radius: 20px;
    transition: all 0.8s ease;
    cursor: pointer;
}

.menu-item__drop {
    color: var(--color-light);
    margin: 0 1px;
    padding: 7px 12px;
    border-radius: 20px;
    cursor: pointer;
}

.sluzby-container {
    position: relative;
}

.sluzby-container i {
    font-size: 0.75em;
}

.sluzby-window {
    visibility: hidden;
    position: absolute;
    top: calc(100% + 7px);
    left: 0;
    background-color: #000000c5;
    box-shadow: 0px 2px 6px rgba(0,0,0,0.3);
    z-index: 1000;
    width: max-content;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    padding: 0.5rem;
    border-radius: 0.1em;
    transition-delay: 0.1s;
}

.menu-item__sluzby:hover + .sluzby-window,
.sluzby-window:hover, .menu-item__sluzby:focus-within {
    visibility: visible;
}

.sluzby-window img {
    width : 1.5em;
}

.menu-item__drop:hover {
    box-shadow: inset 1px 1px 5px rgba(0,0,0,0.1);
    transform: scale(0.98);
    transition: all 0.1s ease;
    text-shadow: 0px 0px 1px rgba(255, 255, 255, 0.2);
}

.menu-item:hover {
    box-shadow: inset 1px 1px 5px rgba(0,0,0,0.1);
    transform: scale(0.98);
}

.menu-item:active {
    box-shadow: inset 1px 2px 5px rgba(0,0,0,0.2);
    transition: all 0.2s ease;
}

.header-submenu {
    width: 100%;
    text-align: left;
    font-weight: bold;
    position: relative;
    box-shadow: 0px 3px 10px rgba(0,0,0,0.1);
}

.header-submenu .menu-list {
    justify-content: left;
}

.header-submenu a {
    color: var(--color-dark-gray);
    cursor: pointer;
}

.header-dropdown {
    display: none;
    width: 100%;
    background-color: #000000e3;
    box-shadow: 0px 3px 10px rgba(0,0,0,0.1);
    z-index: 1002;
}

.header-dropdown_list {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
    padding: 1rem var(--menu-padding); 
    justify-items: end;
}

.header-dropdown_list .menu-item__drop {
    color: var(--color-light);
    padding: 0.3em 0;
    transition: all 0.2s ease;
}

.header-dropdown_list img {
    width: 1.3em;
    margin-right: 0.5rem;
}

.menu-icon-dropdown {
    display: none;
    cursor: pointer;
    margin-left: 10px;
    position: relative;
    top: 1px;
}

.menu-icon-dropdown button{
    border: none;
    padding: 0;
    border-radius: 0;
    text-shadow: none;
}

.menu-icon-dropdown button:hover {
    box-shadow: none;
    transform: none;
    transition: none;
}

.menu-icon-dropdown:hover i {
    text-shadow: none;
    transform: none;
    transition: none;
}


/*****************************************************************STAFF_IMAGE*/

#staff-wide {
    width: 100%;
    position: relative;
    height: auto;
    display: block;
    margin: 0 auto;
    box-shadow: 4px 4px 6px rgba(0,0,0,0.3);
}

/**********************************************************************QUOTE*/

.quote {
    font-size: 1.8rem;
    text-align: center;
    color: var(--color-gray);
    font-style: italic;
    font-weight: 300;
    width: 100%;
    background-color: #ffffff35;
    margin-block-start: 0;
    margin-block-end: 0;
    padding: 1rem 0;
}


/*****************************************************************SELECT_SERVICE*/

.select-service {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    margin: 0rem auto;
    gap: 1.5rem;
    background-color: var(--color-main-red);
    box-shadow: 0px 0px 6px rgba(0,0,0,0.8);
}

.select-service__pecsluzba h6, .select-service__stacionar h6 {
    color: var(--color-light);
}

.select-service__pecsluzba, .select-service__stacionar {
    border-left: var(--color-light) 3px solid;
    margin: 1rem;
    padding: 0.4rem 1rem;
    max-width: 27rem;
    transition: all 0.2s ease;
}

.select-service__pecsluzba p, .select-service__stacionar p, .help-us p {
    color: var(--color-light);
} 

.select-service__pecsluzba-header, .select-service__stacionar-header {
    display: flex;
    align-items: center;
}

.select-service__pecsluzba-header img, .select-service__stacionar-header img {
    width: 3em;
    margin-right: 0.6rem;
}

.select-service__pecsluzba:hover, .select-service__stacionar:hover {
    transform: scale(0.97);
    background-color: #00000009;
    border-radius: 0.5em;
    box-shadow: 2px 3px 5px rgba(0, 0, 0, 0.2) inset;
}

/*******************************************************************SELECT_NEWS*/

.select-news {
    margin: 1rem auto;
    background-color: var(--color-light);
    padding: 0rem var(--content-padding);
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 4em;
    overflow-wrap: anywhere;    
}

.news-item { 
    max-width: 17rem;
}

.news-item__img {
    width: 300px;
}

.news-item__img-onpage{
    max-width: 700px;
    width: 100%;
    height: auto;
}

.select-news p {
    color: var(--color-dark);
}

/*************************************************************************NEWS*/

.newspage-item {
    width: 100%;
    overflow-wrap: anywhere;
}

.newspage-item__link {
    /*reset link styles*/
    text-decoration: none;
    color: inherit;
}

/***********************************************************************ARCHIV*/

.archiv-btn:hover{
    color: var(--color-main-red);
}

.archiv-item {
    width: 100%;
    overflow-wrap: anywhere;
}

.archiv-item__link {
    /*reset link styles*/
    text-decoration: none;
    color: inherit;
}

/********************************************************************DOCUMENTS*/

.file-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.document-item {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    padding: 1rem;
    background-color: var(--color-light);
    box-shadow: 0px 2px 6px rgba(0,0,0,0.4);
    border-radius: 0.5em;
    margin-bottom: 1.5rem;
}

.document-item__name {
    color: var(--color-dark);
    transition: all 0.2s ease;
}

.document-item .fa-download {
    transition: all 0.2s ease;
}

.document-item:hover .fa-download {
    transform: scale(1.25);
}

.document-item:hover .document-item__name {
    transform: scale(1.02);
}

/**********************************************************DESCRIPTION PROCESS*/

.description-item {
    padding: 1rem;
    margin-top: 1rem;
    margin-bottom: 1.5rem;
    border-radius: 1.5em;
    background-color: var(--color-light);
    box-shadow: 1px 2px 6px rgba(0,0,0,0.4);
    transition: all 0.3s ease;
}

.description-item__number {
    color: var(--color-dark-gray);
    font-size: 1.5em;
    padding-bottom: 0.5em;
    border-bottom: 2px solid var(--color-main-red);
}

.description-item:hover {
    transform: scale(0.99);
}

/**********************************************************************HELP_US*/

.help-us {
    margin: 1rem auto;
    padding: 2rem var(--content-padding);
    text-align: center;
}

.help-us-bg {
    width: 100%;
    background-color: var(--color-main-red);
    box-shadow: 0px 0px 6px rgba(0,0,0,0.7);
}

.help-us__button {
    margin-top: 1.5rem;
}

.help-us__content {
    padding: 1rem var(--content-padding);
}

.help-us__content p {
    margin: 1em 0;
}

.help-us__thanks {
    background-color: var(--color-light);
    width: max-content;
    border-radius: 0em 1em 1em 0em;
    padding: 1rem var(--content-padding);
    margin: 3rem 0;
    box-shadow: 2px 3px 6px rgba(0,0,0,0.4);
}

.help-us__thanks h6{
    color: var(--color-main-red);
}

/*******************************************************************ACHIEVEMENTS*/

.achievements {
    text-align: center;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 3rem;
    margin: 4rem auto;
}

/**********************************************************************SPONSORS*/

.sponsors {
    color: var(--color-main-red);
    margin: 5rem auto;
    padding: 0 var(--content-padding);
}

.sponsors-slideshow div {
    text-align: center;
}

.sponsors-slideshow__img {
    padding-top: 0.2em;
    max-width: 125px;
    margin: 0 auto;
}   

.slick-prev:before, .slick-next:before {
    color: var(--color-main-red);
    border: 0;
    font-size: 23px;
}

.slick-dotted.slick-slider {
    margin-bottom: 3em;
}

.sponsors-slideshow button:hover {
    box-shadow: 0px 0px 0px rgba(0,0,0,0);
}

.sponsors-page {
    text-align: center;
}

.sponsors-page__headline {
    border-bottom: var(--color-main-red) 1px solid;
    width: 50%;
    margin: 0.8em auto;
    padding-bottom: 0.5em;
    
}

.sponsors-slideshow {
    margin: 2rem auto;
}

.town_name {
    color: var(--color-dark-gray);
}

/*******************************************************************ARTICLES*/

.article-head {
    background-color: var(--color-main-red);
    color: var(--color-light);
    padding: 1rem 0;
}

.article-head h3, .article-head h6 {
    color: var(--color-light);
}

/****************************************************************CONTACTS*/

.contact__domov, .contact__pecsluzba, .contact__stacionar {
    margin-bottom: 2.5rem;
    box-shadow: 0px 3px 10px rgba(0,0,0,0.25);
    border-radius: 1.5em 1.5em 1em 1em;
    position: relative;
}

.contact__domov__address, .contact__pecsluzba__address, .contact__stacionar__address {
    background-color: #00000042;
    position: absolute;
    top: 0;
    right: 0;
    padding: 0 1em;
    border-radius: 0em 1em 0em 1em;
}

.contact__domov__address p, .contact__pecsluzba__address p, .contact__stacionar__address p {
    text-align: center;
    font-size: 1.3rem;
    margin-block-start: 0em;
    margin-block-end: 0em;
    padding: 0.5em 0;
    color: var(--color-light);
    font-weight: bold;
}

.contact__domov h4, .contact__pecsluzba h4, .contact__stacionar h4 {
    color: var(--color-light);
    background-color: var(--color-main-red);
    padding: 1em;
    padding-top: 1.7em;
    border-radius: 0.5em 0.5em 0em 0em;
    margin-block-end: 0em;
}

.contact__domov__title, .contact__pecsluzba__title, .contact__stacionar__title {
    display: flex;
    justify-content: space-evenly;
    flex-wrap: wrap;
    background-color: #e8e8e8;
    font-weight: bold;
    color: #353535;
}

.contact__domov__title p, .contact__pecsluzba__title p, .contact__stacionar__title p {
    font-size: 1.1rem;
}

.contact__domov__info p, .contact__pecsluzba__info p, .contact__stacionar__info p {
    font-size: 1.2rem;
    text-align: center;
    padding-bottom: 1rem;
    margin-block-start: 0em;
    margin-block-end: 0em;
}

.contact__domov__info, .contact__pecsluzba__info, .contact__stacionar__info {
    padding-bottom: 1.5em;
    text-align: center;
    position: relative;
}

.contact__domov__bank-info {
    text-align: center;
}

.contact__pecsluzba__id, .contact__stacionar__id {
    text-align: end;
    color: var(--color-dark-gray);
    padding-right: 1em;
}

.contact__pecsluzba__hours-button, .contact__stacionar__hours-button {
    margin-top: 1em;
    font-size: 1em;
}

.contact__pecsluzba button i, .contact__stacionar button i {
    font-size: 0.75em;
}

.contact__pecsluzba button:hover, .contact__stacionar button:hover {
    color: var(--color-main-red); 
}

.contact__pecsluzba__hours, .contact__stacionar__hours {
    position: absolute;
    top: calc(100% - 15px);
    left: 0;
    background-color: #414141f0;
    box-shadow: 0px 2px 6px rgba(0, 0, 0, 0.3);
    z-index: 1001;
    display: none;
    padding: 1.5rem;
    border-radius: 0.1em;
    transition-delay: 0.1s;
    color: var(--color-light);
    width: 100%;
}

.contact__pecsluzba__hours--visible, .contact__stacionar__hours--visible {
    display: grid;
}

.contact__pecsluzba__hours ul, .contact__stacionar__hours ul {
    padding-inline-start: 0;  
}

.contact__pecsluzba__hours h5, .contact__stacionar__hours h5 {
    color: var(--color-light);
    font-variant: small-caps;
}

.contact__pecsluzba__hours-capacity {
    display: flex;
    gap: 3rem;
    margin: 0 auto;
}

.close-btn {
    transition: 0s;
    width: max-content;
    display: flex;
    background-color: #ffffff07;
    font-weight: 100;
    position: absolute;
    bottom: 15px;
    right: 15px;
}

.close-btn:hover {
    background-color: #ffffff;
    color: cadetblue;
    box-shadow: 0px 0px 6px rgba(0,0,0,0.2);
    transform: scale(1.02);
}

/*****************************************************************STORIES*/

.story__ludmila, .story__zdena {
    margin-bottom: 4rem;
    box-shadow: 0px 3px 10px rgba(0,0,0,0.25);
    border-radius: 1.5em 1.5em 1em 1em;
    position: relative;
}

.story__ludmila h4, .story__zdena h4 {
    color: var(--color-light);
    background-color: var(--color-main-red);
    padding: 1em;
    border-radius: 0.5em 0.5em 0em 0em;
    margin-block-end: 0em;
    cursor: pointer;
}

.story__ludmila h4:hover i, .story__zdena h4:hover i {
    transform: scale(1.2);
    transition: all 0.2s ease;
}

.story__content {
    display: none;
}

.story--visible {
    display: block;
}

.story-second-line {
    display: flex;
    justify-content: space-between;
    align-items: end;
}

/****************************************************PS_SERVICE & DS_SERVICE*/

.PS-content, .DS-content {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
}

.PS__img, .DS__img {
    margin-top: .5em;
    margin-bottom: .5em;
    box-shadow: 1px 2px 6px rgba(0, 0, 0, 0.2);
}

.PS-content h3 img, .DS-content h3 img {
    width: 2em;
    margin-right: .3em;
}

.PS-content li, .DS-content li {
    list-style-type: disc; 
}

/*****************************************************************REFERENCE*/

.reference-content {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(450px, 1fr));
    gap: 2rem;
    margin-bottom: 5rem;
}

.reference-content__item {
    background: linear-gradient(rgba(255, 255, 255, 0.6), rgba(255, 255, 255, 0.6)), url(../img/paper_bg.jpg);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    padding: 1.5rem;
    border-radius: 0.2em;
    box-shadow: 1px 3px 8px rgba(0,0,0,0.5);
    font-style: italic;
    font-family:'Times New Roman', Times, serif;
    color: #212121;
}

.reference-content__item p {
    font-size: 1.1rem;
}

/************************************************************************GALLERY*/

.gallery-btns-container {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    gap: 1em;
}

.gallery-btn{
    width: 100%;
    text-align: center;
    border: 1px solid var(--color-dark);
    padding: 1em;
    font-size: 1.2em;
    border-radius: 1em;
    cursor: pointer;
    transition: all 0.2s ease;
    box-shadow: 1px 2px 6px rgba(0,0,0,0.2);
}

.gallery1-content {
    display: block;
    text-align: center;
}
    
.gallery2-content {
    display: none;
    text-align: center;
}

.gallery-btn a{
    color: var(--color-dark-gray);
}

.pressed {
    transform: scale(0.99);
    box-shadow: 2px 3px 6px rgba(0,0,0,0.3) inset;
}

/*************************************************************************FOOTER*/

footer {
    position: relative;
    padding: 1.25rem 0;
    width: 100%;
    z-index: 1000;
    background-color: var(--color-main-red);
    color: #ffffff;
    box-shadow: 0px 0px 6px rgba(0,0,0,0.7);
}

.nav-above-footer {
    padding: 0.35rem 0.8rem;
    margin: 1.5rem 3.5rem;
    margin-top: 3rem;
    border-left: var(--color-main-red) 3px solid;
}

.footer-menu {
    width: max-content;
}

.footer-menu li {
    list-style: none;
    margin: 0.25em 0px;
    transition: all 0.15s ease;
}

.footer-menu li:hover {
    transform:translateX(5px);

}

.footer-content {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}

.footer-content a {
    color: var(--color-light);
    text-decoration: none;
    font-weight: 600;
}

.footer-file{
    color: var(--color-light);
}

/*****************************************************************BUTTONS*/


button {
    background-color: var(--color-main-red);
    color: #ffffff;
    border: none;
    padding: 0.5em 1.5em;
    font-size: 0.9rem;
    cursor: pointer;
    border: 2px solid #ffffff;
    border-radius: 1.4em;
    font-weight: bold;
    transition: all 0.3s ease;
}

button:hover {
    background-color: rgba(255,255,255,0.1);
    box-shadow: 2px 4px 10px rgba(0,0,0,0.25);
}
