WEBサイト制作の勉強

WEBサイト制作の勉強の為の解説ブログです。

フェリカテクニカルアカデミー

3月3日作業データ(Furniture-store)

index.html

<!DOCTYPE html>
<html lang="ja">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Furniture-store</title>
<link rel="stylesheet" href="css/style.css">
<link rel="stylesheet" href="css/hamburgers.css">
</head>
<body>
<header>
<h1>Furniture-store</h1>

<p class="hamburger hamburger--3dxy" id="ham-btn">
  <span class="hamburger-box">
    <span class="hamburger-inner"></span>
  </span>
</p>
</header>
<nav id="g-nav">
<ul>
<li><a href="#">Brands</a></li>
<li><a href="#">Products</a></li>
<li><a href="#">Stores</a></li>
<li><a href="#">Catalogs</a></li>
<li><a href="#">Styling tips</a></li>
<li><a href="#">Partners & Press</a></li>
</ul>
</nav>

<nav id="g-nav-sp">
<ul>
<li><a href="#">Brands</a></li>
<li><a href="#">Products</a></li>
<li><a href="#">Stores</a></li>
<li><a href="#">Catalogs</a></li>
<li><a href="#">Styling tips</a></li>
<li><a href="#">Partners & Press</a></li>
</ul>
</nav>
<div class="container">
<div class="content-wrapper">
<div class="content-box">
<div class="content-img">
<img src="img/main-01.jpg" alt="">
</div>
<div class="content-txt">
<h2>Lorem, ipsum dolor</h2>
<p>Lorem ipsum dolor sit amet consectetur adipisicing elit. Amet accusantium autem minima nobis hic. Quidem!</p>
</div>
</div><!-- /.content-box -->

<div class="content-box">
<div class="content-img">
<img src="img/main-02.jpg" alt="">
</div>
<div class="content-txt">
<h2>Lorem, ipsum dolor</h2>
<p>Lorem ipsum dolor sit amet consectetur adipisicing elit. Amet accusantium autem minima nobis hic. Quidem!</p>
</div>
</div><!-- /.content-box -->

<div class="content-box">
<div class="content-img">
<img src="img/main-03.jpg" alt="">
</div>
<div class="content-txt">
<h2>Lorem, ipsum dolor</h2>
<p>Lorem ipsum dolor sit amet consectetur adipisicing elit. Amet accusantium autem minima nobis hic. Quidem!</p>
</div>
</div><!-- /.content-box -->
</div><!-- /.content-wrapper -->

<div class="col-1">
<h2>Lorem ipsum dolor sit amet consectetur<br> adipisicing elit. Eaque, exercitationem!</h2>
<p>Lorem ipsum dolor sit, amet consectetur<br> adipisicing elit. Assumenda, odit dolores vero<br>
odio aspernatur laudantium iusto!</p>
</div><!-- /.col-1 -->
<div class="col-3-wrapper">
<div class="col-3-box">
<div class="col-3-img">
<img src="img/col-3-1.jpg" alt="">
</div>
<div class="col-3-txt">
<h2>Lorem, ipsum dolor</h2>
<p class="icon"><img src="img/icon-1.svg" alt=""></p>
</div>
</div><!-- /.col-3-box -->
<div class="col-3-box">
<div class="col-3-img">
<img src="img/col-3-2.jpg" alt="">
</div>
<div class="col-3-txt">
<h2>Lorem, ipsum dolor</h2>
<p class="icon"><img src="img/icon-2.svg" alt=""></p>
</div>
</div><!-- /.col-3-box -->
<div class="col-3-box">
<div class="col-3-img">
<img src="img/col-3-3.jpg" alt="">
</div>
<div class="col-3-txt">
<h2>Lorem, ipsum dolor</h2>
<p class="icon"><img src="img/icon-3.svg" alt=""></p>
</div>
</div><!-- /.col-3-box -->
</div><!-- /.col-3-wrapper -->
<footer>
<p><small>&copy; 2010-2023 Furniture-store All rights reserved</small></p>
</footer>
</div><!-- /.container -->
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.6.3/jquery.min.js"></script>
<script>
$(function(){
$('#ham-btn').on('click',function(){
$(this).toggleClass('is-active');
$('#g-nav-sp').slideToggle(200);
});
});
</script>
</body>
</html>

style.css

@charset "utf-8";
/* 使用するカラーを登録 */
:root{
--color_1:#e6eec5;
--color_2:#c5dbee;
--color_3:#eee0c5;
}



*{
margin: 0;
padding: 0;
box-sizing: border-box;
}
ul{
list-style: none;
}
a{
text-decoration: none;
}
img{
vertical-align: bottom;
max-width: 100%;
}

/* pcレイアウト */
header{
width: 100%;
height: 100px;
background-color: var(--color_1);
display: flex;
justify-content: center;
align-items: center;
}
#g-nav{
width: 100%;
height: 50px;
background-color: var(--color_2);
}
#g-nav>ul{
max-width: 960px;
height: 50px;
margin: 0 auto;
display: flex;
justify-content: center;
align-items: center;
}
#g-nav li{
margin: 0 16px;
}
#g-nav a{
color: #111;
padding: 10px 16px;
}
#g-nav a:hover{
text-decoration: underline 3px #e04c4c;
text-underline-offset: 4px;
}

.container{
padding: 10px;
}
.content-box{
display: flex;
justify-content: space-between;
margin-bottom: 10px;
}
.content-box:nth-of-type(even){
flex-direction: row-reverse;
}
.content-img{
width: calc((100% - 10px) / 3 * 2);
height: 500px;
background-color: #e04c4c;
}
.content-img>img{
object-fit: cover;
object-position: center center;
width: 100%;/* 必須 */
height: 100%;/* 必須 */
}
.content-txt{
width: calc((100% - 10px) / 3);
background-color: var(--color_3);
padding: 40px;
}

/* col-1部分 */
.col-1{
width: 100%;
padding: 100px 20px;
background-color: var(--color_2);
margin-bottom: 10px;
text-align: center;
}
.col-1>h2{
margin-bottom: 30px;
}
.col-1>p{
line-height: 2;
}

/* col-3部分 */
.col-3-wrapper{
display: flex;
justify-content: space-between;
margin-bottom: 10px;
}
.col-3-box{
width: calc((100% - 20px) / 3);
}
.col-3-img{
width: 100%;
height: 260px;
}
.col-3-img>img{
object-fit: cover;
object-position: left top;
width: 100%;
height: 100%;
}
.col-3-txt{
padding: 40px 20px;
background-color: var(--color_1);
}
.col-3-box:nth-of-type(2)>.col-3-txt{
background-color: var(--color_2);
}
.col-3-box:nth-of-type(3)>.col-3-txt{
background-color: var(--color_3);
}
.col-3-txt>h2{
text-align: center;
margin-bottom: 30px;
}
.icon{
width: 80px;
height: 80px;
border-radius: 50%;
background-color: #FFF;
padding: 14px;
margin: 0 auto;
}

/* フッター部分 */
footer{
width: 100%;
height: 140px;
background-color: var(--color_3);
}
footer>p{
text-align: center;
line-height: 140px;
font-size: 18px;
}

#g-nav-sp{
display: none;
}
#ham-btn{
display: none;
}

/* 900px以下のレイアウト */
@media (max-width:900px){
/* ヘッダー部分 */
header{
height: 60px;
justify-content: space-between;
padding-left: 15px;
position: fixed;
top: 0;
left: 0;
}
#g-nav{
display: none;
}
#g-nav-sp{
width: 100%;
height: calc(100vh - 60px);
background-color: var(--color_2);
position: fixed;
top: 60px;
left: 0;
padding: 40px;
}
#g-nav-sp li{
margin-bottom: 20px;
}
#g-nav-sp a{
display: block;
color: #111;
font-size: 18px;
padding: 4px 0;
border-bottom: 1px solid #222;
}
#ham-btn{
display: block;
}

.container{
padding: 70px 10px 10px;
}

/* col-3部分 */
.col-3-wrapper{
display: block;
}
.col-3-box{
width: 100%;
display: flex;
margin-bottom: 10px;
}
.col-3-img{
width: 50%;
height: 300px;
}
.col-3-txt{
width: 50%;
}


}

/* 640px以下のレイアウト */
@media (max-width:640px){

.content-box{
display: block;
}
.content-img{
width: 100%;
height: 320px;
margin-bottom: 10px;
}
.content-txt{
width: 100%;
}


.col-3-box{
display: block;
}
.col-3-img{
width: 100%;
height: 260px;
}
.col-3-txt{
width: 100%;
}

}