body, html {
	font-family: 'Raleway', sans-serif;
	text-rendering: optimizeLegibility !important;
	-webkit-font-smoothing: antialiased !important;
	color: #777;
	font-weight: 300;
	width: 100% !important;
	height: 100% !important;
}
h2 {
	margin: 0 0 20px 0;
	font-weight: 500;
	font-size: 34px;
	color: #333;
	text-transform: uppercase;
}
h3 {
	font-size: 22px;
	font-weight: 500;
	color: #333;
}
h4 {
	font-size: 24px;
	text-transform: uppercase;
	font-weight: 400;
	color: #333;
}
h5 {
	text-transform: uppercase;
	font-weight: 700;
	line-height: 20px;
}
p {
	font-size: 16px;
}
p.intro {
	margin: 12px 0 0;
	line-height: 24px;
}
a {
	color: #fc0505;
}
a:hover, a:focus {
	text-decoration: none;
	color: #222;
}
ul, ol {
	list-style: none;
}
.clearfix:after {
	visibility: hidden;
	display: block;
	font-size: 0;
	content: " ";
	clear: both;
	height: 0;
}
.clearfix {
	display: inline-block;
}
* html .clearfix {
	height: 1%;
}
.clearfix {
	display: block;
}
ul, ol {
	padding: 0;
	webkit-padding: 0;
	moz-padding: 0;
}
hr {
	height: 2px;
	width: 70px;
	text-align: center;
	position: relative;
	background: #fc0505;
	margin: 0;
	margin-bottom: 40px;
	border: 0;
}
.btn:active, .btn.active {
	background-image: none;
	outline: 0;
	-webkit-box-shadow: none;
	box-shadow: none;
}
a:focus, .btn:focus, .btn:active:focus, .btn.active:focus, .btn.focus, .btn:active.focus, .btn.active.focus {
	outline: none;
	outline-offset: none;
}
/* Navigation */
#menu {
	padding: 20px;
	transition: all 0.8s;
}
#menu.navbar-default {
	background-color: rgba(248, 248, 248, 0);
	border-color: rgba(231, 231, 231, 0);
}
#menu a.navbar-brand {
	font-family: "https://fonts.googleapis.com/css?family=Roboto";
	font-size: 66px;
	color: #ffffff;
	font-weight: 700;
	letter-spacing: 2px;
}
/* Responsividad para el nombre del hotel */
@media (max-width: 768px) {
    #menu a.navbar-brand {
        font-size: 28px;
        padding-top: 15px;
    }
}
#menu.navbar-default .navbar-nav > li > a {
	text-transform: uppercase;
	color: #ddd;
	font-weight: 500;
	font-size: 15px;
	padding: 5px 0;
	border: 2px solid transparent;
	letter-spacing: 0.5px;
	margin: 10px 15px 0 15px;
}
#menu.navbar-default .navbar-nav > li > a:hover {
	color: #f80101;
}
.on {
	background-color: #262626 !important;
	padding: 0 !important;
	padding: 10px 0 !important;
}
.navbar-default .navbar-nav > .active > a, .navbar-default .navbar-nav > .active > a:hover, .navbar-default .navbar-nav > .active > a:focus {
	color: #fa0404 !important;
	background-color: transparent;
}
.navbar-toggle {
	border-radius: 0;
}
.navbar-default .navbar-toggle:hover, .navbar-default .navbar-toggle:focus {
	background-color: #ff0000;
	border-color: #a82c2c;
}
.navbar-default .navbar-toggle:hover>.icon-bar {
	background-color: #FFF;
}
.section-title {
	margin-bottom: 70px;
}
.section-title .overlay {
	padding: 80px 0;
	background: rgba(0, 0, 0, 0.7);
}
.section-title p {
	font-size: 22px;
	color: rgba(255,255,255,0.8);
}
.section-title hr {
	margin: 0 auto;
	margin-bottom: 40px;
}
.btn-custom {
	text-transform: uppercase;
	color: #fff;
	background-color: #38ee14;
	border: 0;
	padding: 14px 20px;
	margin: 0;
	font-size: 16px;
	font-weight: 500;
	letter-spacing: 0.5px;
	border-radius: 0;
	margin-top: 20px;
	transition: all 0.5s;
}
.btn-custom:hover, .btn-custom:focus, .btn-custom.focus, .btn-custom:active, .btn-custom.active {
	color: #fff;
	background-color: #038334;
}
/* Header Section */
.intro {
	display: table;
	width: 100%;
	padding: 0;
	position: relative;
    overflow: hidden;
	background-color: #000;
}

.intro-video {
    position: absolute;
    top: 50%;
    left: 50%;
    min-width: 100%;
    min-height: 100%;
    width: auto;
    height: auto;
    z-index: 0;
    transform: translate(-50%, -50%);
    object-fit: cover;
}

.intro .overlay {
	background: rgba(0,0,0,0.4);
    position: relative;
    z-index: 1;
}
.intro h1 {
	font-family: 'Remachine Script', cursive;
	color: #fff;
	font-size: 10em;
	font-weight: 700;
	margin-top: 0;
	margin-bottom: 10px;
}
.intro span {
	color: #a7c44c;
	font-weight: 600;
}
.intro p {
	color: #fff;
	font-size: 32px;
	font-weight: 300;
	margin-top: 10px;
	margin-bottom: 40px;
}
header .intro-text {
	padding-top: 250px;
	padding-bottom: 200px;
	text-align: center;
}

/* Responsividad para el Header (Intro Section) */
@media (max-width: 768px) {
    .intro h1 {
        font-size: 3.5rem; /* Reduce el tamaño de 10em en móviles */
        margin-bottom: 20px;
    }
    .intro p {
        font-size: 1.2rem; /* Reduce el subtítulo */
        margin-bottom: 30px;
    }
    header .intro-text {
        padding-top: 150px; /* Menos espacio arriba en móviles */
        padding-bottom: 100px;
    }
}
/* About Section */
#about {
	padding: 120px 0;
}
#about h3 {
	font-size: 20px;
}
#about .about-text {
	margin-left: 10px;
}
#about .about-img {
	display: inline-block;
	position: relative;
}
#about .about-img:before {
	display: block;
	content: '';
	position: absolute;
	top: 8px;
	right: 8px;
	bottom: 8px;
	left: 8px;
	border: 1px solid rgba(255, 255, 255, 0.5);
}
#about p {
	line-height: 24px;
	margin: 15px 0 30px;
}
/* Menu Section */
#restaurant-menu {
	padding: 0 0 60px 0;
}
#restaurant-menu .section-title {
	background: #444 url(../img/menu-bg.jpg) center center no-repeat fixed;
	background-size: cover;
}
#restaurant-menu .section-title h2 {
	color: #fff;
}
#restaurant-menu img {
	width: 300px;
	box-shadow: 15px 0 #a7c44c;
}
#restaurant-menu h3 {
	padding: 10px 0;
	text-transform: uppercase;
}
#restaurant-menu .menu-section hr {
	margin: 0 auto;
}
#restaurant-menu .menu-section {
	margin: 0 20px 80px;
}
#restaurant-menu .menu-section-title {
	font-size: 26px;
	display: block;
	font-weight: 500;
	color: #444;
	margin: 20px 0;
	text-align: center;
}
#restaurant-menu .menu-item {
	margin: 35px 0;
	font-size: 18px;
}
#restaurant-menu .menu-item-name {
	font-weight: 600;
	font-size: 17px;
	color: #555;
	border-bottom: 2px dotted rgb(213, 213, 213);
}
#restaurant-menu .menu-item-description {
	font-style: italic;
	font-size: 15px;
}
#restaurant-menu .menu-item-price {
	float: right;
	font-weight: 600;
	color: #555;
	margin-top: -26px;
}

/* Menu habitaciones */

#habitaciones-menu {
	padding: 0 0 60px 0;
}
#habitaciones-menu .section-title {
	background: #444 url(../img/habi.jpg) center center no-repeat fixed;
	background-size: cover;
}
#habitaciones-menu .section-title h2 {
	color: #fff;
}
#habitaciones-menu img {
	width: 300px;
	box-shadow: 15px 0 #a7c44c;
}
#habitaciones-menu h3 {
	padding: 10px 0;
	text-transform: uppercase;
}
#habitaciones-menu .menu-section hr {
	margin: 0 auto;
}
#habitaciones-menu .menu-section {
	margin: 0 20px 80px;
}
#habitaciones-menu .menu-section-title {
	font-size: 26px;
	display: block;
	font-weight: 500;
	color: #444;
	margin: 20px 0;
	text-align: center;
}
#habitaciones-menu .menu-item {
	margin: 35px 0;
	font-size: 18px;
}
#habitaciones-menu .menu-item-name {
	font-weight: 600;
	font-size: 17px;
	color: #555;
	border-bottom: 2px dotted rgb(213, 213, 213);
}
#habitaciones-menu .menu-item-description {
	font-style: italic;
	font-size: 15px;
}
#habitaciones-menu .menu-item-price {
	float: right;
	font-weight: 600;
	color: #555;
	margin-top: -26px;






}
/* Portfolio Section */
#portfolio {
	padding: 0 0 120px 0;
}
#portfolio .section-title {
	background: #444 url(../img/gallery-bg.jpg) center center no-repeat fixed;
	background-size: cover;
	margin-bottom: 50px;
}
#portfolio .section-title h2 {
	color: #fff;
}
.categories {
	padding-bottom: 30px;
	text-align: center;
}
ul.cat li {
	display: inline-block;
}
ol.type li {
	display: inline-block;
	margin: 0 10px;
	padding: 20px 0;
}
ol.type li a {
	color: #999;
	font-weight: 500;
	font-size: 14px;
	padding: 12px 24px;
	background: #eee;
	border: 0;
	border-radius: 0;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}
ol.type li a.active {
	color: #fff;
	background-color: #ff0404;
}
ol.type li a:hover {
	color: #fff;
	background-color: #ff0404;
}
.isotope-item {
	z-index: 2
}
.isotope-hidden.isotope-item {
	z-index: 1
}
.isotope, .isotope .isotope-item {
	/* change duration value to whatever you like */
	-webkit-transition-duration: 0.8s;
	-moz-transition-duration: 0.8s;
	transition-duration: 0.8s;
}
.isotope-item {
	margin-right: -1px;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
}
.isotope {
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	-webkit-transition-property: height, width;
	-moz-transition-property: height, width;
	transition-property: height, width;
}
.isotope .isotope-item {
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	-webkit-transition-property: -webkit-transform, opacity;
	-moz-transition-property: -moz-transform, opacity;
	transition-property: transform, opacity;
}
.portfolio-item {
	margin: 15px 0;
}
.portfolio-item .hover-bg {
	overflow: hidden;
	position: relative;
}
.portfolio-item .hover-bg:before {
	display: block;
	content: '';
	position: absolute;
	top: 6px;
	right: 6px;
	bottom: 6px;
	left: 6px;
	border: 1px solid rgba(255, 255, 255, 0.6);
}
.hover-bg .hover-text {
	position: absolute;
	text-align: center;
	margin: 0 auto;
	color: #fff;
	background: rgba(0, 0, 0, 0.6);
	padding: 30% 0 0 0;
	height: 100%;
	width: 100%;
	opacity: 0;
	transition: all 0.5s;
}
.hover-bg .hover-text>h4 {
	opacity: 0;
	color: #fff;
	-webkit-transform: translateY(100%);
	transform: translateY(100%);
	transition: all 0.3s;
	font-size: 17px;
	letter-spacing: 0.5px;
	font-weight: 500;
}
.hover-bg:hover .hover-text>h4 {
	opacity: 1;
	-webkit-backface-visibility: hidden;
	-webkit-transform: translateY(0);
	transform: translateY(0);
}
.hover-bg:hover .hover-text {
	opacity: 1;
}
/* Menu Section responsivo */
#restaurant-menu .container .row {
    display: flex;
    flex-wrap: wrap;
    gap: 40px;
}

#restaurant-menu .col-sm-6 {
    flex: 1 1 100%; /* Una columna en móvil */
}

/* Equipo / Bar Section responsivo */
#team #row {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 20px;
}

#team .col-md-4 {
    flex: 1 1 300px; /* Tamaño base de 300px, crece si hay espacio */
    max-width: 400px;
}

@media (min-width: 769px) {
    #restaurant-menu .col-sm-6 {
        flex: 1 1 calc(50% - 40px); /* Dos columnas en tablets/desktop */
    }
}

/* Modal responsivo mejorado */
@media (max-width: 600px) {
    .modal-content-res {
        padding: 20px 15px;
        width: 95%;
    }
    .reservation-form .row {
        display: block;
    }
    .reservation-form .col-md-6 {
        width: 100%;
        margin-bottom: 10px;
    }
}

/* --- SECCIÓN TEAM PREMIUM --- */
#team {
    color: #fff;
    background: #444 url(../img/team-bg.jpg) center top no-repeat fixed;
    background-size: cover;
}

#team .overlay {
    padding: 120px 0 80px 0;
    background: rgba(0, 0, 0, 0.6);
}

#team .container {
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 15px !important;
}

.team-grid {
    margin-top: 50px;
}

.team-card {
    position: relative;
    height: 550px; /* Tarjetas más largas */
    margin-bottom: 30px;
    border-radius: 15px;
    overflow: hidden;
    box-shadow: 0 10px 30px rgba(0,0,0,0.3);
    cursor: pointer;
    background-color: #111;
    transition: transform 0.4s ease;
}

.team-img-bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
    transition: transform 0.5s ease;
    z-index: 1;
}

.team-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.8); /* 80% opacidad inicial */
    transition: opacity 0.5s ease;
    z-index: 2;
}

.team-content {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 90%;
    text-align: center;
    color: #ffffff;
    z-index: 3;
    transition: all 0.4s ease;
}

.team-content h3 {
    color: #ffffff;
    font-size: 24px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 2px;
    margin-bottom: 20px;
    text-shadow: 0 2px 10px rgba(0,0,0,0.5);
}

.team-btn {
    display: inline-block;
    padding: 10px 25px;
    border: 2px solid #ffffff;
    color: #ffffff;
    text-transform: uppercase;
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 1px;
    text-decoration: none;
    background: rgba(255, 255, 255, 0.1);
    backdrop-filter: blur(5px);
    border-radius: 5px;
    transition: all 0.3s ease;
}

.team-btn:hover {
    background: #ffffff;
    color: #111;
    transform: scale(1.05);
}

/* Efectos HOVER */
.team-card:hover .team-img-bg {
    transform: scale(1.2); /* Zoom suave */
}

.team-card:hover .team-overlay {
    opacity: 0; /* Imagen totalmente clara */
}

.team-card:hover {
    box-shadow: 0 15px 45px rgba(0,0,0,0.5);
}

/* Responsive Grid para Team */
@media (max-width: 991px) {
    .team-card {
        height: 350px;
    }
}

@media (max-width: 768px) {
    .team-card {
        height: 400px;
    }
}

/* Call Reservation Section */
#call-reservation {
	padding: 90px 0;
	color: #fff;
	/* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#8eb640+50,779936+100 */
	background: #ff0404; /* Old browsers */
	background: #ff0404
 /* IE6-9 */
}
#call-reservation .overlay {
	padding: 80px 0;
	background: #ff0404;
}
#call-reservation h2 {
	font-family: 'Open Sans', sans-serif;
	color: #fff;
	font-weight: 400;
	margin: 0;
}
#call-reservation hr {
	background: #fff;
}
#call-reservation h3 {
	color: #fff;
	font-weight: 500;
	font-size: 20px;
	margin: 5px 0;
}

/* Responsividad para Call Reservation */
@media (max-width: 768px) {
    #call-reservation {
        padding: 40px 0;
    }
    #call-reservation h2 {
        font-size: 20px; /* Título más pequeño */
        line-height: 1.4;
    }
    #call-reservation iframe {
        width: 100% !important; /* Mapa al 100% del ancho */
        height: 300px !important; /* Altura ajustada */
        max-width: 100%;
    }
}
/* Contact Section */
#contact {
	padding: 100px 0 60px 0;
	background: #F6F6F6;
}
#contact .section-title p {
	color: #777;
}
#contact form {
	padding: 0;
}
#contact h3 {
	text-transform: uppercase;
	font-size: 20px;
	font-weight: 400;
	color: #555;
}
#contact .text-danger {
	color: #cc0033;
	text-align: left;
}
label {
	font-size: 12px;
	font-weight: 400;
	font-family: 'Open Sans', sans-serif;
	float: left;
}
#contact .form-control {
	display: block;
	width: 100%;
	padding: 6px 12px;
	font-size: 16px;
	line-height: 1.42857143;
	color: #444;
	background-color: #fff;
	background-image: none;
	border: 1px solid #ddd;
	border-radius: 0;
	-webkit-box-shadow: none;
	box-shadow: none;
	-webkit-transition: none;
	-o-transition: none;
	transition: none;
}
#contact .form-control:focus {
	border-color: #999;
	outline: 0;
	-webkit-box-shadow: transparent;
	box-shadow: transparent;
}
.form-control::-webkit-input-placeholder {
color: #777;
}
.form-control:-moz-placeholder {
color: #777;
}
.form-control::-moz-placeholder {
color: #777;
}
.form-control:-ms-input-placeholder {
color: #777;
}
#contact .contact-item {
	margin: 20px 0 40px 0;
}
#contact .contact-item span {
	font-weight: 400;
	color: #aaa;
	text-transform: uppercase;
	margin-bottom: 6px;
	display: inline-block;
}
#contact .contact-item p {
	font-size: 16px;
}
/* Footer Section*/
#footer {
	background: #262626;
	padding: 50px 0 0 0;
}
#footer h3 {
	color: #ff0404;
	font-weight: 400;
	font-size: 18px;
	text-transform: uppercase;
	margin-bottom: 20px;
}
#footer .copyrights {
	padding: 20px 0;
	margin-top: 50px;
	/* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#779936+0,8eb640+50 */
	background: #ff0404; /* Old browsers */
	
}
#footer .social {
	margin: 20px 0 30px 0;
}
#footer .social ul li {
	display: inline-block;
	margin: 0 20px;
}
#footer .social i.fa {
	font-size: 26px;
	padding: 4px;
	color: #fff;
	transition: all 0.3s;
}
#footer .social i.fa:hover {
	color: #eee;
}
#footer p {
	font-size: 15px;
	color: rgba(255,255,255,0.8)
}
#footer a {
	color: #f6f6f6;
}
#footer a:hover {
	color: #333;
}

/* Modal de Reserva */
.modal-overlay {
    display: none;
    position: fixed;
    z-index: 10000;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0,0,0,0.8);
    backdrop-filter: blur(4px);
    display: none; /* Se cambia a flex con la clase .show */
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity 0.4s ease;
    overflow-y: auto; /* Permitir scroll si el contenido es largo */
    padding: 20px;
}

.modal-overlay.show {
    display: flex;
    opacity: 1;
}

.modal-content-res {
    background-color: #fff;
    padding: 30px;
    border-radius: 12px;
    width: 100%;
    max-width: 500px;
    margin: auto; /* Ayuda al centrado vertical si el contenido crece */
    position: relative;
    transform: scale(0.7);
    transition: transform 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    box-shadow: 0 10px 30px rgba(0,0,0,0.5);
}

.modal-overlay.show .modal-content-res {
    transform: scale(1);
}

.modal-header-res {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 25px;
    border-bottom: 2px solid #ff0404;
    padding-bottom: 10px;
}

.modal-header-res h2 {
    margin: 0;
    font-size: 24px;
    color: #333;
    text-transform: none;
}

.close-modal-res {
    background: none;
    border: none;
    font-size: 32px;
    cursor: pointer;
    color: #999;
    line-height: 1;
}

.close-modal-res:hover {
    color: #ff0404;
}

.reservation-form .form-group-res {
    margin-bottom: 15px;
}

.reservation-form label {
    display: block;
    margin-bottom: 5px;
    font-weight: 600;
    color: #444;
    font-size: 14px;
    float: none;
}

.reservation-form .form-control-res {
    width: 100%;
    padding: 12px;
    border: 1px solid #ddd;
    border-radius: 6px;
    font-size: 15px;
    color: #333;
    transition: border-color 0.3s;
}

.reservation-form .form-control-res:focus {
    border-color: #04ff75;
    outline: none;
}
/*RESERVA MODAL DIRECTO*/
.reservation-form .btn-submit-res {
    width: 100%;
    padding: 15px;
    background-color: #ff0404;
    color: #fff;
    border: none;
    border-radius: 6px;
    font-size: 18px;
    font-weight: 700;
    cursor: pointer;
    transition: background-color 0.3s, transform 0.2s;
    margin-top: 15px;
    text-transform: uppercase;
}

.reservation-form .btn-submit-res:hover {
    background-color: #d60303;
    transform: translateY(-2px);
}

.reservation-form .btn-submit-res:active {
    transform: translateY(0);
}

@media (max-width: 480px) {
    .modal-content-res {
        padding: 20px;
    }
    .modal-header-res h2 {
        font-size: 20px;
    }
}

/* WhatsApp Floating Button */
.whatsapp-float {
    position: fixed;
    width: 60px;
    height: 60px;
    bottom: 40px;
    right: 40px;
    background-color: #25d366;
    color: #FFF;
    border-radius: 50px;
    text-align: center;
    font-size: 30px;
    box-shadow: 2px 2px 3px rgba(0,0,0,0.3);
    z-index: 10000;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none !important;
}

.whatsapp-float:hover {
    background-color: #128c7e;
    transform: scale(1.1);
    box-shadow: 2px 2px 10px rgba(0,0,0,0.4);
    color: #FFF;
}

.my-float {
    margin-top: 0;
}

/* Responsividad para móviles */
/* --- GALERÍA PREMIUM INTERACTIVA (FULL WIDTH) --- */
#portfolio {
    padding: 80px 0;
    background-color: #ffffff;
}

#portfolio .container {
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 !important; /* Elimina espacio lateral del contenedor */
}

/* Ajuste Isotope Grid para Full Width */
.portfolio-items {
    width: 100%;
}

.premium-item {
    padding: 8px; /* Pequeña separación entre imágenes */
    transition: all 0.5s ease;
}

.premium-card {
    position: relative;
    width: 100%;
    border-radius: 15px; /* Esquinas redondeadas */
    overflow: hidden;
    cursor: pointer;
    background-color: #111;
}

.premium-card::before {
    content: "";
    display: block;
    padding-top: 120%; /* Proporción 1:1.2 (Altura proporcional al ancho) */
}

/* Imagen de fondo con Zoom */
.premium-img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
    transition: transform 0.6s cubic-bezier(0.165, 0.84, 0.44, 1);
    z-index: 1;
}

/* Overlay oscuro 80% */
.premium-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.8);
    transition: opacity 0.5s ease;
    z-index: 2;
}

/* Contenido del Texto */
.premium-content {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 90%;
    text-align: center;
    color: #ffffff;
    z-index: 3;
    pointer-events: none;
}

.premium-content h4 {
    color: #ffffff;
    font-size: 24px; /* Texto más grande */
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 3px;
    margin-bottom: 25px;
    text-shadow: 0 4px 15px rgba(0,0,0,0.6);
}

.premium-btn-view {
    display: inline-block;
    padding: 12px 30px;
    border: 2px solid #ffffff;
    color: #ffffff;
    text-transform: uppercase;
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 2px;
    border-radius: 0; /* Botón cuadrado para encajar con el estilo mosaico */
    background: rgba(255,255,255,0.05);
    backdrop-filter: blur(8px);
    pointer-events: auto;
    transition: all 0.3s ease;
}

.premium-btn-view:hover {
    background: #ffffff;
    color: #111;
    text-decoration: none;
    transform: scale(1.05);
}

/* HOVER EFFECTS */
.premium-card:hover .premium-img {
    transform: scale(1.15); /* Zoom elegante */
}

.premium-card:hover .premium-overlay {
    opacity: 0; /* Imagen totalmente clara */
}

/* Responsive Grid */
@media (max-width: 1200px) {
    /* Eliminadas alturas fijas para usar aspect-ratio */
}

@media (max-width: 768px) {
    /* Eliminadas alturas fijas para usar aspect-ratio */
}

/* --- SECCIÓN GALERÍA DE HABITACIONES PREMIUM --- */
#habitaciones-galeria {
    padding: 100px 0;
    background-color: #f9f9f9;
}

#habitaciones-galeria .container {
    width: 90% !important; /* Ocupa el 90% del ancho */
    max-width: 1800px !important; /* Límite para pantallas ultra-anchas */
}

.rooms-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr); /* 4 columnas en escritorio */
    gap: 25px;
}

.room-card {
    position: relative;
    height: 550px; /* Tamaño mucho más grande */
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 15px 40px rgba(0,0,0,0.15);
    cursor: pointer;
    transition: transform 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.room-card:hover {
    transform: translateY(-10px);
    box-shadow: 0 25px 50px rgba(0,0,0,0.25);
}

.room-img-container {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
}

.room-img-bg {
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
    transition: transform 0.6s ease;
}

/* Overlay oscuro 80% transparencia por defecto */
.room-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.8);
    transition: background 0.5s ease;
    z-index: 2;
}

.room-info {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    text-align: center;
    color: #ffffff;
    z-index: 3;
    padding: 20px;
}

.room-info h3 {
    color: #ffffff;
    font-size: 32px; /* Títulos más grandes para tarjetas más grandes */
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 4px;
    margin-bottom: 25px;
    text-shadow: 0 4px 15px rgba(0,0,0,0.6);
}

.room-btn {
    display: inline-block;
    padding: 14px 35px;
    border: 2px solid #ffffff;
    color: #ffffff;
    text-transform: uppercase;
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 2px;
    text-decoration: none;
    transition: all 0.3s ease;
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.05);
    backdrop-filter: blur(5px);
}

.room-btn:hover {
    background-color: #ffffff;
    color: #222222;
    text-decoration: none;
    transform: scale(1.05);
}

/* Efectos HOVER */
.room-card:hover .room-img-bg {
    transform: scale(1.25); /* Zoom más pronunciado */
}

.room-card:hover .room-overlay {
    background: rgba(0, 0, 0, 0.1); /* Ligerísimo velo para mantener legibilidad */
}

@media (max-width: 1400px) {
    .room-info h3 {
        font-size: 26px;
    }
}

@media (max-width: 1200px) {
    .rooms-grid {
        grid-template-columns: repeat(2, 1fr); /* 2 columnas en tablets */
    }
    .room-card {
        height: 500px;
    }
}

@media (max-width: 768px) {
    #habitaciones-galeria .container {
        width: 95% !important;
    }
    .room-card {
        height: 450px;
    }
}

@media (max-width: 480px) {
    .rooms-grid {
        grid-template-columns: 1fr; /* 1 columna en móviles */
    }
}
