/*----------------------------------------------------
@File: Default Styles
@Author: Rocky
@URL: http://wethemez.com
Author E-mail: rockybd1995@gmail.com

This file contains the styling for the actual theme, this
is the file you need to edit to change the look of the
theme.
---------------------------------------------------- */
/*=====================================================================
@Template Name: Royal Hotel
@Author: Rocky
@Developed By: Rocky
@Developer URL: http://rocky.wethemez.com
Author E-mail: rockybd1995@gmail.com

@Default
    Styles

    Table of Content:
    01/ Variables
    02/ predefin
    03/ header
    04/ button
    05/ banner
    06/ breadcrumb
    07/ about
    08/ team
    09/ project
    10/ price
    11/ team
    12/ blog
    13/ video
    14/ features
    15/ career
    16/ contact
    17/ footer

    =====================================================================*/
/*----------------------------------------------------*/
/*font Variables*/
/*Color Variables*/
/*=================== fonts ====================*/
@import url('https://fonts.googleapis.com/css2?family=Roboto:wdth,wght@75..100,100..900&display=swap');

.col-md-offset-right-1,
.col-lg-offset-right-1 {
    margin-right: 8.33333333%;
}

@font-face {
    font-family: 'Maname';
    src: url('/fonts/Maname-Regular.ttf') format('truetype');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

/*---------------------------------------------------- */
/*----------------------------------------------------*/
.list_style {
    list-style: none;
    margin: 0px;
    padding: 0px;
}

a {
    text-decoration: none;
    -webkit-transition: all 0.3s ease-in-out;
    -o-transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out;
}

a:hover,
a:focus {
    text-decoration: none;
    outline: none;
}

.row.m0 {
    margin: 0px;
}

.p0 {
    padding: 0px;
}

.mt-30 {
    margin-top: 30px;
}

.mt-25 {
    margin-top: 25px;
}

body {
    line-height: 24px;
    font-size: 14px;
    font-family: "Poppins", sans-serif;
    font-weight: 300;
    color: #777777;
}

section {
    background: #fff;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: "Poppins", sans-serif;
    font-weight: 600;
}

button:focus {
    outline: none;
}


@media (min-width: 1200px) {
    .container {
        max-width: 100%;
        padding-left: 0px !important;
        padding-right: 0px !important;

    }

    .section-container {
        max-width: 1200px;
        margin: auto;
        background-color: #fff;
    }
}

.section-container {
    margin: 0 auto;
    padding: 0 30px;
}

.section_gap {
    padding: 100px 0;
}

.d_flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}

.row_reverse {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
}

.mb_30 {
    margin-bottom: -30px;
}

.section_title {
    margin-bottom: 75px;
}

.section_title h2 {
    font-family: 'Maname', sans-serif;
    font-weight: 400;
    font-size: 36px;
    line-height: 45px;
}

.section_title p {
    font-family: 'Roboto', sans-serif;
    font-weight: 500;
    font-size: 16px;
    line-height: 30px;
    color: #000;
    margin-bottom: 100px;
}

.title {
    color: #222222;
    font-family: 'Maname', sans-serif;
    font-weight: 600;
    font-size: 36px;
    text-align: center;
}


.title_w {
    color: #000;
}

.title {
    font-size: 36px;
    line-height: 45px;
    font-weight: 600;
}

/*---------------------------------------------------- */
/*----------------------------------------------------*/
.theme_btn {
    font-size: 14px;
    line-height: 30px;
    text-transform: uppercase;
    color: #fff;
    font-weight: 600;
    background: #f3c300;
    padding: 5px 30px;
}

.theme_btn:before {
    background: #f8b100;
}

.theme_btn:hover {
    color: #fff;
}

.white_btn {
    background: #fff;
    padding: 0px 40px;
    line-height: 40px;
    font-size: 14px;
    color: #222222;
    font-family: "Poppins", sans-serif;
    font-weight: 500;
}

.button_hover {
    border-radius: 0px;
    position: relative;
    z-index: 1;
    -webkit-transition: all 0.3s linear;
    -o-transition: all 0.3s linear;
    transition: all 0.3s linear;
    overflow: hidden;
    border: 0px;
    display: inline-block;
    text-align: center;
}

.button_hover:before {
    content: "";
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
    position: absolute;
    -webkit-transform: translateX(-100%);
    -ms-transform: translateX(-100%);
    transform: translateX(-100%);
    z-index: -1;
    background: #535353;
    -webkit-transition: all 0.3s linear;
    -o-transition: all 0.3s linear;
    transition: all 0.3s linear;
    opacity: 0;
}

.button_hover:hover {
    color: #fff;
}

.button_hover:hover:before {
    -webkit-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
    opacity: 1;
}

.theme_btn_two {
    font-size: 14px;
    font-weight: 500;
    line-height: 30px;
    background: #222222;
    color: #fff;
    text-transform: uppercase;
    padding: 5px 29px;
}

.book_now_btn {
    width: 100%;
    display: block;
    background: #000;
    color: #fff;
    text-transform: uppercase;
    font-family: 'Roboto', sans-serif;
    font-weight: 700;
    font-size: 20px;
    line-height: 30px;
    padding: 5px 20px;
}

/*---------------------------------------------------- */
/*----------------------------------------------------*/
/*============== header css =============*/
.header_area {
    top: 0;
    left: 0;
    width: 100%;
    z-index: 20;
}

.header-top {

    padding: 3px 0px;
    background-color: #000;
}

.header-wrapper {
    width: 80%;
    margin: auto;
}

.header-top a {
    color: #fff;
    -webkit-transition: all 0.3s linear;
    -o-transition: all 0.3s linear;
    transition: all 0.3s linear;
}

.header-top a:hover {
    color: #f3c300;
}

.header-top ul {
    padding-left: 0px;
    margin-bottom: 0px;
}

.header-top ul li {
    display: inline-block;
    margin-right: 15px;
}

@media (max-width: 414px) {
    .header-top ul li {
        margin-right: 0px;
    }
}

.header-top .header-top-left a {
    margin-right: 8px;
    font-size: 12px;
    font-weight: 500;
    line-height: 20px;
    display: inline-block;
}

.header-top .header-top-right {
    text-align: right;
}

.header-top .header-top-right .header-social a {
    color: #fff;
    margin-left: 15px;
    -webkit-transition: all 0.3s linear;
    -o-transition: all 0.3s linear;
    transition: all 0.3s linear;
    font-size: 14px;
}

.header-top .header-top-right .header-social a:hover {
    color: #f3c300;
}

.navbar {
    padding: 0px;
    border: 0px;
    border-radius: 0px;
}


.navbar {
    background: #fff;
    padding: 0px 25px;
}



.navbar-container {
    width: 1200px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: auto;
}

@media (min-width: 576px) {

    .navbar-container {
        max-width: 100%;
    }
}

@media (min-width: 768px) {
    .navbar-container {
        max-width: 100%;
    }
}

@media (min-width: 992px) {
    .navbar-container {
        max-width: 100%;
    }
}

@media (min-width: 1200px) {
    .navbar-container {
        max-width: 1140px;
    }
}

.navbar .logo_h {
    padding-top: 21px;
    width: 120px;
    height: 100px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.navbar .logo_h img {
    width: 100%;
}

.navbar .menu_nav .nav-item .nav-link {
    font: 500 12px/80px "Poppins", sans-serif;
    color: #222222;
    text-transform: uppercase;
    padding: 0px;
}

.navbar .menu_nav .nav-item .nav-link:after {
    display: none;
}

.navbar .menu_nav .nav-item:hover .nav-link,
.navbar .menu_nav .nav-item.active .nav-link {
    color: #52c5fd;
}

.navbar .menu_nav .nav-item.submenu {
    position: relative;
}

.navbar .menu_nav .nav-item.submenu ul {
    border: none;
    padding: 0px;
    border-radius: 0px;
    -webkit-box-shadow: none;
    box-shadow: none;
    margin: 0px;
    background: transparent;
}

@media (min-width: 992px) {
    .navbar .menu_nav .nav-item.submenu ul {
        position: absolute;
        top: 100%;
        left: 0px;
        min-width: 220px;
        text-align: left;
        opacity: 0;
        -webkit-transition: all 300ms ease-in;
        -o-transition: all 300ms ease-in;
        transition: all 300ms ease-in;
        visibility: hidden;
        display: block;
        border: none;
        padding: 0px;
        border-radius: 0px;
    }
}

.navbar .menu_nav .nav-item.submenu ul:before {
    content: "";
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 10px 10px 0 10px;
    border-color: #eeeeee transparent transparent transparent;
    position: absolute;
    right: 24px;
    top: 45px;
    z-index: 3;
    opacity: 0;
    -webkit-transition: all 400ms linear;
    -o-transition: all 400ms linear;
    transition: all 400ms linear;
}

.navbar .menu_nav .nav-item.submenu ul .nav-item {
    display: block;
    float: none;
    margin-right: 0px;
    border-bottom: 1px solid #ededed;
    margin-left: 0px;
    background: #fff;
    -webkit-transition: all 0.4s linear;
    -o-transition: all 0.4s linear;
    transition: all 0.4s linear;
}

@media (min-width: 992px) {
    .navbar .menu_nav .nav-item.submenu ul .nav-item {
        margin-top: 10px;
    }
}

.navbar .menu_nav .nav-item.submenu ul .nav-item .nav-link {
    line-height: 45px;
    color: #222222;
    padding: 0px 30px;
    -webkit-transition: all 150ms linear;
    -o-transition: all 150ms linear;
    transition: all 150ms linear;
    display: block;
}

.navbar .menu_nav .nav-item.submenu ul .nav-item:last-child {
    border-bottom: none;
}

.navbar .menu_nav .nav-item.submenu ul .nav-item:hover .nav-link {
    background: #f0f0f0;
    color: #52c5fd;
}

@media (min-width: 992px) {
    .navbar .menu_nav .nav-item.submenu:hover ul {
        visibility: visible;
        opacity: 1;
    }
}

.navbar .menu_nav .nav-item.submenu:hover ul .nav-item {
    margin-top: 0px;
}

.navbar .menu_nav .nav-item+li {
    margin-left: 30px;
}

.menu_two {
    background: rgba(255, 255, 255, 0.15);
}

.menu_two .menu_nav .nav-item .nav-link {
    line-height: 60px;
    color: #fff;
}

.navbar_fixed {
    position: fixed;
    width: 100%;
    left: 0;
    background: #fff;
    top: 0;
    top: -50px;
    -webkit-transform: translateY(50px);
    -ms-transform: translateY(50px);
    transform: translateY(50px);
    -webkit-box-shadow: 0 0 30px rgba(0, 0, 0, 0.1);
    box-shadow: 0 0 30px rgba(0, 0, 0, 0.1);
    transition: transform 300ms ease, background 300ms ease, -webkit-transform 300ms ease;
}

.navbar_fixed .navbar {
    background: #fff;
}

.navbar_fixed .header-top {
    display: none;
}

.navbar_fixed.header_two {
    background: rgba(34, 34, 34, 0.9);
}



/*---------------------------------------------------- */
/*----------------------------------------------------*/
/*============= Start banner_area css =============*/
.banner_area {
    /* background: #04091e; */
    position: relative;
    z-index: 1;
    width: 100%;
}

.banner_area .bg-parallax {
    background: #fff;
}

.banner_area {
    width: 100%;
    bottom: 0;
    left: 0;
}

.booking_table {
    position: relative;
    overflow: hidden;
    width: 100%;
    min-height: 600px;
    background: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
}



.hero-img-wrapper {
    width: 650px;
    height: 400px;
    /* padding-top: 120px;  */
}

.hero-img-wrapper>img {
    width: 100%;
    height: 100%;
}

.hero-content {
    font-family: 'Roboto', sans-serif;
    font-weight: 400;
    font-size: 16px;
    margin-left: 70px;
    margin-bottom: 0px !important;
    color: #000;
    height: 400px;
    width: 20%;
    display: flex;
    align-items: flex-end;
}

.select {
    font-family: 'Roboto', sans-serif;
    font-weight: 500;
    font-size: 16px;
    background: transparent;
    border-radius: 0px;
    border: none;
    border-bottom: 1px solid #2b3146;
    font-size: 13px;
    line-height: 40px;
    height: 40px;
    padding: 10px;
}

.overlay {
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    height: 125%;
    bottom: 0;
    z-index: -1;
}

.banner_content {
    position: relative;
    z-index: 2;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto;
}

.banner_content>img {
    width: 30%;
    height: auto;
}

@media (max-width: 572px) {
    .banner_content>img {
        width: 100%;
    }
}

.none {
    display: none;
}

.input-group {
    position: relative;
    /* obavezno da bi absolute radio unutar */
    width: 100%;
}

.guests-show {
    background: transparent;
    border-radius: 0px;
    border: none;
    border-bottom: 1px solid #2b3146;
    font-size: 13px;
    line-height: 40px;
    height: 40px;
    color: #777;
    padding: 10px;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    position: relative;
    z-index: 2;
}

#childrenAgeInput {
    position: absolute;
    top: calc(100% + 5px);
    left: 0;
    width: 100%;
    background: #04091e;
    border-radius: 8px;
    border: 1px solid #2b3146;
    color: #ddd;
    padding: 15px;
    z-index: 10000;
    transform: translateY(-10px);
    transition: all 0.25s ease;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
}

.children-age-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 10px;
}

.children-age-header p {
    margin: 0;
    font-size: 1rem;
    color: #fff;
}

.close-children-btn {
    background: transparent;
    border: none;
    color: #aaa;
    font-size: 1.4rem;
    cursor: pointer;
    transition: color 0.2s ease;
}

.close-children-btn:hover {
    color: #fff;
}

.child-age-input {
    margin-bottom: 10px;
    width: 100%;
}

.child-age-input label {
    display: block;
    margin-bottom: 4px;
    color: #ccc;
}

#childrenAgeInput {
    z-index: 1000000;
}

#childrenAgeInput.active {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}


.guests-label>input {
    font-family: 'Roboto', sans-serif;
    font-weight: 400;
    font-size: 18px;
    background: transparent;
    border: 0;
    width: 13px;
    outline: none;
    color: #000;
}

.guests-label {
    display: flex;
    align-items: center;
    margin-top: 15px;
    border: 0;
    font-family: 'Roboto', sans-serif;
    font-weight: 500;
    height: auto;
    color: #000;
}

.guests-label>button {
    height: 30px;
    width: 30px;
}


.guests-show {
    width: 100%;
    display: flex;
    justify-content: space-between;
    /* tekst levo, dugmići desno */
    align-items: center;
}


.guests-controls {
    display: flex;
    align-items: center;
    gap: 8px;
    /* razmak između dugmića i inputa */
}

.guest-buttons {
    background: transparent;
    border: 1px solid #000;
    padding: 5px 10px;
    cursor: pointer;
    transition: 0.3s;
    border-radius: 50%;
    height: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.guest-buttons:hover {
    background-color: #000;
}


.guest-buttons:hover .minus-icon,
.guest-buttons:hover .plus-icon {
    color: #fff;
}

.guests-number {
    width: 40px;
    text-align: center;
    border: none;
    background: transparent;
    font-size: 16px;
}





#guests {
    position: relative;
}

.hotel_booking_area {
    background: #fff;
}

/*============= End banner_area css =============*/
.hotel_booking_table {
    max-width: 1200px;
    margin: 50px auto 0 auto;
    background: #fff;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    padding: 40px 50px 50px 50px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}

.hotel_booking_table h2 {
    font-family: 'Roboto', sans-serif;
    font-weight: 500;
    font-size: 24px;
    line-height: 30px;
    color: #000;
    text-align: left;
}



.boking_table {
    margin-left: -50px;
}

.book_tabel_item .form-group {
    margin-bottom: 0px;
}

.book_tabel_item .form-group .input-group {
    position: relative;
}

.book_tabel_item .form-group .input-group .form-control {
    border: 1px solid #2b3146;
    background: transparent;
    border-radius: 0px;
    font-size: 13px;
    line-height: 38px;
    padding: 0px 20px;
    color: #777777;
    z-index: 0;
}

.book_tabel_item .form-group .input-group .form-control.placeholder {
    color: #777777;
}

.book_tabel_item .form-group .input-group .form-control:-moz-placeholder {
    color: #777777;
}

.book_tabel_item .form-group .input-group .form-control::-moz-placeholder {
    color: #777777;
}

.book_tabel_item .form-group .input-group .form-control::-webkit-input-placeholder {
    color: #777777;
}

.book_tabel_item .form-group .input-group .form-control:focus {
    outline: none;
    -webkit-box-shadow: none;
    box-shadow: none;
}

.book_tabel_item .form-group .input-group .input-group-addon {
    background: transparent;
    padding: 0px;
    border: 0px;
    position: absolute;
    right: 20px;
    top: 50%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    color: #777777;
    z-index: 2;
}

.book_tabel_item .input-group {
    margin-bottom: 10px;
}

.book_tabel_item .nice-select {
    background: transparent;
    border-radius: 0px;
    border: 1px solid #2b3146;
    font-family: 'Roboto', sans-serif;
    font-weight: 500;
    font-size: 18px;
    line-height: 40px;
    height: 40px;
    color: #777;
}

.book_tabel_item .nice-select:after {
    content: "\e874";
    font-family: 'Linearicons-Free';
    font-size: 13px;
    color: #777777;
    border: 0px;
    top: 0;
    margin-top: 0px;
    right: 20px;
    -webkit-transform: rotate(0);
    -ms-transform: rotate(0);
    transform: rotate(0);
    -webkit-transform-origin: 0 0;
    -ms-transform-origin: 0 0;
    transform-origin: 0 0;
}

/*=========== breadcrumb_area css =============*/
.breadcrumb_area {
    position: relative;
    padding: 51px 0px 150px;
    background: #fff;
    z-index: 1;
    overflow: hidden;
}

.breadcrumb-image-wrapper {
    width: fit-content;
    height: auto;
    overflow: hidden;
    margin: 0 auto;
}

.breadcrumb-image-wrapper img {

    object-fit: cover;
    object-position: center;
}

.message {
    width: 231px;
    height: 167px;
}

.hill {
    width: 106px;
    height: 114px;
}

.keys {
    width: 256px;
    height: 150px;
}

.faq {
    width: 167px;
    height: 203px;
}

.exclamation {
    width: 195px;
    height: 183px;
}

.page-cover-tittle {
    font-family: 'Maname', sans-serif;
    font-weight: 600;
    display: block;
    font-size: 36px;
    line-height: 45px;
    color: #000;
}

.breadcrumb {
    text-align: center;
    background: transparent;
    padding: 0px;
    display: inline-block;
}

.breadcrumb li {
    display: inline-block;
    color: #fff;
}

.breadcrumb li a {
    color: #fff;
}

.breadcrumb li+li:before {
    content: "\e87a";
    font-family: 'Linearicons-Free';
    font-size: 14px;
    font-weight: 600;
    vertical-align: middle;
    margin: 0px 10px 0px 7px;
}



/* Grid wrapper */
.travel-programs-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 50px;
    height: fit-content;
}

/* Individual card */
.travel-card {
    overflow: hidden;
    height: 300px;
    margin-bottom: 70px;
}

@media (max-width: 767px) {
    .travel-card {
        padding: 0 20px;
        height: auto;
        margin-bottom: 50px;
    }
}

/* Image wrapper */
.travel-image-wrapper {
    width: 100%;
    height: 200px;
    position: relative;
}

/* Banner image */
.travel-image-wrapper img {
    width: 100%;
    height: 200px;
    object-fit: cover;
}

/* Overlay for text and button */
.travel-card-overlay {
    width: 100%;
    /* semi-transparent background */
    color: #000;
    padding: 15px;
    text-align: center;
}

/* Destination title */
.destination-name {
    font-family: 'Maname', sans-serif;
    font-weight: 700;
    font-size: 36px;
    margin: 0 0 10px 0;
}

/* Pregledaj button */
.pregledaj-btn {
    background-color: #ff7f50;
    color: white;
    padding: 8px 16px;
    border: none;
    text-decoration: none;
    font-weight: bold;
    border-radius: 4px;
    display: inline-block;
    transition: background-color 0.3s ease;
}

.pregledaj-btn:hover {
    background-color: #e0673f;
}

/* Responsive adjustments */
@media (max-width: 768px) {
    .travel-programs-grid {
        grid-template-columns: 1fr;
    }
}

.see-offer {
    font-family: 'Roboto', sans-serif;
    font-weight: 500;
    font-size: 18px;
    color: #000;
}

/*============= End banner_area css =============*/
/*=============Blog Banner css =============*/
.blog_banner {
    min-height: 780px;
    overflow: hidden;
}

.blog_banner .bg-parallax {
    background: url(../image/banner/banner-1.jpg) no-repeat scroll center center;
}

.blog_banner .banner_content {
    margin-bottom: 0px;
    margin-top: 106px;
}

.blog_banner .banner_content h4 {
    font-size: 60px;
    line-height: 66px;
    font-weight: bold;
    color: #fff;
    font-family: "Poppins", sans-serif;
}

.blog_banner .banner_content p {
    font-size: 16px;
    padding: 0px;
    margin-bottom: 35px;
}

.f_48 {
    font-size: 48px;
    line-height: 60px;
    font-weight: 700;
}

.blog_banner_two {
    padding: 187px 0px 104px;
}

.blog_banner_two .bg-parallax {
    background: url(../image/banner/banner-2.jpg) no-repeat scroll center top/cover;
}

/*=============End Blog Banner css =============*/
/*---------------------------------------------------- */
/*----------------------------------------------------*/
.accomodation_item {
    margin-bottom: 30px;
}

.accomodation_item .hotel_img {
    position: relative;
    margin-bottom: 10px;
    overflow: hidden;
    border-radius: 10px;
}

.accomodation_item .hotel_img img {
    -webkit-transition: all 0.4s linear;
    -o-transition: all 0.4s linear;
    transition: all 0.4s linear;
}

.accomodation_item .hotel_img .theme_btn {
    position: absolute;
    bottom: 20px;
    left: 50%;
    -webkit-transform: translate(-50%);
    -ms-transform: translate(-50%);
    transform: translate(-50%);
    padding: 5px 25px;
    max-width: 128px;
}

.accomodation_item .hotel_img:hover img {
    -webkit-transform: scale(1.19);
    -ms-transform: scale(1.19);
    transform: scale(1.19);
}

.accomodation_item h5 {
    font-size: 24px;
    line-height: 28px;
    color: #52c5fd;
    font-weight: 600;
    margin-bottom: 0px;
}

.accomodation_item h5 small {
    font-weight: 300;
    font-size: 14px;
}

.sec_h4 {
    font-size: 18px;
    line-height: 38px;
    font-weight: 600;
    color: #222222;
    margin-bottom: 0px;
}

.accomodation_two {
    margin-bottom: -40px;
}

.accomodation_two .accomodation_item {
    margin-bottom: 45px;
}

/*=========== Start facilities_area css =============*/
.facilities_area {
    position: relative;
    z-index: 1;
    background: #fff;
    overflow: hidden;
}

.facilities_item {
    border-radius: 10px;
    padding: 31px 40px 37px;
    color: #777777;
    margin-bottom: 30px;
    text-align: center;
}



.facilities_image {
    height: 400px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 25px;
}

.ski-pass {
    width: 93px;
    height: 257px;
}

.ski-rent {
    width: 291px;
    height: 55px;
}

.ski-school {
    height: 108px;
    width: 111px;
}

.bus {
    width: 277px;
    height: 177px;
}

.shuttle {
    width: 203px;
    height: 197px;
}

.insurance {
    width: 181px;
    height: 174px;
}

/* .facilities_image img{
      height: auto;
      width: auto;
      max-width: 90%;
      object-fit: contain;
    } */

.facilities_item h4 {
    font-family: 'Roboto', sans-serif;
    font-weight: 500;
    font-size: 16px;
    color: #000;
    margin-bottom: 15px;
    letter-spacing: 0.5px;
}

/* Mobile optimizacija */
@media (max-width: 767px) {
    .facilities_item {
        padding: 25px 20px 30px;
    }

    .facilities_image {
        height: 300px;
        margin-bottom: 20px;
    }


    .ski-pass {
        width: 71px;
        height: 190px;
    }

    .ski-rent {
        width: 218px;
        height: 41px;
    }

    .ski-school {
        height: 83px;
        width: 88px;
    }

    .bus {
        width: 225px;
        height: 141px;
    }

    .shuttle {
        width: 168px;
        height: 161px;
    }

    .insurance {
        width: 146px;
        height: 147px;
    }


    .facilities_item h4 {
        font-size: 16px;
        margin-bottom: 12px;
    }

    .facilities_item p {
        font-size: 13px;
        line-height: 22px;
    }
}

/* Tablet optimizacija */

.facilities_item .sec_h4 {
    padding-bottom: 18px;
    color: #fff;
}

.facilities_item .sec_h4 i {
    color: #f3c300;
    font-size: 24px;
    line-height: 38px;
    display: inline-block;
    vertical-align: bottom;
    padding-right: 20px;
}

.facilities_item p {
    font-family: 'Roboto', sans-serif;
    font-weight: 500;
    font-size: 16px;
    line-height: 24px;
    margin-bottom: 0px;
    color: #000;
}

.facility-icon {
    margin-right: 20px;
    height: 30px;
    width: 30px;
}

.facility-icon-flex {
    display: flex;
    align-items: flex-start;
}

/*=========== End facilities_area css =============*/

/*=========== Live to Ride section css =============*/
.live-to-ride-section {
    background: #fff;
    padding: 60px 0;
}

.live-to-ride-logo {
    text-align: center;
    margin-bottom: 240px;
}

.live-to-ride-logo img {
    max-width: 400px;
    width: 100%;
    height: auto;
}

.live-to-ride-image {
    text-align: center;
    overflow: hidden;
    margin-bottom: 100px;
}

.live-to-ride-image img {
    width: 100%;
    height: auto;
    display: block;
}

/* Mobile optimizacija */
@media (max-width: 767px) {
    .live-to-ride-section {
        padding: 40px 0;
    }

    .live-to-ride-logo {
        margin-bottom: 30px;
    }

    .live-to-ride-logo img {
        max-width: 250px;
    }

}

/* Tablet optimizacija */
@media (min-width: 768px) and (max-width: 991px) {
    .live-to-ride-logo img {
        max-width: 300px;
    }
}

/*=========== End Live to Ride section css =============*/
/*=========== Hotels component css =============*/
.hotel-card {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    gap: 0;
    margin: 30px auto;
    background-color: #fff;
    max-width: 100%;
}

.hotel-image {
    flex: 0 0 50%;
    width: 50%;
    height: 300px;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}

.hotel-image img {
    width: 80%;
    height: 100%;
    display: block;
    object-fit: cover;
}

/* Special case: if it's a logo placeholder */
.hotel-image img.placeholder {
    width: auto;
    height: 100px;
    object-fit: cover;
}

.hotel-content {
    flex: 0 0 40%;
    width: 50%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 0 40px;
}

.hotel-content h1 {
    margin: 0 0 15px;
    font-size: 1.75rem;
    font-weight: 600;
    color: #333;
    line-height: 1.3;
}

.hotel-content p {
    margin: 0 0 25px;
    font-size: 1rem;
    color: #666;
    line-height: 1.6;
}

.hotel-button {
    display: inline-block;
    padding: 12px 30px;
    background-color: transparent;
    color: #333;
    text-decoration: none;
    border: 1px solid #333;
    width: fit-content;
    font-weight: 400;
    transition: all 0.3s ease;
    text-align: center;
}

.hotel-button:hover {
    background-color: #333;
    color: #fff;
    border-color: #333;
}

/*=========== End Hotels component css =============*/
/*=========== Start about_history_area css =============*/
.about_content {
    padding-right: 60px;
}

.about_content p {
    padding: 18px 0px 30px;
}

/*=========== End about_history_area css =============*/
.gallery_item {
    margin-bottom: 30px;
}

.gallery_item img {
    max-width: 100%;
}

.gallery_item .gallery_img {
    position: relative;
}

.gallery_item .gallery_img .hover {
    position: absolute;
    left: 0px;
    top: 0px;
    background: rgba(0, 0, 0, 0.5);
    width: 100%;
    text-align: center;
    font-size: 24px;
    height: 100%;
    color: #fff;
    -webkit-transition: all 300ms ease;
    -o-transition: all 300ms ease;
    transition: all 300ms ease;
    opacity: 0;
}

.gallery_item .gallery_img .hover i {
    position: absolute;
    left: 0px;
    top: 50%;
    width: 100%;
    text-align: center;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    color: #fff;
}

.gallery_item .gallery_img:hover .hover {
    opacity: 1;
}

/*---------------------------------------------------- */
/*----------------------------------------------------*/
/*============ testimonial_area css ============*/
.testimonial_area {
    background: #f9f9ff;
}

.testimonial_slider .testimonial_item {
    border: 1px solid #eeeeee;
    background: #fff;
    padding: 40px;
}

.testimonial_slider .testimonial_item img {
    width: auto;
    margin-right: 30px;
}

.testimonial_slider .testimonial_item p {
    color: #8c8d9e;
    font-size: 14px;
    line-height: 24px;
    margin-bottom: 0px;
    padding-bottom: 15px;
}

.testimonial_slider .testimonial_item .sec_h4 {
    line-height: 30px;
    -webkit-transition: all 0.3s linear;
    -o-transition: all 0.3s linear;
    transition: all 0.3s linear;
}

.testimonial_slider .testimonial_item .sec_h4:hover {
    color: #52c5fd;
}

.testimonial_slider .testimonial_item .star a {
    color: #f3c300;
    font-size: 14px;
}

.testimonial_slider .owl-dots {
    text-align: center;
    margin-top: 80px;
}

.testimonial_slider .owl-dots .owl-dot {
    width: 14px;
    height: 14px;
    background: #eeeeee;
    display: inline-block;
    margin: 0px 5px;
    -webkit-transition: all 0.3s linear;
    -o-transition: all 0.3s linear;
    transition: all 0.3s linear;
}

.testimonial_slider .owl-dots .owl-dot.active {
    background: #f3c300;
}

/*---------------------------------------------------- */
/*----------------------------------------------------*/
/*================= latest_blog_area css =============*/
.single-recent-blog-post {
    margin-bottom: 30px;
}

.single-recent-blog-post .thumb {
    overflow: hidden;
}

.single-recent-blog-post .thumb img {
    -webkit-transition: all 0.7s linear;
    -o-transition: all 0.7s linear;
    transition: all 0.7s linear;
}

.single-recent-blog-post .details {
    padding-top: 30px;
}

.single-recent-blog-post .details .sec_h4 {
    line-height: 24px;
    padding: 10px 0px 13px;
    -webkit-transition: all 0.3s linear;
    -o-transition: all 0.3s linear;
    transition: all 0.3s linear;
}

.single-recent-blog-post .details .sec_h4:hover {
    color: #52c5fd;
}

.single-recent-blog-post .date {
    font-size: 14px;
    line-height: 24px;
    font-weight: 400;
}

.single-recent-blog-post:hover img {
    -webkit-transform: scale(1.23) rotate(10deg);
    -ms-transform: scale(1.23) rotate(10deg);
    transform: scale(1.23) rotate(10deg);
}

.tags .tag_btn {
    font-size: 12px;
    font-weight: 500;
    line-height: 20px;
    border: 1px solid #eeeeee;
    display: inline-block;
    padding: 1px 18px;
    text-align: center;
    color: #222222;
}

.tags .tag_btn:before {
    background: #f3c300;
}

.tags .tag_btn+.tag_btn {
    margin-left: 2px;
}

/*========= blog_categorie_area css ===========*/
.blog_categorie_area {
    background: #f9f9ff;
    padding-top: 80px;
}

.categories_post {
    position: relative;
    text-align: center;
    cursor: pointer;
}

.categories_post img {
    max-width: 100%;
}

.categories_post .categories_details {
    position: absolute;
    top: 20px;
    left: 20px;
    right: 20px;
    bottom: 20px;
    background: rgba(34, 34, 34, 0.8);
    color: #fff;
    -webkit-transition: all 0.3s linear;
    -o-transition: all 0.3s linear;
    transition: all 0.3s linear;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.categories_post .categories_details h5 {
    margin-bottom: 0px;
    font-size: 18px;
    line-height: 26px;
    text-transform: uppercase;
    color: #fff;
}

.categories_post .categories_details p {
    font-weight: 300;
    font-size: 14px;
    line-height: 26px;
    margin-bottom: 0px;
}

.categories_post .categories_details .border_line {
    margin: 10px 0px;
    background: #fff;
}

.categories_post:hover .categories_details {
    background: rgba(248, 182, 0, 0.85);
}

/*============ blog_left_sidebar css ==============*/
.blog_area {
    background: #f9f9ff;
    padding-top: 80px;
}

.blog_item {
    margin-bottom: 40px;
}

.blog_info {
    padding-top: 30px;
}

.blog_info .post_tag {
    padding-bottom: 20px;
}

.blog_info .post_tag a {
    font: 300 14px/21px "Poppins", sans-serif;
    color: #222222;
}

.blog_info .post_tag a:hover {
    color: #52c5fd;
}

.blog_info .blog_meta li a {
    font: 300 14px/20px "Poppins", sans-serif;
    color: #777777;
    vertical-align: middle;
    padding-bottom: 12px;
    display: inline-block;
}

.blog_info .blog_meta li a i {
    color: #222222;
    font-size: 16px;
    font-weight: 600;
    padding-left: 15px;
    line-height: 20px;
    vertical-align: middle;
}

.blog_info .blog_meta li a:hover {
    color: #52c5fd;
}

.blog_post img {
    max-width: 100%;
}

.blog_details {
    padding-top: 20px;
}

.blog_details h2 {
    font-size: 24px;
    line-height: 36px;
    color: #222222;
    font-weight: 600;
    -webkit-transition: all 0.3s linear;
    -o-transition: all 0.3s linear;
    transition: all 0.3s linear;
}

.blog_details h2:hover {
    color: #52c5fd;
}

.blog_details p {
    margin-bottom: 26px;
}

.view_btn {
    font-size: 14px;
    line-height: 36px;
    display: inline-block;
    color: #222222;
    font-weight: 500;
    padding: 0px 30px;
    background: #fff;
}

.blog_right_sidebar {
    border: 1px solid #eeeeee;
    padding: 30px;
}

.blog_right_sidebar .widget_title {
    font-size: 18px;
    line-height: 25px;
    background: #f3c300;
    text-align: center;
    color: #fff;
    padding: 8px 0px;
    margin-bottom: 30px;
}

.blog_right_sidebar .search_widget .input-group .form-control {
    font-size: 14px;
    line-height: 29px;
    border: 0px;
    width: 100%;
    font-weight: 300;
    color: #fff;
    padding-left: 20px;
    border-radius: 45px;
    z-index: 0;
    background: #f3c300;
}

.blog_right_sidebar .search_widget .input-group .form-control.placeholder {
    color: #fff;
}

.blog_right_sidebar .search_widget .input-group .form-control:-moz-placeholder {
    color: #fff;
}

.blog_right_sidebar .search_widget .input-group .form-control::-moz-placeholder {
    color: #fff;
}

.blog_right_sidebar .search_widget .input-group .form-control::-webkit-input-placeholder {
    color: #fff;
}

.blog_right_sidebar .search_widget .input-group .form-control:focus {
    -webkit-box-shadow: none;
    box-shadow: none;
}

.blog_right_sidebar .search_widget .input-group .btn-default {
    position: absolute;
    right: 20px;
    background: transparent;
    border: 0px;
    -webkit-box-shadow: none;
    box-shadow: none;
    font-size: 14px;
    color: #fff;
    padding: 0px;
    top: 50%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    z-index: 1;
}

.blog_right_sidebar .author_widget {
    text-align: center;
}

.blog_right_sidebar .author_widget h4 {
    font-size: 18px;
    line-height: 20px;
    color: #222222;
    margin-bottom: 0px;
}

.blog_right_sidebar .author_widget p {
    margin-bottom: 0px;
}

.blog_right_sidebar .author_widget .social_icon {
    padding: 7px 0px 15px;
}

.blog_right_sidebar .author_widget .social_icon a {
    font-size: 14px;
    color: #222222;
    -webkit-transition: all 0.2s linear;
    -o-transition: all 0.2s linear;
    transition: all 0.2s linear;
}

.blog_right_sidebar .author_widget .social_icon a+a {
    margin-left: 20px;
}

.blog_right_sidebar .author_widget .social_icon a:hover {
    color: #52c5fd;
}

.blog_right_sidebar .popular_post_widget .post_item .media-body {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -ms-flex-item-align: center;
    align-self: center;
    padding-left: 20px;
}

.blog_right_sidebar .popular_post_widget .post_item .media-body h3 {
    font-size: 14px;
    line-height: 20px;
    color: #222222;
    margin-bottom: 4px;
    -webkit-transition: all 0.3s linear;
    -o-transition: all 0.3s linear;
    transition: all 0.3s linear;
}

.blog_right_sidebar .popular_post_widget .post_item .media-body h3:hover {
    color: #52c5fd;
}

.blog_right_sidebar .popular_post_widget .post_item .media-body p {
    font-size: 12px;
    line-height: 21px;
    margin-bottom: 0px;
}

.blog_right_sidebar .popular_post_widget .post_item+.post_item {
    margin-top: 20px;
}

.blog_right_sidebar .post_category_widget .cat-list li {
    border-bottom: 2px dotted #eee;
    -webkit-transition: all 0.3s ease 0s;
    -o-transition: all 0.3s ease 0s;
    transition: all 0.3s ease 0s;
    padding-bottom: 12px;
}

.blog_right_sidebar .post_category_widget .cat-list li a {
    font-size: 14px;
    line-height: 20px;
    color: #777;
}

.blog_right_sidebar .post_category_widget .cat-list li a p {
    margin-bottom: 0px;
}

.blog_right_sidebar .post_category_widget .cat-list li+li {
    padding-top: 15px;
}

.blog_right_sidebar .post_category_widget .cat-list li:hover {
    border-color: #52c5fd;
}

.blog_right_sidebar .post_category_widget .cat-list li:hover a {
    color: #52c5fd;
}

.blog_right_sidebar .newsletter_widget {
    text-align: center;
}

.blog_right_sidebar .newsletter_widget .form-group {
    margin-bottom: 8px;
}

.blog_right_sidebar .newsletter_widget .input-group-prepend {
    margin-right: -1px;
}

.blog_right_sidebar .newsletter_widget .input-group-text {
    background: #fff;
    border-radius: 0px;
    vertical-align: top;
    font-size: 12px;
    line-height: 36px;
    padding: 0px 0px 0px 15px;
    border: 1px solid #eeeeee;
    border-right: 0px;
}

.blog_right_sidebar .newsletter_widget .form-control {
    font-size: 12px;
    line-height: 24px;
    color: #cccccc;
    border: 1px solid #eeeeee;
    border-left: 0px;
}

.blog_right_sidebar .newsletter_widget .form-control.placeholder {
    color: #cccccc;
}

.blog_right_sidebar .newsletter_widget .form-control:-moz-placeholder {
    color: #cccccc;
}

.blog_right_sidebar .newsletter_widget .form-control::-moz-placeholder {
    color: #cccccc;
}

.blog_right_sidebar .newsletter_widget .form-control::-webkit-input-placeholder {
    color: #cccccc;
}

.blog_right_sidebar .newsletter_widget .form-control:focus {
    outline: none;
    -webkit-box-shadow: none;
    box-shadow: none;
}

.blog_right_sidebar .newsletter_widget .bbtns {
    background: #f8b600;
    color: #fff;
    font-size: 12px;
    line-height: 38px;
    display: inline-block;
    font-weight: 500;
    padding: 0px 24px 0px 24px;
    border-radius: 0;
}

.blog_right_sidebar .newsletter_widget .text-bottom {
    font-size: 12px;
}

.blog_right_sidebar .tag_cloud_widget ul li {
    display: inline-block;
}

.blog_right_sidebar .tag_cloud_widget ul li a {
    display: inline-block;
    border: 1px solid #eee;
    background: #fff;
    padding: 0px 13px;
    margin-bottom: 8px;
    -webkit-transition: all 0.3s ease 0s;
    -o-transition: all 0.3s ease 0s;
    transition: all 0.3s ease 0s;
    color: #222222;
    font-size: 12px;
}

.blog_right_sidebar .tag_cloud_widget ul li a:hover {
    background: #f3c300;
    color: #fff;
}

.blog_right_sidebar .br {
    width: 100%;
    height: 1px;
    background: #eeeeee;
    margin: 30px 0px;
}

.blog-pagination {
    padding-top: 25px;
    padding-bottom: 95px;
}

.blog-pagination .page-link {
    border-radius: 0;
}

.blog-pagination .page-item {
    border: none;
}

.page-link {
    background: transparent;
    font-weight: 400;
}

.blog-pagination .page-item.active .page-link {
    background-color: #f3c300;
    border-color: transparent;
    color: #fff;
}

.blog-pagination .page-link {
    position: relative;
    display: block;
    padding: 0.5rem 0.75rem;
    margin-left: -1px;
    line-height: 1.25;
    color: #8a8a8a;
    border: none;
}

.blog-pagination .page-link .lnr {
    font-weight: 600;
}

.blog-pagination .page-item:last-child .page-link,
.blog-pagination .page-item:first-child .page-link {
    border-radius: 0;
}

.blog-pagination .page-link:hover {
    color: #fff;
    text-decoration: none;
    background-color: #f3c300;
    border-color: #eee;
}

/*============ Start Blog Single Styles =============*/
.single-post-area {
    padding-top: 80px;
    padding-bottom: 80px;
}

.single-post-area .social-links {
    padding-top: 10px;
}

.single-post-area .social-links li {
    display: inline-block;
    margin-bottom: 10px;
}

.single-post-area .social-links li a {
    color: #cccccc;
    padding: 7px;
    font-size: 14px;
    -webkit-transition: all 0.2s linear;
    -o-transition: all 0.2s linear;
    transition: all 0.2s linear;
}

.single-post-area .social-links li a:hover {
    color: #222222;
}

.single-post-area .blog_details {
    padding-top: 26px;
}

.single-post-area .blog_details p {
    margin-bottom: 10px;
}

.single-post-area .quotes {
    margin-top: 20px;
    margin-bottom: 30px;
    padding: 24px 35px 24px 30px;
    background-color: white;
    -webkit-box-shadow: -20.84px 21.58px 30px 0px rgba(176, 176, 176, 0.1);
    box-shadow: -20.84px 21.58px 30px 0px rgba(176, 176, 176, 0.1);
    font-size: 14px;
    line-height: 24px;
    color: #777;
    font-style: italic;
}

.single-post-area .arrow {
    position: absolute;
}

.single-post-area .arrow .lnr {
    font-size: 20px;
    font-weight: 600;
}

.single-post-area .thumb .overlay-bg {
    background: rgba(0, 0, 0, 0.8);
}

.single-post-area .navigation-area {
    border-top: 1px solid #eee;
    padding-top: 30px;
    margin-top: 60px;
}

.single-post-area .navigation-area p {
    margin-bottom: 0px;
}

.single-post-area .navigation-area h4 {
    font-size: 18px;
    line-height: 25px;
    color: #222222;
    font-weight: 600;
}

.single-post-area .navigation-area .nav-left {
    text-align: left;
}

.single-post-area .navigation-area .nav-left .thumb {
    margin-right: 20px;
    background: #000;
}

.single-post-area .navigation-area .nav-left .thumb img {
    -webkit-transition: all 300ms linear 0s;
    -o-transition: all 300ms linear 0s;
    transition: all 300ms linear 0s;
}

.single-post-area .navigation-area .nav-left .lnr {
    margin-left: 20px;
    opacity: 0;
    -webkit-transition: all 300ms linear 0s;
    -o-transition: all 300ms linear 0s;
    transition: all 300ms linear 0s;
}

.single-post-area .navigation-area .nav-left:hover .lnr {
    opacity: 1;
}

.single-post-area .navigation-area .nav-left:hover .thumb img {
    opacity: .5;
}

@media (max-width: 767px) {
    .single-post-area .navigation-area .nav-left {
        margin-bottom: 30px;
    }
}

.single-post-area .navigation-area .nav-right {
    text-align: right;
}

.single-post-area .navigation-area .nav-right .thumb {
    margin-left: 20px;
    background: #000;
}

.single-post-area .navigation-area .nav-right .thumb img {
    -webkit-transition: all 300ms linear 0s;
    -o-transition: all 300ms linear 0s;
    transition: all 300ms linear 0s;
}

.single-post-area .navigation-area .nav-right .lnr {
    margin-right: 20px;
    opacity: 0;
    -webkit-transition: all 300ms linear 0s;
    -o-transition: all 300ms linear 0s;
    transition: all 300ms linear 0s;
}

.single-post-area .navigation-area .nav-right:hover .lnr {
    opacity: 1;
}

.single-post-area .navigation-area .nav-right:hover .thumb img {
    opacity: .5;
}

@media (max-width: 991px) {
    .single-post-area .sidebar-widgets {
        padding-bottom: 0px;
    }
}

.comments-area {
    background: #fafaff;
    border: 1px solid #eee;
    padding: 50px 30px;
    margin-top: 50px;
}

@media (max-width: 414px) {
    .comments-area {
        padding: 50px 8px;
    }
}

.comments-area h4 {
    text-align: center;
    margin-bottom: 50px;
    color: #222222;
    font-size: 18px;
}

.comments-area h5 {
    font-size: 16px;
    font-weight: 400;
    margin-bottom: 0px;
}

.comments-area a {
    color: #222222;
}

.comments-area .comment-list {
    padding-bottom: 48px;
}

.comments-area .comment-list:last-child {
    padding-bottom: 0px;
}

.comments-area .comment-list.left-padding {
    padding-left: 25px;
}

@media (max-width: 413px) {
    .comments-area .comment-list .single-comment h5 {
        font-size: 12px;
    }

    .comments-area .comment-list .single-comment .date {
        font-size: 11px;
    }

    .comments-area .comment-list .single-comment .comment {
        font-size: 10px;
    }
}

.comments-area .thumb {
    margin-right: 20px;
}

.comments-area .date {
    font-size: 13px;
    color: #cccccc;
    margin-bottom: 13px;
}

.comments-area .comment {
    color: #777777;
    margin-bottom: 0px;
}

.comments-area .btn-reply {
    background-color: #fff;
    color: #222222;
    border: 1px solid #eee;
    padding: 2px 18px;
    font-size: 12px;
    display: block;
    font-weight: 600;
    -webkit-transition: all 300ms linear 0s;
    -o-transition: all 300ms linear 0s;
    transition: all 300ms linear 0s;
}

.comments-area .btn-reply:hover {
    background-color: #f3c300;
    color: #fff;
}

.comment-form {
    background: #fafaff;
    text-align: center;
    border: 1px solid #eee;
    padding: 47px 30px 43px;
    margin-top: 50px;
    margin-bottom: 40px;
}

.comment-form h4 {
    text-align: center;
    margin-bottom: 50px;
    font-size: 18px;
    line-height: 22px;
    color: #222222;
}

.comment-form .name {
    padding-left: 0px;
}

@media (max-width: 767px) {
    .comment-form .name {
        padding-right: 0px;
        margin-bottom: 1rem;
    }
}

.comment-form .email {
    padding-right: 0px;
}

@media (max-width: 991px) {
    .comment-form .email {
        padding-left: 0px;
    }
}

.comment-form .form-control {
    padding: 8px 20px;
    background: #fff;
    border: none;
    border-radius: 0px;
    width: 100%;
    font-size: 14px;
    color: #777777;
    border: 1px solid transparent;
}

.comment-form .form-control:focus {
    -webkit-box-shadow: none;
    box-shadow: none;
    border: 1px solid #eee;
}

.comment-form textarea.form-control {
    height: 140px;
}

.comment-form ::-webkit-input-placeholder {
    /* Chrome/Opera/Safari */
    font-size: 13px;
    color: #777;
}

.comment-form ::-moz-placeholder {
    /* Firefox 19+ */
    font-size: 13px;
    color: #777;
}

.comment-form :-ms-input-placeholder {
    /* IE 10+ */
    font-size: 13px;
    color: #777;
}

.comment-form :-moz-placeholder {
    /* Firefox 18- */
    font-size: 13px;
    color: #777;
}

.comment-form .primary-btn {
    border-radius: 0px !important;
    border: 1px solid transparent;
    color: #fff;
    text-transform: uppercase;
    font-weight: 600;
    background: #f8b600;
    display: inline-block;
    padding: 7px 44px;
    -webkit-transition: all 0.2s linear;
    -o-transition: all 0.2s linear;
    transition: all 0.2s linear;
}

.comment-form .primary-btn:before {
    background: #f3c300;
}

.comment-form .primary-btn:hover {
    border-color: #f3c300 !important;
    color: #fff !important;
}

/*============ End Blog Single Styles =============*/
/*---------------------------------------------------- */
/*----------------------------------------------------*/
/*============== contact_area css ================*/
.mapBox {
    height: 420px;
    margin-bottom: 80px;
}

.contact_info .info_item {
    position: relative;
    padding-left: 45px;
}

.contact_info .info_item i {
    position: absolute;
    left: 0;
    top: 0;
    font-size: 20px;
    line-height: 24px;
    color: #f3c300;
    font-weight: 600;
}

.contact_info .info_item h6 {
    font-size: 16px;
    line-height: 24px;
    color: #222222;
    font-weight: 300;
    margin-bottom: 0px;
}

.contact_info .info_item h6 a {
    color: #222222;
}

.contact_info .info_item p {
    font-size: 14px;
    line-height: 24px;
    padding: 2px 0px;
}

.contact_form .form-group {
    margin-bottom: 10px;
}

.contact_form .form-group .form-control {
    font-size: 13px;
    line-height: 26px;
    color: #999;
    border: 1px solid #eeeeee;
    font-family: "Poppins", sans-serif;
    border-radius: 0px;
    padding-left: 20px;
}

.contact_form .form-group .form-control:focus {
    -webkit-box-shadow: none;
    box-shadow: none;
    outline: none;
}

.contact_form .form-group .form-control.placeholder {
    color: #999;
}

.contact_form .form-group .form-control:-moz-placeholder {
    color: #999;
}

.contact_form .form-group .form-control::-moz-placeholder {
    color: #999;
}

.contact_form .form-group .form-control::-webkit-input-placeholder {
    color: #999;
}

.contact_form .form-group textarea.form-control {
    height: 140px;
}

.contact_form .theme_btn {
    margin-top: 20px;
    cursor: pointer;
}

/* Contact Success and error Area css
    ============================================================================================ */
.modal-message .modal-dialog {
    position: absolute;
    top: 36%;
    left: 50%;
    -webkit-transform: translateX(-50%) translateY(-50%) !important;
    -ms-transform: translateX(-50%) translateY(-50%) !important;
    transform: translateX(-50%) translateY(-50%) !important;
    margin: 0px;
    max-width: 500px;
    width: 100%;
}

.modal-message .modal-dialog .modal-content .modal-header {
    text-align: center;
    display: block;
    border-bottom: none;
    padding-top: 50px;
    padding-bottom: 50px;
}

.modal-message .modal-dialog .modal-content .modal-header .close {
    position: absolute;
    right: -15px;
    top: -15px;
    padding: 0px;
    color: #fff;
    opacity: 1;
    cursor: pointer;
}

.modal-message .modal-dialog .modal-content .modal-header h2 {
    display: block;
    text-align: center;
    color: #f3c300;
    padding-bottom: 10px;
    font-family: "Poppins", sans-serif;
}

.modal-message .modal-dialog .modal-content .modal-header p {
    display: block;
}

/* End Contact Success and error Area css
    ============================================================================================ */
/*---------------------------------------------------- */
/*----------------------------------------------------*/
/*============== Elements Area css ================*/
.mb-20 {
    margin-bottom: 20px;
}

.mb-30 {
    margin-bottom: 30px;
}

.sample-text-area {
    padding: 100px 0px;
    background: #f9f9ff;
}

.sample-text-area .title_color {
    margin-bottom: 30px;
}

.sample-text-area p {
    line-height: 26px;
}

.sample-text-area p b {
    font-weight: bold;
    color: #f3c300;
}

.sample-text-area p i {
    color: #f3c300;
    font-style: italic;
}

.sample-text-area p sup {
    color: #f3c300;
    font-style: italic;
}

.sample-text-area p sub {
    color: #f3c300;
    font-style: italic;
}

.sample-text-area p del {
    color: #f3c300;
}

.sample-text-area p u {
    color: #f3c300;
}

/*============== End Elements Area css ================*/
/*==============Elements Button Area css ================*/
.elements_button {
    background: #f9f9ff;
}

.elements_button .title_color {
    margin-bottom: 30px;
}

.button-group-area {
    margin-top: 15px;
}

.button-group-area:nth-child(odd) {
    margin-top: 40px;
}

.button-group-area:first-child {
    margin-top: 0px;
}

.button-group-area .theme_btn {
    margin-right: 10px;
}

.button-group-area .white_btn {
    margin-right: 10px;
}

.button-group-area .link {
    text-decoration: underline;
    color: #222222;
    background: transparent;
}

.button-group-area .link:hover {
    color: #fff;
}

.button-group-area .disable {
    background: transparent;
    color: #007bff;
    cursor: not-allowed;
}

.button-group-area .disable:before {
    display: none;
}

.primary {
    background: #52c5fd;
}

.primary:before {
    background: #2faae6;
}

.success {
    background: #4cd3e3;
}

.success:before {
    background: #2ebccd;
}

.info {
    background: #38a4ff;
}

.info:before {
    background: #298cdf;
}

.warning {
    background: #f4e700;
}

.warning:before {
    background: #e1d608;
}

.danger {
    background: #f54940;
}

.danger:before {
    background: #e13b33;
}

.primary-border {
    background: transparent;
    border: 1px solid #52c5fd;
    color: #52c5fd;
}

.primary-border:before {
    background: #52c5fd;
}

.success-border {
    background: transparent;
    border: 1px solid #4cd3e3;
    color: #4cd3e3;
}

.success-border:before {
    background: #4cd3e3;
}

.info-border {
    background: transparent;
    border: 1px solid #38a4ff;
    color: #38a4ff;
}

.info-border:before {
    background: #38a4ff;
}

.warning-border {
    background: #fff;
    border: 1px solid #f4e700;
    color: #f4e700;
}

.warning-border:before {
    background: #f4e700;
}

.danger-border {
    background: transparent;
    border: 1px solid #f54940;
    color: #f54940;
}

.danger-border:before {
    background: #f54940;
}

.link-border {
    background: transparent;
    border: 1px solid #f3c300;
    color: #f3c300;
}

.link-border:before {
    background: #f3c300;
}

.radius {
    border-radius: 3px;
}

.circle {
    border-radius: 20px;
}

.arrow span {
    padding-left: 5px;
}

.e-large {
    line-height: 50px;
    padding-top: 0px;
    padding-bottom: 0px;
}

.large {
    line-height: 45px;
    padding-top: 0px;
    padding-bottom: 0px;
}

.medium {
    line-height: 30px;
    padding-top: 0px;
    padding-bottom: 0px;
}

.small {
    line-height: 25px;
    padding-top: 0px;
    padding-bottom: 0px;
}

.general {
    line-height: 38px;
    padding-top: 0px;
    padding-bottom: 0px;
}

/*==============End Elements Button Area css ================*/
/* =================================== */
/* Elements Page Styles
    /* =================================== */
/*---------- Start Elements Page -------------*/
.whole-wrap {
    background-color: #f9f9ff;
}

.generic-banner {
    margin-top: 60px;
    background-color: #f8b600;
    text-align: center;
}

.generic-banner .height {
    height: 600px;
}

@media (max-width: 767.98px) {
    .generic-banner .height {
        height: 400px;
    }
}

.generic-banner .generic-banner-content h2 {
    line-height: 1.2em;
    margin-bottom: 20px;
}

@media (max-width: 991.98px) {
    .generic-banner .generic-banner-content h2 br {
        display: none;
    }
}

.generic-banner .generic-banner-content p {
    text-align: center;
    font-size: 16px;
}

@media (max-width: 991.98px) {
    .generic-banner .generic-banner-content p br {
        display: none;
    }
}

.generic-content h1 {
    font-weight: 600;
}

.about-generic-area {
    background: #fff;
}

.about-generic-area p {
    margin-bottom: 20px;
}

.white-bg {
    background: #fff;
}

.section-top-border {
    padding: 50px 0;
    border-top: 1px dotted #eee;
}

.switch-wrap {
    margin-bottom: 10px;
}

.switch-wrap p {
    margin: 0;
}

/*---------- End Elements Page -------------*/
.sample-text-area {
    background: #f9f9ff;
    padding: 100px 0 70px 0;
}

.sample-text {
    margin-bottom: 0;
}

.text-heading {
    margin-bottom: 30px;
    font-size: 24px;
}

.typo-list {
    margin-bottom: 10px;
}

@media (max-width: 767px) {
    .typo-sec {
        margin-bottom: 30px;
    }
}

@media (max-width: 767px) {
    .element-wrap {
        margin-top: 30px;
    }
}

b,
sup,
sub,
u,
del {
    color: #f8b600;
}

h1 {
    font-size: 36px;
}

h2 {
    font-size: 30px;
}

h3 {
    font-size: 24px;
}

h4 {
    font-size: 18px;
}

h5 {
    font-size: 16px;
}

h6 {
    font-size: 14px;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    line-height: 1.5em;
}

.typography h1,
.typography h2,
.typography h3,
.typography h4,
.typography h5,
.typography h6 {
    color: #777777;
}

.button-area {
    background: #f9f9ff;
}

.button-area .border-top-generic {
    padding: 70px 15px;
    border-top: 1px dotted #eee;
}

.button-group-area .genric-btn {
    margin-right: 10px;
    margin-top: 10px;
}

.button-group-area .genric-btn:last-child {
    margin-right: 0;
}

.circle {
    border-radius: 20px;
}

.genric-btn {
    display: inline-block;
    outline: none;
    line-height: 40px;
    padding: 0 30px;
    font-size: .8em;
    text-align: center;
    text-decoration: none;
    font-weight: 500;
    cursor: pointer;
    -webkit-transition: all 0.3s ease 0s;
    -moz-transition: all 0.3s ease 0s;
    -o-transition: all 0.3s ease 0s;
    transition: all 0.3s ease 0s;
}

.genric-btn:focus {
    outline: none;
}

.genric-btn.e-large {
    padding: 0 40px;
    line-height: 50px;
}

.genric-btn.large {
    line-height: 45px;
}

.genric-btn.medium {
    line-height: 30px;
}

.genric-btn.small {
    line-height: 25px;
}

.genric-btn.radius {
    border-radius: 3px;
}

.genric-btn.circle {
    border-radius: 20px;
}

.genric-btn.arrow {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.genric-btn.arrow span {
    margin-left: 10px;
}

.genric-btn.default {
    color: #222222;
    background: #f9f9ff;
    border: 1px solid transparent;
}

.genric-btn.default:hover {
    border: 1px solid #f9f9ff;
    background: #fff;
}

.genric-btn.default-border {
    border: 1px solid #f9f9ff;
    background: #fff;
}

.genric-btn.default-border:hover {
    color: #222222;
    background: #f9f9ff;
    border: 1px solid transparent;
}

.genric-btn.primary {
    color: #fff;
    background: #f8b600;
    border: 1px solid transparent;
}

.genric-btn.primary:hover {
    color: #f8b600;
    border: 1px solid #f8b600;
    background: #fff;
}

.genric-btn.primary-border {
    color: #f8b600;
    border: 1px solid #f8b600;
    background: #fff;
}

.genric-btn.primary-border:hover {
    color: #fff;
    background: #f8b600;
    border: 1px solid transparent;
}

.genric-btn.success {
    color: #fff;
    background: #4cd3e3;
    border: 1px solid transparent;
}

.genric-btn.success:hover {
    color: #4cd3e3;
    border: 1px solid #4cd3e3;
    background: #fff;
}

.genric-btn.success-border {
    color: #4cd3e3;
    border: 1px solid #4cd3e3;
    background: #fff;
}

.genric-btn.success-border:hover {
    color: #fff;
    background: #4cd3e3;
    border: 1px solid transparent;
}

.genric-btn.info {
    color: #fff;
    background: #38a4ff;
    border: 1px solid transparent;
}

.genric-btn.info:hover {
    color: #38a4ff;
    border: 1px solid #38a4ff;
    background: #fff;
}

.genric-btn.info-border {
    color: #38a4ff;
    border: 1px solid #38a4ff;
    background: #fff;
}

.genric-btn.info-border:hover {
    color: #fff;
    background: #38a4ff;
    border: 1px solid transparent;
}

.genric-btn.warning {
    color: #fff;
    background: #f4e700;
    border: 1px solid transparent;
}

.genric-btn.warning:hover {
    color: #f4e700;
    border: 1px solid #f4e700;
    background: #fff;
}

.genric-btn.warning-border {
    color: #f4e700;
    border: 1px solid #f4e700;
    background: #fff;
}

.genric-btn.warning-border:hover {
    color: #fff;
    background: #f4e700;
    border: 1px solid transparent;
}

.genric-btn.danger {
    color: #fff;
    background: #f44a40;
    border: 1px solid transparent;
}

.genric-btn.danger:hover {
    color: #f44a40;
    border: 1px solid #f44a40;
    background: #fff;
}

.genric-btn.danger-border {
    color: #f44a40;
    border: 1px solid #f44a40;
    background: #fff;
}

.genric-btn.danger-border:hover {
    color: #fff;
    background: #f44a40;
    border: 1px solid transparent;
}

.genric-btn.link {
    color: #222222;
    background: #f9f9ff;
    text-decoration: underline;
    border: 1px solid transparent;
}

.genric-btn.link:hover {
    color: #222222;
    border: 1px solid #f9f9ff;
    background: #fff;
}

.genric-btn.link-border {
    color: #222222;
    border: 1px solid #f9f9ff;
    background: #fff;
    text-decoration: underline;
}

.genric-btn.link-border:hover {
    color: #222222;
    background: #f9f9ff;
    border: 1px solid transparent;
}

.genric-btn.disable {
    color: #222222, 0.3;
    background: #f9f9ff;
    border: 1px solid transparent;
    cursor: not-allowed;
}

.generic-blockquote {
    padding: 30px 50px 30px 30px;
    background: #fff;
    border-left: 2px solid #f8b600;
}

@media (max-width: 991px) {
    .progress-table-wrap {
        overflow-x: scroll;
    }
}

.progress-table {
    background: #fff;
    padding: 15px 0px 30px 0px;
    min-width: 800px;
}

.progress-table .serial {
    width: 11.83%;
    padding-left: 30px;
}

.progress-table .country {
    width: 28.07%;
}

.progress-table .visit {
    width: 19.74%;
}

.progress-table .percentage {
    width: 40.36%;
    padding-right: 50px;
}

.progress-table .table-head {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}

.progress-table .table-head .serial,
.progress-table .table-head .country,
.progress-table .table-head .visit,
.progress-table .table-head .percentage {
    color: #222222;
    line-height: 40px;
    text-transform: uppercase;
    font-weight: 500;
}

.progress-table .table-row {
    padding: 15px 0;
    border-top: 1px solid #edf3fd;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}

.progress-table .table-row .serial,
.progress-table .table-row .country,
.progress-table .table-row .visit,
.progress-table .table-row .percentage {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.progress-table .table-row .country img {
    margin-right: 15px;
}

.progress-table .table-row .percentage .progress {
    width: 80%;
    border-radius: 0px;
    background: transparent;
}

.progress-table .table-row .percentage .progress .progress-bar {
    height: 5px;
    line-height: 5px;
}

.progress-table .table-row .percentage .progress .progress-bar.color-1 {
    background-color: #6382e6;
}

.progress-table .table-row .percentage .progress .progress-bar.color-2 {
    background-color: #e66686;
}

.progress-table .table-row .percentage .progress .progress-bar.color-3 {
    background-color: #f09359;
}

.progress-table .table-row .percentage .progress .progress-bar.color-4 {
    background-color: #73fbaf;
}

.progress-table .table-row .percentage .progress .progress-bar.color-5 {
    background-color: #73fbaf;
}

.progress-table .table-row .percentage .progress .progress-bar.color-6 {
    background-color: #6382e6;
}

.progress-table .table-row .percentage .progress .progress-bar.color-7 {
    background-color: #a367e7;
}

.progress-table .table-row .percentage .progress .progress-bar.color-8 {
    background-color: #e66686;
}

.single-gallery-image {
    margin-top: 30px;
    background-repeat: no-repeat !important;
    background-position: center center !important;
    background-size: cover !important;
    height: 200px;
    -webkit-transition: all 0.3s ease 0s;
    -moz-transition: all 0.3s ease 0s;
    -o-transition: all 0.3s ease 0s;
    transition: all 0.3s ease 0s;
}

.single-gallery-image:hover {
    opacity: .8;
}

.list-style {
    width: 14px;
    height: 14px;
}

.unordered-list li {
    position: relative;
    padding-left: 30px;
    line-height: 1.82em !important;
}

.unordered-list li:before {
    content: "";
    position: absolute;
    width: 14px;
    height: 14px;
    border: 3px solid #f8b600;
    background: #fff;
    top: 4px;
    left: 0;
    border-radius: 50%;
}

.ordered-list {
    margin-left: 30px;
}

.ordered-list li {
    list-style-type: decimal-leading-zero;
    color: #f8b600;
    font-weight: 500;
    line-height: 1.82em !important;
}

.ordered-list li span {
    font-weight: 300;
    color: #777777;
}

.ordered-list-alpha li {
    margin-left: 30px;
    list-style-type: lower-alpha;
    color: #f8b600;
    font-weight: 500;
    line-height: 1.82em !important;
}

.ordered-list-alpha li span {
    font-weight: 300;
    color: #777777;
}

.ordered-list-roman li {
    margin-left: 30px;
    list-style-type: lower-roman;
    color: #f8b600;
    font-weight: 500;
    line-height: 1.82em !important;
}

.ordered-list-roman li span {
    font-weight: 300;
    color: #777777;
}

.single-input {
    display: block;
    line-height: 40px;
    border: none;
    width: 100%;
    box-sizing: border-box;
    outline: none;
    background: #fff;
    padding: 0 20px;
}

.single-input:focus {
    outline: none;
}

.input-group-icon {
    position: relative;
}

.input-group-icon .icon {
    position: absolute;
    left: 20px;
    top: 0;
    line-height: 40px;
    z-index: 3;
}

.input-group-icon .icon i {
    color: #797979;
}

.input-group-icon .single-input {
    padding-left: 45px;
}

.single-textarea {
    display: block;
    width: 100%;
    line-height: 40px;
    border: none;
    outline: none;
    background: #fff;
    padding: 0 20px;
    height: 100px;
    resize: none;
}

.single-textarea:focus {
    outline: none;
}

.single-input-primary {
    display: block;
    width: 100%;
    line-height: 40px;
    border: 1px solid transparent;
    outline: none;
    background: #fff;
    padding: 0 20px;
}

.single-input-primary:focus {
    outline: none;
    border: 1px solid #f8b600;
}

.single-input-accent {
    display: block;
    width: 100%;
    line-height: 40px;
    border: 1px solid transparent;
    outline: none;
    background: #fff;
    padding: 0 20px;
}

.single-input-accent:focus {
    outline: none;
    border: 1px solid #eb6b55;
}

.single-input-secondary {
    display: block;
    width: 100%;
    line-height: 40px;
    border: 1px solid transparent;
    outline: none;
    background: #fff;
    padding: 0 20px;
}

.single-input-secondary:focus {
    outline: none;
    border: 1px solid #f09359;
}

.default-switch {
    width: 35px;
    height: 17px;
    border-radius: 8.5px;
    background: #fff;
    position: relative;
    cursor: pointer;
}

.default-switch input {
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    cursor: pointer;
}

.default-switch input+label {
    position: absolute;
    top: 1px;
    left: 1px;
    width: 15px;
    height: 15px;
    border-radius: 50%;
    background: #f8b600;
    -webkit-transition: all 0.2s;
    -moz-transition: all 0.2s;
    -o-transition: all 0.2s;
    transition: all 0.2s;
    -webkit-box-shadow: 0px 4px 5px 0px rgba(0, 0, 0, 0.2);
    box-shadow: 0px 4px 5px 0px rgba(0, 0, 0, 0.2);
    cursor: pointer;
}

.default-switch input:checked+label {
    left: 19px;
}

.single-element-widget {
    margin-bottom: 30px;
}

.primary-switch {
    width: 35px;
    height: 17px;
    border-radius: 8.5px;
    background: #fff;
    position: relative;
    cursor: pointer;
}

.primary-switch input {
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
}

.primary-switch input+label {
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
}

.primary-switch input+label:before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    background: transparent;
    border-radius: 8.5px;
    cursor: pointer;
    -webkit-transition: all 0.2s;
    -moz-transition: all 0.2s;
    -o-transition: all 0.2s;
    transition: all 0.2s;
}

.primary-switch input+label:after {
    content: "";
    position: absolute;
    top: 1px;
    left: 1px;
    width: 15px;
    height: 15px;
    border-radius: 50%;
    background: #fff;
    -webkit-transition: all 0.2s;
    -moz-transition: all 0.2s;
    -o-transition: all 0.2s;
    transition: all 0.2s;
    -webkit-box-shadow: 0px 4px 5px 0px rgba(0, 0, 0, 0.2);
    box-shadow: 0px 4px 5px 0px rgba(0, 0, 0, 0.2);
    cursor: pointer;
}

.primary-switch input:checked+label:after {
    left: 19px;
}

.primary-switch input:checked+label:before {
    background: #f8b600;
}

.confirm-switch {
    width: 35px;
    height: 17px;
    border-radius: 8.5px;
    background: #fff;
    position: relative;
    cursor: pointer;
}

.confirm-switch input {
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
}

.confirm-switch input+label {
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
}

.confirm-switch input+label:before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    background: transparent;
    border-radius: 8.5px;
    -webkit-transition: all 0.2s;
    -moz-transition: all 0.2s;
    -o-transition: all 0.2s;
    transition: all 0.2s;
    cursor: pointer;
}

.confirm-switch input+label:after {
    content: "";
    position: absolute;
    top: 1px;
    left: 1px;
    width: 15px;
    height: 15px;
    border-radius: 50%;
    background: #fff;
    -webkit-transition: all 0.2s;
    -moz-transition: all 0.2s;
    -o-transition: all 0.2s;
    transition: all 0.2s;
    -webkit-box-shadow: 0px 4px 5px 0px rgba(0, 0, 0, 0.2);
    box-shadow: 0px 4px 5px 0px rgba(0, 0, 0, 0.2);
    cursor: pointer;
}

.confirm-switch input:checked+label:after {
    left: 19px;
}

.confirm-switch input:checked+label:before {
    background: #4cd3e3;
}

.primary-checkbox {
    width: 16px;
    height: 16px;
    border-radius: 3px;
    background: #fff;
    position: relative;
    cursor: pointer;
}

.primary-checkbox input {
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
}

.primary-checkbox input+label {
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    border-radius: 3px;
    cursor: pointer;
    border: 1px solid #f1f1f1;
}

.primary-checkbox input:checked+label {
    background: url(../image/elements/primary-check.png) no-repeat center center/cover;
    border: none;
}

.confirm-checkbox {
    width: 16px;
    height: 16px;
    border-radius: 3px;
    background: #fff;
    position: relative;
    cursor: pointer;
}

.confirm-checkbox input {
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
}

.confirm-checkbox input+label {
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    border-radius: 3px;
    cursor: pointer;
    border: 1px solid #f1f1f1;
}

.confirm-checkbox input:checked+label {
    background: url(../image/elements/success-check.png) no-repeat center center/cover;
    border: none;
}

.disabled-checkbox {
    width: 16px;
    height: 16px;
    border-radius: 3px;
    background: #fff;
    position: relative;
    cursor: pointer;
}

.disabled-checkbox input {
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
}

.disabled-checkbox input+label {
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    border-radius: 3px;
    cursor: pointer;
    border: 1px solid #f1f1f1;
}

.disabled-checkbox input:disabled {
    cursor: not-allowed;
    z-index: 3;
}

.disabled-checkbox input:checked+label {
    background: url(../image/elements/disabled-check.png) no-repeat center center/cover;
    border: none;
}

.primary-radio {
    width: 16px;
    height: 16px;
    border-radius: 8px;
    background: #fff;
    position: relative;
    cursor: pointer;
}

.primary-radio input {
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
}

.primary-radio input+label {
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    border-radius: 8px;
    cursor: pointer;
    border: 1px solid #f1f1f1;
}

.primary-radio input:checked+label {
    background: url(../image/elements/primary-radio.png) no-repeat center center/cover;
    border: none;
}

.confirm-radio {
    width: 16px;
    height: 16px;
    border-radius: 8px;
    background: #fff;
    position: relative;
    cursor: pointer;
}

.confirm-radio input {
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
}

.confirm-radio input+label {
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    border-radius: 8px;
    cursor: pointer;
    border: 1px solid #f1f1f1;
}

.confirm-radio input:checked+label {
    background: url(../image/elements/success-radio.png) no-repeat center center/cover;
    border: none;
}

.disabled-radio {
    width: 16px;
    height: 16px;
    border-radius: 8px;
    background: #fff;
    position: relative;
    cursor: pointer;
}

.disabled-radio input {
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
}

.disabled-radio input+label {
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    border-radius: 8px;
    cursor: pointer;
    border: 1px solid #f1f1f1;
}

.disabled-radio input:disabled {
    cursor: not-allowed;
    z-index: 3;
}

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

.ordered-list {
    list-style: none;
    padding: 0px;
}

.disabled-radio input:checked+label {
    background: url(../image/elements/disabled-radio.png) no-repeat center center/cover;
    border: none;
}

.default-select {
    height: 40px;
}

.default-select .nice-select {
    border: none;
    border-radius: 0px;
    height: 40px;
    background: #fff;
    padding-left: 20px;
    padding-right: 40px;
}

.default-select .nice-select .list {
    margin-top: 0;
    border: none;
    border-radius: 0px;
    -webkit-box-shadow: none;
    box-shadow: none;
    width: 100%;
    padding: 10px 0 10px 0px;
}

.default-select .nice-select .list .option {
    font-weight: 300;
    -webkit-transition: all 0.3s ease 0s;
    -moz-transition: all 0.3s ease 0s;
    -o-transition: all 0.3s ease 0s;
    transition: all 0.3s ease 0s;
    line-height: 28px;
    min-height: 28px;
    font-size: 12px;
    padding-left: 20px;
}

.default-select .nice-select .list .option.selected {
    color: #f8b600;
    background: transparent;
}

.default-select .nice-select .list .option:hover {
    color: #f8b600;
    background: transparent;
}

.default-select .current {
    margin-right: 50px;
    font-weight: 300;
}

.default-select .nice-select::after {
    right: 20px;
}

@media (max-width: 991px) {
    .left-align-p p {
        margin-top: 20px;
    }
}

.form-select {
    height: 40px;
    width: 100%;
}

.form-select .nice-select {
    border: none;
    border-radius: 0px;
    height: 40px;
    background: #fff !important;
    padding-left: 45px;
    padding-right: 40px;
    width: 100%;
}

.form-select .nice-select .list {
    margin-top: 0;
    border: none;
    border-radius: 0px;
    -webkit-box-shadow: none;
    box-shadow: none;
    width: 100%;
    padding: 10px 0 10px 0px;
}

.mt-10 {
    margin-top: 10px;
}

.form-select .nice-select .list .option {
    font-weight: 300;
    -webkit-transition: all 0.3s ease 0s;
    -moz-transition: all 0.3s ease 0s;
    -o-transition: all 0.3s ease 0s;
    transition: all 0.3s ease 0s;
    line-height: 28px;
    min-height: 28px;
    font-size: 12px;
    padding-left: 45px;
}

.form-select .nice-select .list .option.selected {
    color: #f8b600;
    background: transparent;
}

.form-select .nice-select .list .option:hover {
    color: #f8b600;
    background: transparent;
}

.form-select .current {
    margin-right: 50px;
    font-weight: 300;
}

.form-select .nice-select::after {
    right: 20px;
}

/*---------------------------------------------------- */
/*----------------------------------------------------*/
/*============== footer-area css ===============*/
.footer-area {
    padding: 142px 0px;
}

.single-footer-widget ul li a {
    line-height: 25px;
    display: inline-block;
    color: #777;
    -webkit-transition: all 0.3s linear;
    -o-transition: all 0.3s linear;
    transition: all 0.3s linear;
    margin-bottom: 13px;
}

.single-footer-widget ul li a:hover {
    color: #f3c300;
}

.single-footer-widget .instafeed {
    margin-left: -5px;
    margin-right: -5px;
}

.single-footer-widget .instafeed li {
    margin: 5px;
}

.single-footer-widget .subscribe_form {
    padding-top: 13px;
}

.single-footer-widget .input-group {
    display: block !important;
}

.single-footer-widget input {
    width: 100%;
    border: 1px solid #333333;
    font-size: 13px;
    line-height: 30px;
    padding-right: 40px;
    height: 40px;
    color: #999999;
    background: transparent;
    padding-left: 20px;
}

.single-footer-widget input.placeholder {
    color: #999999;
}

.single-footer-widget input:-moz-placeholder {
    color: #999999;
}

.single-footer-widget input::-moz-placeholder {
    color: #999999;
}

.single-footer-widget input::-webkit-input-placeholder {
    color: #999999;
}

.single-footer-widget input:focus {
    outline: none;
}

.single-footer-widget .sub-btn {
    background: #f3c300;
    color: #fff;
    font-weight: 300;
    border-radius: 0;
    line-height: 34px;
    padding: 4px 11px 0px;
    cursor: pointer;
    position: absolute;
    right: 0px;
    top: 0px;
}

.footer_title {
    font-size: 16px;
    line-height: 24px;
    font-weight: 600;
    text-transform: uppercase;
    margin-bottom: 28px;
}

.border_line {
    width: 100%;
    height: 1px;
    background: #333333;
    margin-top: 30px;
}

.footer-bottom {
    padding-top: 46px;
}

.footer-bottom .footer-text a {
    color: #f3c300;
}

.footer-bottom .footer-social {
    text-align: right;
}

.footer-bottom .footer-social a {
    font-size: 18px;
    line-height: 30px;
    color: #82848f;
    margin-left: 25px;
    -webkit-transition: all 0.3s linear;
    -o-transition: all 0.3s linear;
    transition: all 0.3s linear;
}

.footer-bottom .footer-social a:hover {
    color: #f3c300;
}

/*---------------------------------------------------- */

/*# sourceMappingURL=style.css.map */




/*============== Universal cards ===============*/

/* ================================================
    UNIVERSAL GRID - Responsive rooms/cards grid
    ================================================ */

.search-page-container {
    display: grid;
    grid-template-columns: 220px 1fr;
    gap: 30px;
    margin: 40px auto;
    max-width: 1300px;
    padding: 0 15px;
}

.universal-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 24px;
    padding: 0 20px;
    max-width: 1200px;
    margin: 0 auto 100px auto;

}

.universal-card {
    background: #fff;
    display: flex;
    flex-direction: column;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    height: 100%;
    position: relative;
}

/* Card Image Container */
.card-image {
    width: 100%;
    height: 220px;
    overflow: hidden;
    position: relative;
}

.card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.3s ease;
}

/* ✅ Unificiran padding i kompaktan sadržaj */
.card-content {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.room-name {
    font-family: 'Roboto', sans-serif;
    font-weight: 600;
    font-size: 20px;
    color: #222;
    margin: 29px 0 7px 0;
}

.hotel-name {
    font-family: 'Roboto', sans-serif;
    font-weight: 400;
    font-size: 15px;
    color: #000;
    margin-bottom: 7px;
}

.deposit {
    font-family: 'Roboto', sans-serif;
    font-weight: 400;
    font-size: 15px;
    margin: 0;
}

.price-tag {
    font-family: 'Roboto', sans-serif;
    font-weight: 600;
    font-size: 15px;
    margin-bottom: 8px;
}

.discount-price {
    font-family: 'Roboto', sans-serif;
    font-weight: 600;
    color: #d32f2f;
}

.pricing-note {
    font-family: 'Roboto', sans-serif;
    font-weight: 400;
    font-size: 15px;
    color: #666;
    line-height: 1.3;
}

.pricing-note p {
    margin-bottom: 5px;
}

.pricing-note p:first-child {
    font-weight: 500;
    color: #333;
    margin-bottom: 5px;
}

.old-price {
    text-decoration: line-through;
    color: #aaa;
    margin-left: 6px;
    font-size: 13px;
}

.room-dates {
    font-size: 13px;
    color: #666;
    margin-bottom: 8px;
}



.white-button {
    width: 100%;
    font-family: 'Roboto', sans-serif;
    font-weight: 400;
    font-size: 20px;
    background-color: #fff;
    color: #000;
    padding: 15px;
    border-bottom: 1px solid #000;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.white-button:hover {
    background-color: #000;
    color: #fff;
}

.card-description {
    font-size: 13px;
    color: #444;
    line-height: 1.4;
    margin-bottom: 8px;
}

.card-availability {
    background-color: #e8f5e9;
    color: #2e7d32;
    font-size: 11px;
    width: 70px;
    height: 70px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    position: absolute;
    top: -10px;
    right: -10px;
    text-align: center;
    line-height: 1.2;
    padding: 8px;
}

.card-availability.availability-warning {
    background-color: #fff3cd;
    color: #856404;
}

.card-availability.availability-critical {
    background-color: #f8d7da;
    color: #721c24;
}

.card-actions-row {
    margin-top: auto;
    display: flex;
    justify-content: flex-start;
    padding-top: 10px;
}

.card-btn-yellow {
    background-color: #ffca28;
    color: #000;
    padding: 10px 18px;
    border: none;
    border-radius: 6px;
    cursor: pointer;
    font-weight: 600;
    text-align: center;
    transition: background-color 0.3s ease;
    width: 100%;
}

.card-btn-yellow:hover {
    background-color: #ffc107;
}

/* ================================================
    RESPONSIVE BREAKPOINTS
    ================================================ */

/* Large Desktop - 3 kolone */
@media (min-width: 1200px) {
    .universal-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* Tablet/Medium - 2 kolone */
@media (min-width: 768px) and (max-width: 1199px) {
    .universal-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 20px;
        padding: 15px;
    }

    .card-image {
        height: 200px;
    }
}

/* Mobile - 1 kolona */
@media (max-width: 767px) {
    .universal-grid {
        grid-template-columns: 1fr;
        gap: 16px;
        padding: 10px;
    }

    .card-image {
        height: 180px;
    }

    .room-name {
        font-size: 16px;
    }

    .card-btn-yellow {
        padding: 8px 16px;
        font-size: 14px;
    }
}



/*============== Images modal css ===============*/


.image-modal {
    display: none;
    position: fixed;
    z-index: 9999;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    overflow: auto;
    background-color: rgba(0, 0, 0, 0.85);
    justify-content: center;
    align-items: center;
}

.image-modal__content {
    max-width: 90%;
    max-height: 90%;
    margin: auto;
    display: block;
    border-radius: 6px;
    box-shadow: 0 0 20px rgba(0, 0, 0, 0.5);
}

.image-modal__close {
    position: absolute;
    top: 20px;
    right: 30px;
    color: white;
    font-size: 40px;
    font-weight: bold;
    cursor: pointer;
    transition: 0.3s;
}

.image-modal__close:hover {
    color: #ccc;
}

.placeholder-wrapper {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;

}

.placeholder-wrapper h1 {
    color: #000;
    font-family: "Maname", sans-serif;
    font-size: 36px;
}



/*============== Card specs css ===============*/
.card-specs {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    gap: 6px;
    margin: 10px 0;
    font-size: 12px;
    color: #444;
    overflow-x: auto;
}

.spec-item {
    display: flex;
    align-items: center;
    gap: 4px;
    color: #333;
    background: #f9f9f9;
    padding: 4px 6px;
    /* manji padding */
    border-radius: 5px;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
    white-space: nowrap;
    /* sprečava prelom teksta */
}

.spec-item>img {
    height: 20px;
    width: 20px;
    color: #f3c300;
}

.spec-item:hover {
    background: #fff5cc;
    transform: translateY(-1px);
}

/*============== Destination component css ===============*/

.entry-image {
    margin: 180px auto 100px auto;
    width: 100px;
    /* height: 200px;         */
}

.entry-image img {
    width: 100%;
    height: auto;
    object-fit: cover;
}


/*============== Room show modal css ===============*/

.modal-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.75);
    z-index: 9999;
    justify-content: center;
    align-items: center;
    overflow-y: auto;
    padding: 40px 20px;
}

.modal-container {
    background: #fff;
    max-width: 1200px;
    width: 100%;
    padding: 0;
    position: relative;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    box-shadow: 0 10px 50px rgba(0, 0, 0, 0.3);
}

.modal-close {
    position: absolute;
    top: 10px;
    right: 10px;
    font-size: 32px;
    border: none;
    background: rgba(255, 255, 255, 0.9);
    cursor: pointer;
    color: #000;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10;
    transition: background 0.3s ease;
}

.modal-close:hover {
    background: #fff;
}

.modal-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
    min-height: 600px;
}

.modal-left {
    padding: 20px 20px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.modal-right {
    display: flex;
    flex-direction: column;
    padding: 20px 20px 40px 20px;
    background: #fff;
    overflow-y: auto;
    max-height: 80vh;
}

.modal-top {
    flex: 1;
}

.modal-image-wrapper {
    position: relative;
    width: 100%;
    margin-bottom: 20px;
}

.modal-image-wrapper img {
    width: 100%;
    height: 400px;
    object-fit: cover;
}

.nav-btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    font-size: 24px;
    color: #fff;
    background: rgba(0, 0, 0, 0.5);
    border: none;
    cursor: pointer;
    padding: 12px 16px;
    z-index: 1;
    transition: background 0.3s ease;
}

.nav-btn:hover {
    background: rgba(0, 0, 0, 0.7);
}

.nav-btn.prev {
    left: 10px;
}

.nav-btn.next {
    right: 10px;
}

.dates {
    color: #000;
    font-family: "Roboto", sans-serif;
    font-weight: 500;
    font-size: 20px;
    border-bottom: 1px solid black;
}

.thumbnail-wrapper {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    justify-content: flex-start;
}

.thumbnail-wrapper img {
    width: 80px;
    height: 60px;
    object-fit: cover;
    cursor: pointer;
    border: 2px solid transparent;
    transition: border-color 0.3s ease;
}

.thumbnail-wrapper img:hover {
    border-color: #ccc;
}

.thumbnail-wrapper img.active {
    border-color: #000;
}

.modal-right h2 {
    font-size: 20px;
    font-weight: bold;
    margin: 0 0 10px 0;
    color: #000;
    text-transform: uppercase;
    line-height: 1.3;
}

.subtitle {
    color: #666;
    font-size: 13px;
    margin-bottom: 20px;
    display: block;
}

.modal-dates-display {
    font-size: 14px;
    color: #000;
    margin-bottom: 25px;
    font-weight: 500;
}

#modalDescription {
    font-size: 15px;
    line-height: 1.7;
    color: #333;
    margin-bottom: 25px;
}

#modalDetails {
    margin-bottom: 20px;
}

#modalDetails p {
    font-size: 15px;
    color: #333;
    margin: 8px 0;
}

#modalDetails strong {
    font-weight: 600;
    color: #000;
}

.amenities {
    display: flex;
    flex-wrap: wrap;
    gap: 15px;
    margin: 20px 0;
}

.amenities i {
    font-size: 20px;
    color: #555;
}

.action-buttons {
    display: flex;
    align-items: center;
    flex-direction: row;
    gap: 30px;
}

.modal-dates {
    margin: 25px 0;
}

.modal-dates label {
    display: block;
    font-size: 14px;
    font-weight: 600;
    margin-bottom: 8px;
    color: #000;
}

.modal-dates select {

    width: 100%;
    padding: 12px 15px;
    font-size: 15px;
    border: none;
    border-bottom: 1px solid #000;
    background-color: #fff;
    cursor: pointer;
}

.modal-dates select:hover {
    border-color: #999;
}

.modal-dates select:focus {
    outline: none;
    border-color: #000;
}

.book-now {
    width: 100%;
    color: #fff;
}

.book-now>a {
    background-color: #000;
    color: #fff;
    font-weight: 600;
    text-align: center;
    padding: 16px 20px;
    border: none;
    text-decoration: none;
    font-size: 16px;
    text-transform: uppercase;
    transition: background 0.3s ease;
    cursor: pointer;
    display: block;
    width: 100%;
    letter-spacing: 0.5px;

}

.modal-button {
    width: 50%;
    border-radius: 0px;

}

.book-now>a:hover {
    background-color: #333;
}


/* Mobile */
@media (max-width: 968px) {
    .modal-grid {
        grid-template-columns: 1fr;
    }

    .modal-left {
        padding: 30px;
    }

    .modal-right {
        padding: 30px;
        max-height: none;
    }

    .modal-image-wrapper img {
        height: 300px;
    }

    .thumbnail-wrapper img {
        width: 70px;
        height: 50px;
    }
}

@media (max-width: 480px) {
    .modal-container {
        margin: 20px;
    }

    .modal-left,
    .modal-right {
        padding: 20px;
    }

    .modal-close {
        top: 10px;
        right: 10px;
        width: 35px;
        height: 35px;
        font-size: 28px;
    }

    .modal-right h2 {
        font-size: 20px;
    }

    .modal-image-wrapper img {
        height: 250px;
    }

    .thumbnail-wrapper img {
        width: 60px;
        height: 45px;
    }
}





/*============== Booking form css ===============*/

.booking-form {
    margin: 30px auto;
    max-width: 1250px;
    padding: 30px 15px;
}

.passenger {

    width: 100%;
    display: grid;
    gap: 10px;
    margin-bottom: 30px;
    align-items: center;
}

.passenger h4 {
    grid-column: 1 / -1;
    /* title spans full width */
    margin-bottom: 5px;
}

/* First passenger = 5 equal columns */
.passenger.first-passenger {
    grid-template-columns: repeat(5, 1fr);
}

/* Other passengers = 3 equal columns */
.passenger.other-passenger {
    grid-template-columns: repeat(3, 1fr);
}


/* Two columns on tablets */
@media (min-width: 600px) {
    .passenger {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* Three columns on desktops */
@media (min-width: 992px) {
    .passenger {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* Banner */
.hotel__banner {
    width: 80%;
    max-height: 500px;
    margin: auto;
    overflow: hidden;
    background-color: #f9f9f9;
    display: flex;
    align-items: center;
    justify-content: center;
}

.hotel__banner-image {
    width: 100%;
    height: auto;
    object-fit: contain;
    /* Prikazuje celu sliku bez zoom-a */
    object-position: center;
    max-height: 500px;
}

/* Description */
.hotel__description {
    max-width: 50%;
    margin: 100px auto 150px auto;
    padding: 0 20px;
    font-size: 18px;
    line-height: 1.2;
}

.hotel__name {
    font-size: 32px;
    font-weight: bold;
    margin-bottom: 16px;
}

.hotel__text {
    font-size: 28px;
    line-height: 1.6;
    color: #444;
}

/* Gallery */
.hotel__gallery {
    max-width: 1000px;
    margin: 60px auto;
    padding: 0 20px;
}

.hotel__gallery-title {
    font-family: 'Maname', sans-serif;
    font-weight: 400;
    font-size: 44px;
    font-weight: 600;
    margin-bottom: 160px;
    text-align: center;
}

.hotel__gallery-slider {
    display: flex;
    gap: 20px;
}

.hotel__gallery-slide {
    padding: 5px;
}

.hotel__gallery-image {
    width: 100%;
    /* Increased height to prevent blur and better show the room */
    height: 500px;
    object-fit: cover;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
}

/* ✅ Responsivnost */

/* Tablet */
@media (max-width: 992px) {
    .gallery-top {
        height: 360px;
    }

    .gallery-thumbs {
        height: 100px;
    }

    .hotel__gallery-title {
        font-size: 32px;
    }
}

/* Telefon */
@media (max-width: 600px) {
    .hotel__gallery {
        padding: 0 10px;
        margin: 40px auto;
    }

    .gallery-top {
        height: 260px !important;
    }

    .gallery-thumbs {
        height: 80px;
    }

    .gallery-thumbs .swiper-slide {
        width: 33.33%;
    }

    .hotel__gallery-title {
        font-size: 32px;
    }

    .hotel__banner {
        width: 100%;
        height: 250px;
        padding-bottom: 30px;
    }

    .description-container {
        width: 100%;
        font-size: 12px !important;
    }

    .single-column-description {
        font-size: 14px !important;

    }

    .half-div {
        width: 100% !important;
    }
}



/* =========== Grid for rooms and hotesl ==============

    .universal-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 24px;
    padding: 20px;
    }

    .universal-card {
    display: flex;
    flex-direction: column;
    background-color: #fff;
    border: 1px solid #ddd;
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
    transition: transform 0.2s ease;
    }

    .universal-card:hover {
    transform: scale(1.02);
    }

    .card-image img,
    .card-image {
    width: 100%;
    height: 200px;
    object-fit: cover;
    }

    .card-content {
    padding: 16px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    flex-grow: 1;
    }

    .card-title-row {
    margin-bottom: 12px;
    }

    .card-title {
    font-size: 18px;
    font-weight: bold;
    margin: 0;
    }

    .price-tag {
    margin-top: 6px;
    }

    .discount-price {
    color: #e53935;
    font-weight: bold;
    }

    .old-price {
    text-decoration: line-through;
    color: #999;
    font-size: 14px;
    margin-left: 8px;
    }

    .card-description {
    font-size: 14px;
    color: #444;
    margin: 12px 0;
    }

    .card-availability {
    font-size: 14px;
    font-weight: 500;
    margin-bottom: 10px;
    color: #2e7d32;
    }

    .availability-alert {
    color: #e53935;
    }

    .card-actions-row {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-top: auto;
    }

    .card-btn-yellow {
    background-color: #ffca28;
    color: #000;
    padding: 10px 16px;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    font-weight: 600;
    text-align: center;
    transition: background-color 0.3s ease;
    }

    .card-btn-yellow:hover {
    background-color: #ffc107;
    }


    .amenity-icon {
    width: 20px;
    height: 20px;
    object-fit: cover;
    } */


/*========= Search page css ==========*/

/* Animacija Fade In */
/* @keyframes fadeInUp {
    0% {
    opacity: 0;
    transform: translateY(20px);
    }

    100% {
    opacity: 1;
    transform: translateY(0);
    }
    } */

/* Generalne stilizacije */
.content-container {
    max-width: 1200px;
    margin: 40px auto;
    padding: 0 20px;
    font-family: 'Segoe UI', sans-serif;
    color: #333;
}

/* Banner */
.hotel__banner img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 12px;
    animation: fadeInUp 1s ease-in-out;
}

/* Naslovi sekcija */
.description-wrapper>h2 {
    font-size: 18px;
    font-weight: 600;
    margin-bottom: 0;
    text-align: left;
    color: #333;
    position: relative;
    padding: 15px 20px;
    background: #fff;
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
    transition: all 0.3s ease;
}

.description-wrapper>h2:hover {
    background: #f9f9f9;
}

.description-wrapper>h2::after {
    display: none;
}

.description-wrapper>h2 .toggle-icon {
    font-size: 18px;
    color: #666;
    transition: transform 0.3s ease;
    font-weight: 400;
}

.description-wrapper>h2 .toggle-icon.active {
    transform: rotate(45deg);
}

.description-wrapper {
    margin: 20px 0px;
}

/* Ski info 2-column layout */
.ski-info-container {
    display: flex;
    gap: 40px;
    margin: 200px 0;
}

.ski-info-column {
    flex: 1;
    min-width: 0;
}

.hotel-title {
    font-family: 'Maname', sans-serif;
    font-weight: 400;
    font-size: 36px;
    text-align: center;
    margin-top: 150px;
    margin-bottom: 100px;
}

.ski-column-title {
    font-size: 20px;
    font-weight: 600;
    margin: 0 0 20px 0;
    color: #333;
    border: none;
    background: none;
    text-align: center;
}

.ski-info-section {
    margin-bottom: 12px;
}

.ski-section-title {
    font-family: 'Roboto', sans-serif;
    font-size: 20;
    font-weight: 600;
    width: 100%;
    font-size: 15px;
    font-weight: 500;
    margin: 0;
    padding: 14px 0;
    border: none;
    border-bottom: 1px solid #000;
    background: #fff;
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
    transition: all 0.3s ease;
    text-align: left;
    color: #333;
    text-transform: uppercase;
}

.ski-section-title:hover {
    background: #f9f9f9;
    border-color: #ccc;
}

.toggle-icon-inline {
    font-size: 14px;
    color: #666;
    transition: transform 0.3s ease;
    display: inline-block;
}

.toggle-icon-inline.active {
    transform: rotate(180deg);
}

.ski-section-content {
    font-family: 'Roboto', sans-serif;
    font-weight: 400;
    font-size: 20px;
    padding: 20px;
    border-bottom: 1px solid #000;
    font-size: 14px;
    line-height: 1.6;
    color: #333;
}

.ski-section-content.none {
    display: none;
}

/* Description main with show more functionality */
.description-main {
    margin: 40px 0;
}

.description-preview {
    font-family: 'Maname', sans-serif;
    font-weight: 400;
    font-size: 44px;
    line-height: 1.2;
    color: #333;
    margin-bottom: 40px;
}

.description-full {
    font-family: 'Roboto', sans-serif;
    font-weight: 400;
    font-size: 20px;
    width: 50%;
    font-size: 18px;
    line-height: 1.8;
    color: #333;
    margin-top: 20px;
    animation: fadeInUp 0.5s ease-in-out;
}

.show-more-btn {
    font-family: "Roboto", sans-serif;
    font-weight: 400;

    display: inline-block;
    background: #fff;
    border: none;
    color: #333;
    padding: 12px 30px;
    font-size: 20px;
    font-weight: 500;
    cursor: pointer;
    border-radius: 4px;
    transition: all 0.3s ease;
    margin-top: 15px;
    margin-bottom: 100px;
}

.show-more-btn:hover {
    background: #f8f8f8;
    border-color: #ccc;
}

/* Tekstualni sadržaj */
.description-container {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 30px;
    animation: fadeInUp 0.4s ease-in-out;
    padding: 20px;
    border: 1px solid #ddd;
    border-top: none;
    background: #fff;
}

.description-container .description-left,
.description-container .description-right {
    width: 48%;
    line-height: 1.7;
    font-size: 15px;
    text-align: left;
    color: #555;
}

@media (max-width: 768px) {
    .ski-info-container {
        margin: 160px 0;
    }

    .description-container .description-left,
    .description-container .description-right {
        width: 100%;
    }

    .description-preview {
        font-size: 24px;
    }

    .description-full {
        width: 100%;
    }
}

.half-div {
    font-family: 'Maname', sans-serif;
    width: 50%;
    margin: 0 auto;
    line-height: 1.7;
    font-size: 15px;
    text-align: left;
    color: #000;
}

.half-div>h1 {
    text-align: center;
    font-family: 'Maname', sans-serif;
    font-size: 44px;
    margin-bottom: 113px;
}


/* Single column descriptions */
.single-column-description {
    font-family: 'Roboto', sans-serif;
    font-size: 20px;
    font-weight: 500;
    width: 100%;
    margin: 0 auto;
    font-size: 15px;
    line-height: 1.8;
    padding: 20px;
    border-top: none;
    background: #fff;
    color: #000;
    text-align: justify;
    margin-bottom: 160px;
}


.payment_cancelation_policy {
    width: 100%;
    margin: 150px 0;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
}

.payment-policy-content {

    width: 50%;
    margin: 0 auto;
    text-align: center;
    background-color: #1a1a1a;
    color: #fff;
    width: 780px;
    height: 700px;
    padding: 40px;
}

.payment-policy-content h2 {
    font-family: 'Maname', sans-serif;
    font-weight: 400;
    font-size: 44px;
    margin: 0 0 50px 0;
    line-height: 1.4;
    color: #fff;
}

.arrow-down {
    margin: 40px 0;
    font-size: 32px;
    color: #fff;
}


.payment-policy-btn {
    font-family: 'Roboto', sans-serif;
    font-size: 20px;
    font-weight: 500;
    display: inline-block;
    padding: 14px 35px;
    background-color: transparent;
    color: #fff;
    text-decoration: none;
    letter-spacing: 1.5px;
    transition: all 0.3s ease;
}


/* Galerija */
/* .hotel__gallery-title {
    text-align: center;
    font-size: 28px;
    margin-bottom: 20px;
    color: #1e1e1e;
    }

    .hotel__gallery-slider {
    display: flex;
    flex-wrap: wrap;
    gap: 15px;
    justify-content: center;
    animation: fadeInUp 0.8s ease-in-out;
    }

    .hotel__gallery-slide {
    width: 250px;
    height: 180px;
    overflow: hidden;
    border-radius: 10px;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    }

    .hotel__gallery-slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.3s ease;
    }

    .hotel__gallery-slide:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 20px rgba(0,0,0,0.15);
    } */

.hotel__gallery-slide:hover img {
    transform: scale(1.05);
}

.fade-in-up {
    opacity: 0;
    transform: translateY(20px);
    transition: all 0.8s ease-out;
}

.fade-in-up.visible {
    opacity: 1;
    transform: translateY(0);
}

.ski-resort-images {
    display: flex;
    flex-wrap: wrap;
    gap: 15px;
    justify-content: center;
    margin-top: 20px;
}

/* Optimizacija ski mapa - dinamičko širenje prema broju slika */
.ski-resort-images .hotel__gallery-slide {
    flex: 0 0 auto;
}

/* 1 slika - zauzima 50% */
.ski-resort-images .hotel__gallery-slide:first-child:last-child {
    width: 50%;
}

/* 2 slike - zajedno 70% (svaka po 35%) */
.ski-resort-images .hotel__gallery-slide:first-child:nth-last-child(2),
.ski-resort-images .hotel__gallery-slide:nth-child(2):last-child {
    width: calc(35% - 7.5px);
}

/* 3+ slike - zauzimaju 100% (svaka oko 33%) */
.ski-resort-images .hotel__gallery-slide:first-child:nth-last-child(n+3),
.ski-resort-images .hotel__gallery-slide:first-child:nth-last-child(n+3)~.hotel__gallery-slide {
    width: calc(33.333% - 10px);
}

.ski-resort-images .hotel__gallery-image {
    width: 100%;
    height: auto;
    min-height: 250px;
    object-fit: contain;
    /* Prikazuje celu sliku bez crop-a/zoom-a */
    background-color: #f9f9f9;
    border-radius: 8px;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
    cursor: pointer;
    transition: transform 0.2s ease;
}

.ski-resort-images .hotel__gallery-image:hover {
    transform: scale(1.02);
}

/* Mobilni prikaz - jedna ispod druge */
@media (max-width: 768px) {

    .ski-resort-images .hotel__gallery-slide,
    .ski-resort-images .hotel__gallery-slide:first-child:last-child,
    .ski-resort-images .hotel__gallery-slide:first-child:nth-last-child(2),
    .ski-resort-images .hotel__gallery-slide:nth-child(2):last-child,
    .ski-resort-images .hotel__gallery-slide:first-child:nth-last-child(n+3),
    .ski-resort-images .hotel__gallery-slide:first-child:nth-last-child(n+3)~.hotel__gallery-slide {
        width: 100% !important;
    }
}

/** Review **/

.review_area {
    background-color: #f9fafc;
    padding: 80px 0;
}

.review-form {
    background: white;
    padding: 30px 40px;
    border-radius: 10px;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.08);
}

.review-form label {
    font-weight: 600;
    color: #333;
}

.review-form .form-control {
    width: 100%;
    padding: 10px 14px;
    border: 1px solid #ddd;
    border-radius: 6px;
    margin-bottom: 15px;
    font-size: 1rem;
    transition: border-color 0.2s ease;
}

.review-form .form-control:focus {
    border-color: #0073e6;
    outline: none;
}

.star-rating {
    display: inline-flex;
    flex-direction: row-reverse;
    /* ključna promena! */
    gap: 6px;
    font-size: 32px;
    cursor: pointer;
    user-select: none;
}

.star {
    color: #ccc;
    transition: color 0.25s ease, transform 0.2s ease;
}

.star:hover {
    transform: scale(1.2);
}

/* Kada pređeš mišem, popunjava sve LEVO od zvezdice */
.star:hover,
.star:hover~.star {
    color: #ffc107;
}

/* Aktivne zvezdice nakon klika */
.star.active {
    color: #ffc107;
}


.btn-primary {
    background-color: #0073e6;
    color: white;
    border: none;
    padding: 10px 25px;
    border-radius: 6px;
    cursor: pointer;
    transition: background-color 0.25s ease;
}

.btn-primary:hover {
    background-color: #005bb5;
}

/* Responsivnost */
@media (max-width: 768px) {
    .review-form {
        padding: 20px;
    }

    .star-rating {
        font-size: 28px;
    }

    #childrenAgeInput {
        bottom: calc(100% + 5px);
        top: auto
    }
}

/* Responsive layout */
@media (max-width: 768px) {
    .description-container {
        flex-direction: column;
    }

    .description-container>div {
        width: 100%;
    }

    .hotel__gallery-slide {
        width: 100%;
        height: auto;
    }
}


.alert-banner {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 9999;
    padding: 15px;
    text-align: center;
    font-weight: 500;
    color: white;
    animation: showAndHide 6s ease forwards;
    /* 👈 6 sekundi ukupno */
}

/* zelena = success */
.alert-success {
    background-color: #4CAF50;
}

/* crvena = error */
.alert-error {
    background-color: #f44336;
}

/* Animacija: pojavi se → stoji → nestane */
@keyframes showAndHide {
    0% {
        transform: translateY(-100%);
        opacity: 0;
    }

    10% {
        transform: translateY(0);
        opacity: 1;
    }

    80% {
        transform: translateY(0);
        opacity: 1;
    }

    100% {
        transform: translateY(-100%);
        opacity: 0;
    }
}



.socials {
    display: flex;
    justify-content: center;
    align-items: center;


    border: 1px solid black;
}

.social-icons {
    display: flex;
    gap: 10px;
}

.social-icons a {
    background: transparent;
    color: #fff;
    /* ikone bele */
    font-size: 22px;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
    cursor: pointer;
}

/* .social-icons a:hover {
    background: #f3c300; 
    color: #000; 
    transform: scale(1.1);
    } */
/* Base Swiper layout */
.swiper-container {
    width: 100%;
    margin: 0 auto;
}

/* Main gallery */
.gallery-top {
    width: 100%;
    height: 500px;
    overflow: hidden;
    position: relative;
}

.gallery-top img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Thumbnails */
.gallery-thumbs {
    overflow: hidden;
    height: 120px;
    box-sizing: border-box;
    padding: 10px 0;
}

.gallery-thumbs img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 6px;
    border: 2px solid transparent;
    transition: border 0.3s ease;
}

.gallery-thumbs .swiper-slide-thumb-active img {
    border: 2px solid #c8a15a;
    /* gold accent */
}

.swiper-button-next,
.swiper-button-prev {
    color: #fff;
    width: 32px;
    height: 32px;
    background-color: rgba(0, 0, 0, 0.35);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    transition: all 0.25s ease;
    cursor: pointer;
}

/* Hover efekat */
.swiper-button-next:hover,
.swiper-button-prev:hover {
    background-color: rgba(0, 0, 0, 0.55);
    transform: translateY(-50%) scale(1.08);
}

/* Disabled state */
.swiper-button-disabled {
    opacity: 0.3;
    cursor: not-allowed;
    pointer-events: none;
}

/* Levo i desno pozicioniranje */
.swiper-button-prev {
    left: 10px;
}

.swiper-button-next {
    right: 10px;
}

/* Veličina ikonica */
.swiper-button-next::after,
.swiper-button-prev::after {
    font-size: 14px;
    font-weight: 700;
}

.container {
    max-width: 1200px;
    margin: 0 auto;
}

.page-container {
    display: grid;
    grid-template-columns: 220px 1fr;
    gap: 30px;
    margin: 40px auto;
    max-width: 1200px;
    padding: 0 15px;
}

/* Sidebar stil */
.filter-sidebar {
    background: #fff;
    border-radius: 8px;
    padding: 0 20px;
    height: fit-content;
    position: relative;
}

/* Close button - sakri na desktopu */
.filter-close-btn {
    display: none;
}

.filter-title {
    font-family: 'Roboto', sans-serif;
    font-size: 32px;
    font-weight: 500;
    margin-bottom: 20px;
    padding-bottom: 15px;
    border-bottom: 2px solid #000;
    color: #000;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.filter-group {
    margin-bottom: 20px;
}

.filter-group label {
    display: block;
    font-weight: 600;
    margin-bottom: 8px;
    color: #333;
}

.filter-group input {
    width: 90%;
    border: 1px solid #ddd;
    border-radius: 6px;
    padding: 6px 10px;
    font-size: 14px;
    outline: none;
}

.filter-group select,
.filter-group input[type="range"] {
    width: 100%;
    border: 1px solid #ddd;
    border-radius: 6px;
    padding: 6px 10px;
    font-size: 14px;
    outline: none;
}


.filter-options label {
    display: block;
    font-size: 14px;
    margin-bottom: 5px;
}

.filter-apply-btn {
    width: 100%;
    background: #000000;
    color: #fff;
    border: none;
    padding: 12px 0;
    font-weight: 700;
    border-radius: 4px;
    cursor: pointer;
    transition: background 0.3s ease, transform 0.2s ease;
    margin-top: 20px;
    text-transform: uppercase;
    font-size: 14px;
    letter-spacing: 0.5px;
}

.filter-apply-btn:hover {
    background: #333333;
    transform: scale(1.02);
}

/* ===== Accordion Filter Styles ===== */
.filter-accordion-item {
    border-bottom: 1px solid #e0e0e0;
}

.filter-accordion-toggle {
    width: 100%;
    background: transparent;
    border: none;
    padding: 15px 0;
    text-align: left;
    font-size: 14px;
    font-weight: 500;
    color: #333;
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
    transition: color 0.3s ease;
}

.filter-accordion-toggle:hover {
    color: #000;
}

.filter-accordion-toggle i {
    font-size: 12px;
    transition: transform 0.3s ease;
    color: #666;
}

.filter-accordion-content {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease, padding 0.3s ease;
    padding: 0;
}

.filter-accordion-item.active .filter-accordion-content {
    max-height: 200px;
    padding: 0 0 15px 0;
    overflow-y: auto;
}

.filter-accordion-content select {
    width: 100%;
    border: 1px solid #ddd;
    border-radius: 4px;
    padding: 8px 12px;
    font-size: 14px;
    color: #333;
    background: #fff;
    cursor: pointer;
}

.filter-accordion-content select:focus {
    outline: none;
    border-color: #000;
}

/* ✅ Responsive optimizacija */

/* Filter toggle wrapper - sakrij na desktopu */
.filter-toggle-wrapper {
    display: none;
    padding: 12px 24px;
}

/* Filter toggle button - prikaži samo ispod 1000px */
.filter-toggle-btn {
    background: #000;
    color: #fff;
    border: none;
    padding: 10px 20px;
    border-radius: 6px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
    white-space: nowrap;
    width: auto;
    max-width: 200px;
}

.filter-toggle-btn:hover {
    background: #333;
    transform: scale(1.02);
}

.filter-toggle-btn i {
    margin-right: 8px;
    font-size: 13px;
}

/* Tableti i telefoni */
@media (max-width: 1000px) {

    /* Prikaži filter dugme */
    .filter-toggle-btn {
        display: block;
    }

    .page-container {
        display: flex;
        flex-direction: column;
        gap: 25px;
    }

    .search-page-container {
        display: flex;
        flex-direction: column;
        gap: 25px;
    }

    /* Filtrir bar full width */
    .page-container>*:first-child {
        order: 1 !important;
        width: 100%;
    }

    /* Rooms lista ispod filtera */
    .page-container>*:last-child {
        order: 2 !important;
        width: 100%;
    }

    /* Ako hoćeš malo spacinga unutra */
    .page-container>* {
        margin: 0 auto;
    }

    /* Filter sidebar - sakri po defaultu */
    .filter-sidebar {
        position: fixed;
        top: 0;
        left: -100%;
        height: 100vh;
        width: 320px;
        max-width: 85%;
        background: #fff;
        z-index: 1001;
        overflow-y: auto;
        transition: left 0.3s ease;
        box-shadow: 2px 0 15px rgba(0, 0, 0, 0.2);
    }

    /* Kada je filter aktivan */
    .filter-sidebar.active {
        left: 0;
    }

    /* Overlay pozadina */
    .filter-overlay {
        display: none;
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background: rgba(0, 0, 0, 0.5);
        z-index: 1000;
    }

    .filter-overlay.active {
        display: block;
    }

    /* Close button unutar filtera */
    .filter-close-btn {
        display: block;
        position: absolute;
        top: 15px;
        right: 15px;
        background: transparent;
        border: none;
        font-size: 28px;
        cursor: pointer;
        color: #333;
        padding: 5px 10px;
    }

    .rooms-list {
        order: 2;
    }
}

/* Telefoni manji od 600px */
@media (max-width: 600px) {
    .filter-sidebar {
        padding: 15px;
        box-shadow: none;
        border: 1px solid #ddd;
    }

    .filter-title {
        font-size: 16px;
        margin-bottom: 10px;
    }

    .filter-group {
        margin-bottom: 15px;
    }

    .filter-group select,
    .filter-group input[type="range"] {
        font-size: 13px;
        padding: 5px 8px;
    }

    .filter-apply-btn {
        padding: 8px 0;
        font-size: 14px;
    }

    .price-values {
        font-size: 12px;
    }
}

@media (max-width: 576px) {
    .page-container {
        gap: 15px;
        padding: 0 10px;
    }

    .filter-sidebar {
        padding: 10px;
        width: 100%;
    }
}


.room-presentation-card .styled {
    display: flex;
    gap: 3rem;
    background: #fff;
    padding: 2rem;
    flex-wrap: wrap;
    font-family: 'Segoe UI', sans-serif;
}

.room-left {
    flex: 1 1 65%;
}

.room-right {
    flex: 1 1 30%;
    border-radius: 10px;
    padding: 2rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
}

.price-title {
    font-family: 'Roboto', sans-serif;
    font-weight: 400;
    font-size: 20px;
}

.room-title {
    font-size: 28px;
    font-weight: 700;
    color: #1a1a1a;
}

.room-description {
    font-size: 15px;
    color: #444;
    line-height: 1.6;
    margin-bottom: 1.5rem;
    white-space: pre-wrap;
}

.room-details-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px 20px;
    font-size: 14px;
    margin-bottom: 1.5rem;
}

.room-details-grid i.icon {
    color: #555;
    margin-right: 8px;
}

.room-amenities h4 {
    font-size: 16px;
    margin-bottom: 10px;
    color: #111;
}

.amenities-list {
    display: flex;
    flex-wrap: wrap;
    gap: 10px 15px;
}

.card-specs {
    margin-top: 25px;
}

.card-specs h4 {
    font-size: 18px;
    margin-bottom: 12px;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 8px;
    color: #222;
}

.card-specs h4 .icon {
    color: #f7c948;
}

.amenities-list {
    display: flex;
    flex-wrap: wrap;
    gap: 10px 15px;
}

.amenity-item {
    background: #f7f9fa;
    padding: 8px 14px;
    border-radius: 10px;
    font-size: 14px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: #333;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
    transition: 0.2s ease;
    border: 1px solid #e8ecef;
}

.amenity-item:hover {
    background: #eef2f3;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.12);
}

.amenity-icon {
    width: 18px;
    height: 18px;
    object-fit: contain;
    display: block;
}

.price-table {
    max-width: 1200px;
    text-align: center;

}

.price-table>h2 {
    margin-bottom: 80px;
}


.price-table table tr {
    text-align: center;
}

.price-table table tr:first-child {
    background-color: #000;
    color: #fff;
    text-align: center;
}

.price-section {
    margin-bottom: 1.5rem;
    width: 100%;
}

.price-discounted {
    display: flex;
    flex-direction: column;
    margin-bottom: 50px;
}

.new-price {
    font-family: 'Roboto', sans-serif;
    font-weight: 500;
    font-size: 32px;
    font-weight: 700;
    color: #000;
}

.old-price {
    font-family: 'Roboto', sans-serif;
    font-weight: 400;
    font-size: 20px;
    text-decoration: line-through;
    color: #aaa;
    font-size: 16px;
    margin-left: 10px;
}

.discount-badge {
    margin-top: 8px;
    display: inline-block;
    background-color: #ffca28;
    color: #000;
    font-size: 13px;
    padding: 4px 10px;
    border-radius: 8px;
    font-weight: 600;
}

.btn-primary {
    background: #ffca28;
    color: #000;
    padding: 12px 24px;
    border-radius: 8px;
    font-weight: 600;
    text-decoration: none;
    transition: 0.3s;
    text-align: center;
}

.btn-primary:hover {
    background: #ffc107;
    transform: scale(1.05);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

/* ✅ Mobilna verzija */
@media (max-width: 768px) {
    .room-presentation-card.styled {
        flex-direction: column;
        padding: 1rem;
    }

    .room-right {
        width: 100%;
        padding: 0px !important;
    }
}

/* ================================================
    PAGE WRAPPER - Univerzalni wrapper za staticke stranice
    ================================================ */

.page-wrapper {
    background-color: #fff;
    padding: 60px 0;
}

.page-intro h2 {
    font-family: 'Maname', sans-serif;
    font-size: 36px;
    font-weight: 400;
    margin-bottom: 200px;
    text-align: center;

}

.section-title {
    font-size: 2rem;
    font-weight: 600;
    color: #222;
    margin-bottom: 1rem;
}

.section-subtitle {
    font-size: 1.1rem;
    color: #666;
    max-width: 700px;
    margin: 0 auto;
}

/* ================================================
    FAQ STRANICA STILOVI
    ================================================ */

.faq-container {
    max-width: 600px;
    margin: 50px auto 300px auto;
}

.faq-item {
    background: #fff;
    border-bottom: 1px solid #000;
    margin-bottom: 15px;
    overflow: hidden;
    transition: all 0.3s ease;
}


.faq-question {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px 0px;
    cursor: pointer;
    background: #fff;
    text-transform: uppercase;
}

.faq-question:hover {
    background: #fff;

}

.faq-item.active .faq-question {
    background: #000;
}

.faq-question h3 {
    color: #000;
    font-family: 'Roboto', sans-serif;
    font-weight: 600;
    font-size: 20px;
    margin: 0;
    padding-right: 20px;
    flex: 1;
    transition: color 0.3s ease;
}

.faq-item.active .faq-question h3 {
    color: #fff;

}

.faq-toggle {
    font-size: 1.5rem;
    font-weight: 200;
    min-width: 30px;
    text-align: center;
    transition: transform 0.3s ease;
    color: #000;
}

.faq-item.active .faq-toggle {
    transform: rotate(180deg);
    color: #fff;
}

.faq-answer {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.4s ease;
}

.faq-answer p {
    padding: 20px 25px;
    margin: 0;
    color: #555;
    line-height: 1.6;
    background: #fff;
}

/* FAQ CTA sekcija */
.faq-cta {
    background: #f8f9fa;
    padding: 40px 30px;
    border-radius: 8px;
    margin-top: 50px;
}

.faq-cta h3 {
    font-size: 1.5rem;
    font-weight: 600;
    margin-bottom: 10px;
    color: #222;
}

.faq-cta p {
    color: #666;
    margin-bottom: 20px;
}

.faq-cta .btn {
    padding: 12px 30px;
    font-size: 1rem;
    border-radius: 5px;
    text-decoration: none;
    display: inline-block;
}

.faq-cta .btn-primary {
    background-color: #007bff;
    color: #fff;
    border: none;
    transition: background-color 0.3s ease;
}

/* 
    .faq-cta .btn-primary:hover {
    background-color: #0056b3;
    } */

/* Responsive FAQ */
@media (max-width: 768px) {
    .page-wrapper {
        padding: 40px 0;
    }

    .section-title {
        font-size: 1.5rem;
    }

    .section-subtitle {
        font-size: 1rem;
    }

    .faq-question {
        padding: 15px 20px;
    }

    .faq-question h3 {
        font-size: 1rem;
    }

    .faq-answer p {
        padding: 15px 20px;
        font-size: 0.95rem;
    }

    .faq-cta {
        padding: 30px 20px;
    }

    .faq-cta h3 {
        font-size: 1.3rem;
    }
}

/* ================================================
    O NAMA & KONTAKT STRANICE
    ================================================ */

.about-content {
    text-align: center;
    width: 50%;
    margin: 0 auto;
    color: #000;
    font-size: 20px;
}

/* .about-content .lead {
    font-size: 1.2rem;
    font-weight: 400;
    color: #333;
    } */

.snow-fest-section {
    text-align: center;
    width: 50%;
    margin: 0 auto;
    color: #000;
    font-size: 20px;
}


.stat-box {
    transition: all 0.3s ease;
}

.stat-box:hover {
    transform: translateY(-10px);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
}

.stat-box h2 {
    color: #222;
    font-weight: 700;
}

.cta-section {
    text-align: center;
    width: 50%;
    margin: 180px auto;
    color: #000;
    font-size: 20px;
}

.cta-section h1 {
    font-family: 'Maname', sans-serif;
    font-weight: 400;
    font-size: 36px;
    margin-bottom: 70px !important;
}

.cta-section p {
    margin-bottom: 80px;
}

.cta-section a {
    background-color: #000;
    color: #fff;
    padding: 15px 20px;
}

.contact-card {
    transition: all 0.3s ease;
}

.contact-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
}

.contact-card a {
    transition: color 0.3s ease;
}

.contact-card a:hover {
    color: #007bff !important;
}

.contact-cta {
    box-shadow: 0 10px 30px rgba(102, 126, 234, 0.3);
}

.social-links a {
    transition: all 0.3s ease;
}

.social-links a:hover {
    transform: scale(1.1);
}

.contact-wrapper {
    width: 50%;
    margin: 0 auto;
    text-align: center;
    margin-bottom: 190px;
}

.contact-wrapper h1 {
    font-family: 'Maname', sans-serif;
    font-weight: 400;
    font-size: 36px;
    margin-bottom: 70px !important;
    color: #000;
}

.contact-wrapper p {
    font-family: 'Roboto', sans-serif;
    font-weight: 500;
    font-size: 20px;
    color: #000;
}

/* Responsive */
@media (max-width: 768px) {
    .about-content .lead {
        font-size: 1.1rem;
    }

    .stat-box h2 {
        font-size: 1.8rem;
    }

    .contact-cta .btn {
        width: 100%;
        margin-bottom: 10px;
    }
}



/* WhatsApp Floating Button */
.whatsapp-float {
    position: fixed;
    bottom: 30px;
    right: 30px;
    width: 60px;
    height: 60px;
    background-color: #25D366;
    color: white;
    border-radius: 50%;
    text-align: center;
    font-size: 35px;
    box-shadow: 2px 2px 10px rgba(0, 0, 0, 0.3);
    z-index: 1000;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
}

.whatsapp-float:hover {
    background-color: #128C7E;
    transform: scale(1.1);
    color: white;
    text-decoration: none;
}

.whatsapp-float i {
    line-height: 60px;
}

/* Responsive adjustments */
@media (max-width: 768px) {
    .whatsapp-float {
        width: 50px;
        height: 50px;
        font-size: 28px;
        bottom: 20px;
        right: 20px;
    }

    .whatsapp-float i {
        line-height: 50px;
    }
}

.none {
    display: none;
}

/* ================================================
    ROOMS LIST HEADER - Sorting kontrole
    ================================================ */

.rooms-list-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 24px;
    padding: 16px 20px;
    background: #fff;
    border-radius: 8px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}

.rooms-count {
    margin: 0;
    font-size: 18px;
    font-weight: 600;
    color: #333;
    font-family: 'Roboto', sans-serif;
    text-align: center;
    width: 100%;
}

.sorting-controls {
    display: flex;
    gap: 16px;
    align-items: center;
}

.sort-group {
    display: flex;
    align-items: center;
    gap: 8px;
}

.sort-group label {
    font-size: 14px;
    font-weight: 500;
    color: #555;
    white-space: nowrap;
}

.sort-group select {
    padding: 8px 12px;
    border: 1px solid #ddd;
    border-radius: 6px;
    font-size: 14px;
    background: #fff;
    cursor: pointer;
    transition: all 0.2s ease;
    min-width: 140px;
}

.sort-group select:hover {
    border-color: #2196F3;
}

.sort-group select:focus {
    outline: none;
    border-color: #2196F3;
    box-shadow: 0 0 0 3px rgba(33, 150, 243, 0.1);
}

/* Responsive */
@media (max-width: 768px) {
    .rooms-list-header {
        flex-direction: column;
        gap: 16px;
        align-items: flex-start;
    }

    .sorting-controls {
        flex-direction: column;
        width: 100%;
        gap: 12px;
    }

    .sort-group {
        width: 100%;
        justify-content: space-between;
    }

    .sort-group select {
        flex: 1;
    }
}

/* ================================================
    SORTING HEADER - Iznad page-container
    ================================================ */

.sorting-header-wrapper {
    max-width: 1400px;
    margin: 0 auto 20px auto;
    padding: 0 20px;
}

.sorting-header-content {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    gap: 12px;
    padding: 16px 24px;
    background: transparent;
    position: relative;
}

.sorting-controls-top {
    position: absolute;
    right: 24px;
    top: 50%;
    transform: translateY(-50%);
    display: flex;
    gap: 16px;
    align-items: center;
}

/* Sort Accordion - Similar to filters */
.sort-accordion-item {
    background: #fff;
    border-radius: 4px;
    border-bottom: 1px solid #e0e0e0;
    min-width: 180px;
}

.sort-accordion-toggle {
    width: 100%;
    background: transparent;
    border: none;
    padding: 12px 16px;
    text-align: left;
    font-size: 14px;
    font-weight: 500;
    color: #333;
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
    transition: color 0.3s ease;
}

.sort-accordion-toggle:hover {
    color: #000;
    background: #f8f8f8;
}

.sort-accordion-toggle i {
    font-size: 12px;
    transition: transform 0.3s ease;
    color: #666;
}

.sort-accordion-content {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease, padding 0.3s ease;
    padding: 0 16px;
}

.sort-accordion-item.active .sort-accordion-content {
    max-height: 200px;
    padding: 0 16px 12px 16px;
}

.sort-accordion-item.active .sort-accordion-toggle i {
    transform: rotate(180deg);
}

.sort-accordion-content select {
    width: 100%;
    border: 1px solid #ddd;
    border-radius: 4px;
    padding: 8px 12px;
    font-size: 14px;
    color: #333;
    background: #fff;
    cursor: pointer;
}

.sort-accordion-content select:focus {
    outline: none;
    border-color: #000;
}

/* Responsive za sorting header */
@media (max-width: 1000px) {
    .filter-toggle-wrapper {
        display: block;
    }
}

@media (max-width: 768px) {
    .sorting-header-content {
        flex-direction: column;
        gap: 16px;
        align-items: center;
        justify-content: center;
    }

    .rooms-count {
        text-align: center;
        width: 100%;
    }

    .sorting-controls-top {
        position: static;
        transform: none;
        width: 100%;
        justify-content: center;
        gap: 12px;
    }

    .filter-toggle-btn {
        width: 100%;
    }

    .sort-accordion-item {
        width: 100%;
    }
}


/*============== Custom Footer Styles ===============*/
.footer-area {
    padding: 80px 0 40px;
}

.footer-logo img {
    width: 550px;
    height: 386px;
    height: auto;
    filter: brightness(1.1);
}

.footer_title {
    font-size: 14px;
    font-weight: 700;
    color: #fff;
    text-transform: uppercase;
    margin-bottom: 25px;
    letter-spacing: 1px;
}

.single-footer-widget ul.list_style {
    list-style: none;
    padding: 0;
    margin: 0;
}

.single-footer-widget ul.list_style li {
    margin-bottom: 12px;
}

.single-footer-widget ul.list_style li a {
    color: #777;
    font-size: 14px;
    line-height: 24px;
    transition: all 0.3s ease;
    display: inline-block;
}

.single-footer-widget ul.list_style li a:hover {
    color: #f3c300;
    padding-left: 5px;
}

.footer-text {
    font-family: 'Roboto', sans-serif;
    font-weight: 400;
    font-size: 12px;
    color: #000;
    font-size: 13px;
    line-height: 24px;
    text-align: left;
    margin-top: 150px;
}

/* Responsive Footer */
@media (max-width: 991px) {
    .footer-area {
        padding: 60px 0 30px;
    }

    .footer-logo {
        text-align: center;
        margin-bottom: 30px;
    }

    .single-footer-widget {
        text-align: center;
        margin-bottom: 30px;
    }
}

@media (max-width: 767px) {
    .footer-area {
        padding: 40px 0 20px;
    }

    .footer-logo img {
        max-width: 150px;
    }

    .footer_title {
        font-size: 13px;
        margin-bottom: 15px;
    }

    .single-footer-widget ul.list_style li a {
        font-size: 13px;
    }
}

/* ============================================
   CUSTOM FOOTER LAYOUT STYLES
   ============================================ */

.custom-footer {
    background-color: #ffffff;
    padding: 60px 0 20px;
}

.footer-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
    display: grid;
    grid-template-columns: 1.5fr 1.5fr 1fr;
    gap: 40px;
    align-items: start;
}

/* Logo Section */
.footer-logo-section {
    display: flex;
    justify-content: center;
    align-items: flex-start;
}

.footer-logo-img {
    max-width: 550px;
    max-height: 386px;
    width: 100%;
    height: auto;
}

/* Destinacije Section */
.footer-destinations-section {
    display: flex;
    flex-direction: column;
}

.footer-title {
    font-family: 'Roboto', sans-serif;
    font-weight: 700;
    font-size: 20px;
    color: #000000;
    margin-bottom: 20px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.destinations-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px 20px;
}

.destination-link {
    font-family: 'Roboto', sans-serif;
    font-weight: 400;
    font-size: 16px;
    color: #000000;
    text-decoration: none;
    transition: color 0.3s ease;
    display: block;
}

.destination-link:hover {
    color: #000;
    transform: scale(1.02);
}

/* Links Section */
.footer-links-section {
    display: flex;
    flex-direction: column;
}

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

.footer-links-list li {
    margin-bottom: 12px;
}

.footer-links-list li a {
    font-family: 'Roboto', sans-serif;
    font-weight: 400;
    font-size: 16px;
    color: #000000;
    text-decoration: none;
    transition: color 0.3s ease;
}

.footer-links-list li a:hover {
    color: #000;
    transform: scale(1.02);
    text-decoration: none;
}

/* Copyright */
.footer-copyright {
    text-align: center;
    margin-top: 40px;
    padding-top: 20px;
    border-top: 1px solid #e0e0e0;
}

.footer-copyright p {
    color: #777777;
    font-size: 14px;
    margin: 0;
}

/* ============================================
   FOOTER RESPONSIVE
   ============================================ */

@media (max-width: 991px) {
    .footer-container {
        grid-template-columns: 1fr;
        gap: 30px;
        text-align: left;
    }

    .footer-logo-section {
        justify-content: flex-start;
    }

    .footer-logo-img {
        max-width: 300px;
    }

    .destinations-grid {
        grid-template-columns: repeat(2, 1fr);
        justify-items: start;
    }

    .footer-links-list {
        display: flex;
        flex-direction: column;
        align-items: flex-start;
    }
}

@media (max-width: 576px) {
    .custom-footer {
        padding: 40px 0 20px;
    }

    .footer-container {
        gap: 25px;
    }

    .footer-logo-img {
        max-width: 100%;
    }

    .destinations-grid {
        grid-template-columns: 1fr;
        gap: 10px;
    }

    .footer-text {
        margin-top: 30px;
    }

    .destination-link,
    .footer-links-list li a {
        font-size: 14px;
    }
}

.leaflet-bottom {
    display: none !important;
}

/* ================================================
   KONTAKT STRANICA - Minimalistički dizajn
   ================================================ */

/* Sakrivanje intro sekcije */


/* Kontakt wrapper */
.page-wrapper.section_gap {
    padding: 80px 0;
    background: #fff;
}

/* Kontakt container */
.page-wrapper .container {
    max-width: 900px;
}

/* Glavni naslov */
.page-wrapper h1.main-contact-title {
    font-size: 48px;
    font-weight: 700;
    text-align: center;
    margin-bottom: 80px;
    color: #000;
    font-family: 'Roboto', sans-serif;
}

/* Redefinisanje contact-card stilova za minimalistički izgled */
.page-wrapper .contact-card {
    background: transparent !important;
    border: none !important;
    padding: 0 !important;
    text-align: center;
    margin-bottom: 60px;
}

.page-wrapper .contact-card:hover {
    transform: none;
    box-shadow: none;
}

/* Sakrivanje ikona */
.page-wrapper .contact-card .contact-icon {
    display: none;
}

.page-wrapper .contact-card i {
    display: none;
}

/* Naslovi sekcija */
.page-wrapper .contact-card h4 {
    font-size: 32px;
    font-weight: 700;
    margin-bottom: 30px;
    color: #000;
    font-family: 'Roboto', sans-serif;
}

/* Lista */
.page-wrapper .contact-card ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.page-wrapper .contact-card ul li {
    font-size: 18px;
    margin-bottom: 10px;
    color: #000;
}

.page-wrapper .contact-card ul li a {
    color: #000 !important;
    text-decoration: none;
    font-weight: 400;
}

.page-wrapper .contact-card ul li a:hover {
    color: #333 !important;
}

.page-wrapper .contact-card ul li strong {
    font-weight: 400;
}

/* Email sekcija */
.page-wrapper .contact-card p.mt-3 {
    margin-top: 20px !important;
    font-size: 16px;
    color: #666;
}

/* Radno vreme */
.page-wrapper .contact-card ul li strong {
    font-weight: 600;
}

/* Sakrivanje social sekcije - samo u drugom row-u koji ima klasu mt-4 */
.page-wrapper .row.mt-4 .col-lg-6:last-child {
    display: none;
}

/* Sakrivanje CTA sekcije */
.page-wrapper .contact-cta {
    display: none;
}

/* Layout adjustment - Sve sekcije u jednu kolonu, centrirane */
.page-wrapper>.container>.row:first-of-type .col-lg-6 {
    flex: 0 0 100%;
    max-width: 100%;
}

.page-wrapper>.container>.row.mt-4 .col-lg-6:first-child {
    flex: 0 0 100%;
    max-width: 100%;
}

/* Responsive */
@media (max-width: 768px) {
    .page-wrapper h1.main-contact-title {
        font-size: 36px;
        margin-bottom: 50px;
    }

    .page-wrapper .contact-card h4 {
        font-size: 26px;
        margin-bottom: 20px;
    }

    .page-wrapper .contact-card ul li {
        font-size: 16px;
    }
}

/* Error messages */
.error-message {
    color: #dc3545;
    /* Red color */
    font-size: 12px;
    margin-top: 5px;
    display: block;
}

/* ARSF Fix: Give phone input more space in the grid */
@media (min-width: 992px) {
    .passenger.first-passenger .phone-wrapper {
        grid-column: span 2;
    }
}

@media (min-width: 600px) and (max-width: 991px) {
    .passenger.first-passenger .phone-wrapper {
        grid-column: span 2;
    }
}