@charset "UTF-8";

/* =====================================================
  ACCESS PAGE
===================================================== */
.tg-access-page{
  background:#fff;
  color:var(--tg-text);
}

/* =====================================================
  PAGE HERO
===================================================== */
.tg-page-hero{
  padding-top:calc(var(--tg-header-h) + 96px);
  padding-bottom:96px;
}

.tg-page-title{
  position:relative;
  display:inline-block;
  font-size:clamp(30px, 4vw, 42px);
  line-height:1.45;
  font-weight:500;
  letter-spacing:.08em;
}

.tg-page-title::after{
  content:"";
  display:block;
  width:48px;
  height:1px;
  background:#222;
  margin:18px auto 0;
  opacity:.6;
}

.tg-page-lead{
  max-width:820px;
  margin:40px auto 0;
  text-align:center;
  line-height:2.05;
}

/* =====================================================
  ACCESS INFO
===================================================== */
.tg-access-info{
  padding-top:72px;
  padding-bottom:96px;
}

.tg-access-info__grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:72px;
  align-items:start;
}

.tg-access-info__col .tg-title{
  margin-bottom:36px;
}

.tg-access-card + .tg-access-card{
  margin-top:28px;
}

.tg-access-card__name{
  margin-bottom:10px;
  line-height:1.8;
}

.tg-access-card__text{
  line-height:2;
}

.tg-access-card__link{
  margin-top:10px;
}

.tg-access-card__link a{
  display:inline-block;
  padding-bottom:3px;
  border-bottom:1px solid var(--tg-text);
}

.tg-access-hours{
  margin-top:8px;
}

.tg-access-hours li{
  line-height:2;
}

/* =====================================================
  MAP
===================================================== */
.tg-access-map{
  padding-top:40px;
  padding-bottom:72px;
}

.tg-access-map__frame{
  max-width:1100px;
  margin:0 auto;
}

.tg-access-map__iframe{
  display:block;
  width:100%;
}

/* =====================================================
  FOOT INFO
===================================================== */
.tg-access-foot{
  padding-top:40px;
  padding-bottom:140px;
}

.tg-access-foot__address{
  line-height:2;
}

/* =====================================================
  MOBILE
===================================================== */
@media (max-width:768px){

  .tg-page-hero{
    padding-top:calc(var(--tg-header-h) + 72px);
    padding-bottom:72px;
  }

  .tg-page-lead{
    margin-top:32px;
    font-size:15px;
    line-height:1.95;
  }

  .tg-access-info{
    padding-top:56px;
    padding-bottom:72px;
  }

  .tg-access-info__grid{
    grid-template-columns:1fr;
    gap:48px;
  }

  .tg-access-info__col .tg-title{
    margin-bottom:28px;
  }

  .tg-access-card + .tg-access-card{
    margin-top:24px;
  }

  .tg-access-card__text,
  .tg-access-hours li,
  .tg-access-foot__address{
    font-size:15px;
    line-height:1.95;
  }

  .tg-access-map{
    padding-top:24px;
    padding-bottom:56px;
  }

  .tg-access-map__iframe{
    height:360px;
  }

  .tg-access-foot{
    padding-top:24px;
    padding-bottom:110px;
  }
}