    * {
        font-family: "Inter", Sans-serif;
    }

    body {
        padding: 0;
        margin: 0;
        background-color: #f0f0f0;
    }

    .box_promo {
        padding: 30px 120px;
        background-color: #0d1707;
        color: #ffffff;
    }

    .box_promo_content {
        display: flex;
        flex-direction: row;
        align-items: baseline;
        justify-content: flex-start;
        gap: 30px;
        font-size: 14px;
        font-weight: 400;
        letter-spacing: 0.07em;
        line-height: 1.5;
    }

    .box_promo_content_item {
        flex: 1;
        text-align: center;
    }

    .box_promo_title {
        font-size: 16px;
        font-weight: 600;
    }

    .box_promo_percent {
        font-size: 60px;
        font-weight: 600;
        color: #d3b45a;
    }

    .divider_promo {
        display: flex;
        flex-direction: row;
        align-items: center;
        justify-content: center;
        width: 90%;
        margin: 20px auto;
        gap: 20px;
    }

    .divider_promo_line {
        flex: 1;
        border-bottom: 1px solid #d3b45a;
    }

    .divider_promo_text {
        font-size: 36px;
        font-weight: 600;
        color: #ffffff;
        text-align: center;
    }

    .divider_promo_sm {
        width: 50%;
        margin: 20px auto;
        border-bottom: 1px solid #d3b45a;
    }

    .divider {
        display: flex;
        flex-direction: row;
        align-items: center;
        justify-content: center;
        width: 100%;
        margin: 20px auto;
        gap: 20px; 
    }

    .divider_line {
        flex: 1;
        border-bottom: 1px solid #0f9449;
    }

    .divider_text {
        font-family: "Poltawski Nowy", Sans-serif;
        color: #0f9449;
        font-size: 36px;
        font-weight: 600;
        text-align: center;
    }

    .divider_main_topic {
        width: 80%;
        margin: 80px auto 40px auto;
    }

    .gc_desc, .ht_desc, .ex_desc {
        font-family: "Inter", Sans-serif;
        font-size: 14px;
        font-weight: 400;
        color: #444;
        padding: 0px;
    }

    .ht_desc, .ex_desc {
        margin-top: 15px;
    }

    .ex_location {
        font-family: "Poltawski Nowy", Sans-serif;
        font-size: 16px;
        font-weight: 400;
        font-style: italic;
        color: #444;
        margin: 10px 15px;
        padding: 0px 0px 10px 0px;
        border-bottom: 1px solid #ccc;
    }

    .ex_non_golf {
        padding: 3px 10px;
        background-color: #f0f0f0;
        border-radius: 50px;
        border: 1px solid #ccc;
        font-size: 12px;
        font-weight: 600;
        color: #008800;
        text-align: center;
        margin: 10px 15px 0px 15px;
        display: inline-block;
    }

    .gc_details_right, .ht_details_right, .ex_details_right {
        flex: 1;
    }

    .gc_details_left, .ht_details_left, .ex_details_left {
        width: 50%;
        flex-shrink: 0;
    }

    .gc_info {
        display: flex;
        flex-direction: row;
        gap: 10px;
        margin-bottom: 5px;
        margin-left: 15px;
    }

    .gc_info_title {
        font-family: "Inter", Sans-serif;
        font-size: 14px;
        font-weight: 600;
        color: #000;
        width: 100px;
        text-align: center;
        padding: 3px 10px;
        background-color: #dddddd;
        border-radius: 5px;
    }

    .gc_info_value {
        font-family: "Inter", Sans-serif;
        font-size: 14px;
        font-weight: 400;
        color: #444;
        text-align: left;
        padding: 3px 0px;
    }

    .gc_image,.ht_image,.ex_image {
        aspect-ratio: 4/3;
        width: 100%;
        height: auto;
        border-radius: 10px;
        border: 1px solid #ccc;
    }

    .gc_name,.ht_name,.ex_name {
        font-family: "Poltawski Nowy", Sans-serif;
        font-size: 18px;
        font-weight: 600;
        color: #000;
        padding: 0px 15px;
    }

    .gc_short_desc {
        font-family: "Poltawski Nowy", Sans-serif;
        font-size: 16px;
        font-weight: 400;
        color: #444;
        padding: 0px 15px;
        font-style: italic;
        margin: 5px 0 20px 0;
    }

    .gc_small_img,.ht_small_img {
        display: grid;
        grid-template-columns: repeat(4, 1fr);
        grid-template-rows: repeat(1, 1fr);
        gap: 10px;
        width: 100%;
        margin: 15px 0;
    }

    .gc_small_img img,.ht_small_img img {
        width: 100%;
        aspect-ratio: 4/3;
        object-fit: cover;
        border-radius: 8px;
        border: 1px solid #ddd;
    }

    .golf_course_details_box, .hotel_details_box, .excursion_details_box {
        padding: 15px;
        background-color: #fafafa;
        border: 1px solid #ddd;
        border-radius: 10px;
        font-family: "Inter", Sans-serif;
        font-size: 14px;
        margin: 20px auto;
        display: flex;
        flex-direction: row;
        gap: 10px;
        width: 100%;
        box-sizing: border-box;
    }

    .img_projection {
        cursor: pointer;
        border: 1px solid #cccccc;
        box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.8);
    }

    .main_container {
        paddomg:10px;
        background-color: #ffffff;
    }

    .main_description {
        position: absolute;
        bottom: 20px;
        left: 20px;
        background-color: #ffffffcc;
        padding: 10px;
        border-radius: 30px;
        display: flex;
        flex-direction: row;
        gap: 5px;
        width: calc(100% - 200px);
        margin: 0 70px;
    }

    .main_description span {
        font-size: 14px;
        font-weight: 600;
        color: #000;
        flex: 1;
        text-align: center;
    }

    .main_header {
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        background-color: #ffffffff;
        border-bottom: 1px solid #888;
        display: grid;
        align-items: center;
        z-index: 10000;
    }

    .main_header_top {
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 50px 0;
        position: absolute;
        bottom: 20px;
        width: 100%;
    }

    .main_header_top img {
        width: 200px;
    }

    .main_header_top span {
        font-family: "Poltawski Nowy", Sans-serif;
        font-size: 44px;
        font-weight: 600;
        color: #ffffff;
        text-align: center;
        text-shadow: 2px 2px 4px #000;
    }

    .main_header_menu {
        display: flex;
        gap: 5px;
        padding: 5px 0;
        background-color: #000000;
    }
    
    .main_header_menu span {
        font-family: "Inter", Sans-serif;
        font-size: 12px;
        font-weight: 600;
        color: #ffffff;
        cursor: pointer;
        flex: 1;
        text-align: center;
        border-radius: 35px;
        padding: 5px;
    }

    .main_header_menu span:hover {
        background-color: #646464;
    }

    .main_photo {
        margin-top: 30px;
        background-size: cover;
        background-position: center;
        height: 550px;
        position: relative;
        margin-bottom: 0px;
    }

    .qtn_day_date {

    }

    .qtn_day_text {
        font-size: 14px;
        font-weight: bold;
        display: block;
        /*background: #bdb;*/
        color: #000;
        padding: 0px 15px;
        border-radius: 5px;
        margin: 20px 0 5px 0;
    }

    .qtn_day_title, .qtn_day_desc {
        font-size: 14px;
        font-weight: 400;
        color: #444;
        padding: 0px 15px;
        display: block;
    }

    .qtn_day_details_container {
        /*margin: 20px 0;*/
        margin: 0;
    }

    .qtn_day_gc_dtl {
        font-size: 13px;
        font-weight: bold;
        color: #666;
        padding: 5px 15px;
        margin-top: 10px;
    }

    .qtn_details_title {
        font-family: "Poltawski Nowy", Sans-serif;
        font-size: 20px;
        font-weight: 600;
        color: #000;
        padding: 0px 15px;
    }

    .recm_title {
        font-family: "Poltawski Nowy", Sans-serif;
        font-size: 14px;
        font-weight: 600;
        color: #000;
        padding: 0px 15px;
    }

    .welcome_message {
        margin: 20px 0 40px 0;
    }

    .welcome_message_date {
        padding: 0 30px 50px 0;
        text-align: right;
    }

    .qtn_overview_box, .qtn_destination_info, .qtn_golf_courses, .qtn_hotels, .qtn_excursions, .qtn_pricing {
        padding: 60px 60px 80px 60px;
        background-color: #ffffff;
        border: 1px solid #cccccc;
        font-family: "Inter", Sans-serif;
        font-size: 14px;
        margin: 0px auto 30px auto;
    }

    .qtn_overview_box {
        width: 50%;
        letter-spacing: 0.07em;
    }

    .qtn_destination_info, .qtn_golf_courses, .qtn_hotels, .qtn_excursions, .qtn_pricing {
        width: 80%;
    }

    .qtn_overview_box h1, .qtn_overview_box h2, .qtn_overview_box h3,
    .qtn_destination_info h1, .qtn_destination_info h2, .qtn_destination_info h3,
    .qtn_golf_courses h1, .qtn_golf_courses h2, .qtn_golf_courses h3,
    .qtn_hotels h1, .qtn_hotels h2, .qtn_hotels h3,
    .qtn_excursions h1, .qtn_excursions h2, .qtn_excursions h3,
    .qtn_pricing h1, .qtn_pricing h2, .qtn_pricing h3 {
        padding: 0;
        font-family: "Poltawski Nowy", Sans-serif;
        font-weight: 600;
    }

    .qtn_overview_box h1, .qtn_destination_info h1, .qtn_golf_courses h1, .qtn_hotels h1, .qtn_excursions h1, .qtn_pricing h1 {
        font-size: 20px;
    }

    .qtn_overview_box h2, .qtn_destination_info h2, .qtn_golf_courses h2, .qtn_hotels h2, .qtn_excursions h2, .qtn_pricing h2 {
        font-size: 18px;
    }

    .qtn_overview_box h3, .qtn_destination_info h3, .qtn_golf_courses h3, .qtn_hotels h3, .qtn_excursions h3, .qtn_pricing h3 {
        font-size: 16px;
    }

    .qtn_overview_box p, .qtn_destination_info p, .qtn_golf_courses p, .qtn_hotels p, .qtn_excursions p, .qtn_pricing p {
        padding: 0 15px;
    }

    .topic_title {
        font-family: "Inter", Sans-serif;
        font-size: 22px;
        font-weight: 600;
        padding: 0 0 10px 0;
        border-bottom: 2px solid #dddddd;
    }

    .topic_title_pricing_head {
        font-family: "Inter", Sans-serif;
        font-size: 22px;
        font-weight: 600;
        padding: 0 0 10px 0;
    }

    .topic_title_pricing {
        font-family: "Inter", Sans-serif;
        font-size: 16px;
        font-weight: 600;
        color: #555;
        padding: 0 0 10px 0;
        border-bottom: 1px solid #ccc;
        margin-bottom: 15px;
    }

    .img_projection_close {
        width: fit-content;
        text-align: center;
        font-size: 12px;
        font-weight: 600;
        color: #000000;
        background-color: #ccc;
        padding: 5px 15px;
        border-radius: 0 0 5px 5px;
        display: flex;
        align-items: center;
        justify-content: right;
        gap: 5px;
    }

    .img_projection_box {
        display: flex;
        justify-content: center;
        align-items: center;
        flex-direction: column;
    }

    .img_projection_container {
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background-color: #000000cc;
        z-index: 15000;
        display: none;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        cursor: pointer;
    }

    .inclusion_exclusion {
        display: flex;
        flex-direction: row;
        gap: 15px;
        margin: 20px 0;
    }

    .inclusion_exclusion_left, .inclusion_exclusion_right {
        flex: 1;
        padding: 15px;
        background: #eee;
        color: #000;
        border-radius: 3px;
        border: 1px solid #ddd;
    }

    .package_title {
        margin-top: 15px;
    }

    .prc_hotel_name {
        display: inline-block;
        align-items: center;
        gap: 3px;
        font-size: 14px;
        font-weight: 600;
        color: #000;
    }

    .prc_hotel_name svg {
        vertical-align: bottom;
    }

    .prc_hotel_room {
        display: inline-block;
    }

    #the_img_projection {
        width: 80%;
        border: 1px solid #ccc;
        border-radius: 10px;
    }

    #trip_highlights {
        font-size: 16px;
        font-weight: 600;
        padding-left: 15px;
        color: #000;
    }

    .waiting_screen {
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background-color: #ffffff;
        z-index: 20000;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
    }

    .spinner {
        border: 6px solid #f3f3f3;
        border-top: 6px solid #4CAF50;
        border-radius: 50%;
        width: 60px;
        height: 60px;
        animation: spin 1s linear infinite;
        margin-bottom: 30px;
    }

    .stop_sign_itinerary {
      display: block;
      font-size: 24px;
      font-weight: 600;
      color: #0f9449;
      padding: 0 10px 10px 1px;
      margin: 80px 0 0 0;
    }
    
    @keyframes spin {
      0% { transform: rotate(0deg); }
      100% { transform: rotate(360deg); }
    }
  
    .logo {
        margin-bottom: 30px;
    }
    
    .message {
      font-size: 1.2rem;
      opacity: 0;
      transition: opacity 1s ease-in-out;
      text-align: center;
      max-width: 90%;
      margin-bottom: 30px;
    }
    
    .message.show {
      opacity: 1;
    }
  
    .message.hide {
      opacity: 0;
    }

    .for_mobile {
        display: none;
    }

    .main_header_logo {
        background: none;
        padding: 0px;
        display: inline-block;
    }

    .main_header_logo img {
        width: 250px;
    }

    @media screen and (max-width: 768px) {
        .spinner {
          width: 40px;
          height: 40px;
          border-width: 4px;
          margin-bottom: 20px;
        }
          
        .stop_sign_itinerary {
          font-size: 20px;
          padding: 0 8px 8px 1px;
          margin-bottom: 12px;
        }
          
        .logo {
          margin-bottom: 20px;
          max-width: 80%;
        }
          
        .message {
          font-size: 1rem;
          max-width: 95%;
          margin-bottom: 20px;
        }

        .main_header {
            position: relative;
        }

        .main_header_top {
            display: block;
            position: initial;
            padding: 10px;
            text-align: center;
        }

        .main_header_top span {
            font-size: 24px;
            text-align: center;
            top: 10px;
        }

        .main_header_menu {
            /*
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            grid-template-rows: repeat(3, 1fr);
            */
            display: none;
        }

        .main_photo {
            height: 300px;
            margin-top: 0px;
            position: relative;
            display: flex;
            justify-content: center;
            align-items: baseline;
        }

        /*
        .main_photo .main_description {
            position: absolute;
            bottom: 20px;
            left: 50%;
            transform: translateX(-50%);
        }
        */

        .main_description {
            display: grid;
            grid-template-columns: repeat(1, 1fr);
            grid-template-rows: repeat(4, 1fr);
            border-radius: 5px;
            text-align: left;
            /*width: fit-content;*/
        }

        .main_description span {
            font-size: 14px;
        }

        .golf_course_details_box, .hotel_details_box, .excursion_details_box {
            flex-direction: column;
        }

        .gc_details_right, .ht_details_right, .ex_details_right {
            flex: 1;
        }

        .gc_details_left, .ht_details_left, .ex_details_left {
            width: 100%;
        }
        
        .gc_small_img,.ht_small_img {
            grid-template-columns: repeat(2, 1fr);
            grid-template-rows: repeat(1, 1fr);
        }

        .gc_desc, .ht_desc, .ex_desc {
            font-size: 16px;
            padding: 0px;
        }

        .golf_course_details_box, .hotel_details_box, .excursion_details_box {
            padding: 0px;
            background: none;
            border: none;
            border-bottom: 1px solid #ccc;
            border-radius: 0;
            margin-bottom: 40px;
        }

        .gc_info {
            margin-left: 0px;
            display: block;
        }

        .gc_info_title {
            display: block;
            background: none;
            text-align: left;
            padding: 0px;
            font-size: 16px;
        }

        .gc_info_value {
            font-size: 16px;
        }

        .gc_name, .ht_name, .ex_name {
            font-size: 1.6em;
            padding: 0px;
        }

        .gc_short_desc {
            padding: 0px;
            margin-bottom: 10px;
        }

        .ex_location {
            border-bottom: none;
            margin: 10px 0;
        }

        .ht_name {
            margin-bottom: 10px;
        }

        .qtn_overview_box p, .qtn_destination_info p, .qtn_golf_courses p, .qtn_hotels p, .qtn_excursions p, .qtn_pricing p {
            padding: 0px;
        }

        .for_mobile {
            display: block;
        }

        .for_desktop {
            display: none;
        }

        .qtn_overview_box, .qtn_destination_info, .qtn_golf_courses, .qtn_hotels, .qtn_excursions, .qtn_pricing {
            width: calc(100% - 30px);
            padding: 20px 10px 10px 10px;
            font-size: 16px;
        }

        #golf_courses_all {
            padding-top: 20px;
            border-top: 1px solid #ccc;
        }

        #the_img_projection {
            width: 98%;
        }

        .qtn_day_text, .qtn_day_title, .qtn_day_desc {
            font-size: 16px;
            padding: 0px;
        }

        .qtn_day_text {
            display: block;
            width: 100%;
        }

        .qtn_day_title, .qtn_day_desc {
            display: inline;
        }

        .img_projection_container {
            z-index: -1;
        }

        .qtn_destination_info h3 {
            font-size: 1.2em;
        }

        .main_header_logo {
            display: block;
            width: 100%;
            text-align: center;
        }

        .box_promo {
            display: block;
            padding: 10px;
        }

        .box_promo_content {
            display: block;
        }


        .box_promo_title {
            margin-top: 40px;
        }

        .divider_text, .divider_promo_text {
            font-size: 20px;
        }

        .divider_promo_sm {
            margin: 10px auto;
        }
    }