/* La Porta Rooms Split — static export. Refined Enfold-inspired design. */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;500;600&family=Montserrat:wght@300;400;500;600&display=swap');
:root{
  --gold:#9a7b2e; --gold-dark:#7a5e0e; --ink:#2c2c2c; --muted:#777;
  --line:#e6e6e6; --bg-soft:#f6f4ef; --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Montserrat','Helvetica Neue',Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:#555;font-size:15px;line-height:1.7;background:#fff;-webkit-font-smoothing:antialiased}
a{color:var(--gold);text-decoration:none;transition:color .2s}
a:hover{color:var(--gold-dark)}
img{max-width:100%;display:block}
.wrap{max-width:1160px;margin:0 auto;padding:0 24px}
h1,h2,h3,h4{color:var(--ink);line-height:1.2;font-weight:500}

/* ---- top bar ---- */
.topbar{background:var(--ink);color:#cfcabb;font-size:12px;letter-spacing:.3px}
.topbar a{color:#cfcabb}
.topbar a:hover{color:#fff}
.topbar-inner{display:flex;justify-content:space-between;align-items:center;min-height:38px}
.topbar-right{display:flex;align-items:center;gap:22px}
.lang-switch a{display:inline-flex;align-items:center;gap:6px}
.lang-switch img{width:16px;height:11px;border:1px solid rgba(255,255,255,.2)}
.phone{color:#fff;font-weight:500}

/* ---- header ---- */
.header{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:60;box-shadow:0 1px 12px rgba(0,0,0,.04)}
.header-inner{display:flex;justify-content:space-between;align-items:center;min-height:96px}
.logo{display:flex;align-items:center}
.logo img{height:66px;width:auto}
.mainnav ul{list-style:none;display:flex;gap:34px}
.mainnav a{color:var(--ink);font-size:12.5px;font-weight:500;text-transform:uppercase;letter-spacing:1.2px;padding:6px 0;position:relative}
.mainnav a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--gold);transition:width .25s}
.mainnav a:hover::after,.mainnav a.active::after{width:100%}
.mainnav a.active{color:var(--gold)}

/* ---- hero ---- */
.hero{position:relative;min-height:560px;background-size:cover;background-position:center;display:flex;align-items:center;justify-content:center;text-align:center}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,20,20,.35),rgba(20,20,20,.55))}
.hero-inner{position:relative;z-index:2;color:#fff;padding:30px 24px;max-width:820px}
.hero-inner h2{color:#fff;font-family:var(--serif);font-weight:500;font-size:46px;line-height:1.15;text-shadow:0 2px 18px rgba(0,0,0,.4)}
.hero-cta{display:inline-block;margin-top:28px;background:var(--gold);color:#fff;padding:15px 40px;font-family:var(--sans);font-size:12.5px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;border-radius:2px;transition:background .2s,transform .2s}
.hero-cta:hover{background:#fff;color:var(--ink);transform:translateY(-2px)}
.room-hero{position:relative}
.room-hero img{width:100%;max-height:460px;object-fit:cover}

/* ---- intro heading ---- */
.intro{text-align:center;padding:64px 24px 12px}
.intro h1{font-family:var(--serif);font-size:40px;font-weight:600;color:var(--ink)}
.intro h1 span{display:block;font-size:21px;font-weight:400;color:var(--muted);font-family:var(--sans);letter-spacing:.5px;margin-top:10px}
.intro::after{content:"";display:block;width:64px;height:3px;background:var(--gold);margin:26px auto 0}

/* ---- room cards ---- */
.rooms-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;padding-top:48px;padding-bottom:64px}
.room-card{display:block;background:#fff;border-radius:4px;overflow:hidden;box-shadow:0 6px 22px rgba(0,0,0,.08);transition:transform .28s,box-shadow .28s}
.room-card:hover{transform:translateY(-6px);box-shadow:0 16px 38px rgba(0,0,0,.16)}
.room-card-img{display:block;overflow:hidden;aspect-ratio:3/2}
.room-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.room-card:hover .room-card-img img{transform:scale(1.08)}
.room-card-name{display:block;padding:18px 16px;text-align:center;font-family:var(--serif);font-size:20px;font-weight:600;color:var(--ink)}
.room-card:hover .room-card-name{color:var(--gold)}

/* ---- testimonials ---- */
.testimonials{background:var(--bg-soft);padding:72px 0;text-align:center}
.testimonials h2{font-family:var(--serif);font-size:34px;margin-bottom:14px;font-weight:600}
.testimonials>.wrap>h2+.quotes{margin-top:30px}
.quotes{display:grid;grid-template-columns:1fr 1fr;gap:40px;text-align:left;margin-top:40px}
blockquote{background:#fff;padding:32px 34px;border-radius:4px;box-shadow:0 4px 18px rgba(0,0,0,.06);position:relative}
blockquote::before{content:"\201C";font-family:var(--serif);font-size:70px;color:var(--gold);opacity:.25;position:absolute;top:6px;left:18px;line-height:1}
blockquote p{font-style:italic;color:#666;position:relative;z-index:1}
blockquote footer{margin-top:18px;font-style:normal;color:var(--ink);font-size:14px}
blockquote footer strong{display:block;color:var(--gold)}

/* ---- services ---- */
.services{padding:78px 0;text-align:center}
.services h2{font-family:var(--serif);font-size:34px;font-weight:600}
.services .sub{color:var(--muted);margin:12px 0 44px}
.services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:36px;text-align:center}
.service{padding:8px}
.service h3{font-family:var(--serif);font-size:22px;margin-bottom:12px;color:var(--ink);position:relative;padding-bottom:14px}
.service h3::after{content:"";position:absolute;left:50%;bottom:0;transform:translateX(-50%);width:34px;height:2px;background:var(--gold)}
.service p{font-size:14px;color:#777}

/* ---- room detail ---- */
.room-detail{padding:56px 24px 72px;max-width:980px}
.room-detail h1{font-family:var(--serif);font-size:36px;font-weight:600;margin-bottom:8px;text-align:center}
.room-detail>h1+.gallery{margin-top:34px}
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:36px}
.gallery a{overflow:hidden;border-radius:3px;aspect-ratio:3/2}
.gallery img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.gallery a:hover img{transform:scale(1.08)}
.room-specs{list-style:none;margin:0 0 22px;display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.room-specs li{background:var(--bg-soft);padding:16px;border-radius:4px;font-size:14px;border-left:3px solid var(--gold)}
.room-specs strong{display:block;color:var(--gold);font-size:11px;text-transform:uppercase;letter-spacing:1px;margin-bottom:4px}
.room-detail p{margin-bottom:16px}
.tax{color:#999;font-size:13px;font-style:italic}
.booking{margin-top:28px;text-align:center}
.btn{display:inline-block;background:var(--gold);color:#fff;padding:15px 44px;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;font-size:12.5px;border-radius:2px;transition:background .2s,transform .2s}
.btn:hover{background:var(--gold-dark);color:#fff;transform:translateY(-2px)}

/* ---- content pages ---- */
.content{padding:56px 24px;max-width:960px}
.content h3{font-family:var(--serif);font-size:26px;margin:30px 0 14px;color:var(--ink);font-weight:600}
.content h3:first-child{margin-top:0}
.content p{margin-bottom:16px}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:56px}
.two-col ul{list-style:none}
.two-col li{padding:8px 0;border-bottom:1px solid var(--line)}
.map iframe{display:block}

/* ---- footer ---- */
.footer{background:var(--ink);color:#9b968a;padding:40px 0;font-size:13px;text-align:center}
.footer a{color:#cfcabb}
.footer a:hover{color:#fff}
.footer p{margin:5px 0}

/* ---- hamburger (hidden on desktop) ---- */
.hamburger{display:none;cursor:pointer;width:30px;height:22px;flex-direction:column;justify-content:space-between;padding:0}
.hamburger span{display:block;height:3px;width:100%;background:var(--ink);border-radius:2px;transition:transform .25s ease,opacity .2s ease}
.nav-toggle{display:none}

@media(max-width:1000px){
  .rooms-grid{grid-template-columns:repeat(2,1fr)}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:900px){
  .quotes,.two-col{grid-template-columns:1fr}
  .header-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;min-height:72px}
  .logo{flex:1}
  .logo img{height:52px}
  .hamburger{display:flex}
  .mainnav{flex-basis:100%;width:100%;order:3}
  .mainnav ul{flex-direction:column;gap:0;width:100%;max-height:0;overflow:hidden;transition:max-height .32s ease}
  .mainnav li{border-top:1px solid var(--line)}
  .mainnav a{display:block;padding:15px 4px;font-size:13px}
  .mainnav a::after{display:none}
  .nav-toggle:checked ~ .mainnav ul{max-height:440px;padding-bottom:8px}
  .nav-toggle:checked ~ .hamburger span:nth-child(1){transform:translateY(9px) rotate(45deg)}
  .nav-toggle:checked ~ .hamburger span:nth-child(2){opacity:0}
  .nav-toggle:checked ~ .hamburger span:nth-child(3){transform:translateY(-9px) rotate(-45deg)}
  .hero{min-height:440px}
  .hero-inner h2{font-size:32px}
  .intro h1{font-size:30px}
  .room-specs{grid-template-columns:1fr}
}
@media(max-width:560px){
  .rooms-grid,.services-grid,.gallery{grid-template-columns:1fr}
  .hero{min-height:360px}
  .hero-inner h2{font-size:26px}
  .intro{padding-top:44px}
  .intro h1{font-size:25px}
  .room-detail h1{font-size:28px}
  .topbar-right{gap:12px}
  .phone{display:none}
}
