/* ============================================================
   Generated landing page template (themed via CSS variables
   set inline from the site's palette).
   ============================================================ */

.gsite {
  --p: var(--site-primary, #17211f);
  --a: var(--site-accent, #0f766e);
  --bg: var(--site-background, #fafaf7);
  --sf: var(--site-surface, #ffffff);
  --mut: var(--site-muted, #61706c);
  font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
  background: var(--bg);
  color: var(--p);
  line-height: 1.65;
}
.gsite * { box-sizing: border-box; }
.gsite img { max-width: 100%; display: block; }
.gsite h1, .gsite h2, .gsite h3 { line-height: 1.12; letter-spacing: -0.02em; margin: 0 0 0.4em; }

.gsite .wrap { max-width: 1120px; margin: 0 auto; padding-left: clamp(18px, 4vw, 40px); padding-right: clamp(18px, 4vw, 40px); }

/* nav */
.gsite-nav {
  position: sticky;
  top: 0;
  z-index: 40;
  background: color-mix(in srgb, var(--bg) 88%, transparent);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid color-mix(in srgb, var(--p) 10%, transparent);
}
.gsite-nav .wrap { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding-top: 14px; padding-bottom: 14px; }
.gsite-nav strong { font-size: 1.02rem; letter-spacing: -0.01em; }
.gsite-nav nav { display: flex; gap: 18px; flex-wrap: wrap; }
.gsite-nav nav a { color: var(--mut); font: 550 0.86rem inherit; text-decoration: none; }
.gsite-nav nav a:hover { color: var(--p); }
@media (max-width: 800px) { .gsite-nav nav { display: none; } }

/* buttons */
.gsite .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 24px;
  border-radius: 999px;
  font: 650 0.93rem inherit;
  text-decoration: none;
  transition: filter 0.12s ease, transform 0.12s ease;
}
.gsite .btn:active { transform: translateY(1px); }
.gsite .btn.solid { background: var(--a); color: #fff; }
.gsite .btn.solid:hover { filter: brightness(0.93); }
.gsite .btn.line { border: 1.5px solid color-mix(in srgb, var(--p) 22%, transparent); color: var(--p); background: var(--sf); }

/* hero */
.gsite-hero { padding: clamp(40px, 7vw, 84px) 0 clamp(34px, 5vw, 64px); }
.gsite-hero .wrap { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(26px, 5vw, 64px); align-items: center; }
.gsite-hero .pill {
  display: inline-block;
  font: 650 0.78rem inherit;
  color: var(--a);
  background: color-mix(in srgb, var(--a) 12%, transparent);
  border-radius: 999px;
  padding: 6px 14px;
  margin-bottom: 16px;
}
.gsite-hero h1 { font-size: clamp(1.9rem, 4vw, 3rem); font-weight: 800; }
.gsite-hero .summary { color: var(--mut); font-size: 1.06rem; max-width: 34rem; }
.gsite-hero .cta-row { display: flex; flex-wrap: wrap; gap: 12px; margin: 24px 0 20px; }
.gsite-hero .rating { display: flex; align-items: center; gap: 10px; font-size: 0.95rem; }
.gsite-hero .rating strong { font-size: 1.3rem; }
.gsite-hero .rating .stars { color: var(--accent, #e9a13b); letter-spacing: 2px; color: #e9a13b; }
.gsite-hero .rating .count { color: var(--mut); font-size: 0.88rem; }
.gsite-hero .proof { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 18px; }
.gsite-hero .proof span {
  font: 600 0.8rem inherit;
  background: var(--sf);
  border: 1px solid color-mix(in srgb, var(--p) 12%, transparent);
  border-radius: 999px;
  padding: 6px 14px;
}
.gsite-hero figure { margin: 0; position: relative; }
.gsite-hero figure img {
  border-radius: 18px;
  aspect-ratio: 4/3;
  object-fit: cover;
  box-shadow: 0 24px 60px color-mix(in srgb, var(--p) 25%, transparent);
}
@media (max-width: 880px) { .gsite-hero .wrap { grid-template-columns: 1fr; } }

/* sections */
.gsite-section { padding: clamp(36px, 6vw, 72px) 0; }
.gsite-section.tint { background: color-mix(in srgb, var(--p) 4%, var(--bg)); }
.gsite-section .head { max-width: 600px; margin-bottom: 30px; }
.gsite-section .head .kicker {
  font: 700 0.72rem inherit;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--a);
  display: block;
  margin-bottom: 8px;
}
.gsite-section .head h2 { font-size: clamp(1.4rem, 2.6vw, 1.9rem); }
.gsite-section .head p { color: var(--mut); margin: 0; }

/* why grid */
.why-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 16px; }
.why-grid article {
  background: var(--sf);
  border: 1px solid color-mix(in srgb, var(--p) 9%, transparent);
  border-radius: 14px;
  padding: 22px;
}
.why-grid article span { font: 800 0.85rem inherit; color: var(--a); }
.why-grid h3 { font-size: 1.04rem; margin: 8px 0 6px; }
.why-grid p { color: var(--mut); font-size: 0.9rem; margin: 0; }

/* gallery */
.gallery { display: grid; grid-template-columns: repeat(3, 1fr); grid-auto-rows: 180px; gap: 12px; }
.gallery img { width: 100%; height: 100%; object-fit: cover; border-radius: 12px; }
.gallery img:first-child { grid-column: span 2; grid-row: span 2; }
@media (max-width: 700px) { .gallery { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 140px; } }

/* services */
.service-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: 16px; }
.service-grid article {
  background: var(--sf);
  border: 1px solid color-mix(in srgb, var(--p) 9%, transparent);
  border-left: 4px solid var(--a);
  border-radius: 12px;
  padding: 20px 22px;
}
.service-grid h3 { font-size: 1rem; margin-bottom: 6px; }
.service-grid p { color: var(--mut); font-size: 0.89rem; margin: 0; }

/* tips */
.tips { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 12px; padding: 0; margin: 0; list-style: none; }
.tips li {
  background: var(--sf);
  border: 1px solid color-mix(in srgb, var(--p) 9%, transparent);
  border-radius: 12px;
  padding: 16px 18px;
  font-size: 0.92rem;
  display: flex;
  gap: 10px;
}
.tips li::before { content: "✓"; color: var(--a); font-weight: 800; }

/* reviews */
.review-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 16px; }
.review-grid article {
  background: var(--sf);
  border: 1px solid color-mix(in srgb, var(--p) 9%, transparent);
  border-radius: 14px;
  padding: 20px 22px;
  display: grid;
  gap: 8px;
}
.review-grid .who { display: flex; align-items: center; gap: 10px; }
.review-grid .avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: color-mix(in srgb, var(--a) 16%, transparent);
  color: var(--a);
  font: 700 0.85rem inherit;
}
.review-grid strong { font-size: 0.94rem; }
.review-grid .stars { color: #e9a13b; font-size: 0.85rem; letter-spacing: 2px; }
.review-grid p { color: var(--mut); font-size: 0.92rem; margin: 0; }

/* faq */
.gsite .faq { display: grid; gap: 10px; max-width: 760px; }
.gsite .faq details {
  background: var(--sf);
  border: 1px solid color-mix(in srgb, var(--p) 9%, transparent);
  border-radius: 12px;
  padding: 14px 18px;
}
.gsite .faq summary { font-weight: 650; cursor: pointer; font-size: 0.96rem; }
.gsite .faq p { color: var(--mut); margin: 10px 0 0; font-size: 0.92rem; }

/* hours + map */
.hours-map { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: 20px; align-items: start; }
.hours-card {
  background: var(--sf);
  border: 1px solid color-mix(in srgb, var(--p) 9%, transparent);
  border-radius: 14px;
  padding: 22px 24px;
}
.hours-card dl { margin: 0; display: grid; gap: 8px; }
.hours-card dl div { display: flex; justify-content: space-between; gap: 14px; border-bottom: 1px dashed color-mix(in srgb, var(--p) 12%, transparent); padding-bottom: 8px; }
.hours-card dl div:last-child { border-bottom: 0; padding-bottom: 0; }
.hours-card dt { font-weight: 650; font-size: 0.92rem; }
.hours-card dd { margin: 0; color: var(--mut); font-size: 0.92rem; }
.map-shell { border-radius: 14px; overflow: hidden; border: 1px solid color-mix(in srgb, var(--p) 9%, transparent); }
.map-shell iframe { display: block; width: 100%; height: 360px; border: 0; }
@media (max-width: 820px) { .hours-map { grid-template-columns: 1fr; } }

/* footer */
.gsite-footer {
  background: var(--p);
  color: color-mix(in srgb, #ffffff 88%, var(--p));
  padding: clamp(34px, 5vw, 56px) 0;
  margin-top: 20px;
}
.gsite-footer .wrap { display: flex; align-items: center; justify-content: space-between; gap: 18px; flex-wrap: wrap; }
.gsite-footer .made { font-size: 0.82rem; opacity: 0.75; }
.gsite-footer .made a { color: inherit; font-weight: 700; }
