/* ================================================================
   TATA GARDEN — Shared Frontend CSS  v3.0.0
   Font: Google Sans (only)
   Brand: #146653 | Natural luxury aesthetic
   ================================================================ */

/* ── Google Fonts ── */
@import url('https://fonts.googleapis.com/css2?family=Google+Sans:ital,wght@0,300;0,400;0,500;0,700;1,400&family=Google+Sans+Display:wght@400;500;700&display=swap');

/* ================================================================
   LAYOUT HELPERS  (tokens from _variables.css, base from _base.css)
================================================================ */
.tg-section { padding:96px 40px; }
.tg-inner   { max-width:1280px; margin:0 auto; }
.section-hdr { margin-bottom:64px; }
.section-hdr.center { text-align:center; }
.section-hdr h2 { font-size:clamp(32px,3.5vw,48px); margin-top:12px; }
.section-hdr p  { font-size:16px; color:var(--muted); line-height:1.75; max-width:560px; margin-top:14px; }
.section-hdr.center p { margin:14px auto 0; }

/* ================================================================
   CAROUSEL SHARED
================================================================ */
.carousel-outer {
  overflow: hidden;
  border-radius: var(--r);
  /* Room for card hover transform + shadow without clipping */
  padding: 8px 4px 36px;
  margin: -8px -4px -36px;
}
.carousel-track {
  display:flex; gap:22px;
  transition:transform .45s cubic-bezier(.4,0,.2,1);
  will-change:transform;
  cursor:grab;
}
.carousel-track:active { cursor:grabbing; }

/* Nav buttons */
.carousel-nav { display:flex; align-items:center; justify-content:center; gap:14px; margin-top:28px; }
.cnav-btn {
  width:44px; height:44px; border-radius:50%;
  background:var(--white); border:1.5px solid var(--stone);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; color:var(--g); transition:var(--transition); flex-shrink:0;
}
.cnav-btn:hover:not(:disabled) { background:var(--g); border-color:var(--g); color:#fff; box-shadow:0 4px 16px rgba(20,102,83,.25); }
.cnav-btn:disabled { opacity:.3; cursor:not-allowed; }
.cnav-btn svg { width:18px; height:18px; }

/* Dots */
.cdots { display:flex; gap:6px; align-items:center; }
.cdot { width:7px; height:7px; border-radius:50%; background:var(--g-muted); border:none; cursor:pointer; padding:0; transition:var(--transition); }
.cdot.active { width:24px; border-radius:4px; background:var(--g); }

/* ================================================================
   SECTION 1 — HERO (container style)
================================================================ */
.tg-hero {
  position:relative;
  background:#f7f9fa;
  padding:36px 36px 0;
  overflow:visible;
}
.hero-container {
  position:relative;
  max-width:1280px; margin:0 auto;
  border-radius:24px;
  overflow:hidden;
  background:var(--g-dark);
}
.hero-bg-img {
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  transition:transform 10s ease;
}
.hero-container:hover .hero-bg-img { transform:scale(1.03); }
.hero-overlay {
  position:absolute; inset:0;
  background:
    linear-gradient(110deg, rgba(13,74,59,.7) 0%, rgba(13,74,59,.42) 48%, rgba(13,74,59,.06) 100%),
    linear-gradient(to bottom, rgba(0,0,0,.12) 0%, transparent 35%, transparent 65%, rgba(0,0,0,.25) 100%);
}
.hero-inner {
  position:relative; z-index:2;
  display:grid; grid-template-columns:1fr 300px; gap:48px;
  align-items:center; padding:100px 60px 180px;
}

/* ================================================================
   ADVANTAGES (3 cards — overlap hero)
================================================================ */
.tg-advantages {
  background:linear-gradient(180deg, #f0f7f4 0%, #f8fafb 55%, #ffffff 100%);
  padding:0 36px 96px;
}
.adv-grid {
  max-width:1080px; margin:-110px auto 0;
  display:grid; grid-template-columns:repeat(3,1fr); gap:24px;
  position:relative; z-index:10;
}
.adv-card {
  background:var(--white);
  border-radius:var(--r-lg);
  padding:36px 32px;
  box-shadow:0 24px 72px rgba(20,102,83,.18);
  border-top:4px solid var(--g);
  transition:var(--transition);
}
.adv-card:hover { transform:translateY(-6px); box-shadow:0 32px 80px rgba(20,102,83,.22); }
.adv-card__num {
  font-family:'Google Sans Display',sans-serif;
  font-size:44px; font-weight:700;
  color:var(--g-pale); line-height:1; margin-bottom:16px;
}
.adv-card__title {
  font-family:'Google Sans Display',sans-serif;
  font-size:20px; font-weight:700;
  color:var(--charcoal); margin-bottom:12px; line-height:1.25;
}
.adv-card__desc { font-size:15px; color:var(--muted); line-height:1.7; }
.hero-eyebrow {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(255,255,255,.1); backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.2);
  border-radius:100px; padding:6px 16px;
  font-size:12px; font-weight:500; color:#fff;
  letter-spacing:1.5px; text-transform:uppercase;
  margin-bottom:28px;
}
.hero-eyebrow-dot { width:6px; height:6px; border-radius:50%; background:var(--gold); }
.hero-title {
  font-family:'Google Sans Display',sans-serif;
  font-size:clamp(42px,5vw,72px); font-weight:700;
  color:#fff; line-height:1.05; letter-spacing:-0.03em; margin-bottom:24px;
}
.hero-title em { font-style:normal; color:var(--gold-lt); }
.hero-desc { font-size:17px; color:rgba(255,255,255,.72); line-height:1.75; max-width:540px; margin-bottom:36px; }
.hero-ctas { display:flex; align-items:center; gap:14px; flex-wrap:wrap; }
.hero-shop-btn {
  display:inline-flex; align-items:center; gap:7px;
  padding:13px 22px; border-radius:100px;
  font-size:13.5px; font-weight:600; font-family:inherit;
  color:rgba(255,255,255,.75);
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.22);
  text-decoration:none; white-space:nowrap;
  transition:all .2s;
}
.hero-shop-btn:hover {
  color:#fff; background:rgba(255,255,255,.16);
  border-color:rgba(255,255,255,.5);
  transform:translateY(-1px);
}
.hero-badge {
  display:inline-flex; flex-direction:column; align-items:center; justify-content:center;
  width:fit-content;
  background:rgba(255,255,255,.1); backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.2);
  border-radius:var(--r); padding:16px 28px;
  text-align:center; margin-top:24px;
}
.hero-badge-num { font-family:'Google Sans Display',sans-serif; font-size:38px; font-weight:700; color:#fff; line-height:1; }
.hero-badge-lbl { font-size:12px; color:rgba(255,255,255,.6); margin-top:4px; }

.hero-weather {
  background:rgba(255,255,255,.1); backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,.15);
  border-radius:var(--r-xl); padding:28px;
  color:#fff; min-height:280px;
}
.weather-loading { text-align:center; padding:40px 20px; font-size:13px; color:rgba(255,255,255,.55); }
.weather-top { display:flex; align-items:flex-start; justify-content:space-between; margin-bottom:8px; }
.weather-temp { font-family:'Google Sans Display',sans-serif; font-size:60px; font-weight:700; line-height:1; }
.weather-desc { font-size:14px; color:rgba(255,255,255,.7); text-transform:capitalize; margin-bottom:10px; }
.weather-city { display:flex; align-items:center; gap:5px; font-size:12.5px; color:rgba(255,255,255,.55); }
.weather-divider { height:1px; background:rgba(255,255,255,.12); margin:18px 0; }
.weather-extra { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.weather-extra-item { font-size:12px; color:rgba(255,255,255,.55); }
.weather-extra-item span+span { display:block; font-size:14px; font-weight:500; color:#fff; margin-top:2px; }
.weather-datetime { margin-top:18px; padding-top:18px; border-top:1px solid rgba(255,255,255,.12); }
.weather-date { font-size:12px; color:rgba(255,255,255,.5); margin-bottom:4px; }
.weather-time { font-family:'Google Sans Display',sans-serif; font-size:28px; font-weight:500; letter-spacing:2px; }

.hero-wave { position:absolute; bottom:0; left:0; right:0; line-height:0; }

/* ================================================================
   SECTION 2 — ABOUT
================================================================ */
.tg-about {
  background:linear-gradient(208deg, var(--white) 50%, #eef6f2 100%);
  overflow:visible;
}
.about-grid {
  display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center;
  overflow:visible;
}

/* ── Car scene (right column) ── */
.about-car-wrap { position:relative; overflow:visible; }
.about-car-scene {
  position:relative; overflow:visible;
  min-height:480px;
  display:flex; align-items:flex-end; justify-content:center;
  padding-top:64px;
}

/* car PNG — transparent BG, floats up */
.about-car-img {
  display:block; position:relative; z-index:2;
  width:115%; max-width:none;
  margin-left:-7.5%;
  filter:drop-shadow(0 40px 56px rgba(20,102,83,.22));
  animation:about-car-float 5s ease-in-out infinite;
  will-change:transform;
}
@keyframes about-car-float {
  0%,100% { transform:translateY(0) rotate(0deg); }
  50%      { transform:translateY(-18px) rotate(-0.3deg); }
}

/* ── About photos — overflow / transparent-bg / floating ── */
.about-photo-main {
  display:block;
  position:relative; z-index:2;
  width:110%; max-width:none;
  margin-left:-5%;
  filter:drop-shadow(0 40px 56px rgba(20,102,83,.22));
  animation:about-car-float 5s ease-in-out infinite;
  will-change:transform;
}
.about-photo-sub {
  position:absolute;
  bottom:16px; left:-8%;
  width:52%;
  z-index:3;
  filter:drop-shadow(0 24px 36px rgba(20,102,83,.2));
  animation:about-car-float 4.4s 1.6s ease-in-out infinite;
  will-change:transform;
}

/* ground glow synced with car */
.car-ground {
  position:absolute; bottom:4px; left:8%; width:84%; height:38px;
  background:radial-gradient(ellipse, rgba(20,102,83,.2) 0%, transparent 68%);
  z-index:1;
  animation:car-ground-pulse 5s ease-in-out infinite;
}
@keyframes car-ground-pulse {
  0%,100% { transform:scaleX(1); opacity:.85; }
  50%      { transform:scaleX(.8); opacity:.4; }
}

/* ── Floating stat badges ── */
.car-stat {
  position:absolute; z-index:5;
  background:rgba(255,255,255,.94);
  backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
  border:1px solid rgba(20,102,83,.13);
  border-radius:16px; padding:16px 20px;
  box-shadow:0 10px 32px rgba(20,102,83,.14), 0 2px 8px rgba(0,0,0,.04);
  text-align:center; min-width:96px;
}
.cs-icon {
  width:28px; height:28px; border-radius:8px;
  background:var(--g-pale); color:var(--g);
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 8px;
}
.cs-num {
  font-family:'Google Sans Display',sans-serif;
  font-size:26px; font-weight:700; color:var(--g); line-height:1;
}
.cs-lbl {
  font-size:11px; font-weight:500; color:var(--muted);
  margin-top:4px; white-space:nowrap;
}

/* individual positions + staggered float */
.cs-1 { top:6%;    left:-4%;   animation:cs-float 3.8s 0s ease-in-out infinite; }
.cs-2 { top:2%;    right:-2%;  animation:cs-float 4.3s .7s ease-in-out infinite; }
.cs-3 { bottom:28%; left:1%;   animation:cs-float 4.0s 1.3s ease-in-out infinite; }
.cs-4 { bottom:24%; right:-1%; animation:cs-float 3.6s 0.4s ease-in-out infinite; }

@keyframes cs-float {
  0%,100% { transform:translateY(0); }
  50%      { transform:translateY(-10px); }
}

/* ── About text (left) ── */
.about-text p { font-size:15.5px; color:var(--muted); line-height:1.8; margin-bottom:14px; }
.about-feats { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-top:28px; }
.about-feat {
  display:flex; gap:12px; align-items:flex-start;
  background:#f0f7f4; border-radius:var(--r); padding:16px;
  transition:var(--transition);
}
.about-feat:hover { transform:translateY(-3px); box-shadow:var(--shadow-sm); }
.about-feat-icon { width:38px; height:38px; border-radius:9px; background:var(--g); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.about-feat-icon svg { width:17px; height:17px; color:#fff; }
.about-feat-title { font-size:13.5px; font-weight:500; color:var(--charcoal); margin-bottom:2px; }
.about-feat-desc  { font-size:12px; color:var(--muted); line-height:1.5; }

/* ================================================================
   SECTION 3 — STATS
================================================================ */
.tg-stats {
  background: var(--g-dark);
  padding: 0;
  position: relative;
  overflow: visible;
  min-height: 480px;
}

/* ── Hình ảnh overflow trái ── */
.stats-img-col {
  position: absolute;
  top: 0; left: 36px; right: 54%; bottom: -80px;
  z-index: 2;
  border-radius: 20px;
  overflow: hidden;
}
.stats-img-col img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: center;
  display: block;
}
.stats-img-fade { display: none; }
.stats-img-col--empty .stats-img-fade { display: none; }

/* ── Layout: spacer trái + grid phải ── */
.stats-inner {
  max-width: 1280px;
  margin: 0 auto;
  padding-inline: 40px;
  display: grid;
  grid-template-columns: 46% 54%;
  min-height: 480px;
  position: relative;
  z-index: 3;
}
.stats-void { /* empty — image sits in absolute layer behind */ }

.stats-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0;
  align-content: center;
  padding: 72px 0 72px 52px;
}

/* ── Stat items — left-aligned, no separators ── */
.stat-item {
  padding: 24px 32px 24px 0;
  position: relative;
  text-align: left;
}
.stat-item::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0;
  width: calc(100% - 32px);
  height: 1px;
  background: rgba(255,255,255,.08);
}
.stat-item:nth-child(n+3)::after { display: none; }

.stat-num {
  font-family: 'Google Sans Display', sans-serif;
  font-size: 58px; font-weight: 700;
  color: #fff; line-height: 1;
  margin-bottom: 10px;
  letter-spacing: -.02em;
}
.stat-num em { color: var(--g-muted); font-style: normal; font-size: .65em; }
.stat-lbl {
  font-size: 12.5px; font-weight: 500;
  color: rgba(255,255,255,.5);
  letter-spacing: .12em;
  text-transform: uppercase;
}

/* ================================================================
   SECTION 4 — SERVICES
================================================================ */
.tg-services { background:var(--cream); padding:120px 40px; position:relative; z-index:4; }
.services-featured { display:grid; grid-template-columns:1fr 1fr; gap:32px; margin-bottom:32px; }
.services-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }

.svc-featured-card {
  position:relative; border-radius:var(--r-xl); overflow:hidden;
  min-height:560px; display:flex; flex-direction:column; justify-content:flex-end;
  cursor:pointer; transition:transform .3s,box-shadow .3s;
}
.svc-featured-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-lg); }
.svc-card-bg { position:absolute; inset:0; background-size:cover; background-position:center; transition:transform .5s ease; }
.svc-featured-card:hover .svc-card-bg { transform:scale(1.04); }
.svc-card-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(13,74,59,.95) 0%,rgba(13,74,59,.5) 50%,transparent 100%); }
.svc-card-body { position:relative; z-index:2; padding:40px 36px; }
.svc-badge { display:inline-flex; align-items:center; gap:6px; background:var(--gold); color:var(--charcoal); font-size:10.5px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; padding:4px 12px; border-radius:100px; margin-bottom:16px; }
.svc-card-title { font-family:'Google Sans Display',sans-serif; font-size:clamp(22px,2.2vw,30px); font-weight:700; color:#fff; line-height:1.2; margin-bottom:16px; }
.svc-card-desc { font-size:14.5px; color:rgba(255,255,255,.72); line-height:1.7; margin-bottom:24px; }
.svc-card-points { display:flex; flex-direction:column; gap:8px; margin-bottom:28px; }
.svc-card-points li { display:flex; align-items:flex-start; gap:8px; font-size:13.5px; color:rgba(255,255,255,.82); }
.svc-card-points li svg { width:14px; height:14px; color:var(--gold-lt); margin-top:2px; flex-shrink:0; }
.svc-card-cta { display:inline-flex; align-items:center; gap:8px; background:rgba(255,255,255,.12); backdrop-filter:blur(8px); border:1px solid rgba(255,255,255,.25); border-radius:100px; padding:11px 22px; font-size:13.5px; font-weight:500; color:#fff; transition:var(--transition); }
.svc-card-cta:hover { background:rgba(255,255,255,.22); border-color:rgba(255,255,255,.5); }
.svc-card-cta svg { width:14px; height:14px; }
.svc-card-bg.svc-bg-1 { background:linear-gradient(135deg,var(--g-dark) 0%,var(--g-mid) 100%); }
.svc-card-bg.svc-bg-2 { background:linear-gradient(135deg,#1c3a30 0%,#0d4a3b 100%); }

/* Mini service card */
.svc-mini-card {
  background:var(--white); border:1px solid var(--stone); border-radius:var(--r-lg);
  padding:28px 24px; transition:var(--transition); cursor:pointer; position:relative; overflow:hidden;
}
.svc-mini-card::before { content:''; position:absolute; bottom:0; left:0; right:0; height:3px; background:var(--g); transform:scaleX(0); transition:transform .3s; }
.svc-mini-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); border-color:var(--g-muted); }
.svc-mini-card:hover::before { transform:scaleX(1); }
.svc-mini-icon { width:52px; height:52px; border-radius:14px; background:var(--g-pale); display:flex; align-items:center; justify-content:center; margin-bottom:18px; }
.svc-mini-icon svg { width:24px; height:24px; color:var(--g); }
.svc-mini-title { font-size:15px; font-weight:600; color:var(--charcoal); margin-bottom:8px; }
.svc-mini-desc  { font-size:13px; color:var(--muted); line-height:1.6; margin-bottom:16px; }
.svc-mini-link  { display:inline-flex; align-items:center; gap:5px; font-size:13px; font-weight:500; color:var(--g); }
.svc-mini-link svg { width:13px; height:13px; transition:transform .2s; }
.svc-mini-card:hover .svc-mini-link svg { transform:translateX(3px); }

/* ================================================================
   SECTION 5 — SHOP
================================================================ */
.tg-shop {
  background: linear-gradient(155deg, #eef7f3 0%, #fafffe 55%, #f2f8f5 100%);
  position: relative;
  overflow: hidden;
}
.tg-shop::before {
  content: '';
  position: absolute;
  top: -160px; right: -160px;
  width: 580px; height: 580px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(20,102,83,.07) 0%, transparent 68%);
  pointer-events: none;
}
.tg-shop::after {
  content: '';
  position: absolute;
  bottom: -100px; left: -100px;
  width: 420px; height: 420px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(201,168,76,.06) 0%, transparent 68%);
  pointer-events: none;
}

.shop-tabs-row {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 16px; margin-bottom: 32px;
  padding-bottom: 28px;
  border-bottom: 1px solid rgba(20,102,83,.1);
  position: relative; z-index: 1;
}
.shop-tabs { display:flex; gap:8px; flex-wrap:wrap; }
.shop-tab {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 10px 22px; border-radius: 100px;
  border: 1.5px solid rgba(20,102,83,.2);
  background: rgba(255,255,255,.8); color: var(--ink);
  font-size: 13.5px; font-weight: 500; font-family: inherit;
  cursor: pointer; transition: var(--transition);
  backdrop-filter: blur(4px);
}
.shop-tab:hover { border-color: var(--g); color: var(--g); background: rgba(255,255,255,.95); }
.shop-tab.active {
  background: var(--g); border-color: var(--g); color: #fff;
  box-shadow: 0 6px 20px rgba(20,102,83,.3);
}
.shop-tab-dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor; opacity: .5; }
.shop-tab.active .shop-tab-dot { opacity: .8; }
.shop-view-all {
  display: inline-flex; align-items: center; gap: 7px;
  font-size: 13.5px; font-weight: 600; color: var(--g);
  border: 1.5px solid var(--g); border-radius: 100px;
  padding: 10px 22px; transition: var(--transition); flex-shrink: 0;
  background: rgba(255,255,255,.7);
}
.shop-view-all:hover { background: var(--g); color: #fff; box-shadow: 0 6px 20px rgba(20,102,83,.25); }
.shop-view-all svg { width: 14px; height: 14px; }

.shop-panels { position: relative; z-index: 1; }
.shop-panel { display: none; }
.shop-panel.active { display: block; }

/* Product card */
.prod-card {
  flex: 0 0 calc((100% - 66px) / 4);
  background: #fff;
  border-radius: 18px;
  border: 1px solid rgba(20,102,83,.09);
  overflow: hidden;
  transition: transform .28s cubic-bezier(.4,0,.2,1), box-shadow .28s cubic-bezier(.4,0,.2,1), border-color .2s;
  box-shadow: 0 4px 20px rgba(20,102,83,.07);
}
.prod-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 24px 56px rgba(20,102,83,.15);
  border-color: rgba(20,102,83,.2);
}
.prod-img-wrap { position: relative; height: 260px; background: var(--g-pale); overflow: hidden; }
.prod-img-wrap img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.prod-card:hover .prod-img-wrap img { transform: scale(1.06); }
.prod-badge {
  position: absolute; top: 12px; left: 12px;
  font-size: 10px; font-weight: 700; letter-spacing: .8px; text-transform: uppercase;
  padding: 4px 12px; border-radius: 100px; z-index: 2;
}
.prod-badge.sale { background: #e05252; color: #fff; box-shadow: 0 3px 10px rgba(224,82,82,.35); }
.prod-badge.featured { background: var(--gold); color: var(--charcoal); box-shadow: 0 3px 10px rgba(201,168,76,.4); }
.prod-wish {
  position: absolute; top: 12px; right: 12px;
  width: 34px; height: 34px;
  background: rgba(255,255,255,.92); border: none; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: var(--transition); z-index: 2;
  opacity: 0; transform: scale(.8);
  box-shadow: 0 2px 10px rgba(0,0,0,.1);
}
.prod-card:hover .prod-wish { opacity: 1; transform: scale(1); }
.prod-wish svg { width: 15px; height: 15px; color: var(--muted); }
.prod-quick {
  position: absolute; bottom: 0; left: 0; right: 0;
  padding: 12px 14px;
  background: linear-gradient(to top, rgba(13,74,59,.96) 0%, rgba(13,74,59,.5) 60%, transparent 100%);
  transform: translateY(100%);
  transition: transform .32s cubic-bezier(.4,0,.2,1);
}
.prod-card:hover .prod-quick { transform: translateY(0); }
.prod-add-btn {
  display: flex; align-items: center; justify-content: center; gap: 7px;
  width: 100%; padding: 10px;
  background: var(--g); color: #fff;
  border: none; border-radius: 10px;
  font-size: 13px; font-weight: 600; cursor: pointer;
  font-family: inherit; transition: background .15s;
  letter-spacing: .02em;
}
.prod-add-btn:hover { background: var(--g-dark); }
.prod-add-btn svg { width: 14px; height: 14px; }
.prod-body { padding: 18px 20px 22px; }
.prod-cat { font-size: 10px; font-weight: 700; letter-spacing: 1.6px; text-transform: uppercase; color: var(--g); margin-bottom: 6px; opacity: .8; }
.prod-title {
  font-size: 15.5px; font-weight: 600; color: var(--charcoal);
  margin-bottom: 8px; line-height: 1.35;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.prod-stars { display: flex; align-items: center; gap: 5px; margin-bottom: 10px; }
.star-row   { display: flex; gap: 1px; }
.star  { font-size: 12px; color: #f5a623; }
.star.empty { color: #ddd; }
.review-ct { font-size: 11px; color: var(--muted); }
.prod-price {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
  margin-top: 4px;
  padding-top: 12px;
  border-top: 1px solid rgba(20,102,83,.07);
}
.prod-price .woocommerce-Price-amount { font-size: 18px; font-weight: 700; color: var(--charcoal); }
.prod-price ins  { text-decoration: none; }
.prod-price ins  .woocommerce-Price-amount { color: #d94040; font-size: 19px; }
.prod-price del  .woocommerce-Price-amount { font-size: 13px; color: #bbb; font-weight: 400; }
.out-of-stock { font-size: 11.5px; background: #f0f0f0; color: #aaa; padding: 2px 9px; border-radius: 4px; }

/* ================================================================
   SECTION 6 — PROJECTS / GALLERY
================================================================ */
.tg-projects { background:var(--cream); }
.projects-filters { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:40px; }
.pf-btn {
  display:inline-flex; align-items:center; gap:6px;
  padding:8px 18px; border-radius:100px;
  border:1.5px solid var(--stone); background:var(--white);
  font-size:13px; font-weight:500; color:var(--ink);
  cursor:pointer; transition:var(--transition); font-family:inherit;
}
.pf-btn:hover { border-color:var(--g); color:var(--g); }
.pf-btn.active { background:var(--g); border-color:var(--g); color:#fff; }

.projects-masonry {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
.proj-card {
  position:relative; border-radius:var(--r-lg); overflow:hidden;
  cursor:pointer; transition:transform .3s,box-shadow .3s;
  background:var(--g-pale);
}
.proj-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.proj-card.tall { grid-row:span 2; }
.proj-img { width:100%; height:100%; min-height:260px; object-fit:cover; transition:transform .5s ease; display:block; }
.proj-card.tall .proj-img { min-height:540px; }
.proj-card:hover .proj-img { transform:scale(1.04); }
.proj-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top,rgba(13,74,59,.9) 0%,transparent 60%);
  opacity:0; transition:opacity .3s;
}
.proj-card:hover .proj-overlay { opacity:1; }
.proj-info { position:absolute; bottom:0; left:0; right:0; padding:24px; transform:translateY(8px); opacity:0; transition:var(--transition); }
.proj-card:hover .proj-info { transform:none; opacity:1; }
.proj-cat  { font-size:10px; font-weight:600; letter-spacing:2px; text-transform:uppercase; color:var(--gold-lt); margin-bottom:6px; }
.proj-name { font-size:17px; font-weight:600; color:#fff; line-height:1.3; }
.proj-meta { font-size:12px; color:rgba(255,255,255,.6); margin-top:4px; }
.proj-view-all-wrap { text-align:center; margin-top:48px; }

/* ================================================================
   SECTION 7 — CONNECT / PROCESS
================================================================ */
.tg-connect { background:var(--g-dark); position:relative; overflow:hidden; }
.tg-connect::before { content:''; position:absolute; inset:0; background:url('https://images.unsplash.com/photo-1416879595882-3373a0480b5b?w=1400&q=60') center/cover no-repeat; opacity:.07; }
.tg-connect .t-label { color:var(--g-muted); }
.tg-connect h2    { color:#fff; }
.tg-connect .section-hdr p { color:rgba(255,255,255,.6); }
.connect-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; position:relative; }
.connect-grid::before { content:''; position:absolute; top:38px; left:80px; right:80px; height:1px; background:rgba(255,255,255,.1); z-index:0; }
.connect-card { background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1); border-radius:var(--r-lg); padding:32px 24px; position:relative; z-index:1; transition:background .2s; }
.connect-card:hover { background:rgba(255,255,255,.1); }
.connect-num { position:absolute; top:-16px; left:22px; width:32px; height:32px; background:var(--g); color:#fff; border-radius:50%; font-size:13px; font-weight:600; display:flex; align-items:center; justify-content:center; border:3px solid var(--g-dark); }
.connect-icon { width:52px; height:52px; background:rgba(255,255,255,.08); border-radius:14px; display:flex; align-items:center; justify-content:center; margin-bottom:18px; }
.connect-icon svg { width:24px; height:24px; color:var(--g-muted); }
.connect-title { font-size:15.5px; font-weight:500; color:#fff; margin-bottom:8px; }
.connect-desc  { font-size:13px; color:rgba(255,255,255,.5); line-height:1.65; }
.connect-cta-wrap { text-align:center; margin-top:56px; }

/* ================================================================
   SECTION 8 — TESTIMONIALS
================================================================ */
.tg-testi { background:var(--cream-2); }
.testi-carousel-wrap { position:relative; }
.testi-track-outer { overflow:hidden; }
.testi-track { display:flex; gap:24px; transition:transform .45s cubic-bezier(.4,0,.2,1); }
.testi-card {
  flex:0 0 calc((100% - 48px) / 3);
  background:var(--white); border-radius:var(--r-xl);
  padding:36px 32px; border:1px solid var(--stone);
  position:relative; overflow:hidden; transition:box-shadow .25s;
}
.testi-card:hover { box-shadow:var(--shadow-md); }
.testi-card::before { content:'\201C'; position:absolute; top:-10px; right:24px; font-family:'Google Sans Display',sans-serif; font-size:120px; color:var(--g-pale); line-height:1; z-index:0; }
.testi-stars { display:flex; gap:3px; margin-bottom:18px; position:relative; z-index:1; }
.testi-star  { font-size:15px; color:#f5a623; }
.testi-text  { font-size:15px; line-height:1.75; color:var(--ink); margin-bottom:24px; position:relative; z-index:1; }
.testi-author { display:flex; align-items:center; gap:13px; position:relative; z-index:1; }
.testi-avatar { width:48px; height:48px; border-radius:50%; object-fit:cover; border:2px solid var(--g-pale); }
.testi-avatar-placeholder { width:48px; height:48px; border-radius:50%; background:var(--g); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.testi-avatar-placeholder svg { width:22px; height:22px; color:#fff; }
.testi-name { font-size:14px; font-weight:500; color:var(--charcoal); }
.testi-role { font-size:12px; color:var(--muted); }
.testi-nav  { display:flex; align-items:center; justify-content:center; gap:14px; margin-top:32px; }

/* ================================================================
   SECTION 9 — BLOG / TIN TỨC
================================================================ */
.tg-blog { background:var(--white); }
.blog-grid { display:grid; grid-template-columns:1fr 1fr 1fr; gap:28px; }
.blog-card {
  border-radius:var(--r-lg); overflow:hidden;
  border:1px solid var(--stone); background:var(--white);
  transition:var(--transition);
}
.blog-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); border-color:var(--g-muted); }
.blog-img-wrap { position:relative; height:220px; overflow:hidden; background:var(--g-pale); }
.blog-img-wrap img { width:100%; height:100%; object-fit:cover; transition:transform .4s ease; }
.blog-card:hover .blog-img-wrap img { transform:scale(1.04); }
.blog-cat-tag { position:absolute; top:14px; left:14px; background:var(--g); color:#fff; font-size:10px; font-weight:600; letter-spacing:1px; text-transform:uppercase; padding:4px 10px; border-radius:100px; }
.blog-body { padding:24px; }
.blog-meta { display:flex; align-items:center; gap:12px; font-size:12px; color:var(--muted); margin-bottom:12px; }
.blog-meta svg { width:12px; height:12px; }
.blog-title { font-size:17px; font-weight:600; color:var(--charcoal); line-height:1.4; margin-bottom:10px; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; transition:color .2s; }
.blog-card:hover .blog-title { color:var(--g); }
.blog-excerpt { font-size:13.5px; color:var(--muted); line-height:1.65; margin-bottom:18px; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; }
.blog-read-more { display:inline-flex; align-items:center; gap:5px; font-size:13px; font-weight:500; color:var(--g); }
.blog-read-more svg { width:13px; height:13px; transition:transform .2s; }
.blog-card:hover .blog-read-more svg { transform:translateX(3px); }
.blog-view-all-wrap { text-align:center; margin-top:48px; }

/* ================================================================
   SECTION 10 — CTA BANNER
================================================================ */
.tg-cta-banner {
  padding:0; position:relative;
  background:linear-gradient(140deg, #0d4a3b 0%, #146653 45%, #1a7a63 100%);
  /* ── Full-width breakout: works even inside any max-width container ── */
  width: 100vw;
  margin-left: calc(50% - 50vw);
  box-sizing: border-box;
}
.tg-cta-banner::before {
  content:''; position:absolute; inset:0; pointer-events:none; z-index:0;
  background:
    radial-gradient(ellipse at 15% 70%,  rgba(201,168,76,.18) 0%,transparent 46%),
    radial-gradient(ellipse at 85% 35%,  rgba(31,148,120,.22) 0%,transparent 46%),
    radial-gradient(ellipse at 50% 100%, rgba(255,255,255,.04) 0%,transparent 55%);
}

/* ── Box: flex 2 cột, overflow visible để ảnh tràn lên trên ── */
.cta-banner-box {
  display:flex; align-items:stretch;
  width:100%;
  position:relative; overflow:visible;
  min-height:460px;
  z-index:1;
}

/* Wrapper riêng clip rings — không ảnh hưởng image overflow */
.ctab-deco-clip {
  position:absolute; inset:0;
  overflow:hidden; pointer-events:none; z-index:0;
}
.ctab-ring { position:absolute; border-radius:50%; pointer-events:none; }
.ctab-ring--1 {
  width:460px; height:460px; top:-160px; right:-110px;
  border:1px solid rgba(255,255,255,.055); background:rgba(255,255,255,.018);
}
.ctab-ring--2 {
  width:300px; height:300px; top:-90px; right:-48px;
  border:1px solid rgba(201,168,76,.12);
}

/* ── Cột trái: chứa ảnh overflow ── */
.ctab-left {
  flex:0 0 42%;
  position:relative;
  overflow:visible;
}

/* Ảnh: wrapper fill toàn cột, ảnh đáy sát đáy section, tràn lên trên */
.ctab-img-wrap {
  position:absolute;
  top:0; bottom:0; left:0; right:0;
  display:flex; justify-content:center; align-items:flex-end;
  z-index:5; pointer-events:none;
  overflow:visible;
}
.ctab-img {
  display:block;
  width:clamp(260px, 33vw, 600px);
  max-height:120%;
  height:auto;
  filter:drop-shadow(0 24px 48px rgba(0,0,0,.45));
  position:relative; z-index:1;
  flex-shrink:0;
}

/* ── Floating badges ── */
.ctab-badge {
  position:absolute; z-index:2;
  background:rgba(255,255,255,.96);
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  border-radius:14px;
  box-shadow:0 8px 32px rgba(0,0,0,.18), 0 2px 6px rgba(0,0,0,.06);
  border:1px solid rgba(255,255,255,.85);
  padding:12px 16px;
  white-space:nowrap;
}
.ctab-badge--rating {
  top:6%; right:12%;
  display:flex; flex-direction:column; align-items:flex-start; gap:4px;
  animation:ctab-float 4.0s 0s ease-in-out infinite;
}
.ctab-badge--project {
  top:40%; left:20px;
  display:flex; align-items:center; gap:10px;
  animation:ctab-float 3.7s 0.9s ease-in-out infinite;
}
.ctab-badge--speed {
  top:66%; right:10%;
  display:flex; align-items:center; gap:10px;
  animation:ctab-float 4.4s 1.8s ease-in-out infinite;
}
@keyframes ctab-float {
  0%,100% { transform:translateY(0); }
  50%      { transform:translateY(-12px); }
}
.ctab-bdg-stars { display:flex; gap:2px; }
.ctab-bdg-num {
  display:block; font-family:'Google Sans Display',sans-serif;
  font-size:20px; font-weight:700; color:var(--charcoal); line-height:1;
}
.ctab-bdg-lbl { display:block; font-size:11px; font-weight:500; color:var(--muted); margin-top:2px; }
.ctab-bdg-icon {
  width:32px; height:32px; border-radius:8px;
  background:var(--g-pale); color:var(--g);
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.ctab-bdg-icon--gold { background:rgba(201,168,76,.15); color:var(--gold); }

/* ── Cột phải: content ── */
.ctab-right {
  flex:1; display:flex; align-items:center;
  padding:64px 80px 64px 48px;
  position:relative; z-index:2;
}
.cta-banner-inner { width:100%; }

/* Không có ảnh: cột phải full-width, căn giữa */
.tg-cta-banner:not(.has-img) .ctab-right { padding:64px 80px; justify-content:center; }
.tg-cta-banner:not(.has-img) .cta-banner-inner { max-width:680px; text-align:center; }
.tg-cta-banner:not(.has-img) .ctab-actions { justify-content:center; }
.tg-cta-banner:not(.has-img) .ctab-contact-row { justify-content:center; }

/* Eyebrow */
.ctab-eyebrow {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(201,168,76,.15); border:1px solid rgba(201,168,76,.35);
  border-radius:100px; padding:7px 18px 7px 12px;
  font-size:11px; font-weight:600; letter-spacing:1.8px; text-transform:uppercase;
  color:var(--gold-lt); margin-bottom:24px;
}
.ctab-eyebrow svg { color:var(--gold-lt); flex-shrink:0; }

/* Heading */
.ctab-title {
  color:#fff !important;
  font-size:clamp(32px,3.8vw,56px) !important;
  line-height:1.1 !important;
  margin:0 0 20px !important;
}

/* Description */
.ctab-desc { color:rgba(255,255,255,.65); font-size:17px; line-height:1.75; margin-bottom:36px; }

/* Buttons */
.ctab-actions { display:flex; flex-wrap:wrap; gap:14px; margin-bottom:32px; }
.ctab-btn-secondary {
  display:inline-flex; align-items:center; gap:9px;
  padding:15px 28px; border-radius:100px;
  font-size:15px; font-weight:600; font-family:inherit;
  color:#fff; background:rgba(255,255,255,.1);
  border:1.5px solid rgba(255,255,255,.55);
  text-decoration:none; transition:all .2s;
  white-space:nowrap;
}
.ctab-btn-secondary:hover { background:rgba(255,255,255,.18); border-color:#fff; color:#fff; }
.ctab-btn-secondary svg { flex-shrink:0; }

/* Contact row */
.ctab-contact-row {
  display:flex; align-items:center; flex-wrap:wrap; gap:10px;
  padding-top:24px; border-top:1px solid rgba(255,255,255,.1);
}
.ctab-contact-pill {
  display:inline-flex; align-items:center; gap:7px;
  color:rgba(255,255,255,.52); font-size:13px;
  text-decoration:none; transition:color .15s;
}
.ctab-contact-pill:hover { color:var(--gold-lt); }
.ctab-contact-pill svg { color:var(--gold-lt); flex-shrink:0; }
.ctab-contact-dot { width:4px; height:4px; border-radius:50%; background:rgba(255,255,255,.2); flex-shrink:0; }

/* ================================================================
   SECTION 11 — FAQ
================================================================ */
.tg-faq { background:var(--white); }
.faq-layout { display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:start; }
.faq-sidebar h3 { font-family:'Google Sans Display',sans-serif; font-size:clamp(26px,2.5vw,36px); font-weight:700; color:var(--charcoal); line-height:1.2; margin:12px 0 16px; }
.faq-sidebar p  { font-size:15px; color:var(--muted); line-height:1.75; margin-bottom:28px; }
.faq-contact-card { background:var(--g-pale); border:1px solid var(--g-muted); border-radius:var(--r-lg); padding:24px; }
.faq-contact-card p { font-size:13.5px; color:var(--muted); margin-bottom:0; }
.faq-contact-card a { color:var(--g); font-weight:500; }
.faq-list { display:flex; flex-direction:column; gap:10px; }
.faq-item { border:1.5px solid var(--stone); border-radius:var(--r); overflow:hidden; transition:border-color .2s; }
.faq-item.open { border-color:var(--g); }
.faq-q { padding:18px 22px; display:flex; align-items:center; justify-content:space-between; cursor:pointer; font-size:15px; font-weight:500; color:var(--charcoal); gap:16px; user-select:none; transition:background .15s; }
.faq-q:hover { background:var(--g-pale); }
.faq-item.open .faq-q { background:var(--g-pale); }
.faq-icon { width:26px; height:26px; border-radius:50%; background:var(--g-pale); display:flex; align-items:center; justify-content:center; flex-shrink:0; transition:background .2s,transform .3s; }
.faq-item.open .faq-icon { background:var(--g); transform:rotate(45deg); }
.faq-icon svg { width:12px; height:12px; color:var(--g); }
.faq-item.open .faq-icon svg { color:#fff; }
.faq-a { max-height:0; overflow:hidden; transition:max-height .35s ease,padding .3s; font-size:14.5px; color:var(--muted); line-height:1.75; padding:0 22px; }
.faq-item.open .faq-a { max-height:300px; padding:0 22px 20px; }

/* ================================================================
   SECTION 12 — PARTNERS
================================================================ */
.tg-partners { background:var(--cream); padding:56px 40px; border-top:1px solid var(--stone); }
.partners-inner { max-width:1280px; margin:0 auto; }
.partners-label { text-align:center; margin-bottom:32px; }
.partners-track { display:flex; align-items:center; justify-content:center; flex-wrap:wrap; gap:12px; }
.partner-item { display:flex; align-items:center; justify-content:center; padding:14px 24px; background:var(--white); border:1px solid var(--stone); border-radius:var(--r); min-width:140px; height:64px; transition:var(--transition); filter:grayscale(1); opacity:.5; }
.partner-item:hover { filter:grayscale(0); opacity:1; box-shadow:var(--shadow-sm); transform:translateY(-2px); }
.partner-item img { max-height:36px; max-width:100%; object-fit:contain; }
.partner-name { font-size:16px; font-weight:600; color:var(--muted); font-family:'Google Sans Display',sans-serif; }
.partner-item:hover .partner-name { color:var(--g); }

/* ================================================================
   RESPONSIVE
================================================================ */
@media (max-width:1200px) {
  .prod-card { flex:0 0 calc((100% - 44px) / 3); }
  .services-grid { grid-template-columns:repeat(2,1fr); }
  .blog-grid { grid-template-columns:1fr 1fr; }
}
@media (max-width:1024px) {
  .hero-inner { grid-template-columns:1fr; padding:80px 36px 160px; }
  .hero-weather { display:block; }
  .adv-grid { grid-template-columns:1fr; margin-top:-80px; }
  .about-grid { grid-template-columns:1fr; gap:40px; }
  .about-car-wrap { order:-1; }
  .about-car-scene { min-height:340px; padding-top:40px; }
  .about-car-img { width:100%; margin-left:0; }
  .about-photo-main { width:100%; margin-left:0; }
  .about-photo-sub  { width:48%; bottom:12px; left:-4%; }
  .cs-1 { top:2%;   left:0; }
  .cs-2 { top:2%;   right:0; }
  .cs-3 { bottom:20%; left:0; }
  .cs-4 { bottom:16%; right:0; }
  .stat-item:nth-child(3)::before { display:none; }
  .services-featured { grid-template-columns:1fr; }
  .svc-featured-card { min-height:400px; }
  .connect-grid { grid-template-columns:repeat(2,1fr); }
  .connect-grid::before { display:none; }
  .testi-card { flex:0 0 calc((100% - 24px) / 2); }
  .faq-layout { grid-template-columns:1fr; gap:40px; }
  .ctab-right { padding:48px 48px 48px 32px; }
  .projects-masonry { grid-template-columns:repeat(2,1fr); }
  .proj-card.tall { grid-row:span 1; }
  .proj-card.tall .proj-img { min-height:260px; }
}
@media (max-width:768px) {
  .tg-section { padding:64px 24px; }
  .tg-stats    { min-height: 0; }
  .stats-img-col { position:relative; width:100%; height:280px; }
  .stats-inner { grid-template-columns:1fr; padding-inline:24px; min-height:0; }
  .stats-void  { display:none; }
  .stats-grid  { padding:48px 0; grid-template-columns:repeat(2,1fr); }
  .stat-item   { padding:16px 16px 16px 0; }
  .stat-item::after { width:calc(100% - 16px); }
  .stat-num    { font-size:44px; }
  .tg-partners { padding:40px 24px; }
  .tg-hero     { padding:16px 16px 0; }
  .tg-advantages { padding:0 16px 64px; }
  .adv-grid    { gap:16px; }
  .adv-card    { padding:28px 24px; }
  .section-hdr { margin-bottom:40px; }
  .prod-card { flex:0 0 calc((100% - 22px) / 2); }
  .blog-grid { grid-template-columns:1fr; }
  .testi-card { flex:0 0 100%; }
  .projects-masonry { grid-template-columns:1fr; }
  .ctab-left { flex:0 0 36%; }
  .ctab-right { padding:48px 32px; }
  .ctab-img { width:clamp(200px, 32vw, 400px); }
  .ctab-badge { padding:9px 12px; }
  .ctab-bdg-num { font-size:17px; }
  .ctab-badge--rating { right:4%; }
  .ctab-badge--project { left:2%; }
  .ctab-badge--speed { right:4%; }
  .ctab-actions { flex-direction:column; align-items:flex-start; }
  .ctab-actions .btn { width:100%; justify-content:center; max-width:380px; }

  /* ── Hero mobile ── */
  .hero-inner   { padding:48px 24px 100px; gap:0; }
  .hero-weather { display:none; }
  .hero-title   { font-size:clamp(30px,8vw,46px); margin-bottom:16px; }
  .hero-desc    { font-size:15px; margin-bottom:24px; }
  .hero-ctas    { flex-direction:column; align-items:stretch; gap:10px; }
  .hero-ctas .btn, .hero-shop-btn { justify-content:center; width:100%; }
  .btn-lg       { padding:15px 24px; font-size:14.5px; }
}
@media (max-width:480px) {
  .ctab-left { display:none; }
  .ctab-right { padding:48px 20px; justify-content:center; }
  .cta-banner-inner { text-align:center; }
  .ctab-eyebrow { justify-content:center; }
  .ctab-actions { flex-direction:column; align-items:center; }
  .ctab-contact-row { justify-content:center; }
  .prod-card { flex:0 0 calc(100% - 22px); }
  .about-feats { grid-template-columns:1fr; }
  .connect-grid { grid-template-columns:1fr; }
  .hero-inner  { padding:40px 20px 90px; }
  .hero-title  { font-size:clamp(26px,7.5vw,38px); }
  .hero-eyebrow { font-size:10px; padding:5px 12px; margin-bottom:18px; }
  .adv-grid    { margin-top:-60px; }
  .about-photo-main { width:100%; margin-left:0; }
  .about-photo-sub  { width:44%; bottom:8px; left:-4%; }
}
