@charset "UTF-8";

 /* 全体の設定 */
        body{
  font-family:
    "Noto Sans JP",
    system-ui,
    -apple-system,
    "Hiragino Sans",
    "Hiragino Kaku Gothic ProN",
    "Yu Gothic",
    "Meiryo",
    sans-serif;
  margin: 0;
  line-height: 1.6;
  color: #333;
font-size:13px;
  scroll-behavior: smooth;
/* スクロールを滑らかに */
}
/* ヘッダー（ナビ） */
        header{
  background: #2c3e50;
  color: white;
  padding: 1rem;
  position: sticky;
  top: 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

nav a{
  color: white;
  text-decoration: none;
  margin-left: 12px;
font-size:1.0em;
}
/* メインビジュアル */
        .hero{
   background: linear-gradient(rgba(0,0,0,0.5), rgba(0,0,0,0.5)), 
                        url('https://images.unsplash.com/photo-1497215728101-856f4ea42174?auto=format&fit=crop&w=1000&q=80');
  background-size: cover;
  height: 60vh;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  text-align: center;
}

.disp-img{
  max-width: 100%; /* 親要素の幅に合わせて縮小 */
    height: auto;   /* アスペクト比を維持 */
}

.table-wrap {
  overflow-x: scroll;
}

table.toplist{
  width: 100%;
}
table.toplist th,td{
    padding: 0px 1px;      /* 余白指定 */
  border: none !important;
}
table.toplist td.col01{
width:30%;
}
table.toplist td.col02{
width:70%;
}


table.toplist th,td p{
text-align: left;
}
table.toplist th,td ul{
  margin: 0;
  padding-left: 0;
  list-style: none; /* マーカーを非表示 */
}


table.toplist2{
    border-collapse:  collapse; /* セルの線を重ねる */
  width: 100%;
margin-bottom:30px;
  white-space: nowrap;
}
table.toplist2 th,td{
    border: solid 1px;  /* 枠線指定 */
    padding: 6px 3px;      /* 余白指定 */
text-align:center;
}
table.toplist2 th,td p{
margin:0;
}

table.toplist2 th,td img{
    border-radius: 30px;
}










.soft{
  display:flex; /*横並び*/
  flex-wrap: wrap; /*折り返し*/
 }
.soft dt {
  width: 25%;
margin-bottom:40px;
}
.soft dd {
  margin-left: 0; /*初期値リセット*/
  width: 75%;
margin-bottom:40px;
}



/* セクション共通 */
        section{
  padding: 60px 20px;
  max-width: 800px;
  margin: 0 auto;
}
.section-title{
  text-align: center;
  border-bottom: 2px solid #2c3e50;
  padding-bottom: 10px;
  margin-bottom: 30px;
}


h3.topdisp{
margin: 3em 0em 1.5em 0em;
padding: 0.5em 1em; 
background:#2c3e50;
border-radius: 10px;
color:#fff;
}



.flex{
    /*コレ追加*/display: flex;
}
.flex div{
padding:0 0.5em;
}
.right{

width:50%;
}
.left{

width:50%;
}


.box1 {
    padding: 0.5em;
    margin: 0.5em;
    background: #f0ffff;/*背景色*/
    border-top: solid 6px #1dc1d6;
    box-shadow: 0 3px 4px rgba(0, 0, 0, 0.32);/*影*/
}
.box1 p {
    margin: 0; 
    padding: 0;
}


#table01{
width:100%;
}

/* table01 */
#table01 tr {
  border-bottom: 1px solid #eee;
}

#table01 th,
#table01 td {
  padding: 10px 0;
  border: none;
text-align:left;
}

#table01 th {
  width: 30%;
}

/* sp */
@media only screen and (max-width: 480px) {
  #table01 th,
  #table01 td {
    width: 100%;
    display: block;
  }

  #table01 th {
    width: 100%;
  }

  #table01 td {
    padding-top: 0;
  }
}




#table02{
width:100%;
margin:20px 0;
}

/* table02 */
#table01 tr {
  border-bottom: 1px solid #eee;
}

#table02 th,
#table02 td {
  padding: 10px 0;
  border: none;
text-align:left;
background:#fff;
}

#table02 th {
  width: 30%;
}

/* sp */
@media only screen and (max-width: 640px) {
  #table02 th,
  #table02 td {
    width: 100%;
    display: block;
  }

  #table02 th {
    width: 100%;
  }

  #table02 td {
    padding-top: 0;
  }
}






.price{
color:red;
font-weight:bold;
font-size:1.2em;
}
.pr{
color:green;
font-size:0.9em;
padding:0 5px 10px 5px;
}
.prmain{
color:green;
font-size:1.0em;
padding:0 5px 10px 5px;
text-align:center;
}

h4.title{
color:green;
padding:0;
margin:0.5em 0 1em 0;
line-height:0;
}



h1.maintitle{
padding:0 4em;
font-size:1.5em;
}
h2.maintitle{
padding:0 4em;
color:#eee;
font-size:1em;
}
p.maintitle{
font-size:0.8em;
font-weight:bold;
line-height:5em;
}





.flex-container{
display:flex;
flex-wrap:wrap;
gap:5px;
}
.item{
flex: 1 1 170px;
border:1px solid #ccc;
margin:2px;
padding:2px;
border:radius:8px;
text-align:center;
}



.example {
  list-style: none;              /* マーカーなし */
  padding-left: 0;               /* 左余白も削除 */
}
.example img{
width:95%;
height:95%;
}



.thumbnails {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.thumbnails img {
  width: calc(14.6% - 10px);
  height: auto;
padding:10px;
margin:5px 2px;
border:1px solid #ddd;
}
@media (max-width: 640px) {
  .thumbnails img {
    width: calc(20% - 10px);
  }
}
@media (max-width: 240px) {
  .thumbnails img {
    width: 100%;
  }
}




img {
  filter: brightness(1.1) saturate(1.1); /* 派手すぎない自然な補正 */
 }



.hover {
	display: inline-block;
	cursor: pointer;
	transition: all 0.3s ease 0s;
}
.hover:hover {
	opacity: 0.6;
}

ul.no-point{
list-style:none;
padding-left:25px;
}






/* フォームのコンテナ */
.contact-container {
  max-width: 700px;
  margin: 0 auto;
  background: #fff;
  padding: 30px;
  border-radius: 12px;
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.05); }


p.contact {
  text-align: center;
  font-size: 0.9rem;
  color: #666;
  margin-bottom: 30px;
}

/* 各入力グループ */
.form-group {
  margin-bottom: 20px;
}

label {
  display: block;
  font-weight: bold;
  margin-bottom: 8px;
}

label span {
  background: #ff4d4d;
  color: #fff;
  font-size: 0.7rem;
  padding: 2px 6px;
  border-radius: 4px;
  margin-left: 5px;
  vertical-align: middle;
}

/* 入力フィールドのスタイル */
input[type="text"],
input[type="email"],
input[type="tel"],
textarea {
  width: 100%;
  padding: 12px;
  border: 1px solid #ddd;
  border-radius: 6px;
  box-sizing: border-box; /* paddingを含めたサイズ計算 */
  font-size: 1rem;
  transition: border-color 0.3s, box-shadow 0.3s; }

/* フォーカス時の強調 */
input:focus,
textarea:focus {
  outline: none;
  border-color: #3498db;
  box-shadow: 0 0 8px rgba(52, 152, 219, 0.2); }

/* 送信ボタン */
.submit-btn {
  display: block;
  width: 100%;
  padding: 15px;
  background-color: #3498db;
  color: #fff;
  border: none;
  border-radius: 6px;
  font-size: 1.1rem;
  font-weight: bold;
  cursor: pointer;
  transition: background 0.3s;
}

.submit-btn:hover {
  background-color: #2980b9;
}









/* フッター */
        footer{
  background: #f4f4f4;
  text-align: center;
  padding: 20px;
  font-size: 0.9em;
}

/* スマホ対応 */
        @media (max-width: 640px) {
  header {
  flex-direction: column;
}
nav{
  margin-top: 10px;
}
}