/* PEB Global Hotel */
@font-face { font-family: 'century-gothic'; src: local('Century Gothic'), local('CenturyGothic'); font-weight: 400; font-style: normal; }
:root { --brown: #934200; --black: #000; --gray: #6e6f72; --light: #F4F5F4; --white: #fff; --font: 'century-gothic', 'Nunito', 'Trebuchet MS', 'Arial Rounded MT Bold', 'Verdana', Arial, sans-serif; --transition: 0.3s ease all; }
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; font-family: var(--font); font-size: 1rem; font-weight: 400; line-height: 1.5; color: #000; background-color: var(--white); text-rendering: optimizeLegibility; -webkit-font-smoothing: antialiased; }
h1, h2, h3, h4, h5, h6 { margin-top: 0; font-family: var(--font); font-weight: 700; line-height: 1.3; letter-spacing: 0.2px; }
h1 { font-size: 2.42rem; margin-bottom: 1rem; } h2 { font-size: 2.14rem; margin-bottom: 1.5rem; } h3 { font-size: 1.71rem; margin-bottom: 1.5rem; } h4 { font-size: 1.42rem; margin-bottom: 1.5rem; font-weight: 400; }
p { margin-top: 0; margin-bottom: 1rem; }
a { color: var(--brown); text-decoration: none; transition: var(--transition); -webkit-backface-visibility: hidden; backface-visibility: hidden; }
a:hover { color: var(--gray); }
img { max-width: 100%; height: auto; }
address { font-style: normal; }
ul { margin: 0; padding: 0; }
.container { width: 100%; padding-right: 15px; padding-left: 15px; margin-right: auto; margin-left: auto; max-width: 1140px; }
.container-fluid { width: 100%; padding-right: 15px; padding-left: 15px; margin-right: auto; margin-left: auto; }
.row { display: flex; flex-wrap: wrap; margin-right: -15px; margin-left: -15px; }
.col, [class*="col-"] { position: relative; width: 100%; padding-right: 15px; padding-left: 15px; }
.col-12 { flex: 0 0 100%; max-width: 100%; }
@media (min-width: 576px) { .col-sm-2 { flex: 0 0 16.6667%; max-width: 16.6667%; } .col-sm-12 { flex: 0 0 100%; max-width: 100%; } }
@media (min-width: 768px) { .col-md-6 { flex: 0 0 50%; max-width: 50%; } }
.align-items-center { align-items: center; } .text-center { text-align: center; } .mb-4 { margin-bottom: 1.5rem; } .pb-4 { padding-bottom: 1.5rem; }
@media (min-width: 768px) { .mb-md-0 { margin-bottom: 0; } }
.pt-0 { padding-top: 0 !important; } .py-0 { padding-top: 0 !important; padding-bottom: 0 !important; }
.bg-light { background-color: var(--light) !important; } .bg { width: 100%; }
.bg-image { background-repeat: no-repeat; background-position: center center; background-size: cover; backface-visibility: hidden; color: var(--white); }
.img-fluid { max-width: 100%; height: auto; }
.fixed-top { position: fixed; top: 0; left: 0; right: 0; z-index: 1030; }
.main { display: block; } .navbar-collapse { flex-basis: 100%; flex-grow: 1; align-items: center; } .position-static { position: static !important; }
.vh-100 { min-height: 100vh; height: 100vh !important; }
.center-flex-y { display: flex; flex-direction: column; justify-content: center; }
.top-content-banner { position: fixed; top: 0; width: 100%; z-index: 11111; padding-top: 10px; background: rgba(0,0,0,0.85); display: none; }
.top-content-banner .container { display: flex; justify-content: center; align-items: center; gap: 20px; padding-bottom: 10px; }
.top-content-banner a { color: var(--white); font-size: 13px; display: flex; align-items: center; gap: 6px; }
#nav.navbar { position: fixed; top: 0; right: 0; left: 0; z-index: 1030; display: flex; align-items: center; font-family: var(--font); font-weight: 400; padding: 0; height: 120px; background: linear-gradient(180deg, rgba(0,0,0,0.85) 0%, rgba(0,0,0,0) 100%); transition: var(--transition); backface-visibility: hidden; }
#nav.navbar.scrolled { background: rgba(0,0,0,0.85); backdrop-filter: blur(10px); box-shadow: 2px 2px 8px 0 rgba(0,0,0,0.1); height: 88px; }
.nav-container { display: flex; align-items: center; justify-content: space-between; width: 100%; max-width: 1200px; margin: 0 auto; padding: 0 20px; position: relative; }
.logo { display: inline-block; flex-shrink: 0; }
.logo-img { width: 72px; height: 60px; object-fit: contain; }
#nav.navbar.scrolled .logo-img { width: 60px; height: 50px; }
#navbar { flex-grow: 0; margin-left: auto; margin-right: 1rem; }
.nav.navbar-nav { display: flex; flex-direction: row; list-style: none; padding: 0; margin: 0; gap: 0; }
.nav.navbar-nav .nav-item { position: relative; padding: 0; margin: 0; }
.nav.navbar-nav .nav-item > .nav-link { display: block; padding: 0.7rem; color: var(--white) !important; font-size: 14px; font-family: var(--font); text-decoration: none; white-space: nowrap; transition: var(--transition); }
.nav.navbar-nav .nav-item > .nav-link:hover { color: var(--gray) !important; }
.nav-link.dropdown-toggle::after { display: none; }
.dropdown-menu { position: absolute; top: 100%; left: 0; z-index: 1000; display: block; visibility: hidden; opacity: 0; transition: visibility 0.15s, opacity 0.15s linear; min-width: 16rem; padding: 0.5rem 0; margin: 0; background-color: var(--white); border-radius: 0; border: none; box-shadow: 0 8px 24px rgba(0,0,0,0.15); list-style: none; }
.nav-item.dropdown:hover > .dropdown-menu, .nav-item.dropdown.open > .dropdown-menu { visibility: visible; opacity: 1; }
.dropdown-menu .nav-link { display: block; padding: 0.3rem 1rem; font-size: 14px; color: var(--black) !important; text-decoration: none; transition: var(--transition); }
.dropdown-menu .nav-link:hover { background: var(--black); color: var(--white) !important; }
.dropdown-country { padding: 0.5rem 0; }
.dropdown-country-name { display: block; font-size: 1.2rem; font-weight: 700; border-bottom: 2px solid var(--black); color: var(--black); padding: 0.5rem 1rem; margin-bottom: 0.5rem; }
.dropdown-region-holder { column-count: 2; margin-bottom: 1rem; padding: 0 1rem; }
.dropdown-region { break-inside: avoid-column; margin-bottom: 0.5rem; }
.dropdown-region-name { display: inline-block; font-size: 0.9rem; font-weight: 700; border-bottom: 1px solid var(--brown); margin-top: 0.8rem; margin-bottom: 0.4rem; color: var(--black); }
.dropdown-hotel-name { display: block; font-size: 13px; padding: 0.1rem 0; color: var(--black); transition: var(--transition); }
.dropdown-hotel-name:hover { background: var(--black); color: var(--white); padding-left: 5px; }
.dropdown-hotel-name.active-hotel { color: var(--brown); font-weight: 700; }
.btn { display: inline-block; font-family: var(--font); font-weight: 700; text-align: center; vertical-align: middle; cursor: pointer; border: none; padding: 1rem 2rem; font-size: 14px; line-height: 1; border-radius: 0; transition: var(--transition); text-decoration: none; }
.btn-primary { background: var(--brown); color: var(--white); } .btn-primary:hover { background: var(--black); color: var(--white); }
.btn-white { background: var(--white); color: var(--black); } .btn-white:hover { background: var(--gray); color: var(--white); }
.check-availability { order: 3; flex-shrink: 0; }
.nav-toggler { display: none; flex-direction: column; justify-content: space-between; align-items: center; width: 22px; height: 22px; background: none; border: none; cursor: pointer; padding: 0; outline: none; order: 4; }
.burger-top, .burger-mid, .burger-low { display: block; height: 2px; width: 22px; background: var(--white); transition: var(--transition); transform-origin: center; }
.nav-toggler.open .burger-top { transform: rotate(45deg) translate(7px, 8px); }
.nav-toggler.open .burger-mid { opacity: 0; }
.nav-toggler.open .burger-low { transform: rotate(-45deg) translate(7px, -8px); }
.hero-section { position: relative; overflow: hidden; }
.hero-section::before { content: ''; position: absolute; inset: 0; background: linear-gradient(to bottom, rgba(0,0,0,0.75) 0%, rgba(0,0,0,0.4) 60%, rgba(0,0,0,0.5) 100%); z-index: 0; }
.hero-section .container { position: relative; z-index: 1; }
.hero-content { display: flex; justify-content: space-between; align-items: flex-start; gap: 2rem; }
.hero-text { max-width: 600px; padding-top: 3rem; }
.hero-text h1 { font-size: clamp(2rem, 4vw, 3.5rem); font-weight: 700; color: var(--white); margin-bottom: 0.75rem; text-shadow: 0 2px 8px rgba(0,0,0,0.4); }
.hero-subtitle { font-size: 1.1rem; color: var(--white); margin-bottom: 1.5rem; text-shadow: 0 1px 4px rgba(0,0,0,0.4); }
.stars { display: flex; gap: 16px; margin-bottom: 0; } .stars img { width: 28px; height: 28px; }



#check-availability { background: rgba(0,0,0,0.85); padding: 22px; margin-top: -80px; margin-bottom: 3em; position: relative; z-index: 111; scroll-margin-top: 88px; }
#check-availability a:not(.btn) { color: var(--white); font-weight: 500; text-decoration: underline; } #check-availability a:not(.btn):hover { color: var(--gray); }
.form-row { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 0; } .form-row.flex-1 { justify-content: space-between; }
.form-row.avail-actions { display: flex; align-items: center; justify-content: flex-end; gap: 1rem; margin-top: 0.5rem; }
.form-group { flex: 1; min-width: 120px; } .form-group-shorter { max-width: 150px; }
.form-group label { color: var(--white); display: block; font-size: 11px; font-weight: 700; letter-spacing: 0.5px; margin-bottom: 4px; text-transform: uppercase; }
.custom-select, .date-picker, .form-control { display: block; width: 100%; height: calc(1.5em + 0.75rem + 2px); padding: 0.375rem 0.75rem; font-size: 0.9rem; font-weight: 400; line-height: 1.5; color: #333; background-color: var(--white); border: 1px solid #ced4da; border-radius: 0; appearance: none; font-family: var(--font); }
.custom-select { padding-right: 1.75rem; background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 4 5'%3e%3cpath fill='%23343a40' d='M2 0L0 2h4zm0 5L0 3h4z'/%3e%3c/svg%3e"); background-repeat: no-repeat; background-position: right 0.75rem center; background-size: 8px 10px; }
.custom-select:focus, .date-picker:focus, .form-control:focus { outline: none; border-color: var(--brown); box-shadow: 0 0 0 2px rgba(147,66,0,0.2); }
.btn-check-availability { white-space: nowrap; }
.component { position: relative; padding-top: 3em; padding-bottom: 3em; } .component.pt-0 { padding-top: 0; }
.image-text { min-height: 0; margin-top: 0; margin-bottom: 0; } .image-text .row { align-items: center; } .image-text figure { margin: 0; }
.image-text figure img { width: 100%; height: 100%; object-fit: cover; display: block; }
.image-text--left-image figure { overflow: hidden; border-radius: 2px; } .image-text--right-image figure { overflow: hidden; border-radius: 2px; }
.image-text .col-md-6.text { padding-left: 3rem; } .image-text h2 { font-size: 2rem; margin-bottom: 1.25rem; }
.brand-color { color: var(--brown); font-weight: 500; }
.subnav-wrapper { position: sticky; top: 88px; z-index: 100; padding-top: 0; padding-bottom: 0; }
.subnav { background: var(--black); text-align: center; }
.subnav a { color: var(--white); text-transform: uppercase; font-weight: 700; font-size: 0.85rem; letter-spacing: 0.5px; padding: 0.65rem 1.5rem; display: inline-block; transition: var(--transition); text-decoration: none; }
.subnav a.active { background: var(--white); color: var(--black) !important; } .subnav a:hover:not(.active) { color: var(--gray) !important; }
.hotel-facilities .icons { display: flex; flex-wrap: wrap; padding-left: 0; list-style: none; }
.hotel-facilities .icons li { width: 50%; padding-left: 44px; margin-bottom: 36px; position: relative; font-size: 0.95rem; font-weight: 500; color: #333; }
.hotel-facilities .icons li::before { content: ''; height: 30px; width: 30px; display: block; background-repeat: no-repeat; background-size: 100% 100%; position: absolute; left: 0; top: 50%; transform: translateY(-50%); }
.icon__bar::before { background-image: url('images/icons/coffee-bar.svg'); } .icon__coffee::before { background-image: url('images/icons/tea-coffee-facilities.svg'); } .icon__gym::before { background-image: url('images/icons/gym.svg'); } .icon__health-vitality-centre::before { background-image: url('images/icons/health-vitality-centre.svg'); } .icon__meeting::before { background-image: url('images/icons/meeting-room.svg'); } .icon__restaurants::before { background-image: url('images/icons/resturant.svg'); } .icon__room-service::before { background-image: url('images/icons/room-services.svg'); } .icon__swimming::before { background-image: url('images/icons/swiming-pool.svg'); }
.hotel-facilities h4 { font-size: 1.5rem; margin-bottom: 2rem; color: var(--black); }
.hotel-facilities figure { margin: 0; overflow: hidden; } .hotel-facilities figure img { width: 100%; height: auto; display: block; transition: transform 0.4s ease; } .hotel-facilities figure:hover img { transform: scale(1.03); }
.your-experience { padding: 0; } .your-experience .container-fluid { padding: 0; } .your-experience .row { margin: 0; gap: 0; }
.your-experience__image { aspect-ratio: 12 / 9; flex: 0 0 50%; max-width: 50%; background-repeat: no-repeat; background-size: cover; background-position: center; display: flex; align-items: center; justify-content: center; margin-bottom: 0; transition: background-size 0.4s ease; position: relative; text-decoration: none; overflow: hidden; }
.your-experience__image::before { content: ''; position: absolute; inset: 0; background-color: rgba(0,0,0,0.35); transition: opacity 0.3s ease; }
.your-experience__image:hover { background-size: 110%; } .your-experience__image:hover::before { opacity: 0; }
.your-experience__image > div { max-width: 397px; color: var(--white); position: relative; z-index: 1; padding: 2rem; }
.your-experience__image > div h3 { font-size: 2.5rem; font-weight: 700; color: var(--white); margin-bottom: 0.5rem; text-shadow: 0 2px 8px rgba(0,0,0,0.4); }
.your-experience__image > div p { font-size: 1rem; color: var(--white); margin-bottom: 0; text-shadow: 0 1px 4px rgba(0,0,0,0.4); }
.hotel-gallery { padding-top: 3em; overflow: hidden; } .hotel-slider { width: 100%; }
.hotel-gallery h2 { text-align: center; margin-bottom: 2rem; font-size: 2.5rem; }
.gallery-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; padding: 0 8px 8px; }
.gallery-grid .col { padding: 0; overflow: hidden; } .gallery-image { display: block; overflow: hidden; cursor: pointer; }
.gallery-image img { width: 100%; height: 220px; object-fit: cover; display: block; transition: transform 0.4s ease, filter 0.3s ease; filter: brightness(0.95); }
.gallery-image:hover img { transform: scale(1.06); filter: brightness(1.05); }
.component.split-line { position: relative; } .component.split-line::before { content: ''; width: 2px; height: calc(100% - 6em); background-color: #ccc; left: 50%; top: 3em; transform: translateX(-50%); position: absolute; }
.component.split-line .row { align-items: flex-start; } .component.split-line .col-md-6 { padding-right: 3rem; } .component.split-line .col-md-6:last-child { padding-right: 15px; padding-left: 3rem; }
.feedback-col h3, .contact-col h3 { font-size: 1.8rem; margin-bottom: 1.5rem; color: var(--black); }
.feedback-col blockquote { border-left: 3px solid var(--brown); padding-left: 1.25rem; margin: 0; } .feedback-col blockquote p { font-size: 1.05rem; color: #333; font-style: italic; }
.contact-col a.numbers { display: flex; align-items: center; gap: 8px; color: var(--black); font-size: 1rem; font-weight: 600; } .contact-col a.numbers:hover { color: var(--brown); }
.hotel-whatsapp { display: flex; align-items: center; gap: 10px; color: var(--black); font-weight: 600; } .hotel-whatsapp:hover { color: #2CB742; }
.contact-col a:not(.numbers):not(.hotel-whatsapp) { color: var(--brown); } .contact-col address { color: #555; line-height: 1.8; }
.g_map iframe { border: 0; width: 100%; display: block; height: 450px; }
.newsletter-sign { background-color: var(--gray); color: var(--white); padding: 2.5rem 1rem; display: flex; justify-content: center; align-items: center; }
.newsletter-sign .row { width: 100%; } .newsletter-sign .col-sm-12 { display: flex; flex-direction: column; align-items: center; gap: 16px; }
.newsletter-sign p { font-size: 1.2rem; font-weight: 700; margin-bottom: 0; } .newsletter-form { width: 100%; max-width: 500px; }
.newsletter-fields { display: flex; gap: 0; } .newsletter-fields input[type="email"] { flex: 1; padding: 0.75rem 1rem; border: none; border-radius: 0; font-size: 0.9rem; font-family: var(--font); outline: none; }
.newsletter-fields button { padding: 0.75rem 1.5rem; background: var(--black); color: var(--white); border: none; font-weight: 700; font-size: 13px; font-family: var(--font); cursor: pointer; transition: var(--transition); letter-spacing: 0.5px; text-transform: uppercase; } .newsletter-fields button:hover { background: var(--brown); }
.whatsapp a { position: fixed; z-index: 1000; bottom: 40px; right: 40px; display: flex; transition: transform 0.2s ease; } .whatsapp a:hover { transform: scale(1.1); }
#footer { background: var(--black); color: var(--white); padding: 40px 0; font-size: 14px; } #footer p { color: var(--white); font-size: 14px; } #footer p strong { font-size: 16px; display: block; margin-bottom: 1rem; color: var(--white); }
#footer a { color: var(--white); font-size: 14px; text-decoration: none; transition: var(--transition); } #footer a:hover { color: var(--gray); }
.footer-row { display: flex; flex-direction: row; justify-content: space-between; flex-wrap: wrap; margin-bottom: 2rem; }
.footer-brand { flex: 0 0 auto; max-width: 180px; } .footer-logo img { width: 47px; height: 39px; object-fit: contain; margin-bottom: 1.5rem; display: block; } .footer-brand p { line-height: 1.7; }
#footer .col-sm-2 { flex: 0 0 auto; white-space: nowrap; } .menu { padding-left: 0; margin-left: 0; list-style: none; } .menu li { margin-bottom: 5px; }
.copyright { font-weight: 700; color: var(--white); padding-top: 20px; margin-bottom: 0; text-align: center !important; border-top: 1px solid rgba(255,255,255,0.1); }
.social-icons { display: flex; gap: 1rem; margin-top: 1rem; padding: 0; list-style: none; } .social-icons li { margin: 0; }
.social-icons li a { display: flex; align-items: center; justify-content: center; width: 34px; height: 34px; border: 1px solid rgba(255,255,255,0.3); border-radius: 50%; color: var(--white) !important; font-size: 0.9rem; transition: var(--transition); } .social-icons li a:hover { background: var(--white); color: var(--black) !important; border-color: var(--white); }
.fade-in { opacity: 0; transform: translateY(24px); transition: opacity 0.6s ease, transform 0.6s ease; } .fade-in.visible { opacity: 1; transform: translateY(0); }
.fade-in-delay-1 { transition-delay: 0.1s; } .fade-in-delay-2 { transition-delay: 0.2s; } .fade-in-delay-3 { transition-delay: 0.3s; }
@media (max-width: 991px) { #nav.navbar { height: 80px; } .logo-img { width: 56px; height: 48px; } #navbar { display: none; position: fixed; top: 80px; left: 0; width: 100%; background: rgba(0,0,0,0.95); backdrop-filter: blur(10px); padding: 1rem 0 2rem; overflow-y: auto; max-height: calc(100vh - 80px); z-index: 999; } #navbar.open { display: block; } .nav.navbar-nav { flex-direction: column; } .nav.navbar-nav .nav-item { border-bottom: 1px solid rgba(255,255,255,0.08); } .nav.navbar-nav .nav-item > .nav-link { padding: 0.85rem 1.5rem; font-size: 15px; } .dropdown-menu { position: static; visibility: visible; opacity: 1; box-shadow: none; background: rgba(255,255,255,0.05); display: none; border-radius: 0; } .nav-item.dropdown.open > .dropdown-menu { display: block; } .dropdown-menu .nav-link { color: rgba(255,255,255,0.8) !important; padding: 0.4rem 2rem; } .dropdown-menu .nav-link:hover { background: rgba(255,255,255,0.1); color: var(--white) !important; } .dropdown-country-name { color: var(--white); border-color: rgba(255,255,255,0.3); padding: 0.5rem 1.5rem; } .dropdown-region-holder { column-count: 1; padding: 0 1.5rem; } .dropdown-region-name { color: rgba(255,255,255,0.7); } .dropdown-hotel-name { color: rgba(255,255,255,0.6); } .dropdown-hotel-name:hover { background: rgba(255,255,255,0.1); color: var(--white); } .nav-toggler { display: flex; order: 4; } .check-availability { font-size: 12px; padding: 0.6rem 0.8rem; order: 3; } .hero-content { flex-direction: column; } .your-experience__image { flex: 0 0 100%; max-width: 100%; aspect-ratio: 16/9; } .image-text .col-md-6.text { padding-left: 15px; margin-top: 1.5rem; } .component.split-line::before { display: none; } .component.split-line .col-md-6 { padding-right: 15px; } .component.split-line .col-md-6:last-child { padding-left: 15px; margin-top: 2rem; } .gallery-grid { grid-template-columns: repeat(3, 1fr); } .footer-row { flex-wrap: wrap; gap: 2rem; } .footer-brand, #footer .col-sm-2 { flex: 0 0 45%; max-width: 45%; } }
@media (max-width: 767px) { #check-availability { margin-top: -40px; } .form-row.flex-1 { flex-direction: column; } .form-group { min-width: 100%; } .form-group-shorter { max-width: 100%; } .form-row.avail-actions { flex-direction: column; align-items: stretch; } .form-row.avail-actions .form-group { text-align: center; } .hero-text h1 { font-size: 1.8rem; } .gallery-grid { grid-template-columns: repeat(2, 1fr); } .gallery-image img { height: 150px; } .subnav { overflow-x: auto; white-space: nowrap; text-align: left; } .subnav a { padding: 0.65rem 1rem; font-size: 0.75rem; } .hotel-facilities .icons li { width: 100%; } .newsletter-fields { flex-direction: column; } .newsletter-fields input[type="email"], .newsletter-fields button { width: 100%; } .footer-brand, #footer .col-sm-2 { flex: 0 0 100%; max-width: 100%; } .footer-row { gap: 1.5rem; } .whatsapp a { bottom: 20px; right: 20px; } .stars img { width: 22px; height: 22px; } }
@media (max-width: 575px) { h1 { font-size: 1.75rem; } h2 { font-size: 1.5rem; } h3 { font-size: 1.25rem; } .hero-text { padding-top: 1rem; } .component { padding-top: 2em; padding-bottom: 2em; } .hotel-gallery h2 { font-size: 1.75rem; } .gallery-grid { grid-template-columns: repeat(2, 1fr); gap: 4px; padding: 0 4px 4px; } .gallery-image img { height: 120px; } .top-content-banner { display: block; } #nav.navbar { top: 40px; } #navbar { top: 120px; } }
.scroll-progress { position: fixed; top: 0; left: 0; height: 3px; background: var(--brown); z-index: 99999; transition: width 0.1s linear; }
.nav-item a.active-hotel { font-weight: 700; color: var(--brown) !important; }