/* ═══════════════════════════════════════════
   Hotel La Casa del Sol — Global Styles
   ═══════════════════════════════════════════ */

@font-face { font-family:'Arsenica'; src:url('/fonts/ArsenicaTrial-Thin.ttf') format('truetype'); font-weight:100; font-style:normal; font-display:swap; }
@font-face { font-family:'Arsenica'; src:url('/fonts/ArsenicaTrial-ThinItalic.ttf') format('truetype'); font-weight:100; font-style:italic; font-display:swap; }
@font-face { font-family:'Arsenica'; src:url('/fonts/ArsenicaTrial-Light.ttf') format('truetype'); font-weight:300; font-style:normal; font-display:swap; }
@font-face { font-family:'Arsenica'; src:url('/fonts/ArsenicaTrial-Regular.ttf') format('truetype'); font-weight:400; font-style:normal; font-display:swap; }
@font-face { font-family:'Arsenica'; src:url('/fonts/ArsenicaTrial-Medium.ttf') format('truetype'); font-weight:500; font-style:normal; font-display:swap; }

:root {
  --brand:#3e5f68; --mid:#8f9dae; --light:#e1e0df; --warm:#a4a09f;
  --bg:#f7f6f4; --dark:#1a2226; --text:#4a5a60;
  --fh:'Arsenica',Georgia,serif;
  --fb:'Helvetica Neue',Helvetica,Arial,sans-serif;
  --fn:Georgia,'Times New Roman',serif;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:var(--fb);background:var(--bg);color:var(--dark);overflow-x:hidden}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
.num{font-family:var(--fn)!important}
.rv{opacity:0;transform:translateY(30px)}

/* ─── NAV ─── */
.n{position:fixed;top:0;width:100%;z-index:200;display:flex;justify-content:space-between;align-items:center;padding:1.5rem 3rem;transition:all .5s}
.n.solid{background:var(--light);backdrop-filter:blur(12px);border-bottom:1px solid rgba(62,95,104,.1);padding:.6rem 3rem;box-shadow:0 2px 20px rgba(26,34,38,.08)}
.n--inner{background:var(--light);padding:.6rem 3rem;box-shadow:0 2px 20px rgba(26,34,38,.08)}
.n--inner .n-logo{opacity:1;pointer-events:auto}
.n--inner .n-links a{color:var(--brand)}
.n--inner .n-links a:hover{color:var(--dark)}
.n--inner .n-links a.active{color:#1a2226;border-bottom:1px solid var(--brand);font-weight:600}
.n--inner .n-cta{border-color:var(--brand)!important;color:var(--brand)!important}
.n--inner .n-cta:hover{background:var(--brand)!important;color:#fff!important}
.n--inner .n-ham span{background:var(--brand)}
.n-logo{height:48px;transition:opacity .5s,height .5s;object-fit:contain}
.n-logo--hero{opacity:0;pointer-events:none}
.n.solid .n-logo--hero{opacity:1;pointer-events:auto}
.n-links{display:flex;gap:2rem;list-style:none;align-items:center}
.n-links a{font-size:.68rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.85);transition:all .3s}
.n-links a.active{color:#fff;border-bottom:1px solid rgba(255,255,255,.5);padding-bottom:2px}
.n.solid .n-links a{color:var(--brand)}
.n.solid .n-links a:hover{color:var(--dark)}
.n.solid .n-links a.active{color:#1a2226;border-bottom:1px solid var(--brand);font-weight:600}
.n-links a:hover{color:#fff}
.n-cta{padding:.45rem 1.3rem;border:1px solid rgba(255,255,255,.4);font-size:.65rem!important;letter-spacing:.2em;transition:all .3s}
.n-cta:hover{background:rgba(255,255,255,.15)}
.n.solid .n-cta{border-color:var(--brand)!important;color:var(--brand)!important;background:transparent}
.n.solid .n-cta:hover{background:var(--brand)!important;color:#fff!important}
.n-ham{display:none;background:none;border:none;cursor:pointer;padding:.5rem}
.n-ham span{display:block;width:22px;height:1.5px;margin:5px 0;transition:all .3s;background:rgba(255,255,255,.8)}
.n.solid .n-ham span{background:var(--brand)}

/* ─── HERO (full & mini) ─── */
.hero{position:relative;height:100vh;min-height:700px;overflow:hidden;display:flex;align-items:flex-end}
.hero-mini{position:relative;height:55vh;min-height:380px;overflow:hidden;display:flex;align-items:flex-end}
.hero-media{position:absolute;inset:0}
.hero-media img{width:100%;height:100%;object-fit:cover}
.hero-grad{position:absolute;inset:0;background:linear-gradient(0deg,rgba(26,34,38,.78) 0%,rgba(26,34,38,.2) 45%,rgba(26,34,38,.05) 100%)}
.hero-c{position:relative;width:100%;padding:0 6% 5rem}
.hero-text h1{font-family:var(--fh);font-weight:100;font-size:clamp(2.8rem,6vw,5.5rem);line-height:1.05;color:#fff;letter-spacing:.02em;margin-bottom:.6rem}
.hero-text h1 strong{font-weight:400}
.hero-text p{font-family:var(--fb);font-size:.8rem;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.5)}
.hero-mini .hero-c{padding:0 6% 3rem}
.hero-mini .hero-text h1{font-size:clamp(2rem,4.5vw,3.5rem)}

.scroll-hint{position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.5rem;color:rgba(255,255,255,.35);font-size:.6rem;letter-spacing:.2em;text-transform:uppercase}
.scroll-line{width:1px;height:40px;background:rgba(255,255,255,.2);position:relative;overflow:hidden}
.scroll-line::after{content:'';position:absolute;top:-100%;width:100%;height:50%;background:#fff;animation:scrolldown 2s infinite}
@keyframes scrolldown{0%{top:-50%}100%{top:150%}}

/* ─── SECTIONS ─── */
.s{padding:6rem 3rem}
.s-inner{max-width:1240px;margin:0 auto}
.s-center{text-align:center;max-width:680px;margin:0 auto}
.kicker{font-family:var(--fb);font-size:.62rem;font-weight:600;letter-spacing:.4em;text-transform:uppercase;color:var(--brand);margin-bottom:1rem}
.s-title{font-family:var(--fh);font-weight:300;font-size:clamp(1.7rem,3.2vw,2.6rem);line-height:1.2;margin-bottom:1rem;color:var(--dark)}
.s-title i{font-weight:100;font-style:italic;color:var(--brand)}
.s-body{font-size:.92rem;line-height:2;color:var(--text);max-width:560px}
.sep{width:40px;height:1px;background:var(--brand);margin:1.5rem 0}
.sep-c{margin:1.5rem auto}

/* ─── BAND / PARALLAX ─── */
.band{position:relative;height:50vh;min-height:360px;overflow:hidden;display:flex;align-items:center;justify-content:center}
.band-bg{position:absolute;top:-80%;left:0;width:100%;height:300%;background-size:cover;background-position:center}
.band-ov{position:absolute;inset:0;background:rgba(26,34,38,.55)}
.band-q{position:relative;text-align:center;color:#fff;padding:2rem;max-width:640px}
.band-q blockquote{font-family:var(--fh);font-weight:400;font-style:italic;font-size:clamp(1.2rem,2.4vw,1.8rem);line-height:1.55;margin-bottom:.7rem}
.band-q cite{font-family:var(--fb);font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;opacity:.5;font-style:normal}

/* ─── ABOUT (overlap) ─── */
.about{display:grid;grid-template-columns:1.1fr 1fr;gap:0;align-items:center;position:relative}
.about-img{position:relative;z-index:1}
.about-img img{width:100%;height:580px;object-fit:cover}
.about-card{background:#fff;padding:4rem 3.5rem;margin-left:-5rem;position:relative;z-index:2;box-shadow:0 20px 60px rgba(26,34,38,.06)}
.about-stats{display:flex;gap:2.5rem;margin-top:2rem}
.about-stats div{border-left:2px solid var(--light);padding-left:1rem}
.about-stats .sn{font-family:var(--fn);font-size:1.8rem;color:var(--brand);display:block;line-height:1}
.about-stats .sl{font-family:var(--fb);font-size:.6rem;letter-spacing:.15em;text-transform:uppercase;color:var(--warm);margin-top:.25rem;display:block}

/* ─── ROOMS (cards) ─── */
.rooms-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.r-card{cursor:pointer;position:relative;height:560px;overflow:hidden;cursor:pointer}
.r-card img{width:100%;height:100%;object-fit:cover;transition:transform .7s cubic-bezier(.4,0,.2,1)}
.r-card:hover img{transform:scale(1.06)}
.r-overlay{position:absolute;inset:0;background:linear-gradient(0deg,rgba(26,34,38,.85) 0%,rgba(26,34,38,0) 55%);display:flex;flex-direction:column;justify-content:flex-end;padding:2rem;color:#fff;transition:background .4s}
.r-card:hover .r-overlay{background:linear-gradient(0deg,rgba(62,95,104,.92) 0%,rgba(62,95,104,.3) 60%)}
.r-name{font-family:var(--fh);font-weight:400;font-size:1.4rem;letter-spacing:.04em;margin-bottom:.2rem}
.r-meta{font-family:var(--fn);font-size:.72rem;letter-spacing:.12em;opacity:.6;margin-bottom:.8rem}
.r-desc{font-size:.82rem;line-height:1.7;opacity:0;max-height:0;overflow:hidden;transition:all .5s}
.r-card:hover .r-desc{opacity:.85;max-height:200px;margin-bottom:.8rem}
.r-feats{font-size:.72rem;opacity:0;transition:opacity .4s .2s}
.r-card:hover .r-feats{opacity:.7}
.r-feats span{display:inline-block;border:1px solid rgba(255,255,255,.25);padding:.2rem .6rem;margin:.15rem .1rem;border-radius:1px}
.r-price{font-family:var(--fn);font-size:1.3rem;color:var(--light);margin-top:.8rem}
.r-price small{font-size:.65rem;opacity:.6}

/* ─── STRIP (auto-scroll) ─── */
.strip-wrap{overflow:hidden;position:relative;cursor:grab}
.strip-wrap:active{cursor:grabbing}
.strip{display:flex;gap:.3rem;width:max-content;animation:autoScroll 30s linear infinite}
.strip.dragging{animation-play-state:paused}
.strip img{flex:0 0 280px;height:210px;object-fit:cover;transition:transform .3s;pointer-events:none;user-select:none}
@keyframes autoScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ─── SPLIT SECTION (pool / amenities) ─── */
.split{display:grid;grid-template-columns:1fr 1fr;height:900px}
.split-media{position:relative;overflow:hidden}
.split-media img{width:100%;height:100%;object-fit:cover;transition:transform 8s ease}
.split-media:hover img{transform:scale(1.04)}
.split-content{display:flex;flex-direction:column;justify-content:center;padding:5rem}
.split-content--brand{background:var(--brand);color:#fff}
.split-content--brand .kicker{color:var(--mid)}
.split-content--brand .s-title{color:#fff}
.split-content--brand .s-title i{color:var(--light)}
.split-content--brand .sep{background:var(--mid)}
.split-content--brand .s-body{color:rgba(255,255,255,.68);max-width:none}

/* Pool features */
.pool-feats{list-style:none;margin-top:1.5rem}
.pool-feats li{font-size:.84rem;color:rgba(255,255,255,.6);padding:.4rem 0;border-bottom:1px solid rgba(255,255,255,.08)}

/* Amenities list */
.am-list{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:0}
.am-list li{padding:.4rem 0;border-bottom:1px solid rgba(255,255,255,.1);font-size:.74rem;color:rgba(255,255,255,.75);display:flex;align-items:flex-start;gap:.4rem}
.am-list li::before{content:'';width:6px;height:6px;border:1px solid var(--mid);border-radius:50%;flex-shrink:0;margin-top:.4rem}
.am-list li:nth-child(odd){padding-right:1.5rem}
.am-list li:nth-child(even){padding-left:1.5rem;border-left:1px solid rgba(255,255,255,.06)}
.am-list li strong{display:block;font-family:var(--fb);font-weight:600;font-size:.72rem;letter-spacing:.06em;color:#fff;margin-bottom:0}

/* ─── RESTAURANT (2-col) ─── */
.rest{display:grid;grid-template-columns:1fr 1.2fr;gap:4rem;align-items:start}
.rest-photos{display:grid;grid-template-columns:1fr 1fr;gap:.35rem}
.rest-photos img{width:100%;object-fit:cover;aspect-ratio:1/1}
.rest-items{list-style:none;margin-top:1.5rem}
.rest-items li{padding:.5rem 0;border-bottom:1px solid var(--light);font-size:.88rem;color:var(--text)}
.rest-items li::before{content:'·';margin-right:.7rem;color:var(--brand);font-weight:700}

/* ─── GALLERY MOSAIC ─── */
.mosaic{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:280px;gap:.4rem;grid-auto-flow:dense}
.mosaic .wide{grid-column:span 2}
.mosaic img{width:100%;height:100%;object-fit:cover;object-position:center 30%;transition:transform .6s}
.mosaic div{overflow:hidden}
.mosaic div:hover img{transform:scale(1.05)}

/* ─── BARRIO ─── */
.barrio{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.barrio-img img{width:100%;height:420px;object-fit:cover}

/* ─── LOCATION ─── */
.loc{background:var(--dark);color:#fff}
.loc-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.loc .kicker{color:var(--mid)}
.loc .s-title{color:#fff}
.loc .s-title i{color:var(--mid)}
.loc .sep{background:var(--mid)}
.loc .s-body{color:rgba(255,255,255,.6)}
.loc-info{margin-top:2rem;padding:1.5rem;border:1px solid rgba(255,255,255,.1);font-family:var(--fn);font-size:.85rem;line-height:2.2;color:rgba(255,255,255,.65)}
.loc-info strong{display:block;font-family:var(--fh);font-weight:400;color:var(--mid);letter-spacing:.06em;font-size:1rem;margin-bottom:.3rem}

/* ─── BOOKING FORM ─── */
.bk-form{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem;margin-top:2.5rem;max-width:640px;margin-left:auto;margin-right:auto}
.fg{display:flex;flex-direction:column}
.fg.w{grid-column:span 2}
.fg label{font-size:.6rem;font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:var(--brand);margin-bottom:.35rem}
.fg input,.fg select,.fg textarea{border:none;border-bottom:1px solid var(--light);background:transparent;padding:.6rem 0;font-family:var(--fb);font-size:.9rem;color:var(--dark);outline:none;transition:border-color .3s}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-bottom-color:var(--brand)}
.fg textarea{resize:none;height:55px}
.bk-btn{grid-column:span 2;padding:1rem;background:var(--brand);color:#fff;border:none;font-family:var(--fb);font-size:.68rem;font-weight:600;letter-spacing:.28em;text-transform:uppercase;cursor:pointer;transition:background .3s}
.bk-btn:hover{background:var(--mid)}
.bk-ok{display:none;margin-top:2rem;padding:1.5rem;border-left:3px solid var(--brand);font-size:.9rem;color:var(--brand);line-height:1.8}

/* ─── FOOTER ─── */
.ft{background:var(--dark);color:rgba(225,224,223,.4);padding:1.2rem 3rem .8rem}
.ft-row{max-width:1240px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem .5rem;padding-bottom:.8rem;border-bottom:1px solid rgba(255,255,255,.06)}
.ft-nav{display:flex;gap:1.5rem;list-style:none}
.ft-nav a{font-size:.62rem;font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:rgba(225,224,223,.45);transition:color .3s}
.ft-nav a:hover{color:rgba(225,224,223,.8)}
.ft-contact{font-size:.65rem;text-align:right;line-height:1.8}
.ft-contact a{color:inherit;transition:color .3s}
.ft-contact a:hover{color:rgba(225,224,223,.8)}
.ft-end{max-width:1240px;margin:.6rem auto 0;font-size:.58rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:.3rem}

/* ─── ROOM DETAIL PAGE ─── */
/* Room block (listing page) */
.room-block{display:grid;grid-template-columns:1.2fr 1fr;gap:0;cursor:pointer;overflow:hidden;transition:box-shadow .4s;background:#fff}
.room-block:hover{box-shadow:0 16px 50px rgba(26,34,38,.12)}
.room-block--flip{direction:rtl}
.room-block--flip>*{direction:ltr}
.room-block{max-height:480px}
.room-block-img{position:relative;overflow:hidden;height:480px}
.room-block-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.4,0,.2,1)}
.room-block:hover .room-block-img img{transform:scale(1.05)}
.room-block-content{display:flex;flex-direction:column;justify-content:center;padding:3.5rem}
.room-block-content h3{font-family:var(--fh);font-weight:400;font-size:1.6rem;margin-bottom:.3rem;color:var(--dark)}
.room-block-content .r-meta{font-family:var(--fn);font-size:.78rem;color:var(--warm);margin-bottom:1rem}
.room-block-content .s-body{font-size:.88rem}
.room-block-arrow{display:inline-flex;align-items:center;gap:.5rem;margin-top:1.8rem;font-size:.65rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--brand);transition:gap .3s}
.room-block:hover .room-block-arrow{gap:1rem}
.room-block-arrow::after{content:'→';font-size:1rem;transition:transform .3s}
.room-block:hover .room-block-arrow::after{transform:translateX(4px)}

/* Room detail (individual page) */
.room-detail{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start;margin-top:3rem}
.room-detail--flip .room-detail-photos{order:2}
.room-detail--flip .room-info{order:1}
.room-detail-photos{display:grid;grid-template-columns:1fr 1fr;gap:.35rem}
.room-detail-photos img{width:100%;aspect-ratio:4/3;object-fit:cover;cursor:pointer;transition:transform .3s}
.room-detail-photos img:first-child{grid-column:span 2;aspect-ratio:16/9}
.room-detail-photos img:hover{transform:scale(1.02)}
.room-info h3{font-family:var(--fh);font-weight:400;font-size:1.6rem;margin-bottom:.5rem;color:var(--dark)}
.room-info .r-meta{font-family:var(--fn);font-size:.8rem;color:var(--warm)}
.room-info .s-body{margin-top:1rem}
.room-amenities{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:.3rem;margin-top:1.5rem}
.room-amenities li{font-size:.82rem;color:var(--text);padding:.4rem 0;border-bottom:1px solid var(--light);display:flex;align-items:center;gap:.5rem}
.room-amenities li::before{content:'';width:16px;height:16px;flex-shrink:0;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%233e5f68' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") no-repeat center/contain}
.room-back{display:inline-flex;align-items:center;gap:.5rem;font-size:.65rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--brand);margin-bottom:2rem;transition:gap .3s}
.room-back:hover{gap:.8rem}
.room-back::before{content:'←';font-size:1rem}

/* ─── FLIP CARDS ─── */
.flip-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.flip-row--4{grid-template-columns:repeat(4,1fr)}
.flip-card{perspective:800px;height:320px;cursor:pointer}
.flip-card-inner{position:relative;width:100%;height:100%;transition:transform .7s cubic-bezier(.4,0,.2,1);transform-style:preserve-3d}
.flip-card:hover .flip-card-inner{transform:rotateY(180deg)}
.flip-front,.flip-back{position:absolute;inset:0;backface-visibility:hidden;overflow:hidden}
.flip-front img{width:100%;height:100%;object-fit:cover}
.flip-front-ov{position:absolute;inset:0;background:linear-gradient(0deg,rgba(26,34,38,.7) 0%,rgba(26,34,38,.1) 60%);display:flex;align-items:flex-end;padding:1.5rem}
.flip-front-ov h4{font-family:var(--fh);font-weight:400;font-size:1.1rem;color:#fff;letter-spacing:.03em}
.flip-back{transform:rotateY(180deg);background:var(--brand);display:flex;flex-direction:column;justify-content:center;padding:2rem}
.flip-back h4{font-family:var(--fh);font-weight:400;font-size:1rem;color:#fff;margin-bottom:.6rem}
.flip-back p{font-size:.82rem;line-height:1.8;color:rgba(255,255,255,.7)}

/* ─── MAP EMBED ─── */
.map-wrap{width:100%;height:400px;margin:0;padding:0;line-height:0}
.map-wrap iframe{width:100%;height:100%;border:none;filter:grayscale(.3);display:block}

/* ─── RESPONSIVE ─── */
@media(max-width:1024px){
  .rooms-row{grid-template-columns:1fr 1fr}
  .mosaic{grid-template-columns:1fr 1fr;grid-auto-rows:200px}
}
@media(max-width:768px){
  .n-links{display:none}
  .n-ham{display:block}
  .n-links.open{display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:var(--light);padding:1.5rem 2rem;gap:1rem;border-bottom:2px solid var(--mid)}
  .n-links.open a{color:var(--brand)!important}
  .hero-c{padding:0 5% 4rem}
  .hero-text h1{font-size:clamp(2rem,8vw,3.5rem)}
  .hero-mini .hero-c{padding:0 5% 2.5rem}
  .about{grid-template-columns:1fr}
  .about-card{margin-left:0;margin-top:-2rem}
  .rooms-row{grid-template-columns:1fr}
  .r-card{height:450px}
  .split{grid-template-columns:1fr;height:auto}
  .split-content{padding:3rem 2rem}
  .rest{grid-template-columns:1fr}
  .barrio{grid-template-columns:1fr}
  .loc-grid{grid-template-columns:1fr}
  .mosaic{grid-template-columns:1fr 1fr;grid-auto-rows:200px}
  .bk-form{grid-template-columns:1fr}
  .fg.w,.bk-btn{grid-column:span 1}
  .ft-row{flex-direction:column;text-align:center}
  .ft-nav{flex-wrap:wrap;justify-content:center}
  .ft-contact{text-align:center}
  .s{padding:4rem 1.5rem}
  .strip img{flex:0 0 240px;height:180px}
  .room-block{grid-template-columns:1fr}
  .room-block--flip{direction:ltr}
  .room-block-img{min-height:280px}
  .flip-row,.flip-row--4{grid-template-columns:1fr 1fr}
  .flip-card{height:260px}
  .room-detail{grid-template-columns:1fr}
  .am-list{grid-template-columns:1fr}
  .am-list li:nth-child(even){padding-left:0;border-left:none}
  .am-list li:nth-child(odd){padding-right:0}
  .rest-photos{grid-template-columns:1fr}
}
@media(max-width:480px){
  .hero{min-height:500px}
  .hero-mini{min-height:300px;height:40vh}
  .hero-text h1{font-size:clamp(1.6rem,7vw,2.5rem)}
  .s{padding:3rem 1rem}
  .s-title{font-size:clamp(1.4rem,5vw,2rem)}
  .about-card{padding:2.5rem 1.5rem}
  .about-stats{flex-wrap:wrap;gap:1.5rem}
  .rooms-row{gap:.8rem}
  .r-card{height:380px}
  .room-block-content{padding:2rem 1.5rem}
  .room-block-content h3{font-size:1.2rem}
  .room-block{max-height:none}
  .room-block-img{height:300px}
  .room-detail{gap:2rem}
  .room-detail-photos{grid-template-columns:1fr}
  .room-detail-photos img:first-child{grid-column:span 1}
  .room-amenities{grid-template-columns:1fr}
  .split-content{padding:2rem 1.2rem}
  .pool-feats li{font-size:.78rem}
  .rest{gap:2rem}
  .flip-row,.flip-row--4{grid-template-columns:1fr}
  .flip-card{height:240px}
  .mosaic{grid-template-columns:1fr;grid-auto-rows:220px}
  .barrio{gap:2rem}
  .barrio-img img{height:280px}
  .loc-grid{gap:2.5rem}
  .loc-info{font-size:.78rem;padding:1rem}
  .band{height:40vh;min-height:260px}
  .band-q blockquote{font-size:clamp(1rem,4vw,1.4rem)}
  .bk-form{gap:1rem}
  .map-wrap{height:280px}
  .strip img{flex:0 0 200px;height:150px}
  .ft-nav{gap:1rem}
  .ft-nav a{font-size:.55rem}
  .ft-contact{font-size:.58rem}
  .n{padding:1rem 1.5rem}
  .n.solid,.n--inner{padding:.5rem 1.5rem}
  .n-logo{height:38px}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
  .rv{opacity:1;transform:none}
}
