/*
Theme Name: Residencial Paraíso Bilene
Theme URI: https://residencialparaisobilene.lovable.app
Author: Residencial Paraíso Bilene
Author URI: https://residencialparaisobilene.lovable.app
Description: Tema WordPress de luxo inspirado no Residencial Paraíso Bilene — apartamentos T1 e T2 na Praia do Bilene, Moçambique. Design elegante em tons âmbar e escuros, com tipografia Playfair Display + Inter, totalmente responsivo com menu hambúrguer mobile, secções para Apartamentos, Galeria, Restaurante, Lazer, Blog e Contactos.
Version: 1.0.0
Requires at least: 5.8
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: rpbilene
Tags: hotel, hospitality, travel, accommodation, custom-colors, custom-menu, custom-logo, featured-images, threaded-comments, translation-ready, responsive-layout, block-styles, wide-blocks
*/

/* ===== Reset & base ===== */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:#16213a;
  background:#fff;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:color .25s}
h1,h2,h3,h4,h5{font-family:'Playfair Display',Georgia,serif;font-weight:700;line-height:1.2;margin:0 0 .6em}
p{margin:0 0 1em}

:root{
  --amber:#d4a52c;
  --amber-dark:#a8821f;
  --dark:#1a2438;
  --dark-deeper:#0f1729;
  --muted:#6b7280;
  --bg-soft:#f7f8fa;
  --border:#e5e7eb;
}

.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}
.text-amber{color:var(--amber)}
.bg-amber{background:var(--amber)}
.section{padding:6rem 0}
.section-dark{background:var(--dark);color:#fff}
.section-darker{background:var(--dark-deeper);color:#fff}
.divider{width:48px;height:3px;background:var(--amber);margin:1rem auto 2rem}
.eyebrow{font-size:.7rem;font-weight:700;letter-spacing:.3em;text-transform:uppercase;color:var(--amber)}

.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  background:var(--amber);color:#1a1a1a;
  padding:.9rem 1.8rem;font-weight:700;font-size:.75rem;
  letter-spacing:.2em;text-transform:uppercase;border-radius:2px;
  border:none;cursor:pointer;transition:background .25s,transform .25s;
}
.btn:hover{background:var(--amber-dark);transform:translateY(-2px)}
.btn-outline{background:transparent;color:#fff;border:2px solid #fff}
.btn-outline:hover{background:#fff;color:var(--dark)}

/* ===== Header ===== */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(26,36,56,.95);backdrop-filter:blur(8px);
}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;height:80px}
.site-logo img{height:60px;width:auto}
.main-nav ul{display:flex;gap:2rem;list-style:none;margin:0;padding:0}
.main-nav a{
  color:rgba(255,255,255,.75);font-size:.7rem;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;
}
.main-nav a:hover,.main-nav .current-menu-item>a{color:var(--amber);border-bottom:2px solid var(--amber);padding-bottom:4px}
.nav-cta{display:flex;align-items:center;gap:1.5rem}
.lang-switch{display:flex;align-items:center;gap:.5rem;color:rgba(255,255,255,.5);font-size:.7rem;font-weight:700;border-right:1px solid rgba(255,255,255,.2);padding-right:1.5rem}
.lang-switch a.active{color:var(--amber)}
.menu-toggle{display:none;background:none;border:none;color:#fff;cursor:pointer;padding:8px}

@media(max-width:1024px){
  .main-nav,.nav-cta{display:none}
  .menu-toggle{display:block}
  .site-header.menu-open .main-nav,.site-header.menu-open .nav-cta{
    display:flex;flex-direction:column;position:absolute;top:80px;left:0;right:0;
    background:var(--dark);padding:1.5rem;gap:1rem;
  }
  .site-header.menu-open .main-nav ul{flex-direction:column;gap:1rem}
}

/* ===== Hero ===== */
.hero{
  position:relative;height:85vh;min-height:600px;
  display:flex;align-items:center;justify-content:center;text-align:center;
  overflow:hidden;margin-top:0;
}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;animation:slowZoom 20s ease-in-out infinite alternate}
@keyframes slowZoom{from{transform:scale(1)}to{transform:scale(1.08)}}
.hero::after{content:"";position:absolute;inset:0;background:rgba(0,0,0,.45)}
.hero-content{position:relative;z-index:2;color:#fff;padding:0 1.5rem;max-width:900px}
.hero h1{font-size:clamp(2.2rem,5vw,4.5rem);color:#fff;margin-bottom:1.5rem}
.hero p{font-size:clamp(1rem,1.5vw,1.25rem);opacity:.9;max-width:600px;margin:0 auto 2.5rem;font-weight:300}

/* ===== Search bar ===== */
.search-bar{
  background:#fff;border-radius:999px;padding:.5rem;
  max-width:900px;margin:2rem auto 0;display:flex;gap:.5rem;align-items:center;
  box-shadow:0 20px 40px -10px rgba(0,0,0,.3);
}
.search-bar .field{flex:1;padding:.75rem 1.25rem;border-right:1px solid #f0f0f0}
.search-bar .field:last-of-type{border-right:none}
.search-bar label{display:block;font-size:.6rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:#9ca3af;margin-bottom:.25rem}
.search-bar input,.search-bar select{width:100%;border:none;outline:none;font-weight:700;font-size:.875rem;background:transparent;color:#16213a}
@media(max-width:768px){
  .search-bar{flex-direction:column;border-radius:1rem;padding:1rem}
  .search-bar .field{border-right:none;border-bottom:1px solid #f0f0f0;width:100%}
  .search-bar .btn{width:100%;justify-content:center}
}

/* ===== Cards / grid ===== */
.grid{display:grid;gap:2rem}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

.feature-card{}
.feature-card .img-wrap{position:relative;height:260px;border-radius:8px;overflow:hidden;margin-bottom:1.25rem}
.feature-card img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.feature-card:hover img{transform:scale(1.08)}
.feature-card .icon{position:absolute;bottom:1rem;left:1rem;width:42px;height:42px;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--amber);font-size:1.1rem;box-shadow:0 4px 10px rgba(0,0,0,.15)}
.feature-card h4{font-size:1.25rem;margin-bottom:.5rem}
.feature-card p{font-size:.875rem;color:var(--muted)}

.room-card{display:grid;grid-template-columns:1fr 1fr;background:#fff;border:1px solid var(--border);margin-bottom:2rem;overflow:hidden;border-radius:4px;box-shadow:0 4px 20px rgba(0,0,0,.04)}
.room-card .room-img{height:100%;min-height:320px;background-size:cover;background-position:center}
.room-card .room-body{padding:2rem}
.room-card .badge{display:inline-block;background:var(--amber);color:#1a1a1a;font-size:.65rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;padding:.25rem .75rem;margin-bottom:1rem}
.room-card h3{font-size:1.75rem;margin-bottom:.5rem}
.room-card .price{color:var(--amber);font-size:1.5rem;font-weight:700;font-family:'Playfair Display',serif}
.room-card .amenities{display:flex;flex-wrap:wrap;gap:.5rem;margin:1rem 0 1.5rem;font-size:.75rem;color:var(--muted)}
.room-card .amenities span::before{content:"✓ ";color:var(--amber);font-weight:700}
@media(max-width:768px){.room-card{grid-template-columns:1fr}}

/* ===== Testimonials ===== */
.testimonial{background:#fff;padding:2rem;border:1px solid var(--border);position:relative}
.testimonial .stars{color:var(--amber);margin-bottom:1rem;letter-spacing:2px}
.testimonial p{font-style:italic;color:#4b5563;margin-bottom:1.5rem;font-size:.95rem}
.testimonial cite{font-weight:700;color:#16213a;font-style:normal}

/* ===== Gallery ===== */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
@media(max-width:768px){.gallery-grid{grid-template-columns:repeat(2,1fr)}}
.gallery-grid a{display:block;height:260px;overflow:hidden;border-radius:4px}
.gallery-grid img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.gallery-grid a:hover img{transform:scale(1.1)}

/* ===== Blog cards ===== */
.post-card{background:#fff;border:1px solid var(--border);overflow:hidden;transition:box-shadow .25s,transform .25s}
.post-card:hover{box-shadow:0 10px 30px rgba(0,0,0,.08);transform:translateY(-4px)}
.post-card .thumb{height:200px;overflow:hidden;position:relative}
.post-card .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.post-card:hover .thumb img{transform:scale(1.1)}
.post-card .cat{position:absolute;top:.75rem;left:.75rem;background:var(--amber);color:#fff;font-size:.6rem;font-weight:700;padding:.2rem .6rem;letter-spacing:.2em;text-transform:uppercase}
.post-card .body{padding:1.5rem}
.post-card h4{font-size:1.05rem;margin-bottom:.75rem;color:#16213a}
.post-card:hover h4{color:var(--amber)}
.post-card .excerpt{font-size:.8rem;color:var(--muted);margin-bottom:1rem}
.post-card .read-more{color:var(--amber);font-size:.75rem;font-weight:700}

/* ===== Footer ===== */
.site-footer{background:var(--dark-deeper);color:rgba(255,255,255,.7);padding:4rem 0 2rem}
.site-footer .grid{grid-template-columns:repeat(3,1fr);gap:3rem;margin-bottom:3rem}
@media(max-width:768px){.site-footer .grid{grid-template-columns:1fr;gap:2rem}}
.site-footer h4{color:#fff;font-size:.75rem;font-weight:700;letter-spacing:.25em;text-transform:uppercase;font-family:'Inter',sans-serif;margin-bottom:1rem}
.site-footer a:hover{color:var(--amber)}
.site-footer .brand{font-family:'Playfair Display',serif;font-size:1.25rem;color:#fff;font-weight:700;margin-bottom:1rem;display:block}
.site-footer .brand .amber{color:var(--amber)}
.site-footer .copyright{border-top:1px solid rgba(255,255,255,.1);padding-top:2rem;text-align:center;font-size:.75rem;opacity:.6}

/* ===== Floating WhatsApp ===== */
.wa-float{
  position:fixed;bottom:24px;right:24px;z-index:90;
  width:60px;height:60px;border-radius:50%;
  background:#25D366;color:#fff;display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 25px rgba(0,0,0,.25);transition:transform .25s;
}
.wa-float:hover{transform:scale(1.1)}
.wa-float svg{width:30px;height:30px}

/* ===== Page headers (interior pages) ===== */
.page-hero{
  margin-top:80px;height:50vh;min-height:380px;
  background:linear-gradient(rgba(15,23,41,.6),rgba(15,23,41,.6)),var(--page-hero-img) center/cover;
  display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;
}
.page-hero h1{font-size:clamp(2rem,4vw,3.5rem);color:#fff}
.page-hero .breadcrumbs{font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;opacity:.8}

/* ===== Single / page content ===== */
.content-area{max-width:820px;margin:0 auto;padding:5rem 1.5rem}
.content-area h2{font-size:2rem;margin-top:2rem}
.content-area img{border-radius:4px;margin:1.5rem 0}
.content-area blockquote{border-left:4px solid var(--amber);padding:.5rem 0 .5rem 1.5rem;font-style:italic;color:var(--muted)}

/* ===== Sidebar / widgets ===== */
.widget{margin-bottom:2.5rem}
.widget h3{font-size:1rem;text-transform:uppercase;letter-spacing:.2em;font-family:'Inter',sans-serif;border-bottom:2px solid var(--amber);padding-bottom:.5rem;margin-bottom:1rem}
.widget ul{list-style:none;padding:0;margin:0}
.widget li{padding:.5rem 0;border-bottom:1px solid var(--border);font-size:.875rem}

/* ===== Utility ===== */
.text-center{text-align:center}
.mb-0{margin-bottom:0}
.section-title{text-align:center;margin-bottom:3rem}
.section-title h2{font-size:clamp(2rem,3vw,2.75rem);margin-bottom:.5rem}
.section-title p{color:var(--muted)}

/* WP core classes */
.alignleft{float:left;margin:0 1.5rem 1rem 0}
.alignright{float:right;margin:0 0 1rem 1.5rem}
.aligncenter{display:block;margin:1rem auto}
.wp-caption{max-width:100%}
.wp-caption-text{font-size:.8rem;color:var(--muted);text-align:center;margin-top:.5rem}
.screen-reader-text{position:absolute!important;clip:rect(1px,1px,1px,1px);height:1px;width:1px;overflow:hidden}