/* ==========================================================
   Hotel María Gloria — Liquid Glass Blue Edition
   PHP puro + Bootstrap friendly
   ========================================================== */
:root{
  --hm-primary:#082C6C;
  --hm-primary-2:#0B3D91;
  --hm-navy:#061A3A;
  --hm-sky:#EAF2FF;
  --hm-sky-2:#F5F8FC;
  --hm-white:#FFFFFF;
  --hm-text:#13233A;
  --hm-muted:#64748B;
  --hm-line:rgba(8,44,108,.12);
  --hm-glass:rgba(255,255,255,.72);
  --hm-glass-strong:rgba(255,255,255,.90);
  --hm-shadow:0 22px 70px rgba(8,44,108,.16);
  --hm-shadow-soft:0 14px 38px rgba(15,23,42,.10);
  --hm-radius:28px;
  --hm-radius-sm:18px;
  --hm-transition:all .28s cubic-bezier(.2,.8,.2,1);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:-apple-system,BlinkMacSystemFont,"SF Pro Display","Segoe UI",Roboto,Arial,sans-serif;
  background:radial-gradient(circle at top left,#eef5ff 0,#fff 34%,#f7f9fc 100%);
  color:var(--hm-text);
  line-height:1.65;
  overflow-x:hidden;
}
body::before{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(circle at 12% 18%,rgba(8,44,108,.10),transparent 26%),
    radial-gradient(circle at 88% 8%,rgba(11,61,145,.12),transparent 22%),
    linear-gradient(180deg,rgba(255,255,255,.1),rgba(234,242,255,.35));
}
a{color:inherit} img{max-width:100%;display:block}.container{position:relative}.text-muted{color:var(--hm-muted)!important}

/* Header */
header nav{
  position:fixed;top:14px;left:50%;transform:translateX(-50%);width:min(1180px,calc(100% - 28px));height:72px;z-index:999;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:.65rem .85rem .65rem 1.1rem;
  background:rgba(255,255,255,.78);border:1px solid rgba(255,255,255,.78);border-bottom-color:rgba(8,44,108,.10);
  box-shadow:0 18px 60px rgba(8,44,108,.16);backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px);
  border-radius:999px;
}
.logo-wrap{display:flex;align-items:center;text-decoration:none}.logo-wrap img{height:48px;width:auto;object-fit:contain}.nav-links{display:flex;align-items:center;gap:.35rem;list-style:none;margin:0;padding:0}.nav-links a{
  display:flex;align-items:center;gap:.45rem;text-decoration:none;color:#17345E;font-weight:700;font-size:.92rem;padding:.72rem .88rem;border-radius:999px;transition:var(--hm-transition);white-space:nowrap;
}.nav-links a:hover,.nav-links a.active{background:rgba(8,44,108,.08);color:var(--hm-primary)}
.nav-links a[href*="carrito"]{background:linear-gradient(135deg,var(--hm-primary),var(--hm-primary-2));color:#fff;box-shadow:0 12px 28px rgba(8,44,108,.24)}
.nav-links a[href*="carrito"]:hover{transform:translateY(-1px);box-shadow:0 16px 36px rgba(8,44,108,.30)}
.cart-count{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 6px;border-radius:999px;background:#fff;color:var(--hm-primary);font-size:.72rem;font-weight:900}.menu-toggle{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:12px;border-radius:999px;background:rgba(8,44,108,.06)}.menu-toggle span{height:2px;width:24px;background:var(--hm-primary);border-radius:4px}
main{padding-top:0}.page-offset{height:92px}
@media(max-width:1080px){.nav-links{position:absolute;top:82px;right:0;width:min(390px,calc(100vw - 28px));display:none;flex-direction:column;align-items:stretch;padding:1rem;background:rgba(255,255,255,.92);border:1px solid rgba(8,44,108,.10);box-shadow:var(--hm-shadow);border-radius:26px;backdrop-filter:blur(22px)}.nav-links.show{display:flex}.nav-links a{justify-content:space-between;padding:1rem}.menu-toggle{display:flex}.logo-wrap img{height:44px}}
@media(max-width:640px){header nav{top:10px;height:66px;width:calc(100% - 20px)}.logo-wrap img{height:40px}.menu-text{display:inline}.page-offset{height:82px}}

/* Hero */
.hero{position:relative;min-height:78vh;display:flex;align-items:flex-end;overflow:hidden;margin:0;border-bottom-left-radius:48px;border-bottom-right-radius:48px;background-image:linear-gradient(180deg,rgba(6,26,58,.12),rgba(6,26,58,.52)),url('/assets/img/hero-1600.webp');background-size:cover;background-position:center 85%;box-shadow:0 28px 70px rgba(8,44,108,.20)}
.hero::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 22%,rgba(255,255,255,.08),transparent 34%),linear-gradient(90deg,rgba(8,44,108,.58),rgba(8,44,108,.10) 48%,rgba(6,26,58,.32));}
.hero-content{position:relative;z-index:2;width:min(1180px,calc(100% - 32px));margin:0 auto 120px;color:#fff}.hero-kicker{display:inline-flex;align-items:center;gap:.5rem;padding:.45rem .75rem;border:1px solid rgba(255,255,255,.34);background:rgba(255,255,255,.16);border-radius:999px;backdrop-filter:blur(14px);font-weight:700}.hero-title{font-size:clamp(2.4rem,6vw,5.7rem);line-height:.98;font-weight:850;letter-spacing:-.06em;max-width:860px;margin:1rem 0;text-shadow:0 18px 55px rgba(0,0,0,.28)}.hero-subtitle{font-size:clamp(1rem,1.5vw,1.25rem);max-width:680px;color:rgba(255,255,255,.88);margin:0}.hero-actions{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:1.4rem}.hero-mini{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;max-width:720px;margin-top:1.4rem}.hero-mini div{padding:.95rem;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.24);border-radius:20px;backdrop-filter:blur(16px)}.hero-mini strong{display:block;font-size:1.1rem}.hero-mini span{font-size:.85rem;color:rgba(255,255,255,.82)}
@media(max-width:768px){.hero{min-height:72vh;border-bottom-left-radius:30px;border-bottom-right-radius:30px;background-image:linear-gradient(180deg,rgba(6,26,58,.18),rgba(6,26,58,.58)),url('/assets/img/hero-768.webp')}.hero-content{margin-bottom:170px}.hero-mini{grid-template-columns:1fr}.hero-mini div{padding:.75rem}.hero-title{letter-spacing:-.04em}}

/* Booking glass bar */
.reservation-form{position:absolute;z-index:3;left:50%;bottom:24px;transform:translateX(-50%);width:min(1120px,calc(100% - 28px));display:grid;grid-template-columns:1.1fr 1.1fr .9fr .9fr auto;gap:.8rem;align-items:end;padding:1rem;background:rgba(255,255,255,.82);border:1px solid rgba(255,255,255,.82);box-shadow:0 24px 70px rgba(8,44,108,.20);border-radius:28px;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px)}
.form-group label,.booking-field label{display:block;font-size:.78rem;color:var(--hm-muted);font-weight:800;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.35rem}.reservation-form input,.reservation-form select,.booking-field input,.booking-field select,.booking-field textarea,.form-control{width:100%;border:1px solid rgba(8,44,108,.14)!important;background:rgba(255,255,255,.92)!important;border-radius:16px!important;padding:.86rem 1rem!important;min-height:48px;color:var(--hm-text);box-shadow:inset 0 1px 0 rgba(255,255,255,.9);outline:none;transition:var(--hm-transition)}.reservation-form input:focus,.booking-field input:focus,.booking-field select:focus,.booking-field textarea:focus,.form-control:focus{border-color:rgba(8,44,108,.35)!important;box-shadow:0 0 0 4px rgba(8,44,108,.08)!important}.btn-reserve,.btn,.btn-primary,.btn-hm{border:0!important;border-radius:999px!important;background:linear-gradient(135deg,var(--hm-primary),var(--hm-primary-2))!important;color:#fff!important;font-weight:800;padding:.9rem 1.35rem!important;min-height:48px;text-decoration:none!important;box-shadow:0 14px 34px rgba(8,44,108,.26);transition:var(--hm-transition);display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.btn-reserve:hover,.btn:hover,.btn-primary:hover,.btn-hm:hover{transform:translateY(-2px);box-shadow:0 20px 44px rgba(8,44,108,.32);color:#fff!important}.btn-ghost{background:rgba(255,255,255,.82)!important;color:var(--hm-primary)!important;border:1px solid rgba(8,44,108,.12)!important;box-shadow:var(--hm-shadow-soft)}
@media(max-width:900px){.reservation-form{grid-template-columns:1fr 1fr;bottom:18px}.reservation-form .btn-reserve{grid-column:1/-1}}@media(max-width:560px){.reservation-form{grid-template-columns:1fr;border-radius:24px}.hero-content{margin-bottom:310px}}

/* Sections */
section{position:relative}.hm-section{padding:92px 0}.bg-white{background:transparent!important}.bg-light{background:rgba(234,242,255,.42)!important}.section-eyebrow{display:inline-flex;align-items:center;gap:.5rem;padding:.42rem .75rem;background:rgba(8,44,108,.08);color:var(--hm-primary);font-size:.8rem;font-weight:900;text-transform:uppercase;letter-spacing:.08em;border-radius:999px}.section-title{font-size:clamp(2rem,3vw,3.25rem);font-weight:850;line-height:1.04;letter-spacing:-.045em;color:var(--hm-navy);margin:0 0 1rem}.section-title::after{display:none}.section-copy{font-size:1.05rem;color:var(--hm-muted);max-width:760px}.glass-panel,.cart-shell,.hotel-soft-section .container>.row,.admin-like-card{background:var(--hm-glass);border:1px solid rgba(255,255,255,.72);box-shadow:var(--hm-shadow-soft);border-radius:var(--hm-radius);backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px)}.hotel-soft-section .container>.row{padding:1.1rem}.img-ajustada{width:100%;border-radius:var(--hm-radius);box-shadow:var(--hm-shadow-soft);object-fit:cover}.justificado{text-align:justify}.alert-soft{background:rgba(234,242,255,.8);border:1px solid rgba(8,44,108,.12);border-radius:18px;padding:1rem;color:#17345E}.cart-badge,.hm-pill{display:inline-flex;align-items:center;gap:.5rem;border-radius:999px;background:rgba(8,44,108,.08);color:var(--hm-primary);font-weight:800;padding:.42rem .75rem;font-size:.86rem}.hm-divider{height:1px;background:linear-gradient(90deg,transparent,rgba(8,44,108,.16),transparent);margin:1.1rem 0}

/* Room cards */
.room-card,.room-detail-card,.cart-room{border:1px solid rgba(8,44,108,.10)!important;background:rgba(255,255,255,.82)!important;border-radius:28px!important;overflow:hidden;box-shadow:var(--hm-shadow-soft);transition:var(--hm-transition);height:100%;backdrop-filter:blur(16px)}.room-card:hover,.room-detail-card:hover,.cart-room:hover{transform:translateY(-6px);box-shadow:var(--hm-shadow)}.room-card img,.room-detail-card img,.cart-room img{width:100%;height:245px;object-fit:cover}.room-card .card-body,.room-detail-card .card-body{padding:1.35rem}.card-title,.room-detail-card h2{font-weight:850;color:var(--hm-navy);letter-spacing:-.025em}.price,.room-price{color:var(--hm-primary);font-weight:900}.price span{display:block;font-size:1.25rem}.features-list{list-style:none;margin:0;padding:0;display:grid;gap:.45rem}.features-list li{display:flex;align-items:center;gap:.55rem;color:#244363}.features-list i{color:var(--hm-primary)}

/* Gallery */
.gallery-wrapper{background:rgba(255,255,255,.64);border:1px solid rgba(255,255,255,.7);border-radius:30px;padding:1rem;box-shadow:var(--hm-shadow-soft);backdrop-filter:blur(18px)}.gallery-container{gap:1rem;scroll-snap-type:x mandatory;scrollbar-width:none}.gallery-container::-webkit-scrollbar{display:none}.gallery-container a{flex:0 0 310px;scroll-snap-align:start;position:relative;overflow:hidden;border-radius:24px;box-shadow:0 14px 32px rgba(8,44,108,.12)}.gallery-container img{width:100%;height:230px;object-fit:cover;transition:transform .45s ease}.gallery-container a:hover img{transform:scale(1.05)}.gallery-control{position:absolute;z-index:5;top:50%;transform:translateY(-50%);width:46px;height:46px;border:0;border-radius:999px;background:rgba(255,255,255,.88);color:var(--hm-primary);box-shadow:var(--hm-shadow-soft);font-size:1.3rem}.gallery-control.left{left:20px}.gallery-control.right{right:20px}

/* Cart pro */
.booking-page{padding:116px 0 80px}.booking-layout{display:grid;grid-template-columns:minmax(0,1fr) 420px;gap:1.2rem;align-items:start}.booking-card{background:rgba(255,255,255,.82);border:1px solid rgba(255,255,255,.82);border-radius:30px;box-shadow:var(--hm-shadow-soft);backdrop-filter:blur(20px);overflow:hidden}.booking-card-header{padding:1.2rem 1.25rem;border-bottom:1px solid var(--hm-line);display:flex;align-items:center;justify-content:space-between;gap:1rem}.booking-card-body{padding:1.25rem}.room-select-card{display:grid;grid-template-columns:190px 1fr;gap:1rem;padding:1rem;border:1px solid rgba(8,44,108,.10);border-radius:26px;background:rgba(255,255,255,.72);margin-bottom:1rem;transition:var(--hm-transition)}.room-select-card.selected{border-color:rgba(8,44,108,.34);box-shadow:0 16px 40px rgba(8,44,108,.12);background:#fff}.room-select-card img{height:170px;width:100%;object-fit:cover;border-radius:22px}.room-grid-content{display:grid;grid-template-columns:1fr auto;gap:1rem}.room-controls{display:grid;grid-template-columns:repeat(3,104px);gap:.65rem;align-content:start}.stepper{display:flex;align-items:center;justify-content:space-between;gap:.35rem;background:#fff;border:1px solid rgba(8,44,108,.12);border-radius:999px;padding:.28rem}.stepper button{width:32px;height:32px;border:0;border-radius:999px;background:rgba(8,44,108,.08);color:var(--hm-primary);font-weight:900}.stepper input{width:36px;border:0;text-align:center;font-weight:900;color:var(--hm-primary);background:transparent}.mini-label{display:block;font-size:.72rem;font-weight:900;color:var(--hm-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.28rem}.booking-summary{position:sticky;top:104px}.summary-line{display:flex;justify-content:space-between;gap:1rem;padding:.68rem 0;border-bottom:1px solid rgba(8,44,108,.09)}.summary-line:last-child{border-bottom:0}.summary-total{font-size:1.8rem;font-weight:950;color:var(--hm-primary);letter-spacing:-.04em}.empty-cart-note{border:1px dashed rgba(8,44,108,.22);background:rgba(234,242,255,.55);border-radius:22px;padding:1rem;color:#244363}.secure-note{display:flex;gap:.7rem;align-items:flex-start;background:rgba(234,242,255,.7);border:1px solid rgba(8,44,108,.10);border-radius:20px;padding:.85rem;color:#244363;font-size:.92rem}.checkout-form{display:grid;gap:.8rem}.checkout-form .row-fields{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}.room-line-total{font-weight:950;color:var(--hm-primary);font-size:1.08rem;text-align:right}.admin-link-soft{font-size:.84rem;color:var(--hm-muted)}
@media(max-width:1080px){.booking-layout{grid-template-columns:1fr}.booking-summary{position:relative;top:auto}.room-grid-content{grid-template-columns:1fr}.room-controls{grid-template-columns:repeat(3,1fr)}}@media(max-width:680px){.booking-page{padding-top:96px}.room-select-card{grid-template-columns:1fr}.room-select-card img{height:210px}.room-controls{grid-template-columns:1fr}.checkout-form .row-fields{grid-template-columns:1fr}}

/* Footer / floating */
footer{background:linear-gradient(135deg,var(--hm-navy),var(--hm-primary));color:#fff;margin-top:0;border-top-left-radius:34px;border-top-right-radius:34px}footer a{color:#fff;text-decoration:none}.footer-inner{padding:3rem 0}.whatsapp-float{position:fixed;right:20px;bottom:20px;z-index:997;width:58px;height:58px;border-radius:999px;background:#22c55e;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 18px 38px rgba(34,197,94,.32);text-decoration:none;font-size:1.6rem}.whatsapp-float:hover{color:#fff;transform:translateY(-2px)}

/* Utility */
.rounded{border-radius:22px!important}iframe{border:0;min-height:360px}.f-hotel{border-radius:28px;background:rgba(255,255,255,.8);overflow:hidden;box-shadow:var(--hm-shadow-soft);border:1px solid rgba(8,44,108,.1)}.f-hotel .image{height:270px;background-size:cover;background-position:center}.desc h3{color:var(--hm-navy);font-weight:850}.contact-info li{margin-bottom:.7rem;color:#244363}.badge.bg-success{background:rgba(22,163,74,.12)!important;color:#15803d!important;border:1px solid rgba(22,163,74,.18);border-radius:999px;padding:.45rem .65rem}

/* ==========================================================
   V4 Ajuste visual: header más fino + reserva compacta sticky
   ========================================================== */
header nav{
  top:18px;
  width:min(1120px,calc(100% - 44px));
  height:60px;
  padding:.42rem .58rem .42rem .9rem;
  border-radius:30px;
  background:rgba(255,255,255,.84);
  box-shadow:0 14px 42px rgba(8,44,108,.14);
}
.logo-wrap img{height:38px;max-width:140px;object-fit:contain}
.nav-links{gap:.12rem}
.nav-links a{
  font-size:.82rem;
  padding:.55rem .64rem;
  font-weight:800;
  letter-spacing:-.01em;
}
.nav-links a[href*="carrito"]{
  padding:.62rem .82rem;
  box-shadow:0 10px 22px rgba(8,44,108,.22);
}
.cart-count{min-width:19px;height:19px;font-size:.66rem}

.hero{
  min-height:720px;
  border-bottom-left-radius:40px;
  border-bottom-right-radius:40px;
}
.hero-content{
  width:min(1120px,calc(100% - 44px));
  margin:0 auto 118px;
}
.hero-title{
  font-size:clamp(2.35rem,4.75vw,4.75rem);
  max-width:760px;
  letter-spacing:-.055em;
}
.hero-subtitle{max-width:640px;font-size:clamp(.98rem,1.25vw,1.15rem)}
.hero-actions{margin-top:1.05rem}
.hero-mini{max-width:660px;gap:.6rem;margin-top:1rem}
.hero-mini div{padding:.72rem .85rem;border-radius:17px}
.hero-mini strong{font-size:1rem}.hero-mini span{font-size:.8rem}

.reservation-form{
  bottom:22px;
  width:min(980px,calc(100% - 56px));
  grid-template-columns:1fr 1fr .72fr .72fr auto;
  gap:.58rem;
  padding:.64rem;
  border-radius:24px;
  background:rgba(255,255,255,.88);
  box-shadow:0 18px 48px rgba(8,44,108,.19);
}
.form-group label,.booking-field label{font-size:.67rem;margin-bottom:.22rem;letter-spacing:.08em}
.reservation-form input,.reservation-form select{
  min-height:40px!important;
  padding:.56rem .75rem!important;
  border-radius:13px!important;
  font-size:.92rem;
}
.reservation-form .btn-reserve{
  min-height:42px!important;
  padding:.62rem .96rem!important;
  font-size:.88rem;
  white-space:nowrap;
}

.reservation-form.is-sticky{
  position:fixed;
  top:88px;
  bottom:auto;
  left:50%;
  transform:translateX(-50%);
  z-index:996;
  width:min(920px,calc(100% - 36px));
  padding:.48rem;
  border-radius:22px;
  box-shadow:0 18px 50px rgba(8,44,108,.20);
  animation:hmBookingDrop .22s ease-out;
}
.reservation-form.is-sticky .form-group label{font-size:.62rem}
.reservation-form.is-sticky input{min-height:36px!important;padding:.45rem .65rem!important;font-size:.86rem}
.reservation-form.is-sticky .btn-reserve{min-height:38px!important;padding:.52rem .82rem!important;font-size:.84rem}
@keyframes hmBookingDrop{from{opacity:0;transform:translate(-50%,-8px)}to{opacity:1;transform:translate(-50%,0)}}

@media(max-width:1180px){
  header nav{width:calc(100% - 30px)}
  .nav-links a{font-size:.78rem;padding:.5rem .5rem}
  .logo-wrap img{height:36px;max-width:128px}
}
@media(max-width:1080px){
  header nav{height:62px;border-radius:26px}
  .nav-links{top:74px}
  .nav-links a{font-size:.94rem;padding:1rem}
  .logo-wrap img{height:40px;max-width:150px}
  .reservation-form.is-sticky{top:84px}
}
@media(max-width:900px){
  .hero{min-height:760px}
  .hero-content{margin-bottom:238px}
  .reservation-form{grid-template-columns:1fr 1fr;width:calc(100% - 32px);bottom:18px;padding:.7rem}
  .reservation-form .btn-reserve{grid-column:1/-1;width:100%}
  .reservation-form.is-sticky{top:auto;bottom:12px;grid-template-columns:1fr 1fr;z-index:1001}
}
@media(max-width:560px){
  .hero{min-height:850px}
  .hero-content{width:calc(100% - 28px);margin-bottom:315px}
  .hero-title{font-size:2.25rem}
  .hero-mini{display:none}
  .reservation-form,.reservation-form.is-sticky{grid-template-columns:1fr;border-radius:22px;width:calc(100% - 24px)}
  .reservation-form.is-sticky .form-group:nth-child(3),
  .reservation-form.is-sticky .form-group:nth-child(4){display:none}
}
