
:root {
  --red:#E8484D; --red-dark:#c93a3e; --teal:#00A699;
  --dark:#2D2D2D; --mid:#5C5C5C; --light:#8A8A8A;
  --off-white:#F7F5F2; --white:#FFFFFF; --border:#E5E0D8;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'DM Sans',sans-serif;color:var(--dark);-webkit-font-smoothing:antialiased;}
h1,h2,h3,h4{font-family:'DM Serif Display',serif;}
a{color:inherit;}
img{display:block;max-width:100%;}
.btn{display:inline-block;padding:.65rem 1.5rem;border-radius:8px;font-weight:500;font-size:.95rem;cursor:pointer;text-decoration:none;transition:all .2s;border:none;font-family:'DM Sans',sans-serif;}
.btn-primary{background:var(--red);color:#fff;}
.btn-primary:hover{background:var(--red-dark);}
.btn-teal{background:var(--teal);color:#fff;}
.btn-teal:hover{opacity:.9;}
.btn-outline{background:transparent;color:var(--dark);border:1.5px solid var(--border);}
.btn-outline:hover{border-color:var(--dark);}
.btn-full{width:100%;text-align:center;display:block;}
.btn-lg{padding:.9rem 2rem;font-size:1rem;}
/* NAV */
.nav{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.97);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);}
.nav-inner{max-width:1280px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:0 2rem;height:70px;}
.nav-logo{display:flex;align-items:center;gap:10px;text-decoration:none;}
.nav-logo img{height:38px;width:auto;}
.nav-logo-text{font-family:'DM Serif Display',serif;font-size:1.25rem;color:var(--red);}
.nav-links{display:flex;align-items:center;gap:2rem;list-style:none;}
.nav-links a{text-decoration:none;color:var(--dark);font-weight:500;font-size:.93rem;transition:color .2s;}
.nav-links a:hover,.nav-links a.active{color:var(--red);}
.hamburger{display:none;background:none;border:none;cursor:pointer;font-size:1.4rem;color:var(--dark);}
.mobile-menu{display:none;background:#fff;border-top:1px solid var(--border);padding:1.5rem 2rem;flex-direction:column;gap:1rem;}
.mobile-menu a{text-decoration:none;color:var(--dark);font-weight:500;}
.mobile-menu.open{display:flex;}
/* BREADCRUMB */
.breadcrumb{padding:.75rem 2rem;background:var(--off-white);border-bottom:1px solid var(--border);font-size:.83rem;color:var(--light);max-width:100%;}
.breadcrumb a{text-decoration:none;color:var(--light);}
.breadcrumb a:hover{color:var(--red);}
.breadcrumb span{margin:0 .4rem;}
/* GALLERY */
.gallery{display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:240px 240px;gap:5px;max-height:490px;overflow:hidden;}
.gallery-main{grid-row:1/3;}
.gallery img{width:100%;height:100%;object-fit:cover;cursor:pointer;transition:opacity .2s;}
.gallery img:hover{opacity:.88;}
/* DETAIL LAYOUT */
.detail-layout{max-width:1280px;margin:0 auto;padding:2.5rem 2rem 5rem;display:grid;grid-template-columns:1fr 370px;gap:4rem;align-items:start;}
/* LEFT */
.prop-header{margin-bottom:1.5rem;}
.prop-header h1{font-size:clamp(1.7rem,3vw,2.3rem);margin-bottom:.5rem;}
.prop-meta-top{display:flex;flex-wrap:wrap;gap:1.2rem;align-items:center;color:var(--mid);font-size:.88rem;}
.rating-badge{display:flex;align-items:center;gap:.35rem;color:var(--dark);font-weight:600;}
.rating-badge i{color:#F5A623;}
.pill{font-size:.73rem;font-weight:600;padding:.28rem .75rem;border-radius:20px;border:none;}
.pill.skiinout{background:rgba(0,166,153,.12);color:var(--teal);}
.pill.pet{background:rgba(232,72,77,.1);color:var(--red);}
.pill.family{background:rgba(245,166,35,.12);color:#B8860B;}
.pill.close{background:rgba(45,71,97,.1);color:#2D4761;}
.pill.large{background:rgba(100,70,200,.1);color:#6446C8;}
.divider{border:none;border-top:1px solid var(--border);margin:1.8rem 0;}
.meta-row{display:flex;gap:1.5rem;flex-wrap:wrap;padding-bottom:1.5rem;}
.meta-item{display:flex;align-items:center;gap:.55rem;font-size:.9rem;}
.meta-item i{color:var(--red);font-size:.95rem;}
.sec-head{font-size:1.2rem;margin-bottom:1rem;}
.body-text{color:var(--mid);line-height:1.75;font-size:.93rem;margin-bottom:.8rem;}
/* AMENITIES */
.amenities-grid{display:grid;grid-template-columns:1fr 1fr;gap:.8rem;}
.amenity{display:flex;align-items:center;gap:.65rem;font-size:.9rem;}
.amenity i{color:var(--dark);width:18px;text-align:center;font-size:.95rem;}
/* RATES */
.rates-table{width:100%;border-collapse:collapse;font-size:.9rem;}
.rates-table th{text-align:left;padding:.6rem .8rem;font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--light);background:var(--off-white);border-bottom:2px solid var(--border);}
.rates-table td{padding:.7rem .8rem;border-bottom:1px solid var(--border);color:var(--mid);}
.rates-table tr:last-child td{border-bottom:none;}
.rates-table td:last-child{font-weight:600;color:var(--dark);text-align:right;}
/* MAP */
.map-wrap{border-radius:12px;overflow:hidden;border:1px solid var(--border);height:260px;}
.map-wrap iframe{width:100%;height:100%;border:none;}
/* RULES */
.rules-list{list-style:none;display:flex;flex-direction:column;gap:.65rem;}
.rules-list li{display:flex;align-items:center;gap:.65rem;font-size:.9rem;color:var(--mid);}
.rules-list i{width:18px;text-align:center;color:var(--red);}
/* BOOKING CARD */
.booking-card{position:sticky;top:86px;border:1px solid var(--border);border-radius:16px;padding:1.8rem;box-shadow:0 8px 32px rgba(0,0,0,.09);background:#fff;}
.booking-price{margin-bottom:1.3rem;}
.booking-price .amount{font-size:1.75rem;font-weight:600;font-family:'DM Serif Display',serif;}
.booking-price .per{color:var(--light);font-size:.88rem;}
.booking-price .rating{display:flex;align-items:center;gap:.3rem;font-size:.85rem;margin-top:.2rem;}
.booking-price .rating i{color:#F5A623;}
.date-grid{display:grid;grid-template-columns:1fr 1fr;border:1.5px solid var(--border);border-radius:10px;overflow:hidden;margin-bottom:.8rem;}
.date-field{padding:.7rem .9rem;}
.date-field:first-child{border-right:1.5px solid var(--border);}
.date-field label{display:block;font-size:.66rem;text-transform:uppercase;letter-spacing:.06em;font-weight:600;margin-bottom:.25rem;}
.date-field input{width:100%;border:none;outline:none;font-size:.88rem;font-family:'DM Sans',sans-serif;color:var(--dark);}
.guests-sel{width:100%;border:1.5px solid var(--border);border-radius:10px;padding:.7rem .9rem;font-family:'DM Sans',sans-serif;font-size:.88rem;color:var(--dark);outline:none;margin-bottom:1rem;appearance:none;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238A8A8A' stroke-width='1.5' fill='none'/%3E%3C/svg%3E") right .9rem center no-repeat;}
.booking-note{text-align:center;font-size:.78rem;color:var(--light);margin-bottom:1.1rem;}
.booking-note i{color:var(--teal);}
.price-policy{border-top:1px solid var(--border);padding-top:1rem;font-size:.82rem;color:var(--mid);line-height:1.6;}
.price-policy strong{color:var(--dark);}
/* FOOTER */
footer{background:#1C1C1C;color:rgba(255,255,255,.7);padding:4rem 1.5rem 2rem;}
.footer-inner{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:3rem;}
.footer-logo-text{font-family:'DM Serif Display',serif;font-size:1.4rem;color:#fff;margin-bottom:.8rem;}
.footer-tagline{font-size:.86rem;line-height:1.6;margin-bottom:1.2rem;}
.footer-social{display:flex;gap:1rem;}
.footer-social a{color:rgba(255,255,255,.5);font-size:1.1rem;transition:color .2s;text-decoration:none;}
.footer-social a:hover{color:#fff;}
.footer-col h4{font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.35);margin-bottom:1rem;font-weight:600;}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:.55rem;}
.footer-col a{color:rgba(255,255,255,.6);text-decoration:none;font-size:.88rem;transition:color .2s;}
.footer-col a:hover{color:#fff;}
.footer-contact-item{display:flex;gap:.65rem;align-items:flex-start;font-size:.88rem;margin-bottom:.65rem;}
.footer-contact-item i{color:var(--red);margin-top:.15rem;flex-shrink:0;}
.footer-bottom{max-width:1280px;margin:3rem auto 0;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;align-items:center;font-size:.8rem;flex-wrap:wrap;gap:1rem;}
/* RESPONSIVE */
@media(max-width:1024px){
  .detail-layout{grid-template-columns:1fr;}
  .booking-card{position:static;}
  .gallery{grid-template-columns:1fr 1fr;grid-template-rows:220px;max-height:unset;}
  .gallery-main{grid-row:auto;grid-column:1/3;}
}
@media(max-width:768px){
  .nav-links{display:none;}
  .hamburger{display:block;}
  .gallery{grid-template-columns:1fr;max-height:unset;}
  .gallery-main{grid-column:auto;}
  .amenities-grid{grid-template-columns:1fr;}
  .footer-inner{grid-template-columns:1fr 1fr;}
  .date-grid{grid-template-columns:1fr;}
  .date-field:first-child{border-right:none;border-bottom:1.5px solid var(--border);}
}
@media(max-width:480px){
  .footer-inner{grid-template-columns:1fr;}
  .breadcrumb{padding:.6rem 1rem;}
  .detail-layout{padding:1.5rem 1rem 4rem;}
}
