/*
Theme Name: Head Blog
Theme URI: https://headthemes.com/theme/head-blog/
Author: HeadThemes
Author URI: https://headthemes.com/
Description: Warm emotional tourism redesign for Ferien in Kitzeck based on Head Blog. Preserves WordPress content, images, links, menus and booking shortcodes while creating a professional accommodation website.
Version: 3.3.0-kitzeck-layout-fix
Tested up to: 6.8
Requires PHP: 5.6
License: GNU General Public License v3
License URI: http://www.gnu.org/licenses/gpl.html
Tags: one-column, two-columns, right-sidebar, flexible-header, rtl-language-support, footer-widgets, custom-header, custom-background, custom-menu, featured-images, translation-ready, custom-logo, threaded-comments, blog
Text Domain: head-blog
*/

/* The bootstrap.css file is auto-enqueued in functions.php */

/* WordPress Core */
.gallery-caption {
    font-weight: bold;
}
.alignnone {
    margin: 5px 20px 20px 0;
}
.aligncenter,
div.aligncenter {
    display: block;
    margin: 5px auto 5px auto;
}
.alignright {
    float: right;
    margin: 5px 0 20px 20px;
}
.alignleft {
    float: left;
    margin: 5px 20px 20px 0;
}
.aligncenter {
    display: block;
    margin: 5px auto 5px auto;
}
a img.alignright {
    float: right;
    margin: 5px 0 20px 20px;
}
a img.alignnone {
    margin: 5px 20px 20px 0;
}
a img.alignleft {
    float: left;
    margin: 5px 20px 20px 0;
}
a img.aligncenter {
    display: block;
    margin-left: auto;
    margin-right: auto;
}
.wp-caption {
    background: #fff;
    border: 1px solid #f0f0f0;
    max-width: 96%;
    /* Image does not overflow the content area */
    padding: 5px 3px 10px;
    text-align: center;
}
img.alignnone {
    max-width: 96%;
    height: auto;
    width: auto;
}
.wp-caption.alignnone {
    margin: 5px 20px 20px 0;
}
.wp-caption.alignleft {
    margin: 5px 20px 20px 0;
}
.wp-caption.alignright {
    margin: 5px 0 20px 20px;
}
.wp-caption img {
    border: 0 none;
    height: auto;
    margin: 0;
    max-width: 98.5%;
    padding: 0;
    width: auto;
}
.wp-caption p.wp-caption-text {
    font-size: 13px;
    line-height: 17px;
    margin: 0;
    padding: 10px 0 0 0;
    color: #000;
}
/* Recommended CSS from WP for defined content width support */
.size-auto,
.size-full,
.size-large,
.size-medium,
.size-thumbnail {
    max-width: 100%;
    height: auto;
}
iframe,
embed {
    max-width: 100%;
}
img {
    max-width: 100%;
    height: auto;
}
.sticky,
.bypostauthor {}
table { 
    width: 100%; 
    border-collapse: collapse; 
}
th { 
    font-weight: bold; 
}
td, th { 
    padding: 6px; 
}
.screen-reader-text {
    clip: rect(1px, 1px, 1px, 1px);
    clip-path: polygon(0px 0px, 0px 0px,0px 0px, 0px 0px);
    position: absolute !important;
    white-space: nowrap;
    height: 1px;
    width: 1px;
    overflow: hidden;
}
body, html {
    overflow-x: hidden;
}
body {
    font-family: 'Raleway', "Helvetica Neue", helvetica, arial, sans-serif;
    padding: 0;
    color: #404040;
    font-weight: 400;
    line-height: 1.6;
    font-size: 15px;
    word-wrap: break-word;
}
a, a:active, a:hover, a:focus {
    text-decoration: none;
    color: #8a6d3b;
}
h1, h2, h3, h4, h5, h6 {
    line-height: normal;
    word-wrap: break-word;
    color: #000;
}
.page-header a {
    border-bottom: 0;
    color: #000;
}
a:active {
    border-bottom: none;
}
.main-container {
    background-color: #fff;
}
.homepage-row.row {
    margin: 0;
    padding: 60px 0 0 0;
    background: #fff;
    color: black;
}
@media (min-width: 768px) {
    .nav > li > a:before {
        position: absolute;
        content: '';
        bottom: 0;
        left: 50%;
        width: 0;
        height: 2px;
        background-color: #8a6d3b;
        -webkit-transition: all 1s;
        transition: all 1s;
    }
    .nav > li:hover > a:before {
        width: 100%;
        left: 0;
    }
    .navbar-nav > li > a {
        padding-top: 20px;
        padding-bottom: 20px;
        transition: all 0.5s ease-in-out;
        -moz-transition: all 0.5s ease-in-out;
        -webkit-transition: all 0.5s ease-in-out;
        -o-transition: all 0.5s ease-in-out;
    }
    .shrink .navbar-nav > li > a {
        padding-top: 15px;
        padding-bottom: 15px;
        font-size: 14px;
    }
    .navbar-nav li:hover .dropdown-menu{
        visibility:visible;
        border-top: 4px solid #ccc;
        border-radius: 0;
        transition: all 0.5s ease-in-out;
        -moz-transition: all 0.5s ease-in-out;
        -webkit-transition: all 0.5s ease-in-out;
        -o-transition: all 0.5s ease-in-out;
    }
    #site-navigation .container{
        padding-left: 0;
        padding-right: 0;
    }
    .navbar-default .navbar-nav > .active > a,
    .navbar-default .navbar-nav > .active > a:hover,
    .navbar-default .navbar-nav > .active > a:focus,
    .navbar-default .navbar-nav > .open > a,
    .navbar-default .navbar-nav > .open > a:hover,
    .navbar-default .navbar-nav > .open > a:focus {
        background-color: transparent;
    }
    .navbar-center .navbar-nav {
        display: inline-block;
        float: none;
        vertical-align: top;
    }

    .navbar-center .menu-container {
        text-align: center;
    }
}
@media (min-width: 600px) {
    .admin-bar #site-navigation.shrink {
        top: 32px;
    }
}
@media (max-width: 767px) {
    .nav > li.active > a:after, .current-page-parent:after {
        height: 0 !important;
        background-color: transparent !important;
    }
    .navbar-nav a:hover, .navbar-nav a:focus {
        color: #ffffff !important;
        background-color: #000 !important;
    }
    .menu-container {
        width: 70%;
        position: absolute;
        left: 0;
        transform: translate3d(-100%, 0, 0);
        overflow-y: auto;
        overflow-x: auto;
        height: 100vh;
        padding-bottom: 60px;
        z-index: 9;
        background-color: #fff;
        top: 60px;
    }
    .shrink .menu-container {
        top: 50px;
    }
    .openNav .menu-container {
        transform: translate3d(0, 0, 0);
        transition: transform 500ms ease;
    }
    .openNav .page-area {
        left: 0;
        transform: translate3d(70%, 0, 0);
        transition: transform 500ms ease;
    }
    .page-area {
        left: 0;
        transform: translate3d(0, 0, 0);
        transition: transform 500ms ease;
    }
    .navbar-nav {
        padding: 0;
        margin: 0;
    }
    .navbar-nav a {
        font-size: 14px;
        padding: 15px 10px !important;
        margin: 0 !important;
        line-height: 16px !important;
        background-color: white;
        float: left !important;
        margin: 0px !important;
        width: 100%;
        text-transform: none !important;
        word-wrap: break-word;
        white-space: normal !important;
    }
    .navbar-nav li, .navbar-nav ul {
        padding: 0 0 0 10px !important;
        margin: 0px !important;
    }
    .open-panel {
        width: 32px;
        height: 32px;
        position: absolute;
        top: 18px;
        right: 22px;
        -webkit-transform: rotate(0deg);
        -moz-transform: rotate(0deg);
        -o-transform: rotate(0deg);
        transform: rotate(0deg);
        -webkit-transition: .5s ease-in-out;
        -moz-transition: .5s ease-in-out;
        -o-transition: .5s ease-in-out;
        transition: .5s ease-in-out;
        cursor: pointer;
    }
    .shrink .open-panel {
        top: 12px;
    }
    .open-panel span {
        display: block;
        position: absolute;
        height: 3px;
        width: 100%;
        background: #000;
        opacity: 1;
        left: 0;
        -webkit-transform: rotate(0deg);
        -moz-transform: rotate(0deg);
        -o-transform: rotate(0deg);
        transform: rotate(0deg);
        -webkit-transition: .25s ease-in-out;
        -moz-transition: .25s ease-in-out;
        -o-transition: .25s ease-in-out;
        transition: .25s ease-in-out;
    }
    .open-panel span:nth-child(1) {
        top: 0px;
        -webkit-transform-origin: left center;
        -moz-transform-origin: left center;
        -o-transform-origin: left center;
        transform-origin: left center;
    }
    .open-panel span:nth-child(2) {
        top: 9px;
        -webkit-transform-origin: left center;
        -moz-transform-origin: left center;
        -o-transform-origin: left center;
        transform-origin: left center;
    }
    .open-panel span:nth-child(3) {
        top: 18px;
        -webkit-transform-origin: left center;
        -moz-transform-origin: left center;
        -o-transform-origin: left center;
        transform-origin: left center;
    }
    .open-panel.open span:nth-child(1) {
        -webkit-transform: rotate(45deg);
        -moz-transform: rotate(45deg);
        -o-transform: rotate(45deg);
        transform: rotate(45deg);
        top: -2px;
        left: 3px;
    }
    .open-panel.open span:nth-child(2) {
        width: 0%;
        opacity: 0;
    }
    .open-panel.open span:nth-child(3) {
        -webkit-transform: rotate(-45deg);
        -moz-transform: rotate(-45deg);
        -o-transform: rotate(-45deg);
        transform: rotate(-45deg);
        top: 21px;
        left: 3px;
    }
    .caret, .dropdown-submenu>a:after {
        display: none !important; 
    }
    .navbar-nav .dropdown-menu {
        width: 100%;
        display: block !important;
        left: 0 !important;
        position: relative !important;
        border: none !important;
        -webkit-box-shadow: none !important;
        box-shadow: none !important;
    }
    .openNav .page-area:after {
        content: '';
        position: absolute;
        top: 0;
        right: 0;
        bottom: 0;
        background-color: #00000085;
        left: 0;
    }
    .split-images .news-text-wrap h2 {
        font-size: 100%;
    }
}
.dropdown-menu > li > a {
    border-bottom: 0;
}
#site-navigation {
    min-height: 60px;
}
.navbar-collapse {
    padding-left: 0;
    padding-right: 0;
}
.dropdown-submenu {
    position: relative;
}

.dropdown-submenu>.dropdown-menu {
    top: 0;
    left: 100%;
    margin-top: -6px;
    margin-left: -1px;
    -webkit-border-radius: 0 6px 6px 6px;
    -moz-border-radius: 0 6px 6px;
    border-radius: 0 6px 6px 6px;
}

.dropdown-submenu:hover>.dropdown-menu {
    display: block;
}

.dropdown-submenu>a:after {
    display: block;
    content: " ";
    float: right;
    width: 0;
    height: 0;
    border-color: transparent;
    border-style: solid;
    border-width: 5px 0 5px 5px;
    border-left-color: #ccc;
    margin-top: 5px;
    margin-right: -10px;
}

.dropdown-submenu:hover>a:after {
    border-left-color: #fff;
}

.dropdown-submenu.pull-left {
    float: none;
}
.dropdown-submenu.pull-left>.dropdown-menu {
    left: -100%;
    margin-left: 10px;
    -webkit-border-radius: 6px 0 6px 6px;
    -moz-border-radius: 6px 0 6px 6px;
    border-radius: 6px 0 6px 6px;
}
.dropdown-menu > .active > a, .dropdown-menu > .active > a:hover, .dropdown-menu > .active > a:focus {
    background-color: #8a6d3b;
}
.navbar-toggle {
    border: 1px solid #ccc;
}
.navbar-toggle .icon-bar {
    background-color: #ccc;
}
.navbar-nav > li > a {
    border-bottom: 0;
    text-transform: uppercase;
}
.nav > li.active > a:after, .current-page-parent:after {
    position: absolute;
    content: '';
    bottom: 0;
    left: 0;
    width: 100%;
    height: 2px;
    background-color: #8a6d3b;
}
article {
    clear: both;
    float: left;
    margin-bottom: 10px;
    width: 100%;
}
.updated:not(.published) {
    display: none;
}
.space-right {
    margin-right: 10px;
}
.main-content {
    float: left;
    width: 100%;
}
.page-header {
    width: 100%;
    margin: 20px 0;
    text-align: center;
}
.single-entry-summary, .entry-footer {
    margin-top: 15px;
    width: 100%;
    clear: both;
}
.tagcloud a {
    font-size: 15px !important;
    padding: 2px 10px;
    border: 1px solid;
    margin-bottom: 5px;
    display: inline-block;
}
input, textarea {
    background-color: #fff;
    padding: 6px;
    color: #464a4c;
    border-radius: 0;
    margin-bottom: 10px;
}
.comment-respond label,
.comment-respond input {
    width: 100%;
}
select {
    max-width: 100%;
    padding: 5px;
    color: #000;
}
#sidebar {
    display: block;
    max-width: 100%;
    overflow: hidden;
}
.widget {
    border: 1px solid #dddddd;
    padding: 15px;
    background-color: rgba(0, 0, 0, 0.01);
}
.homepage-widget-area {
    float: left;
    width: 100%;
}
.page-area {
    padding-top: 15px;
}
header.archive-page-header {
    padding: 0 15px 30px;
}
.widget {
    word-wrap: break-word;
    -webkit-hyphens: auto;
    -moz-hyphens: auto;
    hyphens: auto;
    margin-bottom: 15px;
}
.widget ul {
    padding-left: 0;
    list-style-type: none;
}
.widget li > ul {
    padding-left: 15px;
}
.widget ul li {
    margin: 4px 0px 0px;
    padding: 0px 0px 4px;
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
}
.widget ul li:last-child {
    border-bottom: none;
}
.widget-title {
    font-size: 18px;
    position: relative;
    width: 100%;
    clear: both;
    margin-top: 10px;
    margin-bottom: 10px;
    text-transform: uppercase;
    display: inline-block;
    text-align: center;
    padding: 0 15px;
}
.widget-title:after {
    content: '';
    position: absolute;
    right: 0;
    bottom: 50%;
    height: 1px;
    background-color: #dddddd;
    left: 0;
}
.widget-title h3 {
    font-size: 15px;
    float: none;
    padding: 10px 15px;
    margin: 0;
    font-style: normal;
    display: inline-block;
    background-color: #fff;
    position: relative;
    z-index: 5;
    border: 1px solid #dddddd;
}

.section-title {
    width: 100%;
    position: relative;
    float: left;
    clear: both;
    overflow: hidden;
}
.section-title:after {
    content: '';
    position: absolute;
    right: 0;
    bottom: 10px;
    height: 2px;
    background-color: #eaeaea;
    left: 16px;
    z-index: 6;
    -webkit-transform: skewX(-15deg);
    -ms-transform: skewX(-15deg);
    transform: skewX(-15deg);
}
.section-title .widget-title {
    width: auto;
    margin-left: 2px;
    float: left;
}
.section-title .widget-title a {
    float: left;
}
.section-title .widget-title:after {
    display: none;
}
.section-title a {
    position: relative;
    z-index: 3;
    color: #000;
    padding: 14px 14px;
    top: -2px;
    font-weight: 300;
    font-size: 14px;
    float: left;
    margin-bottom: 8px;
    font-style: italic;
}
.section-title a:after {
    content: "";
    position: absolute;
    top: 0;
    left: -40px;
    right: -15px;
    height: 100%;
    background-color: #eaeaea;
    -webkit-transform: skewX(-15deg);
    -ms-transform: skewX(-15deg);
    transform: skewX(-15deg);
    z-index: -1;
    display: block;
}
h1.site-title a, .site-title a, h1.site-title, .site-title {
    margin: 0;
    padding: 0;
    font-size: 60px;
    line-height: 70px;
    word-wrap: break-word;
    font-weight: 700;
    color: #000;
    letter-spacing: -.02em;
    text-transform: uppercase;
}
p.site-description {
    font-size: 23px;
    line-height: 28px;
    margin: 0;
    -webkit-transition: all 0.5s ease;
    transition: all 0.5s ease;
}
.site-branding-logo a {
    border: none;
    z-index: 999;
    position: relative;
}
.site-branding-logo img {
    width: auto;
}
.site-branding-text {
    z-index: 998;
    position: relative;
}
.site-heading {
    max-width: 1170px;
    text-align: center;
    padding: 180px 15px;
    color: #000;
}
.navbar {
    margin-bottom: 0;
}
.main-menu {
    position: relative;
}
#site-navigation,
#site-navigation.shrink {
    background-color: #ffffff;
    webkit-box-shadow: 0px 7px 19px -1px rgba(0,0,0,0.17);
    -moz-box-shadow: 0px 7px 19px -1px rgba(0,0,0,0.17);
    box-shadow: 0px 7px 19px -1px rgba(0,0,0,0.17);
    border: none;
}
#site-navigation, nav a {
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
    color: #000;
    border-radius: 0;
}
#site-navigation.shrink {
    min-height: 50px;
    position: fixed;
    width: 100%;
    z-index: 9999;
    top: 0;
}
.shrink h1.site-title, .shrink .site-title {
    font-size: 19px;
    line-height: 23px;
}
.shrink p.site-description {
    font-size: 12px;
    line-height: 15px;
}
.featured-thumbnail {
    width: 100%;
    position: relative;
}
.featured-thumbnail img {
    width: 100%;
    text-align: center;
}
.single-page-header {
    color: #fff;
    font-size: 44px;
    font-weight: 400;
}
.single-footer {
    display: block;
    clear: both;
}
nav.navigation.pagination {
    text-align: center;
    width: 100%;
    clear: both;
    margin: 20px 0;
}
nav.navigation.pagination .nav-links a, nav.navigation.pagination .current {
    padding: 5px 10px;
    border: none;
    border-radius: 0;
    position: relative;
    z-index: 1;
}
nav.navigation.pagination .nav-links a:before, nav.navigation.pagination .current:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: -1;
    display: block;
    border: 1px solid #b5b5b5;
}
nav.navigation.pagination .current {
    color: #fff;
}
nav.navigation.pagination .current:before {
    background-color: #8a6d3b;
    border: 1px solid #8a6d3b;
}
#content-footer-section {
    background-color: #fff;
    padding: 15px;
}
#content-footer-section .widget {
    border: none;
    background: transparent;
}
#content-footer-section .widget:nth-child(4n+1) {
    clear: both;
}
.footer-credits {
    background-color: #1e1e1e;
    clear: both;
}
.footer-credits-text {
    padding: 20px 0;
    color: #fff;
}
.site-header {
    padding: 0;
    background-color: #fff;
    position: relative;
    overflow: hidden;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
}

#wp-custom-header img {
    position: absolute;
    height: auto;
    left: 50%;
    max-width: 1000%;
    min-height: 100%;
    width: auto;
    top: 50%;
    -ms-transform: translateX(-50%) translateY(-50%);
    -moz-transform: translateX(-50%) translateY(-50%);
    -webkit-transform: translateX(-50%) translateY(-50%);
    transform: translateX(-50%) translateY(-50%);
}
li.home-icon.front_page_on {
    background-color: #8a6d3b;
}
li.home-icon.front_page_on a, li.home-icon.front_page_on a:hover {
    color: #fff;
}
li.home-icon a {
    padding-left: 20px;
    padding-right: 20px;
}
li.home-icon.front_page_on:before {
    position: absolute;
    content: "";
    top: -4px;
    left: 0;
    right: 0;
    height: 4px;
    background-color: #8a6d3b;
}
/* Search styling */
form#searchform, .search-icon {
    position: relative;
}
#searchsubmit {
    position: absolute;
    top: 2px;
    right: 2px;
    bottom: 2px;
    width: 80px;
    color: #fff;
    background-color: #8a6d3b;
}
input#s {
    width: 100%;
    padding-right: 90px;
}

/* Comments */
.comment-form #comment, .comment-form #submit {
    width: 100%;
}

cite.fn {
    font-weight: bold;
}
a.comment-reply-link {
    border: 1px solid #ccc;
    padding: 10px 20px;
}
.reply {
    margin: 20px 0;
}
.comment-meta.commentmetadata {
    margin: 10px 0;
    font-size: 12px;
    font-style: italic;
}
.comment-body {
    margin-bottom: 40px;
}
.commentlist li {
    list-style-type: none;
}
.error-template {
    padding-bottom: 60px;
}
.btn-default, input[type="submit"], input#submit, button, a.comment-reply-link { 
    box-shadow: 0 1px 2px rgba(0,0,0,0.15);
    transition: all 0.3s ease-in-out;
    -webkit-transition: all 0.3s ease-in-out;
    border: 1px solid #8e8e8e;
}
input#submit:hover, .btn-default:hover, input[type="submit"]:hover, button:hover, a.comment-reply-link:hover { 
    box-shadow: 0 5px 15px rgba(0,0,0,0.3);
}

.inner-wrapper {
    float: left;
    display: block;
    margin-bottom: 15px;
    width: 100%;
}
.posted-date,
.cat-links a,
.cat-links span,
.tags-links span,
.comments-meta {
    opacity: 0.7;
    padding-right: 8px;
    font-size: 13px;
    font-weight: 300;
    font-style: italic;
}
.cat-links {
    padding: 10px;
}
.single .cat-links {
    padding-left: 0;
}
.comments-meta a{
    color: #404040;
}

span.comments-meta i {
    margin-left: 0;
}
.read-more-button a {
    padding: 10px 20px;
    margin-top: 20px;
    border: 1px solid;
    position: relative;
    display: inline-block;
}
.tags-links a {
    position: relative;
    font-style: italic;
    opacity: 0.8;
    margin-right: 8px;
}
h1.single-title {
    text-align: center;
}
.news-item-content, .postauthor-container, .comments-template, .single-wrap {
    padding: 30px 15px;
    background-color: rgba(0, 0, 0, 0.01);
    border: 1px solid #dddddd;
    margin-bottom: 30px;
}

.news-item.layout-two {
    margin-bottom: 10px;
    clear: both;
}
.news-item.layout-two .news-thumb {
    margin-bottom: 5px;
    margin-right: 15px;
    max-width: 80px;
    float: left;
}
.news-item h2 {
    font-size: 26px;
    margin-top: 0;
    margin-bottom: 0;
    font-weight: 300;
    line-height: 1.1;
}
.news-item.layout-two h2, .news-item.layout-two h2 a {
    font-size: 15px;
    line-height: 18px;
}
.news-item h2 a {
    color: #000;
    font-size: 42px;
}
.news-thumb {
    margin-bottom: 20px;
    text-align: center;
}
.news-thumb img {
    padding: 1px;
    border: 1px solid #dddddd;
}
.post-excerpt {
    font-style: italic;
    font-weight: 300;
}
.author-meta-by {
    font-style: italic;
    opacity: 0.7;
    font-size: 14px;
    font-weight: 300;
}
.author-meta a {
    color: #000;
    text-transform: uppercase;
    font-size: 14px;
    margin-right: 8px;
}
.comments-meta a {
    padding-right: 5px;
}


/* --------------------------------------------------------------------------
   Kitzeck Professional Hospitality Redesign
   Visual redesign only: WordPress content, images, menu links and booking
   system output stay untouched. Styles are scoped to the existing theme markup.
---------------------------------------------------------------------------- */
:root {
    --kk-bg: #f7f3ec;
    --kk-surface: rgba(255,255,255,.92);
    --kk-surface-solid: #fffdf9;
    --kk-text: #1f2a24;
    --kk-muted: #66736b;
    --kk-line: rgba(63, 51, 36, .12);
    --kk-brand: #7c4f28;
    --kk-brand-dark: #432718;
    --kk-accent: #9f7a3f;
    --kk-green: #385342;
    --kk-radius-lg: 34px;
    --kk-radius-md: 22px;
    --kk-shadow-soft: 0 18px 55px rgba(44, 31, 18, .12);
    --kk-shadow-card: 0 12px 36px rgba(44, 31, 18, .10);
    --kk-max: 1180px;
}

html {
    scroll-behavior: smooth;
}

body {
    background:
        radial-gradient(circle at 12% 6%, rgba(159,122,63,.12), transparent 34rem),
        linear-gradient(180deg, #fbf8f2 0%, var(--kk-bg) 56%, #f3ecdf 100%);
    color: var(--kk-text);
    font-family: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    font-size: 17px;
    line-height: 1.78;
    letter-spacing: .005em;
}

body:before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: -2;
    pointer-events: none;
    background-image:
        linear-gradient(rgba(124,79,40,.035) 1px, transparent 1px),
        linear-gradient(90deg, rgba(124,79,40,.035) 1px, transparent 1px);
    background-size: 44px 44px;
    mask-image: linear-gradient(to bottom, transparent 0, #000 18%, #000 74%, transparent 100%);
}

a,
a:active,
a:focus {
    color: var(--kk-brand);
}

a:hover {
    color: var(--kk-brand-dark);
}

h1, h2, h3, h4, h5, h6,
.single-title,
.news-item h2,
.widget-title h3 {
    color: var(--kk-text);
    font-family: Georgia, "Times New Roman", serif;
    letter-spacing: -.025em;
}

p {
    margin: 0 0 1.25em;
}

img {
    border-radius: 0;
}

/* Header / hero ------------------------------------------------------------ */
.site-header.kk-hero {
    min-height: clamp(520px, 72vh, 780px);
    display: flex;
    align-items: stretch;
    padding: 0;
    background-color: #2f2a20;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    position: relative;
    isolation: isolate;
}

.site-header.kk-hero:before,
.site-header.kk-hero:after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
}

.site-header.kk-hero:before {
    z-index: -1;
    background:
        linear-gradient(100deg, rgba(24, 24, 18, .78) 0%, rgba(24, 24, 18, .48) 44%, rgba(24, 24, 18, .18) 100%),
        radial-gradient(circle at 72% 26%, rgba(255, 255, 255, .20), transparent 26rem);
}

.site-header.kk-hero:after {
    z-index: -1;
    background: linear-gradient(180deg, transparent 62%, rgba(247,243,236,1) 100%);
}

.kk-hero__inner {
    width: 100%;
    display: flex;
    align-items: center;
    padding-top: 62px;
    padding-bottom: 88px;
}

.site-heading.kk-hero__content {
    max-width: 760px;
    padding: clamp(60px, 9vw, 130px) 15px clamp(48px, 8vw, 110px);
    text-align: left;
    color: #fff;
}

.kk-hero__logo {
    margin-bottom: 22px;
}

.kk-hero__logo img {
    max-height: 96px;
    width: auto;
    filter: drop-shadow(0 12px 24px rgba(0,0,0,.28));
}

.kk-hero__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 16px;
    padding: 9px 14px;
    border: 1px solid rgba(255,255,255,.36);
    border-radius: 999px;
    background: rgba(255,255,255,.13);
    backdrop-filter: blur(12px);
    color: rgba(255,255,255,.92);
    font-size: 13px;
    font-weight: 750;
    letter-spacing: .13em;
    text-transform: uppercase;
}

h1.site-title.kk-hero__title,
.site-title.kk-hero__title,
h1.site-title.kk-hero__title a,
.site-title.kk-hero__title a {
    color: #fff;
    font-size: clamp(48px, 8.3vw, 92px);
    line-height: .94;
    font-family: Georgia, "Times New Roman", serif;
    font-weight: 700;
    text-transform: none;
    letter-spacing: -.06em;
    text-shadow: 0 18px 55px rgba(0,0,0,.34);
}

p.site-description.kk-hero__subtitle {
    max-width: 620px;
    margin-top: 22px;
    margin-bottom: 0;
    color: rgba(255,255,255,.90);
    font-size: clamp(20px, 2.6vw, 31px);
    line-height: 1.25;
    font-weight: 420;
    text-shadow: 0 8px 24px rgba(0,0,0,.30);
}

.kk-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    margin-top: 34px;
}

.kk-btn,
.read-more-button a,
input[type="submit"],
button,
.btn-default,
a.comment-reply-link,
#searchsubmit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    padding: 13px 22px;
    border-radius: 999px;
    border: 1px solid transparent;
    font-family: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    font-size: 14px;
    font-weight: 780;
    letter-spacing: .06em;
    text-transform: uppercase;
    transition: transform .22s ease, box-shadow .22s ease, background .22s ease, color .22s ease, border-color .22s ease;
}

.kk-btn:hover,
.read-more-button a:hover,
input[type="submit"]:hover,
button:hover,
.btn-default:hover,
a.comment-reply-link:hover {
    transform: translateY(-2px);
    box-shadow: 0 14px 30px rgba(67,39,24,.20);
}

.kk-btn--primary,
input[type="submit"],
button,
.btn-default,
#searchsubmit {
    background: linear-gradient(135deg, #9f7a3f 0%, #7c4f28 100%);
    color: #fff !important;
    box-shadow: 0 14px 34px rgba(67,39,24,.24);
}

.kk-btn--ghost {
    color: #fff !important;
    border-color: rgba(255,255,255,.38);
    background: rgba(255,255,255,.12);
    backdrop-filter: blur(12px);
}

.kk-hero__facts {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 22px;
}

.kk-hero__facts span {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: 7px 13px;
    border-radius: 999px;
    background: rgba(255,255,255,.14);
    border: 1px solid rgba(255,255,255,.22);
    color: rgba(255,255,255,.88);
    font-size: 13px;
    font-weight: 650;
}

/* Navigation -------------------------------------------------------------- */
.kk-main-menu {
    min-height: 0;
    background: transparent;
    margin-top: -42px;
    position: sticky;
    top: 0;
    z-index: 9998;
    padding: 0 18px;
}

.admin-bar .kk-main-menu {
    top: 32px;
}

#site-navigation.kk-navigation,
#site-navigation.kk-navigation.shrink {
    width: min(var(--kk-max), calc(100vw - 36px));
    min-height: 70px;
    margin: 0 auto;
    border: 1px solid rgba(255,255,255,.55);
    border-radius: 999px;
    background: rgba(255,255,255,.86);
    backdrop-filter: blur(24px) saturate(1.25);
    box-shadow: 0 18px 48px rgba(31,42,36,.16);
    transition: transform .24s ease, box-shadow .24s ease, background .24s ease, border-color .24s ease;
}

body.kk-is-scrolled #site-navigation.kk-navigation,
#site-navigation.kk-navigation.shrink {
    transform: translateY(8px);
    background: rgba(255,253,249,.94);
    border-color: var(--kk-line);
    box-shadow: 0 18px 42px rgba(31,42,36,.17);
}

.kk-navigation__inner.container {
    width: 100%;
    padding-left: 24px;
    padding-right: 24px;
}

.navbar-center .kk-menu-container {
    text-align: center;
}

.kk-menu.navbar-nav {
    float: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 2px;
    margin: 0;
}

.kk-menu.navbar-nav > li > a,
#site-navigation.kk-navigation nav a,
#site-navigation.kk-navigation a {
    color: var(--kk-text);
}

.kk-menu.navbar-nav > li > a {
    padding: 23px 12px;
    border: 0;
    border-radius: 999px;
    color: var(--kk-text) !important;
    font-size: 12px;
    font-weight: 780;
    letter-spacing: .075em;
    line-height: 1;
    text-transform: uppercase;
}

.kk-menu.navbar-nav > li:hover > a,
.kk-menu.navbar-nav > .active > a,
.kk-menu.navbar-nav > .current-menu-item > a,
.kk-menu.navbar-nav > .current-menu-parent > a,
.kk-menu.navbar-nav > .open > a {
    background: rgba(124,79,40,.10) !important;
    color: var(--kk-brand-dark) !important;
}

.nav > li > a:before,
.nav > li.active > a:after,
.current-page-parent:after,
li.home-icon.front_page_on:before {
    display: none !important;
}

.kk-menu .dropdown-menu {
    min-width: 240px;
    padding: 10px;
    border: 1px solid var(--kk-line) !important;
    border-radius: 20px !important;
    background: rgba(255,253,249,.98);
    box-shadow: 0 24px 52px rgba(31,42,36,.16);
}

.kk-menu .dropdown-menu > li > a {
    padding: 11px 13px !important;
    border-radius: 14px;
    color: var(--kk-text) !important;
    font-size: 14px;
    line-height: 1.25;
    white-space: normal;
}

.kk-menu .dropdown-menu > li > a:hover,
.kk-menu .dropdown-menu > .active > a {
    background: rgba(124,79,40,.10) !important;
    color: var(--kk-brand-dark) !important;
}

/* Content frame ----------------------------------------------------------- */
.main-container.container {
    width: min(var(--kk-max), calc(100vw - 36px));
    margin-top: clamp(44px, 8vw, 92px);
    padding-left: 0;
    padding-right: 0;
    background: transparent;
}

.page-area {
    padding-top: 0;
}

.kk-content-row.row,
.row {
    margin-left: -12px;
    margin-right: -12px;
}

.kk-page-article,
.kk-support-widgets,
#sidebar {
    padding-left: 12px;
    padding-right: 12px;
}

.single-wrap,
.news-item-content,
.postauthor-container,
.comments-template,
.kk-page-card,
.widget {
    border: 1px solid var(--kk-line);
    border-radius: var(--kk-radius-lg);
    background: var(--kk-surface);
    box-shadow: var(--kk-shadow-card);
}

.single-wrap.kk-page-card,
.single-wrap.kk-single-card {
    padding: clamp(28px, 5.8vw, 70px);
    margin-bottom: 32px;
    overflow: hidden;
}

.main-content-page.kk-entry-shell {
    max-width: 980px;
    margin: 0 auto;
}

.kk-entry-header {
    margin-bottom: clamp(24px, 4vw, 46px);
    text-align: center;
}

h1.single-title.kk-entry-title {
    max-width: 930px;
    margin: 0 auto;
    font-size: clamp(38px, 5vw, 68px);
    line-height: 1.02;
    font-weight: 700;
    text-align: center;
    text-transform: none;
}

.home h1.single-title.kk-entry-title,
.front-page h1.single-title.kk-entry-title {
    font-size: clamp(34px, 4.4vw, 58px);
}

.kk-entry-content {
    color: var(--kk-text);
    font-size: clamp(17px, 1.25vw, 19px);
}

.kk-entry-content > *:first-child {
    margin-top: 0;
}

.kk-entry-content h2,
.kk-entry-content h3,
.kk-entry-content h4 {
    margin-top: 2.1em;
    margin-bottom: .7em;
}

.kk-entry-content h2 {
    font-size: clamp(30px, 3.5vw, 46px);
    line-height: 1.08;
}

.kk-entry-content h3 {
    font-size: clamp(24px, 2.4vw, 34px);
    line-height: 1.16;
}

.kk-entry-content blockquote,
.kk-entry-content > p:first-of-type {
    font-size: clamp(19px, 1.6vw, 23px);
    line-height: 1.65;
    color: #334038;
}

.kk-entry-content blockquote {
    margin: 30px 0;
    padding: 26px 30px;
    border: 0;
    border-left: 5px solid var(--kk-accent);
    border-radius: 24px;
    background: linear-gradient(135deg, rgba(159,122,63,.11), rgba(56,83,66,.06));
}

.kk-entry-content hr {
    margin: 38px auto;
    width: min(180px, 48%);
    border: 0;
    border-top: 1px solid var(--kk-line);
}

.kk-entry-content ul,
.kk-entry-content ol {
    padding-left: 1.35em;
}

.kk-entry-content li {
    margin-bottom: .45em;
}

.kk-entry-content table {
    overflow: hidden;
    border: 1px solid var(--kk-line);
    border-radius: 18px;
    background: #fff;
    box-shadow: 0 10px 24px rgba(31,42,36,.07);
}

.kk-entry-content th,
.kk-entry-content td {
    padding: 15px 16px;
    border-bottom: 1px solid var(--kk-line);
    vertical-align: top;
}

.kk-entry-content tr:last-child th,
.kk-entry-content tr:last-child td {
    border-bottom: 0;
}

.kk-entry-content th {
    background: rgba(124,79,40,.08);
    color: var(--kk-brand-dark);
}

/* Image and gallery treatment -------------------------------------------- */
.news-thumb {
    margin-bottom: 26px;
}

.news-thumb img,
.kk-entry-content img,
.wp-caption,
.gallery img,
.wp-block-image img,
.wp-block-gallery img {
    border: 0 !important;
    padding: 0 !important;
    border-radius: 24px;
    box-shadow: 0 18px 42px rgba(31,42,36,.13);
}

.kk-page-card > .news-thumb:first-child img,
.kk-entry-content > p > a > img,
.kk-entry-content figure img {
    transition: transform .35s ease, box-shadow .35s ease, filter .35s ease;
}

.kk-entry-content > p > a:hover > img,
.kk-entry-content figure:hover img {
    transform: translateY(-3px);
    box-shadow: 0 24px 55px rgba(31,42,36,.18);
}

.gallery,
.wp-block-gallery,
.kk-entry-content .blocks-gallery-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 16px !important;
    margin: 34px 0 !important;
}

.gallery .gallery-item,
.wp-block-gallery .wp-block-image,
.blocks-gallery-grid .blocks-gallery-item {
    width: auto !important;
    margin: 0 !important;
    overflow: hidden;
    border-radius: 24px;
}

.gallery img,
.wp-block-gallery img,
.blocks-gallery-grid img {
    width: 100%;
    height: 100%;
    min-height: 220px;
    object-fit: cover;
}

.wp-caption {
    max-width: 100%;
    padding: 8px !important;
    background: var(--kk-surface-solid);
}

.wp-caption p.wp-caption-text,
.gallery-caption,
figcaption {
    color: var(--kk-muted);
    font-size: 14px;
    line-height: 1.45;
}

/* Booking system and forms ----------------------------------------------- */
.kk-entry-content form,
.booking_form,
.booking_form_div,
.wpbc_booking_form_structure,
.wpbc_structure_form,
.wpbc_container,
.datepick,
.bk_calendar_frame,
.wpbc_calendar_wraper {
    max-width: 100%;
}

.booking_form,
.wpbc_booking_form_structure,
.wpbc_structure_form,
.kk-entry-content form {
    padding: clamp(18px, 3vw, 32px);
    border: 1px solid var(--kk-line);
    border-radius: var(--kk-radius-md);
    background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(250,246,239,.96));
    box-shadow: 0 12px 32px rgba(31,42,36,.08);
}

.booking_form .form-group,
.wpbc_structure_form .form-group {
    margin-bottom: 16px;
}

label {
    color: var(--kk-text);
    font-weight: 720;
}

input,
textarea,
select,
.form-control,
.booking_form input,
.booking_form textarea,
.booking_form select,
.wpbc_structure_form input,
.wpbc_structure_form textarea,
.wpbc_structure_form select {
    width: 100%;
    min-height: 48px;
    padding: 12px 14px;
    border: 1px solid rgba(63,51,36,.18);
    border-radius: 15px;
    background: rgba(255,255,255,.94);
    color: var(--kk-text);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.75);
    transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
}

input:focus,
textarea:focus,
select:focus,
.form-control:focus {
    outline: none;
    border-color: rgba(124,79,40,.60);
    box-shadow: 0 0 0 4px rgba(159,122,63,.14);
    background: #fff;
}

textarea,
.booking_form textarea {
    min-height: 128px;
    resize: vertical;
}

.block_hints,
.wpbc_calendar_wraper,
.datepick,
.booking_calendar_container,
.cal_month_num_1,
.cal_month_num_2 {
    border-radius: var(--kk-radius-md) !important;
}

.block_hints {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
    padding: 12px 0;
}

.block_hints .block_free,
.block_hints .block_booked,
.block_hints .block_pending,
.block_hints .block_time,
.block_hints .block_check_in_out {
    border-radius: 999px !important;
}

.datepick,
.wpbc_calendar_wraper table,
.booking_calendar_container table {
    overflow: hidden;
    border: 1px solid var(--kk-line) !important;
    background: #fff !important;
    box-shadow: 0 16px 38px rgba(31,42,36,.10);
}

.wpbc_calendar_wraper a,
.datepick a {
    border-bottom: 0;
}

/* Sidebar / widgets ------------------------------------------------------- */
body.page #sidebar,
body.single #sidebar,
.kk-support-widgets #sidebar {
    width: 100%;
    max-width: 100%;
    float: none;
    clear: both;
    margin-top: 16px;
}

body.page #sidebar .sidebar__inner,
.kk-support-widgets #sidebar .sidebar__inner {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 24px;
}

.widget {
    padding: 24px;
    margin-bottom: 24px;
    background: rgba(255,253,249,.9);
}

.widget-title {
    margin: 0 0 18px;
    padding: 0;
    text-align: left;
}

.widget-title:after {
    display: none;
}

.widget-title h3 {
    padding: 0;
    border: 0;
    background: transparent;
    font-size: 24px;
    line-height: 1.15;
    text-transform: none;
}

.widget ul li {
    padding: 9px 0;
    border-color: var(--kk-line);
}

/* Listings/search/archive without blog feel ------------------------------ */
.kk-listing-card {
    margin-bottom: 28px;
}

.kk-listing-card__inner.news-item-content {
    display: grid;
    grid-template-columns: minmax(240px, .8fr) minmax(0, 1.2fr);
    gap: 28px;
    align-items: center;
    padding: 24px;
    text-align: left;
}

.kk-listing-card__media.news-thumb {
    margin-bottom: 0;
}

.kk-listing-card__media img {
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
}

.kk-listing-card__title a,
.news-item h2 a {
    color: var(--kk-text);
    font-size: clamp(28px, 3vw, 42px);
    line-height: 1.05;
}

.kk-listing-card__excerpt,
.post-excerpt {
    margin-top: 16px;
    color: var(--kk-muted);
    font-style: normal;
}

.author-meta,
.posted-date,
.comments-meta,
.cat-links,
.tags-links {
    color: var(--kk-muted);
}

/* Footer ------------------------------------------------------------------ */
#content-footer-section {
    margin-top: 56px;
    padding: 38px 0;
    background: transparent;
}

.footer-credits {
    margin-top: 56px;
    padding: 34px 0;
    background: linear-gradient(135deg, #25382d 0%, #142219 100%);
}

.footer-credits-text {
    padding: 0;
    color: rgba(255,255,255,.88);
    font-size: 14px;
}

.footer-credits-text strong {
    color: #fff;
    font-family: Georgia, "Times New Roman", serif;
    font-size: 19px;
}

/* Breadcrumb/search/comments --------------------------------------------- */
#breadcrumbs,
.page-header,
.archive-page-header {
    border-radius: var(--kk-radius-md);
    background: rgba(255,253,249,.72);
    border: 1px solid var(--kk-line);
    box-shadow: 0 8px 24px rgba(31,42,36,.06);
}

#breadcrumbs {
    padding: 12px 18px;
    color: var(--kk-muted);
}

.page-header,
.archive-page-header {
    padding: 28px;
    margin: 0 0 28px;
}

.comments-template,
.comment-respond,
.comment-body {
    border-radius: var(--kk-radius-md);
}

/* Mobile ------------------------------------------------------------------ */
@media (max-width: 991px) {
    .site-header.kk-hero {
        min-height: 620px;
    }

    .kk-menu.navbar-nav > li > a {
        padding-left: 9px;
        padding-right: 9px;
        font-size: 11px;
    }

    .kk-listing-card__inner.news-item-content {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 767px) {
    body {
        font-size: 16px;
    }

    .site-header.kk-hero {
        min-height: 560px;
    }

    .site-heading.kk-hero__content {
        padding-top: 78px;
        text-align: left;
    }

    .kk-hero__actions,
    .kk-hero__facts {
        align-items: stretch;
    }

    .kk-btn {
        width: 100%;
    }

    .kk-main-menu {
        margin-top: -34px;
        padding-left: 12px;
        padding-right: 12px;
    }

    #site-navigation.kk-navigation,
    #site-navigation.kk-navigation.shrink {
        width: calc(100vw - 24px);
        min-height: 64px;
        border-radius: 26px;
    }

    .kk-navigation__inner.container {
        padding-left: 16px;
        padding-right: 16px;
    }

    .kk-navigation__mobile {
        min-height: 64px;
    }

    .kk-menu-toggle.open-panel {
        top: 20px;
        right: 20px;
    }

    .kk-menu-toggle.open-panel span {
        background: var(--kk-text);
    }

    .kk-menu-container.menu-container {
        position: fixed;
        top: 86px;
        left: 18px;
        right: 18px;
        width: auto;
        max-height: calc(100vh - 112px);
        height: auto;
        padding: 12px;
        overflow-y: auto;
        overflow-x: hidden;
        transform: translate3d(0, -18px, 0) scale(.98);
        opacity: 0;
        pointer-events: none;
        border: 1px solid var(--kk-line);
        border-radius: 26px;
        background: rgba(255,253,249,.98);
        box-shadow: 0 24px 58px rgba(31,42,36,.23);
        transition: opacity .24s ease, transform .24s ease;
    }

    .openNav .kk-menu-container.menu-container {
        transform: translate3d(0, 0, 0) scale(1);
        opacity: 1;
        pointer-events: auto;
    }

    .openNav .page-area {
        transform: none;
    }

    .openNav .page-area:after {
        display: none;
    }

    .kk-menu.navbar-nav {
        display: block;
        width: 100%;
    }

    .kk-menu.navbar-nav li,
    .kk-menu.navbar-nav ul {
        padding: 0 !important;
        margin: 0 !important;
    }

    .kk-menu.navbar-nav > li > a,
    .navbar-nav a {
        width: 100%;
        float: none !important;
        display: block;
        margin: 0 !important;
        padding: 13px 14px !important;
        border-radius: 16px;
        background: transparent !important;
        color: var(--kk-text) !important;
        font-size: 13px;
        line-height: 1.25 !important;
        text-align: left;
    }

    .kk-menu .dropdown-menu {
        display: block !important;
        position: relative !important;
        left: auto !important;
        top: auto !important;
        width: 100%;
        min-width: 0;
        margin: 4px 0 8px !important;
        padding: 6px 0 6px 12px;
        border: 0 !important;
        border-left: 1px solid var(--kk-line) !important;
        border-radius: 0 !important;
        background: transparent;
        box-shadow: none;
    }

    .main-container.container {
        width: calc(100vw - 24px);
        margin-top: 44px;
    }

    .single-wrap.kk-page-card,
    .single-wrap.kk-single-card,
    .widget {
        border-radius: 24px;
    }

    .single-wrap.kk-page-card,
    .single-wrap.kk-single-card {
        padding: 24px 18px;
    }

    .gallery,
    .wp-block-gallery,
    .kk-entry-content .blocks-gallery-grid {
        grid-template-columns: 1fr;
        gap: 12px !important;
    }

    .gallery img,
    .wp-block-gallery img,
    .blocks-gallery-grid img {
        min-height: 190px;
    }

    .booking_form,
    .wpbc_booking_form_structure,
    .wpbc_structure_form,
    .kk-entry-content form {
        padding: 16px;
    }
}

@media (max-width: 480px) {
    .kk-hero__eyebrow {
        font-size: 11px;
        letter-spacing: .08em;
    }

    h1.site-title.kk-hero__title,
    .site-title.kk-hero__title,
    h1.site-title.kk-hero__title a,
    .site-title.kk-hero__title a {
        font-size: clamp(40px, 15vw, 60px);
    }

    p.site-description.kk-hero__subtitle {
        font-size: 19px;
    }

    .block_hints {
        display: block;
    }
}


/* --------------------------------------------------------------------------
   Kitzeck premium refinement layer
   Focus: clearer hero images, cleaner page rhythm, no 3-column footer,
   stronger hospitality presentation, better media grouping and award layout.
-------------------------------------------------------------------------- */

:root {
    --kk-premium-max: 1240px;
}

body.kk-premium-theme {
    letter-spacing: .002em;
}

.main-container.container,
#site-navigation .container,
.footer-credits .container,
#content-footer-section .container,
.site-header .container {
    width: 100%;
    max-width: var(--kk-premium-max);
}

.site-header.kk-hero {
    min-height: clamp(580px, 78vh, 860px);
    background-position: center center;
}

.site-header.kk-hero.kk-hero--page {
    min-height: clamp(420px, 54vh, 620px);
}

.kk-hero__content {
    max-width: 820px;
}

.kk-hero__kicker {
    margin: 6px 0 14px;
    font-size: 15px;
    line-height: 1.4;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: rgba(255,255,255,.76);
}

.kk-hero__kicker a,
.kk-hero__kicker a:hover {
    color: inherit;
}

.kk-hero__title {
    max-width: 12ch;
}

.kk-hero__title--page {
    max-width: 14ch;
    font-size: clamp(42px, 6.2vw, 76px);
}

.kk-hero__subtitle {
    max-width: 42rem;
}

.kk-btn--soft {
    color: #fff;
    border-color: rgba(255,255,255,.28);
    background: rgba(255,255,255,.12);
}

.kk-btn--soft:hover,
.kk-btn--soft:focus {
    color: var(--kk-text);
    background: rgba(255,255,255,.94);
}

.kk-main-menu {
    margin-top: -38px;
}

#site-navigation.kk-navigation,
#site-navigation.kk-navigation.shrink {
    max-width: var(--kk-premium-max);
}

.kk-content-row {
    margin-left: 0;
    margin-right: 0;
}

.kk-page-card {
    padding: clamp(28px, 4vw, 54px);
    border-radius: 32px;
    background: rgba(255,253,249,.92);
    box-shadow: 0 20px 70px rgba(40, 26, 12, .09);
}

.kk-page--home .kk-page-card {
    margin-top: 8px;
}

.kk-entry-header,
.page .posted-on,
.page .entry-footer,
.page .postauthor-container,
.page .cat-links,
.page .tags-links,
.page .comments-meta,
.page .posted-date {
    display: none !important;
}

.kk-entry-shell {
    max-width: 100%;
}

.kk-entry-content {
    font-size: 18px;
    line-height: 1.86;
}

.kk-entry-content > * + h2,
.kk-entry-content > * + h3,
.kk-entry-content > * + h4 {
    margin-top: 1.9em;
}

.kk-entry-content h2 {
    font-size: clamp(30px, 3.6vw, 42px);
    margin-bottom: .45em;
}

.kk-entry-content h3 {
    font-size: clamp(24px, 3vw, 32px);
    margin-bottom: .5em;
}

.kk-entry-content ul,
.kk-entry-content ol {
    padding-left: 1.35em;
    margin-bottom: 1.5em;
}

.kk-entry-content blockquote {
    margin: 2.2em 0;
    padding: 24px 28px;
    border: 1px solid var(--kk-line);
    border-left: 4px solid var(--kk-brand);
    border-radius: 22px;
    background: rgba(255,255,255,.72);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.75);
}

.kk-entry-content p > a {
    text-underline-offset: 0.16em;
}

.kk-entry-content .alignleft,
.kk-entry-content .alignright,
.kk-entry-content .aligncenter,
.kk-entry-content figure,
.kk-entry-content .wp-caption {
    margin-bottom: 1.5em;
}

.kk-entry-content img,
.kk-entry-content .wp-caption,
.kk-entry-content iframe {
    border-radius: 26px;
}

.kk-entry-content iframe {
    width: 100%;
}

/* automatic media grouping */
.kk-media-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
    margin: 2.4em 0;
}

.kk-media-grid__item,
.kk-media-grid__item > * {
    margin: 0 !important;
}

.kk-media-grid__item img {
    display: block;
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    border-radius: 24px;
    box-shadow: var(--kk-shadow-card);
}

.kk-logo-grid {
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 16px;
}

.kk-logo-grid .kk-media-grid__item {
    display: flex;
    align-items: stretch;
}

.kk-logo-grid .kk-media-grid__item > * {
    width: 100%;
}

.kk-logo-grid .kk-media-grid__item img {
    aspect-ratio: 4 / 3;
    object-fit: contain;
    padding: 16px;
    background: #fff;
    border: 1px solid rgba(63,51,36,.08);
}

/* booking and form styling */
.kk-entry-content form,
.booking_form,
.wpbc_booking_form_structure,
.wpbc_structure_form {
    border-radius: 28px;
    background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,244,237,.94));
    border: 1px solid rgba(63,51,36,.1);
    box-shadow: 0 18px 50px rgba(31,42,36,.08);
}

.kk-entry-content input[type="text"],
.kk-entry-content input[type="email"],
.kk-entry-content input[type="tel"],
.kk-entry-content input[type="number"],
.kk-entry-content input[type="url"],
.kk-entry-content textarea,
.kk-entry-content select,
.booking_form input[type="text"],
.booking_form input[type="email"],
.booking_form textarea,
.booking_form select {
    min-height: 52px;
    border-radius: 16px;
    border: 1px solid rgba(63,51,36,.12);
    background: rgba(255,255,255,.94);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.8);
}

.kk-entry-content input[type="submit"],
.kk-entry-content button,
.booking_form input[type="submit"],
.booking_form .button,
.kk-entry-content .wp-block-button__link {
    border-radius: 999px;
    padding: 14px 26px;
    border: 0;
    background: linear-gradient(135deg, var(--kk-brand) 0%, var(--kk-brand-dark) 100%);
    color: #fff;
    font-weight: 700;
}

.kk-entry-content table,
.kk-entry-content .widefat,
.kk-entry-content .wp-block-table table {
    border-radius: 20px;
    overflow: hidden;
    background: rgba(255,255,255,.78);
    box-shadow: 0 8px 22px rgba(31,42,36,.06);
}

.kk-entry-content th {
    background: rgba(56,83,66,.08);
}

/* widgets / side content */
.kk-support-widgets {
    margin-top: 22px;
}

.kk-support-widgets #secondary {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 18px;
}

.kk-support-widgets .widget {
    margin-bottom: 0;
}

/* footer without unnecessary 3-column look */
#content-footer-section {
    margin-top: 40px;
    padding: 0 0 10px;
}

.kk-footer-widgets__inner {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
}

.kk-footer-widget,
.kk-footer-widgets__inner .widget {
    width: 100%;
    float: none;
    margin: 0;
}

.footer-credits {
    margin-top: 24px;
}

.footer-credits-text {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
    text-align: center;
}

.footer-credits-text .sep {
    opacity: .45;
}

@media (max-width: 1199px) {
    .kk-media-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767px) {
    .site-header.kk-hero {
        min-height: 560px;
    }

    .site-header.kk-hero.kk-hero--page {
        min-height: 420px;
    }

    .kk-page-card {
        padding: 22px 18px;
        border-radius: 26px;
    }

    .kk-entry-content {
        font-size: 17px;
    }

    .kk-media-grid,
    .kk-logo-grid {
        grid-template-columns: 1fr;
    }

    .kk-footer-widget,
    .kk-footer-widgets__inner .widget {
        padding: 22px 18px;
    }

    .footer-credits-text {
        gap: 6px;
    }
}


/* --------------------------------------------------------------------------
   Kitzeck warm emotional tourism layer
   Warmer, more inviting Südsteiermark feeling while preserving all content.
-------------------------------------------------------------------------- */

:root {
    --kk-bg: #fbf2e5;
    --kk-surface: rgba(255,250,243,.94);
    --kk-surface-solid: #fff9f0;
    --kk-text: #2d241d;
    --kk-muted: #766759;
    --kk-line: rgba(117,72,40,.14);
    --kk-brand: #a65f2b;
    --kk-brand-dark: #5a2f1e;
    --kk-accent: #c18846;
    --kk-green: #526944;
    --kk-wine: #7b3832;
    --kk-honey: #d7a34f;
    --kk-shadow-soft: 0 22px 70px rgba(83,46,22,.13);
    --kk-shadow-card: 0 16px 42px rgba(83,46,22,.12);
}

body.kk-premium-theme {
    background:
        radial-gradient(circle at 10% 8%, rgba(215,163,79,.18), transparent 30rem),
        radial-gradient(circle at 88% 18%, rgba(123,56,50,.10), transparent 28rem),
        linear-gradient(180deg, #fff8ef 0%, #fbf2e5 48%, #f5e3cb 100%);
    color: var(--kk-text);
}

body.kk-premium-theme:before {
    background-image:
        linear-gradient(rgba(166,95,43,.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(166,95,43,.04) 1px, transparent 1px);
}

h1, h2, h3, h4, h5, h6,
.single-title,
.news-item h2,
.widget-title h3 {
    color: #2a2119;
}

.site-header.kk-hero {
    background-color: #4b3324;
    background-position: center center;
}

.site-header.kk-hero:before {
    background:
        linear-gradient(100deg, rgba(52, 32, 20, .82) 0%, rgba(85, 48, 26, .58) 42%, rgba(120, 72, 36, .24) 100%),
        radial-gradient(circle at 76% 24%, rgba(255, 207, 137, .34), transparent 25rem),
        radial-gradient(circle at 28% 78%, rgba(123,56,50,.28), transparent 22rem);
}

.site-header.kk-hero:after {
    background:
        linear-gradient(180deg, transparent 58%, rgba(251,242,229,.98) 100%),
        linear-gradient(90deg, rgba(0,0,0,.18), transparent 52%);
}

.kk-hero__eyebrow {
    color: rgba(255,231,201,.92);
    background: rgba(255, 241, 221, .13);
    border-color: rgba(255, 228, 190, .25);
    box-shadow: 0 10px 32px rgba(0,0,0,.10);
}

.kk-hero__emotion {
    max-width: 38rem;
    margin: 0 0 1.35rem;
    color: #ffe6c3;
    font-family: Georgia, "Times New Roman", serif;
    font-size: clamp(22px, 2.8vw, 34px);
    line-height: 1.24;
    letter-spacing: -.02em;
    text-shadow: 0 2px 22px rgba(0,0,0,.18);
}

.kk-hero__title {
    text-shadow: 0 4px 34px rgba(0,0,0,.36);
}

.kk-hero__subtitle {
    color: rgba(255,244,232,.90);
}

.kk-btn--primary {
    background: linear-gradient(135deg, #c9823c 0%, #8d4328 100%);
    color: #fff;
    box-shadow: 0 18px 44px rgba(98, 45, 23, .34);
}

.kk-btn--primary:hover,
.kk-btn--primary:focus {
    background: linear-gradient(135deg, #d99b55 0%, #963f27 100%);
    color: #fff;
}

.kk-btn--ghost,
.kk-btn--soft {
    border-color: rgba(255,232,199,.38);
    background: rgba(255,243,226,.12);
    color: #fff7ec;
}

.kk-btn--ghost:hover,
.kk-btn--soft:hover,
.kk-btn--ghost:focus,
.kk-btn--soft:focus {
    background: rgba(255,249,239,.94);
    color: #4f2f20;
}

.kk-hero__facts span {
    background: rgba(255,244,229,.12);
    border-color: rgba(255,228,190,.26);
    color: rgba(255,245,232,.94);
}

#site-navigation.kk-navigation,
#site-navigation.kk-navigation.shrink {
    background: rgba(255, 249, 239, .86);
    border-color: rgba(130,75,36,.16);
    box-shadow: 0 16px 42px rgba(80,45,20,.16);
}

.kk-menu.navbar-nav > li > a {
    color: #473327;
}

.kk-menu.navbar-nav > li > a:hover,
.kk-menu.navbar-nav > li.active > a,
.kk-menu.navbar-nav > li.current-menu-item > a,
.kk-menu.navbar-nav > li.current-menu-ancestor > a {
    color: #fff !important;
    background: linear-gradient(135deg, #a65f2b, #7b3832) !important;
}

.kk-page-card,
.single-wrap.kk-single-card,
.widget {
    background: linear-gradient(180deg, rgba(255,250,242,.95), rgba(255,247,235,.90));
    border-color: rgba(130,75,36,.12);
    box-shadow: 0 24px 78px rgba(83,46,22,.11);
}

.kk-entry-content > p:first-of-type,
.kk-page--home .kk-entry-content > p:first-of-type {
    font-size: clamp(19px, 2vw, 22px);
    line-height: 1.78;
    color: #4b3728;
}

.kk-entry-content h2:after,
.kk-entry-content h3:after,
.widget-title h3:after {
    content: "";
    display: block;
    width: 72px;
    height: 3px;
    margin-top: 12px;
    border-radius: 999px;
    background: linear-gradient(90deg, var(--kk-brand), var(--kk-honey));
}

.kk-entry-content blockquote {
    background: linear-gradient(135deg, rgba(255,248,238,.96), rgba(250,231,203,.78));
    border-color: rgba(130,75,36,.12);
    border-left-color: var(--kk-wine);
}

.kk-media-grid__item img,
.gallery img,
.wp-block-gallery img,
.blocks-gallery-grid img {
    border-radius: 28px;
    box-shadow: 0 18px 44px rgba(83,46,22,.15);
}

.kk-media-grid__item:hover img,
.gallery-item:hover img,
.wp-block-gallery figure:hover img {
    transform: translateY(-3px);
    transition: transform .25s ease, box-shadow .25s ease;
    box-shadow: 0 24px 58px rgba(83,46,22,.20);
}

.kk-logo-grid {
    padding: 18px;
    border-radius: 30px;
    background: rgba(255,250,242,.68);
    border: 1px solid rgba(130,75,36,.10);
}

.kk-logo-grid .kk-media-grid__item img {
    background: #fffaf3;
    border-color: rgba(130,75,36,.12);
    box-shadow: 0 10px 28px rgba(83,46,22,.08);
}

.booking_form,
.wpbc_booking_form_structure,
.wpbc_structure_form,
.kk-entry-content form {
    background:
        radial-gradient(circle at 12% 0%, rgba(215,163,79,.14), transparent 18rem),
        linear-gradient(180deg, rgba(255,250,243,.98), rgba(250,236,216,.94));
    border-color: rgba(130,75,36,.13);
}

.kk-entry-content input[type="submit"],
.kk-entry-content button,
.booking_form input[type="submit"],
.booking_form .button,
.kk-entry-content .wp-block-button__link {
    background: linear-gradient(135deg, #b8662f 0%, #743424 100%);
    box-shadow: 0 14px 32px rgba(98,45,23,.22);
}

.footer-credits {
    background:
        radial-gradient(circle at 20% 0%, rgba(215,163,79,.16), transparent 18rem),
        linear-gradient(135deg, #5a3324 0%, #2b2119 100%);
}

.footer-credits-text strong {
    color: #ffe9c7;
}

@media (max-width: 767px) {
    .kk-hero__emotion {
        font-size: 24px;
    }
}


/* --------------------------------------------------------------------------
   Kitzeck layout correction layer
   - booking calendar/form in right sidebar area on homepage
   - award/brand images as small ribbon before footer
-------------------------------------------------------------------------- */
body.kk-is-home .kk-entry-content {
    position: relative;
}

.kk-home-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.55fr) minmax(320px, .9fr);
    gap: 30px;
    align-items: start;
}

.kk-home-main {
    min-width: 0;
}

.kk-home-booking {
    min-width: 0;
}

.kk-home-booking__inner {
    position: sticky;
    top: 118px;
    padding: 24px;
    border-radius: 28px;
    background: linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(250,245,236,.98) 100%);
    border: 1px solid rgba(63,51,36,.10);
    box-shadow: 0 20px 55px rgba(46, 29, 14, .10);
}

.kk-home-booking__label {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 7px 12px;
    margin-bottom: 14px;
    border-radius: 999px;
    background: rgba(124,79,40,.08);
    color: var(--kk-brand-dark);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
}

.kk-home-booking__label:before {
    content: "";
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--kk-brand);
}

.kk-home-booking h2,
.kk-home-booking h3 {
    margin-top: 0;
    margin-bottom: .55em;
    font-size: clamp(25px, 2.1vw, 34px);
}

.kk-home-booking p {
    margin-bottom: 1em;
}

body.kk-is-home .kk-home-booking .kk-media-grid,
body.kk-is-home .kk-home-booking .kk-logo-grid {
    grid-template-columns: 1fr;
}

body.kk-is-home .kk-home-booking .booking_form,
body.kk-is-home .kk-home-booking .wpbc_booking_form_structure,
body.kk-is-home .kk-home-booking .wpbc_structure_form,
body.kk-is-home .kk-home-booking form {
    padding: 18px;
    margin-top: 14px;
}

.kk-footer-ribbon {
    margin-top: 36px;
    margin-bottom: 10px;
}

.kk-footer-ribbon__inner {
    padding: 18px 22px;
    border-radius: 24px;
    background: rgba(255,253,249,.80);
    border: 1px solid rgba(63,51,36,.08);
    box-shadow: 0 12px 36px rgba(46,29,14,.06);
}

.kk-footer-ribbon__title {
    margin: 0 0 14px;
    color: var(--kk-muted);
    font-size: 13px;
    font-weight: 700;
    letter-spacing: .16em;
    text-transform: uppercase;
    text-align: center;
}

.kk-footer-ribbon__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(88px, 1fr));
    gap: 12px;
    align-items: center;
}

.kk-footer-ribbon__item {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 64px;
    padding: 8px 10px;
    border-radius: 16px;
    background: rgba(255,255,255,.78);
    border: 1px solid rgba(63,51,36,.06);
}

.kk-footer-ribbon__item img {
    max-height: 42px;
    width: auto;
    max-width: 100%;
    object-fit: contain;
    box-shadow: none;
    border-radius: 0;
}

@media (max-width: 991px) {
    .kk-home-layout {
        grid-template-columns: 1fr;
    }

    .kk-home-booking__inner {
        position: static;
    }
}
