/* ===== The Base Hua Hin Apartment ===== */
@import url('https://fonts.googleapis.com/css2?family=Prompt:wght@300;400;500;600;700;800;900&family=Inter:wght@300;400;500;600;700;800;900&display=swap');

:root{
  --teal:#2eb8bd;
  --teal-dark:#1b8a8f;
  --teal-light:#eafbfb;
  --coral:#e8836f;
  --coral-dark:#d96a54;
  --coral-light:#fdf1ee;
  --ink:#22333b;
  --muted:#6b7b80;
  --bg:#ffffff;
  --bg-2:#f4fbfb;
  --white:#ffffff;
  --radius:18px;
  --shadow:0 10px 30px rgba(34,51,59,.12);
  --shadow-sm:0 4px 14px rgba(34,51,59,.08);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:"Prompt","Inter","Noto Sans SC","Noto Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
}
img{max-width:100%;display:block;}
a{text-decoration:none;color:inherit;}
ul{margin:0;padding:0;}
.container{max-width:1180px;margin:0 auto;padding:0 24px;}
section{padding:72px 0;}
h1,h2,h3,h4{margin:0 0 .5em;line-height:1.25;}
.eyebrow{
  display:inline-block;
  font-size:13px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--teal-dark);
  font-weight:700;
  margin-bottom:10px;
}
.section-title{font-size:clamp(26px,3.6vw,40px);font-weight:800;color:var(--ink);}
.eyebrow-badge{
  font-size:16px;
  letter-spacing:.04em;
  text-transform:none;
  background:linear-gradient(135deg,rgba(46,184,189,0.14),rgba(232,131,111,0.14));
  color:var(--ink);
  padding:8px 20px;
  border-radius:999px;
  box-shadow:var(--shadow-sm);
}
.section-sub{color:var(--muted);max-width:680px;font-size:16px;}
.center{text-align:center;margin-left:auto;margin-right:auto;}

/* ===== Header ===== */
header.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(255,255,255,0.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(34,51,59,0.08);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 24px;max-width:1180px;margin:0 auto;
}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:18px;color:var(--ink);}
.brand img{width:36px;height:36px;border-radius:50%;object-fit:cover;background:#fff;}
nav.main-nav{display:flex;align-items:center;gap:26px;}
nav.main-nav a{font-weight:600;font-size:15px;color:var(--ink);}
nav.main-nav a:hover{color:var(--teal-dark);}
nav.main-nav a.btn-primary{color:#fff;}
nav.main-nav a.btn-primary:hover{color:#fff;}
.lang-switch{display:flex;gap:4px;background:var(--bg-2);border-radius:999px;padding:4px;flex-wrap:wrap;}
.lang-switch button{
  border:none;background:transparent;padding:6px 10px;border-radius:999px;
  font-size:12.5px;font-weight:700;cursor:pointer;color:var(--muted);
}
.lang-switch button.active{background:var(--teal-dark);color:#fff;}
.nav-toggle{display:none;background:none;border:none;font-size:24px;cursor:pointer;color:var(--ink);}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;align-items:center;gap:8px;justify-content:center;
  padding:14px 28px;border-radius:999px;font-weight:700;font-size:15px;
  cursor:pointer;border:none;transition:transform .15s ease,box-shadow .15s ease;
}
.btn:hover{transform:translateY(-2px);}
.btn-primary{background:var(--teal-dark);color:#fff;box-shadow:var(--shadow-sm);}
.btn-primary:hover{box-shadow:var(--shadow);}
.btn-outline{background:transparent;border:2px solid var(--teal-dark);color:var(--teal-dark);}
.btn-coral{background:var(--coral);color:#fff;}
.btn-line{background:#06c755;color:#fff;}
.btn-sm{padding:10px 18px;font-size:13px;}

/* ===== Hero ===== */
.hero{
  position:relative;overflow:hidden;
  background:linear-gradient(135deg,var(--bg-2) 0%, var(--bg) 55%);
  padding:60px 0 40px;
}
.hero-inner{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;}
.hero-badges{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:18px;}
.badge-award{
  display:inline-flex;align-items:center;gap:8px;background:#fff;border-radius:999px;
  padding:8px 16px;font-size:13px;font-weight:700;box-shadow:var(--shadow-sm);color:var(--ink);
}
.hero h1{font-size:clamp(34px,5vw,54px);font-weight:900;color:var(--ink);}
.hero h1 em{font-style:normal;color:var(--teal-dark);}
.hero p.lead{font-size:18px;color:var(--muted);max-width:520px;margin-bottom:28px;}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:36px;}
.stat-row{display:flex;gap:32px;flex-wrap:wrap;}
.stat-row .stat{min-width:90px;}
.stat .num{font-size:28px;font-weight:900;color:var(--ink);}
.stat .label{font-size:13px;color:var(--muted);}
.hero-img-wrap{position:relative;}
.hero-img-wrap img{border-radius:24px;box-shadow:var(--shadow);}

/* ===== Info strip ===== */
.info-strip{
  background:var(--ink);color:#fff;padding:14px 0;
  font-size:14px;font-weight:600;text-align:center;
}
.info-strip span{color:var(--coral);}

/* ===== Amenities / Features ===== */
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:40px;}
.feature-card{background:#fff;border-radius:var(--radius);padding:28px 22px;box-shadow:var(--shadow-sm);}
.feature-card .icon{font-size:30px;margin-bottom:14px;}
.feature-card h4{font-size:17px;color:var(--ink);}
.feature-card p{font-size:14px;color:var(--muted);margin:0;}

/* ===== Gallery strip ===== */
.gallery-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:36px;}
.gallery-strip img{border-radius:14px;aspect-ratio:4/3;object-fit:cover;box-shadow:var(--shadow-sm);}

/* ===== Room cards ===== */
.room-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px;margin-top:40px;}
.room-card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .2s ease,box-shadow .2s ease;}
.room-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);}
.room-card .thumb{aspect-ratio:16/10;overflow:hidden;position:relative;}
.room-card .thumb img{width:100%;height:100%;object-fit:cover;}
.room-card .floor-badge{
  position:absolute;top:14px;left:14px;background:rgba(255,255,255,.92);
  border-radius:999px;padding:6px 14px;font-size:13px;font-weight:800;color:var(--ink);
  box-shadow:var(--shadow-sm);
}
.room-card .thumb-strip{display:flex;gap:6px;padding:8px 10px 0;background:#fff;}
.room-card .thumb-strip img{width:52px;height:38px;object-fit:cover;border-radius:8px;cursor:pointer;opacity:.7;transition:opacity .15s ease;}
.room-card .thumb-strip img:hover{opacity:1;}
.room-card .accent-bar{height:6px;width:100%;}
.room-card.accent-teal .accent-bar{background:var(--teal);}
.room-card.accent-coral .accent-bar{background:var(--coral);}
.room-card .rc-body{padding:22px 24px 26px;}
.room-card .rc-name{font-size:20px;font-weight:800;color:var(--ink);margin-bottom:4px;}
.room-card .rc-tag{font-size:14px;color:var(--muted);margin-bottom:14px;}
.room-card .rc-meta{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px;}
.room-card .rc-meta span{background:var(--bg-2);border-radius:999px;padding:5px 12px;font-size:13px;font-weight:700;color:var(--ink);}
.room-card .rc-bottom{display:flex;align-items:center;justify-content:space-between;gap:12px;}
.price-pill{font-weight:800;font-size:14px;color:var(--teal-dark);}
.price-pill.contact{font-size:13px;color:var(--muted);font-weight:700;}
.pill{display:inline-block;font-size:11px;font-weight:700;padding:3px 10px;border-radius:999px;background:var(--teal-light);color:var(--teal-dark);}

/* ===== Location ===== */
.location-grid{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:center;margin-top:36px;}
.location-grid img{border-radius:var(--radius);box-shadow:var(--shadow);}
.location-info p{color:var(--muted);font-size:15px;margin-bottom:22px;line-height:1.8;}
.location-info .addr{font-weight:700;color:var(--ink);}

/* ===== Reviews ===== */
.review-stat{
  display:flex;align-items:center;justify-content:center;gap:36px;flex-wrap:wrap;
  background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:34px;margin-top:36px;
}
.review-stat .big-num{font-size:44px;font-weight:900;color:var(--teal-dark);line-height:1;}
.review-stat .big-label{font-size:14px;color:var(--muted);margin-top:6px;}
.review-stat .divider{width:1px;height:56px;background:var(--bg-2);}

/* ===== Contact ===== */
.contact-section{background:linear-gradient(135deg,var(--ink),#1a2830);color:#fff;}
.contact-section .section-title{color:#fff;}
.contact-section .section-sub{color:rgba(255,255,255,.65);}
.contact-grid{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:8px;}

/* ===== FAQ ===== */
.faq-item{border-bottom:1px solid var(--bg-2);padding:18px 0;}
.faq-q{font-weight:700;font-size:16px;color:var(--ink);cursor:pointer;display:flex;justify-content:space-between;align-items:center;}
.faq-a{color:var(--muted);font-size:15px;margin-top:10px;display:none;}
.faq-item.open .faq-a{display:block;}
.faq-item.open .chev{transform:rotate(180deg);}
.chev{transition:transform .2s ease;}

/* ===== Footer ===== */
footer.site-footer{background:var(--ink);color:rgba(255,255,255,.65);padding:50px 0 24px;font-size:14px;}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px;}
footer h5{color:#fff;font-size:15px;margin-bottom:14px;}
footer a{color:rgba(255,255,255,.65);}
footer a:hover{color:#fff;}
footer .foot-links li{margin-bottom:8px;}
.foot-bottom{border-top:1px solid rgba(255,255,255,0.1);margin-top:30px;padding-top:18px;font-size:12px;text-align:center;color:rgba(255,255,255,.45);}

/* ===== Breadcrumb ===== */
.breadcrumb{font-size:13px;color:var(--muted);margin-bottom:18px;}
.breadcrumb a{color:var(--teal-dark);font-weight:600;}

/* ===== Reservation page ===== */
.reserve-layout{max-width:640px;margin:36px auto 0;}
.room-choice{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-bottom:22px;}
.room-choice label{
  border:2px solid var(--bg-2);border-radius:14px;padding:16px;cursor:pointer;
  display:flex;flex-direction:column;gap:4px;transition:border-color .15s ease;
}
.room-choice input{display:none;}
.room-choice label.active{border-color:var(--teal);background:var(--teal-light);}
.room-choice .rc-title{font-weight:800;font-size:14.5px;color:var(--ink);}
.room-choice .rc-sub{font-size:12.5px;color:var(--muted);}

.reserve-form{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:30px;}
.reserve-form .field{margin-bottom:16px;}
.reserve-form label{display:block;font-size:13px;font-weight:700;color:var(--ink);margin-bottom:6px;}
.reserve-form input,.reserve-form select,.reserve-form textarea{
  width:100%;border:2px solid var(--bg-2);border-radius:10px;padding:10px 14px;
  font-size:14px;font-family:inherit;color:var(--ink);background:var(--bg-2);resize:vertical;
}
.reserve-form input:focus,.reserve-form select:focus,.reserve-form textarea:focus{outline:none;border-color:var(--teal);}
.reserve-hint{font-size:12px;color:var(--muted);margin:4px 0 0;line-height:1.6;}
.reserve-note-box{background:var(--coral-light);color:var(--ink);border-radius:12px;padding:14px 16px;font-size:13.5px;line-height:1.6;margin-bottom:24px;display:flex;gap:10px;align-items:flex-start;}
.reserve-actions{display:flex;flex-direction:column;gap:10px;margin-top:18px;}
.reserve-actions .btn{width:100%;}
.reserve-alt-contact{margin-top:22px;padding-top:18px;border-top:1px solid var(--bg-2);}
.reserve-alt-contact .reserve-actions{flex-direction:row;margin-top:8px;}
.reserve-alt-contact .reserve-actions .btn{width:auto;flex:1;}

.success-card{text-align:center;padding:10px 4px 4px;}
.success-icon{font-size:42px;line-height:1;margin-bottom:6px;}
.success-card h3{color:var(--ink);margin:0 0 8px;font-size:19px;}
.success-card p{color:var(--muted);font-size:13.5px;line-height:1.6;margin:0 0 16px;}
.success-summary{margin-bottom:18px;text-align:left;background:var(--bg-2);border-radius:12px;padding:16px;}
.success-summary .sr{display:flex;justify-content:space-between;font-size:13.5px;padding:6px 0;border-bottom:1px solid #fff;}
.success-summary .sr:last-child{border-bottom:none;}
.success-card .btn{width:100%;}

/* ===== Responsive ===== */
@media (max-width:980px){
  .hero-inner,.location-grid{grid-template-columns:1fr;}
  .features-grid{grid-template-columns:repeat(2,1fr);}
  .gallery-strip{grid-template-columns:repeat(2,1fr);}
  .room-grid{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;}
  nav.main-nav{display:none;}
}
@media (max-width:560px){
  section{padding:48px 0;}
  .room-choice{grid-template-columns:1fr;}
  .review-stat{gap:20px;}
}
