@charset "utf-8";
/* CSS Document */

/* ==================================================================
   基本スタイル (PC)
   ================================================================== */

/* --- 共通スタイル (見出しなど) --- */
h2 {
  font-size: 50px !important;
  font-weight: 900;
  display: block;
  text-align: center;
  line-height: 60px;
  margin: 0 0 20px 0;
}

h3 {
  text-align: center;
  display: block;
  font-size: 16px;
  line-height: 16px;
  margin-bottom: 30px;
  font-weight: normal;
	margin-top: 10px!important;
}

/*
.recycle h3{
	margin-top: 10px!important;
}

.news h3{
	margin-top: 10px!important;
}*/

h4 {
  display: block;
  text-align: center;
  font-size: 25px;
  margin:40px auto 30px auto!important;
}

.hleft {
  text-align: left !important;
	margin-top: 10px;
  margin-bottom: 20px !important;
}

.marginnone {
  margin: 0 !important;
}

#mainvisu {
  margin-top: 30px;
}

/* --- NEWS セクション --- */
.news {
  width: 100%;
  background-image: url("../img/top/new-bg.jpg");
  padding: 50px 0 80px 0;
}

.news_cont {
  width: 1000px;
  display: block;
  margin: 0 auto;
  padding: 40px 0 80px 0;
  text-align: center;
}

/* --- Facebook セクション --- */
#facebook_pc {
	display: block;
  width: 500px;
  margin: 30px auto 0;
}

#facebook_sp iframe{
	display: none;
}

/* --- YouTubeボックス --- */
.youtube_box {
  max-width: 1000px;
  margin: 60px auto 40px;
  display: flex;
 gap: 40px;
}

.youtube_box p {
 font-size: 18px;
}

.youtube_box span {
	margin-top: 5px;
	display: block;
 font-size: 14px;
}


.youtube_left{
	margin-bottom: 15px;

}

.youtube_left,
.youtube_right {
  flex: 1;
}

.youtube-video-wrapper {
  position: relative;
  width: 100%;
  height: 0;
  padding-bottom: 56.25%;
  overflow: hidden;
  margin-bottom: 15px;
}

.youtube-video-wrapper iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

/* --- ABOUT セクション --- */
.about {
  background-image: url("../img/top/about.jpg");
  text-align: left;
  display: flex;
  justify-content: center;
  padding: 80px 0;
  background-repeat: no-repeat;
  width: 100%;
  background-size: cover;
  background-position: center center;
  min-height: 500px;
}

.about_cont {
  text-align: left !important;
  width: 820px;
  padding: 40px 90px;
  margin: 0 !important;
  height: auto;
  border: solid 1px rgba(255, 255, 255, 0.9);
  background-color: rgba(255, 255, 255, 0.9);
  border-radius: 10px;
}

.about h2,
.about h3,
.about p {
  text-align: left;
}

.aboutp {
  width: 720px;
  border: 1px #000 solid;
  padding: 20px 50px 20px 50px;
  margin: 20px 0;
  text-align: left;
  font-size: 17px;
}

.aboutp .item {
  display: flex;
  align-items: flex-start;
  margin-bottom: 13px;
}

.aboutp .number {
  width: 2em;
  font-weight: bold;
  flex-shrink: 0;
	font-size: 18px;
}

.aboutp .text {
  flex: 1;
	font-size: 16px;
}

.text1 {
  font-size: 25px;
  font-weight: 500;
  display: block;
	line-height: 1.5;
}

.text2 {
	margin: 10px 0 10px;
  display: block;
	line-height: 1.5;
}

.about span {
	font-size: 13px;
	}

/* --- RECYCLE セクション --- */
.recycle {
  width: 1000px;
  display: block;
  margin: 0 auto;
  padding: 140px 0 80px 0 !important;
  text-align: center;
}

.imgbox1,
.imgbox2 {
  display: flex;
  justify-content: space-between;
  margin-top: 25px;
  text-align: center !important;
  line-height: 2;
}

.imgbox {
  width: 230px;
  height: auto;
  color: #03BE1E; 
	font-weight: bold;
	font-size: 15px;

}

/* --- SDGs セクション --- */
.sdgs {
  background-color: #21ABE9;
  margin-top: 0 !important;
  line-height: 2;
}

.sdgs_cont {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 20px 0 20px 0;
 *width: 1000px;
  text-align: left;
  margin: 0 auto !important;
  color: #FFF !important;
}

.text3 {
  display: block;
  font-size: 16px;
  margin: 15px auto 0 auto;
  text-align: left;
	width: 500px;
}

/* --- CONTENT/SERVICE セクション --- */
.content {
  background-color: #F3F3F3;
  text-align: center;
  padding-bottom: 30px;
  margin-top: 0 !important;
  padding-top: 140px !important;
}

.content_con {
  width: 1000px;
  margin: 0 auto;
}

.service_box1 {
  display: flex;
  justify-content: space-between;
  margin: 40px 0;
}

.service_box2 {
  display: flex;
  justify-content: space-around;
  width: 660px;
  margin: 40px auto 0 auto;
}

.menubar {
  background-color: #FFF;
  border-top: 5px solid #FCD021;
  width: 300px;
  height: 100px;
  line-height: 100px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
}

.menubar img {
  width: 50px;
}

/* --- COMPANY セクション --- */
.company {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 140px 0 0 0;
  width: 1200px;
  margin: 0 auto;
  box-sizing: border-box;
}

.company_left {
  flex: 1;
  padding-right: 50px;
  text-align: left;
}

.company_right {
  flex-shrink: 0;
  width: 400px;
}

.company_right img {
  max-width: 100%;
  height: auto;
  display: block;
}

.company_left h2,
.company_left h3 {
  text-align: left;
  margin-bottom: 10px;
}

.kaisha {
  width: 500px;
}

.kaisha th,
.kaisha td {
  border: none;
  padding: 5px 10px;
  font-size: 16px !important;
  height: 25px;
}

.kaisha th {
  background-color: #E6E6E6;
  width: 100px;
  font-weight: normal;
}

.menu_bottom1.pc {
  margin-top: 20px;
  text-align: left;
}

.menu_bottom1.pc img {
  vertical-align: middle;
  margin-left: 5px;
}

/* --- COMPANY セクション (詳細情報) --- */
.company-section {
  display: flex;
  justify-content: center;
  align-items: flex-start;
	width: 800px;
  margin: 60px auto 0;
  border-radius: 8px;
}

.company-info {
  flex: 1;
  padding-right: 60px;
  max-width: 600px;
}

.company-title {
  font-size: 50px;
  color: #12E930;
  margin-bottom: 10px;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-align: left;
}

.company .company-name {
  font-size: 20px;
  margin-bottom: 30px;
  font-weight: 400;
}

.info-list {
  margin-bottom: 40px;
}

.info-item {
  display: flex;
  margin-bottom: 21px;
}

.info-label {
  flex-basis: 130px;
  font-weight: 700;
  color: #707070;
  font-size: 15px;
}

.info-value {
  flex-grow: 1;
}

.info-item.operation-hours .info-value p {
  margin: 0;
}

.btn-more {
  display: inline-flex;
  align-items: center;
  background-color: #4CAF50;
  color: #fff;
  padding: 15px 30px;
  border-radius: 50px;
  text-decoration: none;
  font-size: 1.1em;
  font-weight: 700;
  transition: background-color 0.3s ease;
}

.btn-more:hover {
  background-color: #45a049;
}

.btn-text {
  margin-right: 10px;
}

.btn-arrow {
  width: 10px;
  height: 10px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: rotate(45deg);
}

.company-image {
  flex: 1;
  text-align: right;
  max-width: 600px;
}

.company-image img {
	width: 100%;
  height: auto;
  display: block;
  border-radius: 8px;
}

#company-btn {
  margin-bottom: 120px;
}


/* --- BANNER セクション --- */
.full-width-bg {
  width: 100%;
  background-color: #f0f0f0;
  padding: 30px 0;
  box-sizing: border-box;
}

.image-gallery-section {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  max-width: 1000px;
  margin: 40px auto;
  padding: 0 20px;
  box-sizing: border-box;
  flex-wrap: wrap;
  gap: 20px;
}

.image-container {
  flex-shrink: 0;
  text-align: center;
  box-sizing: border-box;
  flex-basis: 200px;
}

.image-container .image-link {
  display: block;
  text-decoration: none;
}

.image-container img {
  width: 185px;
  height: auto;
  display: block;
  margin: 0 auto;
}

.image-container img.social-icon {
  width: 68px;
  height: auto;
  gap: 20px;
}


/* ==================================================================
   スマホ用スタイル (767px以下)
   ================================================================== */
@media only screen and (max-width: 767px) {

  /* --- 共通スタイル (見出しなど) --- */
  h2 {
    font-size: 50px; /* !importantは基本的に不要 */
    font-weight: 900;
	  margin-bottom: 0!important;
  }

  h3 {
    font-size: 16px;
	  line-height: 2;
  }

  h4 {
    font-size: 20px;
    font-weight: 500;
	margin-top: 40px;
  }

  .hleft {
    text-align: center !important;
    font-size: 16px;
  }

  #mainvisu {
    margin-top: 0px;
  }
  
  /* --- NEWS セクション --- */
  .news {
    display: block;
    text-align: center;
    background-image: url("../img/top/new-bg_sp.jpg");
    padding: 30px 0 40px 0;
  }

  .news_cont {
    width: 90%;
    padding: 20px 0;
    text-align: center;
  }

  /* --- Facebook セクション --- */
  #facebook_sp {
    width: 100%;
    margin: 20px auto 0;
	display:block!important;
  }
	
#facebook_sp iframe{
	display:block!important;
}

	
#facebook_pc iframe{
	display: none!important;
}

	
  #facebook_sp iframe {
    width: 100%;
  }

  /* --- YouTubeボックス --- */
  .youtube_box {
    flex-direction: column;
    align-items: center;
    width: 100%;
	margin-top: 70px;
	text-align: left;
  }
	

.youtube_box p {
 font-size: 20px;
}

.youtube_box span {
	margin-top: 5px;
	display: block;
 font-size: 14px;
}
	


  .youtube_left,
  .youtube_right {
    width: 100%;
	  text-align: left;
  }

  .youtube_left {
    margin-bottom: 30px;
  }

  /* --- ABOUT セクション --- */
  .about {
    background-image: url("../img/top/about_sp.jpg");
    padding: 30px 0;
  }

  .about_cont {
    width: 90%;
    padding: 30px 5% 20px;
    margin: 0 !important;
    border-radius: 10px;
    box-sizing: border-box;
  }

  .about_cont h2,
  .about_cont h3 {
    /*margin-bottom: 20px !important;*/
    text-align: center !important;
  }

  .aboutp {
    width: 100%;
    border: 1px #000 solid;
    padding: 030px 8% 20px;
    margin: 20px 0;
    box-sizing: border-box;

	}

  .text1 {
	  font-size: 20px;
	text-align: center!important;
	 font-weight: 500;
	  line-height: 1.7;
}

  .text2 {
    font-size: 15px;
	  line-height: 1.7;
	  width: 100%;
	  margin: 0 auto;
  }

  .sple {
    text-align: left !important;
  }

  /* --- RECYCLE セクション --- */
  .recycle {
    width: 90%;
    padding: 60px 0 !important; /* autoは左右には使えないため0に修正 */
    margin: 0 auto;
  }

  .imgbox {
    width: 110px;
    height: auto;
    color: #12E930;
    font-weight: 400;
    font-size: 13px;
  }

  /* --- SDGs セクション --- */
  .sdgs_cont {
    width: 100%;
    display: block;
    text-align: center;
	padding: 50px 0 5px 0 ;
  }

  .sdg_left,
  .sdg_right {
    display: block;
    width: 90%;
    margin: 0 auto;
  }

  .sdg_right img {
    width: 70%;
    margin: 20px auto 0;
  }

  .text3 {
    text-align: left;
	  width: 100%;
	  margin: 0 auto;
  }

  /* --- CONTENT/SERVICE セクション --- */
	
.content {
	padding-top: 80px!important;
}
	
  .content_con {
    width: 100%;
  }
  
  .service_box3 {
    width: 90%;
    margin: 0 auto;
  }

  .menubar {
    width: 100%;
	height: 80px;
    margin-top: 20px;
    border-top: thin #FCD021 10px;
	text-align: left;
  }
  
  /* --- COMPANY セクション --- */
  .company {
    flex-direction: column;
    padding: 20px 0;
    align-items: center;
    width: 100%;
	margin-top: 0px;
  }

  .company_left,
  .company_right {
    width: 100%;
    margin-bottom: 30px;
    padding-right: 0;
  }

  .company_left {
    text-align: center;
  }

  .company_left h2,
  .company_left h3 {
    text-align: center;
  }

  .company_left h2 {
    font-size: 24px;
  }

  .company_left h3 {
    font-size: 20px;
  }

  /* --- COMPANY セクション (詳細情報) --- */
.company-section {
  width: 90%;
  flex-direction: column;
  padding: 0px;
  margin: 40px auto 0;
}

.company-info {
  padding: 0;
  margin-bottom: 10px;
  width: 100%;
  max-width: 100%; /* ★ この行を追加して、PC用の幅制限を解除 */
}

.company-image {
  width: 100%;       /* ★追加：幅を100%に指定 */
  max-width: 100%;   /* ★追加：PC用の幅制限を解除 */
  text-align: center;
}

.company-image img {
  width: 100%;
  display: block;
}
	/*
  .company-title {
    font-size: 2.5em;
  }
*/
  .company .company-name {
    font-size:16px;
	  line-height: 2;
  }

  .company .btn-more {
    width: 100%;
    justify-content: center;
    box-sizing: border-box;
  }
  
  .company .contact-info-block.sp {
    display: block;
    width: 100%;
    margin-top: 20px;
    margin-bottom: 20px;
  }
  
  .company .contact-info-block.sp .info-item {
    display: flex;
    align-items: flex-start;
    margin-bottom: 10px;
    font-size: 15px;
    padding: 0 5px;
  }
  
  .company .contact-info-block.sp .operation-hours .info-key {
    align-self: flex-start;
  }
  
  .company .contact-info-block.sp .info-key {
    flex-shrink: 0;
    width: 100px;
    background-color: #e0e0e0;
    padding: 10px;
    border-radius: 5px;
    text-align: center;
    margin-right: 10px;
    box-sizing: border-box;
    font-weight: bold;
    color: #444;
    font-size: 14px;
  }
  
  .company .contact-info-block.sp .info-value {
    flex-grow: 1;
    padding: 10px 0;
    word-break: break-all;
    line-height: 1.5;
    text-align: left;
    font-size: 14px;
  }
  
  .company .contact-info-block.sp .info-value p {
    margin: 0;
    padding: 0;
  }
  
  .company .menu_bottom1.sp {
    display: block;
    width: 100%;
    text-align: center;
    font-size: 15px;
    margin-top: 20px;
  }
  
  .company .menu_bottom1.sp img {
    vertical-align: middle;
    margin-left: 5px;
  }
	
	
	
	
	/* --- バナー --- */
.full-width-bg {
  width: 100%;
  background-color: #f0f0f0;
  padding: 10px 0;
}
	
.image-gallery-section {
  flex-direction: column;
  align-items: center;
  width: 90%;
}

.image-container {
  width: 100%;
  flex-basis: auto;
margin-bottom: 5px;
	


}

/* ▼ この部分を修正します */
.image-container img {
  width: 185px;     /* ★ 100%からPCと同じ固定値に戻す */
  max-width: 100%;  /* ★ 画面が画像より狭い場合のはみ出しを防止 */
}

	
	
	
/* モバイル用TOPサブメニューのスタイル */
	  /* --- 下段：電話番号バー --- */
  .phone-bar-top {
    padding: 10px 0!important;
  }

	
	
	
	
}