/* =========================
   SERVICES SECTION
   ========================= */

.services-tiles{
  padding: 90px 0 120px;
  position: relative;
}

.services-tiles::before{
  content:"";
  position:absolute;
  inset: -140px -120px auto -120px;
  height: 360px;

  pointer-events:none;
}

/* Section header */
.section-head{
  margin-bottom: 36px;
  max-width: 780px;
}

.section-eyebrow{
  display:inline-block;
  margin-bottom: 12px;
  font-size: .85rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--accent);
  font-weight: 750;
}

.section-title{
  margin: 0 0 16px;
  font-size: clamp(2.0rem, 3.2vw, 3.0rem);
  line-height: 1.12;
  letter-spacing: -.02em;
}

.section-divider{
  width: 72px;
  height: 2px;
  background: linear-gradient(90deg, var(--accent), transparent);
  border-radius: 2px;
  margin: 16px 0 18px;
}

.section-sub{
  color: rgba(255,255,255,.74);
  line-height: 1.75;
  max-width: 62ch;
}

/* =========================
   TILES GRID (presets)
   ========================= */

.tiles-grid{
  display: grid;
  gap: 22px;
}

/* Preset: 3 across (3,6,9...) */
.tiles-grid.grid-3{
  grid-template-columns: repeat(3, 1fr);
}

/* Preset: 2 across (2,4,6,8...) */
.tiles-grid.grid-2{
  grid-template-columns: repeat(2, 1fr);
}

/* Preset: stacked (1 column always) */
.tiles-grid.grid-1{
  grid-template-columns: 1fr;
}

/* Responsive: collapse everything to 1 column */
@media (max-width: 1100px){
  .tiles-grid.grid-3,
  .tiles-grid.grid-2,
  .tiles-grid.grid-1{
    grid-template-columns: 1fr;
  }

  .service-tile{
    height: 420px;
  }
}


/* Tile */
.service-tile{
  position: relative;
  height: 520px;
  border-radius: 26px;
  overflow: hidden;
  isolation: isolate;

  background: #000;
  box-shadow: var(--shadow-soft);

  transition:
    transform .35s cubic-bezier(.2,.8,.2,1),
    box-shadow .35s ease;
}

.service-tile:hover{
  transform: translateY(-6px) scale(1.01);
  box-shadow: var(--shadow);
}

/* Background image */
.tile-bg{
  position:absolute;
  inset:0;
  background-size: cover;
  background-position: center;
  transform: scale(1.05);
  transition: transform .6s ease;
}

.service-tile:hover .tile-bg{
  transform: scale(1.12);
}

/* Dark overlay */
.tile-shade{
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg,
      rgba(0,0,0,.15),
      rgba(0,0,0,.85) 70%);
  z-index:1;
}

/* Content */
.tile-inner{
  position: relative;
  z-index:2;
  height:100%;
  padding: 22px;
  display:flex;
  flex-direction: column;
  justify-content: space-between;
}

/* Top tag */
.tile-top{
  display:flex;
  align-items:center;
  gap:8px;
}

.tile-dot{
  width:6px;
  height:6px;
  border-radius:50%;
  background: var(--accent);
}

.tile-tag{
  font-size:.85rem;
  font-weight:700;
  color: rgba(255,255,255,.9);
}

/* Bottom content */
.tile-bottom{
  transform: translateY(26px);
  transition: transform .35s ease;
}

.service-tile:hover .tile-bottom{
  transform: translateY(0);
}

.tile-bottom h3{
  margin:0 0 6px;
  font-size:1.3rem;
  line-height:1.25;
}

.tile-desc{
  margin:0;
  font-size:.95rem;
  line-height:1.6;
  color: rgba(255,255,255,.72);

  max-height:0;
  opacity:0;
  overflow:hidden;
  transition:
    opacity .3s ease,
    max-height .35s ease;
}

.service-tile:hover .tile-desc{
  max-height:120px;
  opacity:1;
}

.tile-cta{
  display:inline-flex;
  align-items:center;
  gap:6px;
  margin-top:14px;
  font-weight:700;
  color: var(--accent);
}

.tile-arrow{
  transition: transform .25s ease;
}

.service-tile:hover .tile-arrow{
  transform: translateX(4px);
}

/* =========================
   RESPONSIVE
   ========================= */

@media (max-width: 1100px){
  .tiles-grid{
    grid-template-columns: 1fr;
  }

  .service-tile{
    height: 420px;
  }
}

/* ===== Service tile corner logo (responsive + stable) ===== */

.service-tile {
  position: relative;
}

/* ensure positioning context */

.service-tile .tile-corner {
  position: absolute;
  z-index: 3;
  pointer-events: none;

  /* stable corner anchor */
  top: clamp(16px, 2vw, 28px);
  right: clamp(16px, 2vw, 28px);

  /* logo box size (this is what you tweak) */
  width: clamp(180px, 7vw, 200px);
  height: clamp(72px, 7vw, 180px);

  display: grid;
  place-items: center;

  /* optional: nudge it slightly inward/down to match your screenshot */
  transform: translate(50px, -20px);
}

.service-tile .tile-corner-logo {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  opacity: .96;
  filter: drop-shadow(0 12px 28px rgba(0, 0, 0, .45));
}

/* Spa logo: scale up inside the same box (keeps position identical) */
.service-tile.tile--spa .tile-corner-logo {
  transform: scale(1.12);
  transform-origin: center;
}


/* =========================================================
   SERVICES — BIG LOGO SLABS (matches your drawing)
   ========================================================= */

.services-logo-slab {
  padding: 44px 0 110px;
}

/* Row slab */
.logo-slab {
  position: relative;
  display: grid;
  grid-template-columns: 56% 44%;
  min-height: clamp(240px, 20vw, 310px);
  border-radius: 28px;
  overflow: hidden;
  isolation: isolate;
  text-decoration: none;
  color: inherit;
  margin-bottom: 22px;

  /* keep your site feel but no border + no “boxed” look */
  background: rgba(255, 255, 255, .02);
  box-shadow: var(--shadow-soft);

  transition: transform .35s cubic-bezier(.2, .8, .2, 1), box-shadow .35s ease;
}

.logo-slab:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow);
}

/* Swap columns for row 2 */
.logo-slab--logo-right {
  grid-template-columns: 44% 56%;
}

/* --- BIG LOGO SIDE --- */
.logo-slab__logo {
  position: relative;
  display: grid;
  place-items: center;
  padding: clamp(18px, 2.5vw, 42px);

  /* subtle glow + depth behind the logo side */
  background:
    radial-gradient(900px 520px at 30% 35%, rgba(18, 192, 138, .18), transparent 62%),
    radial-gradient(900px 520px at 70% 15%, rgba(197, 138, 99, .10), transparent 65%),
    linear-gradient(180deg, rgba(0, 0, 0, .35), rgba(0, 0, 0, .65));
}

/* Make the logo BIG like your sketch */
.logo-slab__logo img {
  width: min(520px, 92%);
  height: auto;
  object-fit: contain;
  display: block;
  opacity: .98;

  /* makes it feel “hero” */
  filter: drop-shadow(0 22px 60px rgba(0, 0, 0, .70));
}

/* Spa mark slightly larger */
.logo-slab__logo--spa {
  transform: scale(1.06);
  transform-origin: center;
}

/* --- CONTENT SIDE --- */
.logo-slab__content {
  position: relative;
  z-index: 2;
  padding: clamp(22px, 2.8vw, 44px);
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 12px;

  /* clean readable layer */
  background:
    linear-gradient(180deg, rgba(0, 0, 0, .35), rgba(0, 0, 0, .55));
}

/* Align exactly like your drawing */
.logo-slab__content--right {
  text-align: right;
  align-items: flex-end;
}

.logo-slab__content--left {
  text-align: left;
  align-items: flex-start;
}

/* Title */
.logo-slab__title {
  margin: 0;
  font-size: clamp(2.0rem, 2.8vw, 2.8rem);
  line-height: 1.08;
  letter-spacing: -.02em;
}

/* Bullets */
.logo-slab__bullets {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 10px;
  width: min(58ch, 100%);
}

.logo-slab__bullets li {
  position: relative;
  color: rgba(255, 255, 255, .78);
  line-height: 1.65;
  font-size: 1.02rem;
  padding-left: 18px;
}

.logo-slab__content--right .logo-slab__bullets li {
  padding-left: 0;
  padding-right: 18px;
}

.logo-slab__bullets li::before {
  content: "";
  position: absolute;
  left: 0;
  top: .72em;
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: var(--accent);
  box-shadow: 0 0 0 6px rgba(18, 192, 138, .10);
}

.logo-slab__content--right .logo-slab__bullets li::before {
  left: auto;
  right: 0;
}

/* CTA */
.logo-slab__cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-top: 6px;
  font-weight: 750;
  color: var(--accent);
}

.logo-slab__cta span {
  transition: transform .25s ease;
}

.logo-slab:hover .logo-slab__cta span {
  transform: translateX(3px);
}

/* Optional: make row 2 glow feel “spa” warmer */
.logo-slab--spa .logo-slab__logo {
  background:
    radial-gradient(900px 520px at 70% 35%, rgba(197, 138, 99, .18), transparent 62%),
    radial-gradient(900px 520px at 30% 15%, rgba(18, 192, 138, .10), transparent 65%),
    linear-gradient(180deg, rgba(0, 0, 0, .35), rgba(0, 0, 0, .65));
}

@media (max-width: 980px) {

  /* Force stacked layout */
  .logo-slab,
  .logo-slab--logo-right {
    grid-template-columns: 1fr;
  }

  /* Default order: logo first, content second */
  .logo-slab__logo {
    order: 1;
  }

  .logo-slab__content {
    order: 2;
  }

  /* FIX: Spa slab — logo ABOVE text (same as clinic) */
  .logo-slab--logo-right .logo-slab__logo {
    order: 1;
  }

  .logo-slab--logo-right .logo-slab__content {
    order: 2;
  }

  /* Reset alignment so text reads naturally on mobile */
  .logo-slab__content--right {
    text-align: left;
    align-items: flex-start;
  }

  .logo-slab__content--right .logo-slab__bullets li {
    padding-right: 0;
    padding-left: 18px;
  }

  .logo-slab__content--right .logo-slab__bullets li::before {
    right: auto;
    left: 0;
  }
}