/* ============================================================
   WE CARE CLEANING SERVICE PATTAYA — Stylesheet
   ============================================================ */

:root{
  --c-dark:        #2c3338;
  --c-dark-2:      #1f2429;
  --c-blue:        #1476b9;
  --c-blue-dark:   #0f5d94;
  --c-blue-light:  #2196f3;
  --c-pink:        #f83c72;
  --c-pink-dark:   #d8245a;
  --c-yellow:      #fcb720;
  --c-text:        #2a2f34;
  --c-muted:       #6b7280;
  --c-line:        #e6e8ec;
  --c-bg:          #ffffff;
  --c-bg-soft:     #f6f8fb;

  --shadow-1: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);
  --shadow-2: 0 6px 20px rgba(15,93,148,.08), 0 2px 6px rgba(0,0,0,.04);
  --shadow-3: 0 18px 40px rgba(15,93,148,.16), 0 4px 12px rgba(0,0,0,.06);

  --radius-sm: 6px;
  --radius:    10px;
  --radius-lg: 18px;

  --container: 1200px;

  --font-display: "Poppins", "Helvetica Neue", "Segoe UI", system-ui, sans-serif;
  --font-body:    "Nunito Sans", "Helvetica Neue", "Segoe UI", system-ui, sans-serif;
}

/* ---------- reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
body{
  font-family: var(--font-body);
  color: var(--c-text);
  background: var(--c-bg);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}
h1,h2,h3,h4{
  font-family: var(--font-display);
  font-weight: 700;
  line-height: 1.2;
  margin: 0 0 .6em;
  letter-spacing: -.01em;
}
p{ margin: 0 0 1em; }
a{ color: inherit; text-decoration: none; }
img{ max-width: 100%; display: block; }
button{ font: inherit; cursor: pointer; border: 0; background: transparent; color: inherit; }

.container{
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 20px;
}

/* ============================================================
   TOPBAR (dark grey)
   ============================================================ */
.topbar{
  background: var(--c-dark);
  color: #f3f4f6;
  font-size: 14px;
}
.topbar-inner{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  padding: 10px 20px;
  min-height: 68px;
  flex-wrap: wrap;
}
.logo{
  display: flex; align-items: center; gap: 12px;
  color: #fff;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 18px;
  letter-spacing: .01em;
}
.logo img{ height: 46px; width: auto; object-fit: contain; }
.logo-text{ white-space: nowrap; }

.topbar-actions{
  display: flex; align-items: center; gap: 18px;
  flex-wrap: wrap;
}

.book-now{ display:flex; align-items:center; gap:8px; }
.book-now-label{
  font-weight: 700; text-transform: uppercase; letter-spacing: .08em;
  font-size: 12px; color: #cbd5e1; margin-right: 4px;
}
.book-btn{
  display: inline-flex; align-items: center; gap: 6px;
  padding: 7px 12px;
  border-radius: 999px;
  font-weight: 700; font-size: 13px;
  transition: transform .15s ease, box-shadow .2s ease, background .2s ease;
}
.book-btn .icon{ width: 14px; height: 14px; }
.book-btn--tel{ background: var(--c-yellow); color: #1f2429; }
.book-btn--tel:hover{ transform: translateY(-1px); }
.book-btn--wa{ background: #25d366; color: #fff; }
.book-btn--wa:hover{ transform: translateY(-1px); }

.news-link{
  display: inline-flex; align-items: center; gap: 6px;
  color: #e5e7eb; font-weight: 600; font-size: 13px;
}
.news-link:hover{ color: #fff; }
.news-link .icon{ color: #4267B2; background: #fff; border-radius: 4px; padding: 2px; }

.lang-switch{
  display: inline-flex; align-items: center; gap: 6px;
  margin-left: 4px;
}
.lang-btn{
  color: #9ca3af; font-weight: 700; font-size: 13px; letter-spacing: .04em;
  padding: 2px 4px;
}
.lang-btn.is-active{ color: #fff; text-decoration: underline; text-underline-offset: 4px; }
.lang-sep{ color: #4b5563; }

/* ============================================================
   NAVBAR (blue)
   ============================================================ */
.navbar{
  background: linear-gradient(180deg, var(--c-blue), var(--c-blue-dark));
  box-shadow: var(--shadow-1);
  position: relative;
  z-index: 50;
}
.navbar-inner{
  display: flex; align-items: center;
  padding: 0 20px;
  min-height: 48px;
}
.nav-list{
  display: flex; align-items: stretch; gap: 0;
  list-style: none; margin: 0; padding: 0;
  flex: 1;
}
.nav-item{ position: relative; }
.nav-link{
  display: flex; align-items: center; gap: 6px;
  padding: 14px 20px;
  color: #fff;
  font-weight: 700; font-size: 14px;
  text-transform: uppercase; letter-spacing: .04em;
  transition: background .15s ease;
}
.nav-link:hover,
.nav-link.is-active{ background: rgba(0,0,0,.12); }
.caret{ font-size: 10px; opacity: .8; }

.submenu{
  position: absolute; top: 100%; left: 0;
  background: #fff;
  min-width: 240px;
  list-style: none;
  margin: 0; padding: 8px 0;
  border-radius: 0 0 var(--radius) var(--radius);
  box-shadow: var(--shadow-3);
  opacity: 0; visibility: hidden; transform: translateY(6px);
  transition: opacity .15s ease, transform .15s ease, visibility .15s;
  z-index: 60;
}
.nav-item.has-submenu:hover .submenu,
.nav-item.has-submenu:focus-within .submenu{
  opacity: 1; visibility: visible; transform: translateY(0);
}
.submenu-link{
  display: block;
  padding: 10px 18px;
  color: var(--c-text);
  font-weight: 600; font-size: 13.5px;
  border-left: 3px solid transparent;
  transition: background .12s ease, color .12s ease, border-color .12s ease;
}
.submenu-link:hover{
  background: var(--c-bg-soft);
  color: var(--c-blue);
  border-left-color: var(--c-blue);
}

.nav-toggle{
  display: none;
  width: 44px; height: 44px;
  flex-direction: column; justify-content: center; align-items: center;
  gap: 5px;
}
.nav-toggle span{
  display: block; width: 22px; height: 2px; background: #fff; border-radius: 2px;
  transition: transform .2s ease, opacity .2s ease;
}

/* ============================================================
   HERO
   ============================================================ */
#hero{
  position: relative;
  height: clamp(380px, 56vw, 620px);
  overflow: hidden;
  /* solid colour taken from the banner's blue background, so any
     empty space around the image blends in instead of looking broken */
  background: #1f7fd1;
}
.hero-slides{ position: absolute; inset: 0; }
.hero-slide{
  position: absolute; inset: 0;
  /* show the WHOLE image, never crop the edges */
  background-size: contain;
  background-position: center;
  /* never tile the image to fill leftover space */
  background-repeat: no-repeat;
  opacity: 0;
  transition: opacity 1s ease-in-out;
}
.hero-slide.is-active{ opacity: 1; }
/* overlay + caption removed from view — the banner image already
   contains the brand text and phone number, so keep it clean */
.hero-overlay{ display: none; }
.hero-content{ display: none; }
.hero-caption{ max-width: 640px; color: #fff; }
.hero-title{
  font-size: clamp(28px, 4.6vw, 56px);
  margin-bottom: 14px;
  text-shadow: 0 2px 14px rgba(0,0,0,.35);
}
.hero-sub{
  font-size: clamp(15px, 1.8vw, 19px);
  opacity: .95;
  margin-bottom: 28px;
}
.hero-cta{ display: flex; flex-wrap: wrap; gap: 12px; }

.btn{
  display: inline-flex; align-items: center; gap: 8px;
  padding: 13px 26px;
  border-radius: 999px;
  font-family: var(--font-display);
  font-weight: 700; font-size: 14px;
  letter-spacing: .04em; text-transform: uppercase;
  transition: transform .15s ease, box-shadow .2s ease, background .2s ease;
}
.btn-primary{
  background: var(--c-pink); color: #fff;
  box-shadow: 0 8px 22px rgba(248,60,114,.35);
}
.btn-primary:hover{ background: var(--c-pink-dark); transform: translateY(-2px); }
.btn-ghost{
  background: rgba(255,255,255,.12); color: #fff;
  border: 2px solid rgba(255,255,255,.6);
  backdrop-filter: blur(4px);
}
.btn-ghost:hover{ background: rgba(255,255,255,.2); transform: translateY(-2px); }

.hero-dots{
  position: absolute; bottom: 20px; left: 0; right: 0;
  display: flex; justify-content: center; gap: 8px;
  z-index: 3;
}
.hero-dot{
  width: 10px; height: 10px; border-radius: 50%;
  background: rgba(255,255,255,.45);
  transition: background .2s ease, transform .2s ease;
}
.hero-dot.is-active{ background: #fff; transform: scale(1.25); }
/* with a single hero image there is nothing to navigate — hide the dot */
.hero-dots:has(.hero-dot:only-child){ display: none; }

/* ============================================================
   SECTION TITLES
   ============================================================ */
.section{
  padding: 70px 0;
}
.section-title{
  text-align: center;
  font-size: clamp(22px, 2.6vw, 32px);
  color: var(--c-dark);
  margin: 0 auto 36px;
  max-width: 900px;
  position: relative;
  padding-bottom: 18px;
}
.section-title::after{
  content: "";
  position: absolute;
  bottom: 0; left: 50%; transform: translateX(-50%);
  width: 64px; height: 3px; border-radius: 3px;
  background: linear-gradient(90deg, var(--c-blue), var(--c-pink));
}
.section-title--left{
  text-align: left; margin-left: 0;
}
.section-title--left::after{ left: 0; transform: none; }
.section-title--light{ color: #fff; }
.section-title--light::after{ background: #fff; }

/* ============================================================
   SERVICE BOXES
   ============================================================ */
.box-grid{
  display: grid;
  gap: 24px;
}
.box-grid--2{ grid-template-columns: repeat(2, 1fr); }
.box-grid--3{ grid-template-columns: repeat(3, 1fr); }
.box-grid--4{ grid-template-columns: repeat(4, 1fr); }

.service-card{
  display: flex; flex-direction: column;
  background: #fff;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-2);
  border: 1px solid rgba(15,93,148,.06);
  transition: transform .25s ease, box-shadow .25s ease;
  color: var(--c-text);
}
.service-card:hover{
  transform: translateY(-6px);
  box-shadow: var(--shadow-3);
}
.service-card-media{
  position: relative;
  width: 100%;
  aspect-ratio: 4 / 3;
  background: linear-gradient(135deg, #cfe6f5, #eaf3fa);
  overflow: hidden;
}
.service-card-media img{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;            /* fit inside without distortion */
  object-position: center;
  transition: transform .5s ease;
}
.service-card:hover .service-card-media img{ transform: scale(1.06); }
.service-card-media.no-img::before{
  content: "Image"; position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  color: var(--c-blue); font-family: var(--font-display); font-weight: 700; opacity: .4;
}
.service-card-body{
  padding: 20px 22px 22px;
  display: flex; flex-direction: column; gap: 8px;
  flex: 1;
}
.service-card-title{
  font-size: 18px; color: var(--c-dark);
  margin: 0;
}
.service-card-blurb{
  color: var(--c-muted); font-size: 14px; margin: 0;
  flex: 1;
}
.service-card-cta{
  color: var(--c-blue); font-weight: 700; font-size: 13px;
  letter-spacing: .02em; margin-top: 6px;
  text-transform: uppercase;
}

/* ============================================================
   SECTION ABOUT (#section-about)
   ============================================================ */
#section-about{ background: var(--c-bg-soft); }
.about-wrap{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: center;
}
.about-text .section-title{ text-align: left; margin-left: 0; }
.about-para{ color: var(--c-text); font-size: 15.5px; }
.about-gallery{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
}
.about-photo{
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow-2);
  background: linear-gradient(135deg, #e9eff5, #cfe6f5);
  position: relative;
}
.about-photo:nth-child(odd){ transform: translateY(10px); }
.about-photo img{
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center;
}
.about-photo.no-img::after{
  content: "Team photo"; position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  color: var(--c-blue); font-weight: 700; opacity: .4;
}

/* ============================================================
   SECTION INQUIRY (pink)
   ============================================================ */
#section-inquiry{
  background: linear-gradient(135deg, var(--c-pink), #ff7aa0);
  color: #fff;
  padding: 60px 0 70px;
  position: relative;
  overflow: hidden;
}
#section-inquiry::before{
  content:""; position:absolute; right:-80px; top:-80px;
  width: 300px; height: 300px; border-radius: 50%;
  background: rgba(255,255,255,.08);
}
#section-inquiry::after{
  content:""; position:absolute; left:-60px; bottom:-100px;
  width: 240px; height: 240px; border-radius: 50%;
  background: rgba(255,255,255,.06);
}
.inquiry-head{ text-align: center; margin-bottom: 30px; position: relative; z-index: 2; }
.inquiry-head .section-title{ text-align: center; }
.inquiry-head .section-title::after{ background: rgba(255,255,255,.8); }
.inquiry-sub{ opacity: .95; font-size: 16px; }

.inquiry-grid{
  position: relative; z-index: 2;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 14px;
}
.inquiry-pill{
  display: flex; align-items: center; gap: 14px;
  background: rgba(255,255,255,.14);
  border: 1px solid rgba(255,255,255,.35);
  backdrop-filter: blur(6px);
  padding: 14px 18px;
  border-radius: var(--radius);
  color: #fff;
  transition: background .2s ease, transform .15s ease;
}
.inquiry-pill:hover{ background: rgba(255,255,255,.22); transform: translateY(-2px); }
.inquiry-pill .icon{ width: 26px; height: 26px; flex: none; }
.inquiry-pill small{
  display: block; font-size: 11px; letter-spacing: .08em;
  text-transform: uppercase; opacity: .85;
}
.inquiry-pill strong{ font-size: 15px; font-weight: 700; }

/* ============================================================
   FOOTER
   ============================================================ */
#site-footer{
  background: var(--c-dark-2);
  color: #cbd5e1;
  font-size: 14px;
}
.footer-wrap{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 30px;
  padding: 60px 20px 40px;
}
.footer-col h4{
  color: #fff;
  font-size: 15px;
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-bottom: 14px;
}
.footer-col p{ margin: 0 0 8px; }
.footer-col a{ color: #cbd5e1; }
.footer-col a:hover{ color: #fff; text-decoration: underline; }
.footer-address{ line-height: 1.6; }
.footer-list{ list-style: none; margin: 0; padding: 0; }
.footer-list li{ padding: 4px 0; }
.footer-social{
  display: inline-flex; align-items: center; gap: 8px;
  padding: 4px 0;
  color: #cbd5e1;
}
.footer-bottom{
  border-top: 1px solid rgba(255,255,255,.08);
  padding: 14px 0;
  text-align: center;
  font-size: 12.5px;
  color: #8b95a4;
}

/* ============================================================
   PAGE HERO (pricing / quote)
   ============================================================ */
.page-hero{
  background: linear-gradient(135deg, var(--c-blue), var(--c-blue-dark));
  color: #fff;
  padding: 60px 0 70px;
  text-align: center;
}
.page-hero-title{
  font-size: clamp(28px, 4vw, 42px);
  margin-bottom: 12px;
}
.page-hero-sub{
  max-width: 740px; margin: 0 auto;
  font-size: 16px; opacity: .95;
}

/* ============================================================
   PRICING
   ============================================================ */
.price-grid{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 24px;
  padding-top: 50px;
  padding-bottom: 30px;
}
.price-card{
  background: #fff;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-2);
  padding: 30px 26px 26px;
  text-align: center;
  border: 1px solid var(--c-line);
  position: relative;
  transition: transform .2s ease, box-shadow .2s ease;
}
.price-card:hover{ transform: translateY(-4px); box-shadow: var(--shadow-3); }
.price-card--highlight{
  border: 2px solid var(--c-pink);
  box-shadow: 0 20px 40px rgba(248,60,114,.18);
}
.price-card--highlight::before{
  content: "POPULAR";
  position: absolute; top: -12px; left: 50%; transform: translateX(-50%);
  background: var(--c-pink); color: #fff;
  padding: 4px 14px; border-radius: 999px;
  font-size: 11px; font-weight: 700; letter-spacing: .12em;
}
.price-card-head{ margin-bottom: 18px; }
.price-card-discount{
  display: inline-block;
  background: rgba(252,183,32,.18);
  color: #b27300;
  padding: 4px 10px; border-radius: 999px;
  font-size: 11px; font-weight: 700; letter-spacing: .06em;
  text-transform: uppercase;
  margin-bottom: 12px;
}
.price-card-name{
  font-size: 17px;
  text-transform: uppercase; letter-spacing: .04em;
  color: var(--c-dark);
}
.price-card-amount{
  display: flex; align-items: baseline; justify-content: center; gap: 4px;
  margin-top: 8px;
}
.price-card-from{
  font-size: 11px; color: var(--c-muted); letter-spacing: .12em;
  align-self: flex-start; margin-top: 8px;
}
.price-card-currency{
  font-family: var(--font-display); font-weight: 700;
  font-size: 26px; color: var(--c-blue);
}
.price-card-num{
  font-family: var(--font-display); font-weight: 800;
  font-size: 48px; color: var(--c-blue); line-height: 1;
}
.price-card-book{
  display: inline-block;
  width: 100%; margin: 6px 0 18px;
  background: var(--c-blue); color: #fff;
  padding: 12px 0; border-radius: var(--radius);
  font-family: var(--font-display); font-weight: 700; font-size: 14px;
  letter-spacing: .08em;
  transition: background .15s ease;
}
.price-card-book:hover{ background: var(--c-blue-dark); }
.price-card--highlight .price-card-book{ background: var(--c-pink); }
.price-card--highlight .price-card-book:hover{ background: var(--c-pink-dark); }
.price-card-list{
  list-style: none; padding: 0; margin: 0 0 16px;
  text-align: left;
  border-top: 1px solid var(--c-line);
  padding-top: 14px;
}
.price-card-list li{
  position: relative;
  padding: 6px 0 6px 22px;
  font-size: 14px;
  color: var(--c-text);
}
.price-card-list li::before{
  content: "✓";
  position: absolute; left: 0; top: 6px;
  color: var(--c-blue); font-weight: 700;
}
.price-card-time{
  font-size: 12.5px; color: var(--c-muted);
  font-style: italic;
  margin: 0;
}

.price-notes{
  background: var(--c-bg-soft);
  border-radius: var(--radius);
  padding: 22px 26px;
  margin-top: 30px;
  margin-bottom: 60px;
}
.price-notes h3{
  font-size: 18px; margin-bottom: 10px; color: var(--c-dark);
}
.price-notes ul{ margin: 0; padding-left: 18px; }
.price-notes li{ margin: 6px 0; color: var(--c-text); font-size: 14.5px; }

/* ============================================================
   REQUEST QUOTE
   ============================================================ */
.quote-grid{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 22px;
  padding-top: 50px;
  padding-bottom: 30px;
}
.quote-card{
  display: flex; flex-direction: column; align-items: center; gap: 10px;
  background: #fff;
  padding: 36px 24px;
  border-radius: var(--radius-lg);
  text-align: center;
  box-shadow: var(--shadow-2);
  border: 1px solid var(--c-line);
  color: var(--c-text);
  transition: transform .2s ease, box-shadow .2s ease;
}
.quote-card:hover{ transform: translateY(-6px); box-shadow: var(--shadow-3); }
.quote-card-icon{
  width: 80px; height: 80px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: #fff;
  margin-bottom: 8px;
}
.quote-card--whatsapp .quote-card-icon{ background: #25d366; }
.quote-card--messenger .quote-card-icon{ background: #0084ff; }
.quote-card--line .quote-card-icon{ background: #06c755; }
.quote-card h3{ font-size: 20px; margin: 0; color: var(--c-dark); }
.quote-card-cta{
  color: var(--c-blue); font-weight: 700; font-size: 13px;
  text-transform: uppercase; letter-spacing: .04em;
}
.quote-fallback{
  text-align: center;
  padding: 20px 20px 70px;
  color: var(--c-muted);
  font-size: 15px;
}
.quote-fallback a{ color: var(--c-blue); font-weight: 700; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 980px){
  .box-grid--4{ grid-template-columns: repeat(2, 1fr); }
  .about-wrap{ grid-template-columns: 1fr; gap: 30px; }
  .footer-wrap{ grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px){
  /* topbar restructure */
  .topbar-inner{ padding: 10px 16px; gap: 12px; }
  .topbar-actions{
    width: 100%;
    justify-content: space-between;
    gap: 10px;
  }
  .book-now-label{ display: none; }
  .news-link span{ display: none; }
  .news-link{ padding: 6px; }

  /* nav collapses */
  .nav-toggle{ display: flex; }
  .navbar-inner{ flex-wrap: wrap; padding: 0 16px; }
  .nav-list{
    display: none;
    flex-direction: column;
    width: 100%;
    gap: 0;
    background: var(--c-blue-dark);
    margin: 0 -16px;
    padding: 0 16px;
  }
  .navbar.is-open .nav-list{ display: flex; padding-bottom: 10px; }
  .nav-item{ width: 100%; }
  .nav-link{
    width: 100%;
    padding: 14px 4px;
    border-bottom: 1px solid rgba(255,255,255,.08);
  }
  .submenu{
    position: static;
    opacity: 1; visibility: visible; transform: none;
    box-shadow: none;
    border-radius: 0;
    background: rgba(0,0,0,.18);
    padding: 4px 0;
  }
  .submenu-link{ color: #e5e7eb; padding-left: 24px; }
  .submenu-link:hover{ color: #fff; background: rgba(0,0,0,.25); border-left-color: var(--c-pink); }

  .section{ padding: 50px 0; }
  .box-grid{ gap: 18px; }
  .box-grid--2,
  .box-grid--3,
  .box-grid--4{ grid-template-columns: 1fr; }

  .hero-cta{ flex-direction: column; align-items: flex-start; }
  .btn{ padding: 12px 22px; font-size: 13px; }

  .footer-wrap{ grid-template-columns: 1fr; padding: 40px 20px 30px; gap: 24px; }

  .price-grid{ grid-template-columns: 1fr; }
}

@media (max-width: 460px){
  .logo-text{ font-size: 16px; }
  .logo img{ height: 38px; }
  .book-btn span{ display: none; }
  .book-btn{ padding: 7px 10px; }
  .lang-switch{ margin-left: auto; }

  .hero-title{ font-size: 28px; }
  .hero-sub{ font-size: 14.5px; }
}
