footer,header{
  min-width:1200px
}
header{
  position:absolute;
  z-index:2;
  top:0;
  display:-ms-flexbox;
  display:-webkit-box;
  display:-webkit-flex;
  display:flex;
  width:100%;
  height:90px;
  @media only screen and (max-width: 768px) {height:56px;}
  margin:0 auto;
  -ms-flex-pack:justify;
  -webkit-box-pack:justify;
  -webkit-justify-content:space-between;
  justify-content:space-between
}
header .c-logo{
  padding:2vw 0 0 5vw;
  @media only screen and (max-width: 768px) {
          position:relative;
          z-index:1;
          padding:13px 0 0 15px
  }
}
header .c-logo img{
  width: 10vw;
  @media only screen and (max-width: 768px){width: 10vw}
}
.cloudweather_title {
    margin-top:2vw;
    color: white;
    background-color: rgb(51, 51, 51);
    padding: 2vw;
    text-align: center;
    @media only screen and (max-width: 768px) {font-size:6vw;}
    @media only screen and (min-width: 768px) {font-size:3vw;}
    font-family: system-ui, sans-serif;
}
.weathermark{
    width:6vw;
    @media only screen and (max-width: 768px) {width:10vw;}
    @media only screen and (min-width: 768px) {width:6vw;}
    height: auto ;
    transform: translateY(30%);
}
.h2parent{
    display: flex;
    justify-content: center;
    text-align: center;
    line-height: 1.4;
    margin-top: 2vw;
    margin-bottom: 2vw;
}
.cloudweather_desc {
    @media only screen and (max-width: 768px) {font-size:4vw;}
    @media only screen and (min-width: 768px) {font-size:2.2vw;
    font-family: 'Arial', sans-serif;}
    color: white;
    text-align: left;
}
@media (min-width: 768px) {
    .line-break {
      display: none;
    }
  }

  @media (max-width: 768px) {
    .line-break {
      display: block;
    }
  }
body {
    background-color: rgb(51,51,51);
    position: relative;
}
.description {
    max-width: 40vw; /* 必要に応じて調整 */
    color: white;
    display: flex;
    align-items: center;
}
.ulset{
    position:absolute;
    @media only screen and (min-width: 768px) {
    margin-top: 1vw;
    margin-left: 1vw;}
    padding: 0.5vw; /* 内側の余白を設定 */
}
.ulrefresh{ /* idは大文字 classは小文字*/
    width:30vw;
    @media only screen and (max-width: 768px) {width:30vw;}
    @media only screen and (min-width: 768px) {width:20vw;
    margin-top: 1vw;
    margin-left: 1vw;}
    height:auto;
    cursor:pointer;
}
.hanrei{
    position:absolute;
    top:1vw;
    right:1vw;
    background-color: rgba(240, 240, 240,0.3); /* 背景色を設定 */
    border-radius: 5vw; /* 角を丸くする */
    padding: 1vw; /* 内側の余白を設定 */
}
.hanreiicon{
    width:8vw;
    height:8vw;
    @media only screen and (max-width: 768px) {width:8vw;}
    @media only screen and (min-width: 768px) {width:6vw;}
    @media only screen and (max-width: 768px) {height:8vw;}
    @media only screen and (min-width: 768px) {height:6vw;}
}
.tatenarabe{
    position: absolute;
    top: 70%;
    left: 65%;
    transform: translate(-50%, -50%);
    display: flex;
    flex-direction: column; /* 縦に並べる */
    align-items: center; /* 画像を中央に揃える */
}
.tenkiicon-clouddescription{
    display:flex;
}
.real-tenkiicon-clouddescription{
    background-color: rgb(255,255,255);
    border-radius: 1vw; /* 角を丸くする */
    padding: 1vw; /* 内側の余白を設定 */
    display:flex;
    margin-top: 1vw
}
.realweather{
    width:10vw;
    height:10vw;
    margin-left:1.5vw;
    margin-right:1.5vw;
}
.corpmark{
    margin-left:0.5vw;
    width:10vw;
    height:10vw;
}
.below {
    margin-top: 10px; /* 上の要素との間にスペースを追加 */
}
.footer-background {
    background-image: url('../images/japan.png');
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    height: 70vw; /* フッターの高さ */
    position: relative;
}
.footnote {
    text-align: left;
    bottom: 1vw;
    left: 1vw;
    color: white;
    background-color: rgb(51,51,51);
    padding: 0.5vw 1vw; /* 内側の余白を設定 */
    font-size:1.5vw;
    @media only screen and (max-width: 768px) {font-size:1.5vw;}
    @media only screen and (min-width: 768px) {font-size:1vw;}
}
