:root {
	--slanina-blue: #3E648A;
	--slanina-dark-blue: #2c4966;
	--slanina-grey-bg: #F0F2F5;
	--text-dark: #333333;
	--silver-accent: #E0E1DD;
	scroll-behavior: smooth;
}

body {
	font-family: 'Segoe UI', Arial, sans-serif;
	color: var(--text-dark);
	background-color: var(--slanina-grey-bg);
}

.minimum	{
	min-height: 82.8vh;
}

/* Navigace */
.navbar {
	background-color: var(--slanina-blue) !important;
	border-bottom: 3px solid var(--slanina-dark-blue);
	padding: 1rem 0;
}

.navbar-brand {
	font-size: 1.5rem;
	letter-spacing: 1px;
}

.brand-accent {
	color: var(--silver-accent);
	font-weight: 300;
}

.navbar-logo {
	height: 35px;
	margin-top: 0.1em;
	width: auto;
	display: inline-block;
	vertical-align: middle;
	max-width: 100%;
}

.navbar-subtext {
	font-weight: 300;
	letter-spacing: 1px;
}

.telmail {
	color: inherit;
	text-decoration: none;
}

.navbar-nav .nav-link {
	color: white !important;
	font-weight: 700 !important;
	letter-spacing: 0.5px;
	padding-left: 1rem;
	padding-right: 1rem;
}

.navbar-nav .nav-link:hover {
	color: var(--silver-accent) !important;
}

/* Hlavni */

.hlavni-section {
	background: linear-gradient(rgba(62, 100, 138, 0.8), rgba(44, 73, 102, 0.8)), 
	url('../images/pozadi.png');
	background-size: cover;
	background-position: center;
	height: 50vh;
	min-height: 400px;
	color: white;
}

@supports (background-image: url('../images/pozadi.webp')) {
	.hlavni-section {
        background: linear-gradient(rgba(62, 100, 138, 0.8), rgba(44, 73, 102, 0.8)), 
        url('../images/pozadi.webp');
    }
}

.hlavni-title {
	font-size: 4.5rem;
	font-weight: 800;
	text-transform: uppercase;
	text-shadow: 2px 2px 4px rgba(0,0,0,0.3);
}

.maly-obrazek {
	width: 95%;
}

/* Tlačítka */
.btn-custom {
	background-color: var(--slanina-blue);
	color: white;
	border-radius: 0;
	border: 2px solid white;
	padding: 12px 30px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 1px;
	transition: all 0.3s ease;
}

.btn-custom:hover {
	background-color: white;
	color: var(--slanina-blue);
}

.btn-outline-light {
	border-radius: 0;
	border-width: 2px;
}

/* Služby - Karty */

.service-card {
	background-color: white;
	border: 1px solid rgba(0,0,0,0.05);
	padding: 2.5rem;
	transition: all 0.3s ease;
}

.service-card:hover {
	transform: translateY(-5px);
	box-shadow: 0 10px 20px rgba(0,0,0,0.08);
}

.bi-icon-style {
	color: var(--slanina-blue);
	font-size: 3rem;
	display: inline-block;
	margin-bottom: 1rem;
}

.nahrada-h3	{
	font-size: 1.7rem;
	font-weight: bold;
	color: black;
}


.nahrada-h5	{
	font-size: 1.7rem;
	font-weight: bold;
	color: black;
}

/* Kontakt Sekce */
#kontakt {
	background-color: var(--slanina-blue);
	color: var(--silver-accent);
	position: relative;
	border-top: 5px solid var(--slanina-dark-blue);
	scroll-margin-top: 70px;
	font-size: 1.2rem;
}

.qr-wrapper img {
	transition: transform 0.3s ease;
}

.qr-wrapper img:hover {
	transform: scale(1.05);
}

.qr-wrapper p	{
	font-size: 1rem;
}

/* Footer */
footer {
	background-color: #1A2E41;
	color: var(--silver-accent);
}


.map-container {
	position: relative;
	width: 100%;
	padding-bottom: 56.25%;
	height: 0;
	border: 4px solid var(--silver-accent);
	background-color: var(--silver-accent);
}

.map-container iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border: 0;
}

/* reference html */

.ref-card .a:first-child {
	overflow: hidden;
	display: block;
}

.ref-img {
	transition: transform 0.3s ease;
	backface-visibility: hidden;
}

.ref-card:hover .ref-img {
	transform: scale(1.1);
}

.ref-img-wrapper {
	overflow: hidden;
	display: block;
}
.ref-img-wrapper img {
	transition: transform 0.3s ease;
}
.ref-card:hover .ref-img-wrapper img {
	transform: scale(1.1);
}

/* Cookie */

.cookie-container {
	position: -webkit-sticky;
	position: sticky;
	bottom: 0;
	left: 0;
	width: 100%;
	background: #2c4966;
	color: white;
	padding: 15px 20px;
	z-index: 9999;
	display: none;
	justify-content: space-between;
	align-items: center;
	box-shadow: 0 -5px 10px rgba(0,0,0,0.1);
	border-top: 1px solid rgba(255,255,255,0.1);
}

.cookie-text {
	font-size: 14px;
	line-height: 1.4;
	padding-right: 20px;
}

.cookie-btn {
	background: #3e648a;
	color: white;
	border: 1px solid white;
	padding: 8px 20px;
	cursor: pointer;
	border-radius: 4px;
	font-weight: bold;
	transition: 0.3s;
}

.cookie-btn:hover {
	background: white;
	color: #2c4966;
}

.cookie-link {
	color: #ccc;
	font-size: 13px;
	margin-left: 15px;
	text-decoration: underline;
}

/* --- STRÁNKA OCHRANA ÚDAJŮ --- */

.legal-page-body { 
	background-color: #f8f9fa; 
	color: #333; 
}

.legal-container { 
	background: white; 
	padding: 40px; 
	border-radius: 10px; 
	box-shadow: 0 4px 15px rgba(0,0,0,0.05); 
	margin-top: 50px; 
	margin-bottom: 50px; 
}

.legal-container h1 { 
	color: #2c4966; 
	border-bottom: 2px solid #2c4966; 
	padding-bottom: 10px; 
	margin-bottom: 30px; 
}

.legal-container h2 { 
	color: #2c4966; 
	margin-top: 25px; 
	font-size: 1.3rem; 
	font-weight: bold; 
}

.legal-container h3 { 
	color: #2c4966; 
	margin-top: 25px; 
	font-size: 1.3rem; 
	font-weight: bold; 
}

.contact-box { 
	background: #e9ecef; 
	padding: 20px; 
	border-radius: 8px; 
	margin-top: 10px; 
}

/* Responzivita */
@media (max-width: 768px) {

.hlavni-title {
	font-size: 2.5rem;
}

.cookie-container {
        flex-direction: column;
        text-align: center;
    }
    .cookie-text {
        margin-bottom: 10px;
        padding-right: 0;
    }
}

@media (min-width: 992px) {

.navbar-collapse {
        display: flex !important;
        flex-basis: auto;
        order: 0 !important; 
}
    
.navbar-subtext.w-lg-auto {
	width: auto !important;
	margin: 0;
}
}

@media (max-width: 991.98px) {

.navbar-subtext.w-100 {
        color: white;
        text-transform: uppercase;
        margin-top: 5px;
}
}