/* Gorgeous House — breezy vacation-rental theme */
:root{
  --bg:#FAF6F0; --surface:#FFFFFF; --ink:#20302F; --muted:#5F7270;
  --accent:#12877F; --accent-ink:#0B5F59; --accent-soft:#E2F1EE;
  --sand:#EFE3D2; --line:#E8DFD2;
  --maxw:1080px; --gap:16px; --radius:14px;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;font-size:17px;line-height:1.6}
:lang(km){font-family:"Noto Sans Khmer",-apple-system,"Segoe UI",Roboto,sans-serif;line-height:1.85}
:lang(km) h1,:lang(km) h2,:lang(km) h3{font-family:"Noto Sans Khmer",sans-serif}
@font-face{font-family:"Noto Sans Khmer";font-weight:400;font-display:swap;src:url("/fonts/noto-sans-khmer-400.woff2") format("woff2")}
@font-face{font-family:"Noto Sans Khmer";font-weight:700;font-display:swap;src:url("/fonts/noto-sans-khmer-700.woff2") format("woff2")}
@font-face{font-family:"Noto Serif";font-weight:400;font-display:swap;src:url("/fonts/noto-serif-400.woff2") format("woff2")}
@font-face{font-family:"Noto Serif";font-weight:700;font-display:swap;src:url("/fonts/noto-serif-700.woff2") format("woff2")}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;display:block}
h1,h2,h3{line-height:1.25;font-weight:700;color:var(--ink);margin:0 0 .4em;font-family:"Noto Serif",Georgia,"Times New Roman",serif}
h1{font-size:2rem}h2{font-size:1.65rem}h3{font-size:1.2rem}
p{margin:0 0 1rem}
ul{margin:0;padding:0;list-style:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gap)}
.btn{display:inline-flex;align-items:center;gap:8px;font-size:.95rem;font-weight:700;padding:12px 24px;border-radius:50px;border:2px solid transparent;cursor:pointer;transition:background .15s,color .15s,border-color .15s}
.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn-primary:hover{background:var(--accent-ink);text-decoration:none}
.btn-secondary{background:transparent;color:var(--accent);border-color:var(--accent)}
.btn-secondary:hover{background:var(--accent);color:#fff;text-decoration:none}
.btn-white{background:rgba(255,255,255,.92);color:var(--accent-ink);border-color:transparent}
.btn-white:hover{background:#fff;text-decoration:none}
.btn-outline-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.6)}
.btn-outline-light:hover{background:rgba(255,255,255,.15);border-color:#fff;text-decoration:none}
.section{padding:48px 0}
.section-title{margin-bottom:24px;text-align:center}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:20px}
/* ---- sticky header ---- */
.site-header{position:sticky;top:0;z-index:100;background:var(--surface);border-bottom:1px solid var(--line)}
.header-inner{max-width:var(--maxw);margin:0 auto;padding:12px var(--gap);display:flex;align-items:center;justify-content:space-between;gap:12px}
.brand{display:flex;align-items:center;gap:8px;color:var(--accent);font-weight:700;font-size:1rem}
.brand:hover{text-decoration:none}
.header-right{display:flex;align-items:center;gap:8px}
.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;border-radius:50%;border:1px solid var(--line);background:var(--surface);color:var(--muted);cursor:pointer}
.theme-toggle:hover{background:var(--accent-soft);color:var(--accent)}
.theme-toggle svg{width:18px;height:18px;display:block}
.theme-toggle .icon-sun{display:none}
.theme-toggle .icon-moon{display:block}
.lang-dd{position:relative;display:inline-block}
.lang-dd summary{list-style:none;cursor:pointer;padding:5px 10px;border:1px solid var(--line);border-radius:8px;font-size:.82rem;color:var(--muted);background:var(--surface)}
.lang-dd summary::-webkit-details-marker{display:none}
.lang-menu{position:absolute;top:100%;right:0;margin-top:4px;background:var(--surface);border:1px solid var(--line);border-radius:10px;box-shadow:0 4px 16px rgba(0,0,0,.12);padding:4px;z-index:200;min-width:110px}
.lang-menu a{display:block;padding:6px 12px;border-radius:6px;color:var(--ink);font-size:.82rem;white-space:nowrap}
.lang-menu a:hover{background:var(--accent-soft);text-decoration:none}
.lang-menu a.active{background:var(--accent);color:#fff}
/* ---- hero ---- */
.hero{background:var(--accent-soft);padding:80px 0;position:relative;overflow:hidden;background-size:cover;background-position:center;filter:brightness(1.3)}
.hero-scrim{position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,0,0,.45),rgba(0,0,0,.2));z-index:1}
.hero .wrap{position:relative;z-index:2}
.hero-eyebrow{display:inline-block;font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--accent-soft);margin-bottom:10px}
.hero h1{font-size:2rem;margin-bottom:12px;max-width:14ch;color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.6)}
.hero-sub{color:rgba(255,255,255,.85);font-size:1.05rem;margin-bottom:20px;max-width:50ch;text-shadow:0 2px 12px rgba(0,0,0,.6)}
.hero-btns{display:flex;gap:10px;flex-wrap:wrap}
/* ---- trust line ---- */
.trust{text-align:center;padding:20px var(--gap);font-size:.88rem;color:var(--muted);background:var(--surface);border-bottom:1px solid var(--line)}
.trust-star{color:#E8A838;margin-right:6px}
/* ---- about ---- */
.about-text{font-size:1.05rem;color:var(--muted);max-width:65ch;margin:0 auto}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap);margin-top:24px}
.fact-card{text-align:center;padding:24px 12px}
.fact-icon{font-size:1.8rem;margin-bottom:6px}
.fact-card h3{font-size:1rem;margin-bottom:2px}
.fact-card p{font-size:.85rem;color:var(--muted);margin:0}
/* ---- amenities ---- */
.amenities-grid{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
.amenity-chip{display:inline-flex;align-items:center;gap:6px;background:var(--accent-soft);color:var(--accent-ink);padding:8px 16px;border-radius:50px;font-size:.88rem;font-weight:600;border:1px solid transparent}
/* ---- gallery ---- */
.gallery-grid{display:flex;flex-wrap:wrap;gap:var(--gap)}
.gallery-grid::after{content:"";flex-grow:999999}
.gallery-tile{--row-h:180px;height:var(--row-h);flex-grow:var(--ar);flex-basis:calc(var(--ar) * var(--row-h));background:var(--sand);border-radius:var(--radius);overflow:hidden}
.gallery-tile-photo{background-size:cover;background-position:center}
.gallery-tile-photo{cursor:pointer}
.gallery-tile-photo img{display:block;width:100%;height:100%;object-fit:cover;object-position:center;transition:transform .25s ease,filter .25s ease}
.gallery-tile-photo:hover img{transform:scale(1.03);filter:brightness(1.05)}
/* ---- location ---- */
.location-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap)}
.loc-card{text-align:center;padding:16px 8px}
.loc-dist{font-size:1.5rem;font-weight:700;color:var(--accent);font-family:"Noto Serif",serif;margin-bottom:2px}
.loc-label{font-size:.85rem;color:var(--muted)}
.map-placeholder{background:var(--sand);border-radius:var(--radius);height:220px;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:.9rem;margin-top:20px}
.map-embed{margin-top:20px}
.map-link{display:inline-block;margin-top:12px;font-size:.9rem;color:var(--accent);text-decoration:underline}
.map-link:hover{opacity:.8}
/* ---- testimonials ---- */
.testimonials-grid{display:grid;grid-template-columns:1fr;gap:var(--gap)}
.testimonial-card{text-align:center;padding:24px 16px}
.testimonial-card .stars{color:#E8A838;font-size:1.1rem;letter-spacing:2px;margin-bottom:10px}
.testimonial-quote{font-size:.95rem;font-style:italic;color:var(--ink);margin-bottom:6px;line-height:1.5}
.testimonial-attr{font-size:.8rem;color:var(--muted)}
/* ---- about extras ---- */
.about-extras{margin-top:4px;font-size:.95rem}
/* ---- news ---- */
.news-card{background:var(--surface);border:1px dashed var(--line);border-radius:var(--radius);padding:32px 20px;text-align:center;color:var(--muted)}
/* ---- news cards (list page) ---- */
.news-cards{display:grid;gap:var(--gap)}
@media(min-width:600px){.news-cards{grid-template-columns:repeat(2,1fr)}}
@media(min-width:900px){.news-cards{grid-template-columns:repeat(3,1fr)}}
.news-card-item{overflow:hidden;padding:0;display:flex;flex-direction:column}
.news-card-img{display:block;overflow:hidden;aspect-ratio:16/9;background:var(--sand)}
.news-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .2s}
.news-card-img:hover img{transform:scale(1.03)}
.news-card-body{padding:16px 20px 20px;flex:1;display:flex;flex-direction:column}
.news-card-body .meta{font-size:.78rem;color:var(--muted);margin-bottom:4px}
.news-card-body h3{font-size:1.05rem;margin-bottom:6px}
.news-card-body h3 a{color:var(--ink)}
.news-card-body h3 a:hover{color:var(--accent);text-decoration:none}
.news-card-body p{font-size:.88rem;color:var(--muted);margin-bottom:14px;flex:1}
.news-card-body .btn-sm{padding:7px 16px;font-size:.82rem;align-self:flex-start}
/* ---- homepage news feed ---- */
.news-feed{display:grid;gap:var(--gap)}
@media(min-width:600px){.news-feed{grid-template-columns:repeat(3,1fr)}}
.news-feed-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:box-shadow .15s}
.news-feed-card:hover{box-shadow:0 2px 12px rgba(0,0,0,.08)}
.news-feed-card-img{display:block;aspect-ratio:16/10;overflow:hidden;background:var(--sand)}
.news-feed-card-img img{width:100%;height:100%;object-fit:cover}
.news-feed-card-body{padding:14px 16px 16px}
.news-feed-card-body .meta{font-size:.75rem;color:var(--muted);margin-bottom:3px}
.news-feed-card-body h3{font-size:.95rem;margin-bottom:2px}
.news-feed-card-body h3 a{color:var(--ink)}
.news-feed-card-body h3 a:hover{color:var(--accent);text-decoration:none}
/* ---- single post ---- */
.post{max-width:720px;margin:0 auto;padding:40px 0}
.post-title{margin-bottom:8px;text-align:center}
.post .meta{text-align:center;font-size:.82rem;color:var(--muted);margin-bottom:24px}
.post-body{font-size:1.05rem;line-height:1.7;color:var(--ink)}
.post-body p{margin-bottom:1.2rem}
.post-body img{max-width:100%;border-radius:var(--radius);margin:16px 0}
.post-back{text-align:center;margin-top:32px;font-size:.88rem}
.post-video{margin:0 0 20px}
.yt-embed{display:block;width:100%;aspect-ratio:16/9;border:0;border-radius:var(--radius);margin:20px 0}
.video-caption{font-size:.9rem;color:var(--muted);text-align:center;margin-top:8px}
.btn-video{display:inline-block;background:var(--accent);color:#fff;padding:10px 18px;border-radius:var(--radius);text-decoration:none}
.btn-video::before{content:"\25B6";font-size:.8em;margin-right:7px}
.btn-video:hover{background:var(--accent-ink);color:#fff;text-decoration:none}
/* ---- gallery lightbox ---- */
.gallery{display:flex;gap:8px;overflow-x:auto;padding:8px 0;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;margin:24px 0}
.gallery-thumb{flex:0 0 auto;width:240px;max-width:75%;scroll-snap-align:start;border-radius:8px;overflow:hidden;border:1px solid var(--line);transition:border-color .15s}
.gallery-thumb:hover{border-color:var(--accent)}
.gallery-thumb img{display:block;width:100%;height:160px;object-fit:cover}
.gallery-overlay{position:fixed;inset:0;z-index:999;background:rgba(14,22,21,.92);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s}
.gallery-overlay:target{opacity:1;pointer-events:auto}
.gallery-close{position:absolute;top:16px;right:20px;width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.15);color:#fff;font-size:1.6rem;line-height:40px;text-align:center;text-decoration:none}
.gallery-close:hover{background:rgba(255,255,255,.25);text-decoration:none}
.gallery-close::after{content:"✕"}
.gallery-prev,.gallery-next{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.12);color:#fff;font-size:1rem;line-height:44px;text-align:center;text-decoration:none}
.gallery-prev{left:12px}.gallery-next{right:12px}
.gallery-prev::after{content:"‹"}.gallery-next::after{content:"›"}
.gallery-prev:hover,.gallery-next:hover{background:rgba(255,255,255,.25);text-decoration:none}
.gallery-enlarged{max-width:92vw;max-height:88vh;border-radius:8px;box-shadow:0 4px 30px rgba(0,0,0,.5)}
/* ---- share bar ---- */
.post-share{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:32px;padding-top:20px;border-top:1px solid var(--line)}
.share-label{font-size:.82rem;color:var(--muted);margin-right:4px;font-weight:600}
.post-share a,.post-share button{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:var(--surface);border:1px solid var(--line);color:var(--muted);cursor:pointer;transition:background .15s,color .15s}
.post-share a:hover,.post-share button:hover{background:var(--accent-soft);color:var(--accent);text-decoration:none}
.post-share .share-copy.copied{background:var(--accent);color:#fff;border-color:var(--accent)}
/* ---- availability calendar ---- */
.avail-synced{font-size:.82rem;color:var(--muted);text-align:center;margin-bottom:20px}
.avail-banner{background:var(--accent-soft);border:1px solid var(--line);border-radius:var(--radius);padding:16px 20px;text-align:center;margin-bottom:20px}
.avail-banner p{margin:0;font-size:.95rem;color:var(--accent-ink)}
.avail-nav{display:flex;align-items:center;justify-content:space-between;max-width:420px;margin:0 auto 12px}
.avail-nav-btn{background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:6px 14px;cursor:pointer;color:var(--accent);font-size:1rem;font-weight:700}
.avail-nav-btn:hover{background:var(--accent-soft)}
.avail-month-label{font-weight:700;font-size:1.05rem;color:var(--ink)}
.avail-grid{max-width:420px;margin:0 auto}
.avail-row{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.avail-cell{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:.82rem;border-radius:6px;background:var(--surface);border:1px solid var(--line);min-height:0}
.avail-cell-header{font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);background:transparent;border:none;font-weight:600}
.avail-cell-empty{background:transparent;border:none}
.avail-cell-past{color:var(--muted);opacity:.5}
.avail-cell-today{background:var(--accent);color:#fff;font-weight:700;border-color:var(--accent)}
.avail-cell-booked{background:var(--sand);color:var(--muted);text-decoration:line-through;border-color:var(--sand)}
.avail-cell-available{color:var(--ink);font-weight:600}
.avail-legend{display:flex;align-items:center;justify-content:center;gap:20px;margin-top:16px;font-size:.82rem;color:var(--muted)}
.avail-legend-dot{display:inline-block;width:12px;height:12px;border-radius:50%;margin-right:4px}
.avail-legend-available{background:var(--accent);opacity:.6}
.avail-legend-booked{background:var(--sand)}
.avail-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:24px}
/* ---- booking band ---- */
.booking-band{background:var(--accent-soft);text-align:center;padding:48px 0}
.booking-band h2{color:var(--accent-ink)}
.booking-band p{color:var(--accent);margin-bottom:20px}
.booking-btns{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
/* ---- footer ---- */
.site-footer{background:var(--ink);color:var(--muted);padding:36px 0 24px;font-size:.85rem}
.footer-inner{max-width:var(--maxw);margin:0 auto;padding:0 var(--gap)}
.footer-brand{color:var(--surface);font-weight:700;font-size:1rem;margin-bottom:4px;font-family:"Noto Serif",serif}
.footer-addr{font-size:.85rem;margin-bottom:8px}
.footer-contact{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:12px}
.footer-contact a{color:var(--accent);font-size:.82rem}
.footer-social{display:flex;gap:10px;margin-bottom:14px}
.footer-social a{color:var(--muted)}
.footer-social a:hover{color:var(--accent)}
.footer-social svg{width:18px;height:18px}
.footer-bottom{border-top:1px solid #2A3E3B;padding-top:12px;font-size:.78rem;display:flex;gap:12px;flex-wrap:wrap}
.footer-langs{display:flex;gap:10px}
.footer-langs a{color:var(--accent)}
.footer-langs a.active{color:var(--surface);font-weight:700}
.copyright{color:var(--muted)}
/* ---- dark theme ---- */
:root[data-theme="dark"]{
  --bg:#0E1615; --surface:#15201E; --ink:#E9EFEC; --muted:#93A6A2;
  --accent:#46C8BC; --accent-ink:#BFEDE7; --accent-soft:#16302C;
  --sand:#211C16; --line:#25322F;
}
:root[data-theme="dark"] .site-header{background:var(--surface)}
:root[data-theme="dark"] .brand{color:var(--accent)}
:root[data-theme="dark"] .theme-toggle .icon-moon{display:none}
:root[data-theme="dark"] .theme-toggle .icon-sun{display:block}
:root[data-theme="dark"] .lang-menu a.active{color:#0A1018}
:root[data-theme="dark"] .lang-menu a:hover{color:var(--ink)}
:root[data-theme="dark"] .btn-white{background:rgba(21,32,30,.9);color:var(--accent-ink)}
:root[data-theme="dark"] .btn-white:hover{background:#1A2A27}
:root[data-theme="dark"] .gallery-tile{background:var(--surface)}
:root[data-theme="dark"] .map-placeholder{background:var(--surface)}
:root[data-theme="dark"] .hero-eyebrow{color:#E2F1EE}
/* ---- desktop >=768px ---- */
@media(min-width:768px){
  h1{font-size:2.6rem}h2{font-size:1.8rem}
  .section{padding:64px 0}
  .hero{padding:120px 0}
  .hero h1{font-size:3.2rem}
  .about-grid{grid-template-columns:repeat(4,1fr)}
  .gallery-tile{--row-h:260px}
  .location-grid{grid-template-columns:repeat(4,1fr)}
  .testimonials-grid{grid-template-columns:repeat(2,1fr)}
  .map-placeholder{height:280px}
  .map-embed iframe{height:320px!important}
  .site-footer{padding:48px 0 32px}
}

/* ---- brand logo: cap on narrow screens (<380px) ---- */
@media (max-width:379.98px){
  .brand-logo{height:46px!important}
}

/* ---- gallery: mobile swipe carousel (<768px) ---- */
@media (max-width:767.98px){
  .gallery-grid{
    flex-wrap:nowrap;
    overflow-x:auto;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    padding-bottom:6px;
  }
  .gallery-grid::after{content:none}
  .gallery-tile{
    flex:0 0 85%;
    height:auto;
    aspect-ratio:3/2;
    scroll-snap-align:center;
  }
}
