
:root{--blue:#0d4f73;--blue2:#0a3f5c;--sand:#f6f1e8;--gold:#c8a35f;--text:#1c2b33;--muted:#5f6f78;--white:#fff;--line:#e6e0d6;--shadow:0 18px 45px rgba(0,0,0,.14);--radius:18px}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Arial,Helvetica,sans-serif;color:var(--text);background:#fff;line-height:1.6;padding-bottom:118px}a{color:var(--blue);text-decoration:none}a:hover{text-decoration:underline}img{max-width:100%;display:block}.container{width:min(1180px,92%);margin:auto}.skip-link{position:absolute;left:-999px;top:0;background:#000;color:#fff;padding:10px;z-index:10000}.skip-link:focus{left:10px}.topbar{background:var(--blue2);color:#fff;font-size:.92rem}.topbar .container{display:flex;justify-content:space-between;gap:18px;padding:8px 0}.topbar a{color:#fff}.site-header{background:rgba(255,255,255,.96);position:sticky;top:0;z-index:50;border-bottom:1px solid var(--line);backdrop-filter:blur(10px)}.nav{display:flex;align-items:center;justify-content:space-between;padding:12px 0}.logo img{height:58px;width:auto}.menu{display:flex;gap:22px;align-items:center;list-style:none;margin:0;padding:0}.menu a{font-weight:700;color:var(--text)}.menu a.active{color:var(--blue)}.mobile-toggle{display:none;background:none;border:1px solid var(--line);font-size:1.5rem;border-radius:8px;padding:5px 10px}.btn{display:inline-flex;align-items:center;justify-content:center;background:var(--blue);color:#fff!important;border:0;border-radius:999px;padding:12px 22px;font-weight:800;cursor:pointer;box-shadow:0 8px 18px rgba(13,79,115,.22)}.btn:hover{text-decoration:none;background:var(--blue2)}.btn-secondary{background:#fff!important;color:var(--blue)!important;border:1px solid var(--blue);box-shadow:none}.hero{min-height:620px;background:linear-gradient(90deg,rgba(6,40,58,.76),rgba(6,40,58,.25)),url('../img/hotel-roses-platja-fachada.webp') center/cover no-repeat;color:#fff;display:flex;align-items:center}.hero .container{padding:80px 0}.hero h1{font-size:clamp(2.2rem,5vw,4.7rem);line-height:1.05;max-width:850px;margin:12px 0}.hero p{font-size:1.22rem;max-width:760px}.eyebrow{text-transform:uppercase;letter-spacing:.1em;font-size:.78rem;font-weight:900;color:var(--gold)}.hero .eyebrow{color:#f5d58b}.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}.section{padding:76px 0}.section.alt{background:var(--sand)}.section-title{max-width:820px;margin:0 auto 34px;text-align:center}.section-title h2,.split h2{font-size:clamp(1.7rem,3vw,2.6rem);line-height:1.18;margin:8px 0}.split{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:center}.split img,.card,.mapbox{border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.features,.grid{display:grid;gap:22px}.features{grid-template-columns:repeat(4,1fr)}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.feature,.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px}.feature strong{display:block;font-size:1.08rem;margin-bottom:8px;color:var(--blue)}.media-card{padding:0}.media-card img{height:235px;width:100%;object-fit:cover}.card-content{padding:24px}.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.gallery img{height:220px;width:100%;object-fit:cover;border-radius:14px}.booking-bar{position:fixed;left:0;right:0;bottom:0;z-index:80;background:rgba(255,255,255,.97);border-top:1px solid var(--line);box-shadow:0 -10px 30px rgba(0,0,0,.13);padding:12px 0}.booking-form{display:grid;grid-template-columns:repeat(5,1fr) auto;gap:10px;align-items:end}.field label{display:block;font-size:.78rem;font-weight:800;color:var(--blue);margin-bottom:3px}.field input,.field select,.contact-form input,.contact-form textarea{width:100%;padding:11px 12px;border:1px solid #b9c5ca;border-radius:10px;background:#fff;font:inherit}.faq details{background:#fff;border:1px solid var(--line);border-radius:14px;margin:12px 0;padding:18px}.faq summary{font-weight:800;cursor:pointer}.footer{background:#0c2f42;color:#eaf3f7;padding:56px 0 18px}.footer a{color:#fff}.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:34px}.legal{border-top:1px solid rgba(255,255,255,.18);margin-top:28px;padding-top:18px;color:#bfd5df;font-size:.9rem}.cookie-banner{position:fixed;left:20px;bottom:142px;max-width:420px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);border-radius:16px;padding:18px;z-index:90;display:none}.cookie-banner.show{display:block}.cookie-actions{display:flex;gap:10px;justify-content:flex-end}.page-hero{background:linear-gradient(90deg,rgba(6,40,58,.74),rgba(6,40,58,.22)),url('../img/hotel-roses-platja-jardin.webp') center/cover no-repeat;color:#fff;padding:110px 0}.page-hero h1{font-size:clamp(2rem,4vw,3.7rem);line-height:1.1;max-width:860px}.breadcrumbs{font-size:.9rem;margin-bottom:10px}.breadcrumbs a{color:#fff}.list-clean{padding-left:18px}.distance-table{width:100%;border-collapse:collapse;background:#fff;border-radius:14px;overflow:hidden;box-shadow:var(--shadow)}.distance-table th,.distance-table td{padding:14px;border-bottom:1px solid var(--line);text-align:left}.contact-form{display:grid;gap:14px}.notice{background:#fdf8ec;border-left:5px solid var(--gold);padding:18px;border-radius:12px}.legal-content h2{margin-top:36px;color:var(--blue)}@media(max-width:920px){body{padding-bottom:210px}.mobile-toggle{display:block}.menu{display:none;position:absolute;left:4%;right:4%;top:86px;background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:18px;flex-direction:column;align-items:flex-start}.menu.open{display:flex}.topbar .container{flex-direction:column;gap:3px}.split,.grid-2,.grid-3,.features,.footer-grid{grid-template-columns:1fr}.gallery{grid-template-columns:1fr 1fr}.booking-form{grid-template-columns:1fr 1fr}.booking-form .btn{grid-column:1/-1}.hero{min-height:560px}.cookie-banner{left:4%;right:4%;bottom:230px;max-width:none}}@media(max-width:560px){.gallery{grid-template-columns:1fr}.booking-form{grid-template-columns:1fr 1fr}.field:nth-of-type(5){display:none}.logo img{height:48px}.section{padding:54px 0}.page-hero{padding:78px 0}}

.opening-popup{position:fixed;inset:0;background:rgba(6,40,58,.72);z-index:120;display:none;align-items:center;justify-content:center;padding:22px}.opening-popup.show{display:flex}.opening-popup__box{position:relative;max-width:min(760px,94vw);background:#fff;border-radius:22px;box-shadow:0 28px 70px rgba(0,0,0,.35);overflow:hidden}.opening-popup__box img{width:100%;height:auto}.opening-popup__close{position:absolute;right:12px;top:10px;width:40px;height:40px;border:0;border-radius:50%;background:#fff;color:#0d4f73;font-size:2rem;line-height:1;cursor:pointer;box-shadow:0 6px 16px rgba(0,0,0,.2)}.opening-popup__actions{padding:14px 18px 20px;text-align:center;background:#fff}.topbar a[href^="tel"]{color:#fff;font-weight:800}.check{display:flex;gap:10px;align-items:flex-start}.check input{width:auto;margin-top:6px}
@media(max-width:560px){.opening-popup__box{max-width:96vw}.opening-popup__close{right:8px;top:8px}}
