@charset "UTF-8";
@import url("html5reset-1.6.1.css");
@import url('https://fonts.googleapis.com/css?family=Nunito:400,600&display=swap');

/*--------------------テンプレート情報--------------------*/
/*template　Maison de R*/
/*url　https://maisonder.web.fc2.com/*/
/*title　PINEAPPLE DIARY*/
/*code　CSS3*/


/*--------------------ライセンス--------------------*/

/*HTML5 Reset Stylesheet
html5doctor.com Reset Stylesheet v1.6.1
http://html5doctor.com/html-5-reset-stylesheet/
Copyright Richard Clark - http://richclarkdesign.com
Released under the CC0 Public Domain Dedication and MIT License
http://opensource.org/licenses/mit-license.php
*/

/*
jQuery v3.3.1
http://jquery.com/
(c) JS Foundation and other contributors
Released under the MIT license
http://jquery.org/license
http://opensource.org/licenses/mit-license.php
*/

/*
jQuery Smooth scroll
Handy Web Design
https://handywebdesign.net/2017/10/jquery-smooth-scroll/
*/

/*
Google Fonts
"Nunito" is lisenced under the SIL Open Font License
http://scripts.sil.org/OFL
https://fonts.google.com/(Vernon Adams)
*/


/*
Font Awesome(Font License)
"font-awesome" is lisenced under the SIL Open Font License 1.1
http://scripts.sil.org/OFL
https://fontawesome.com/v4.7.0/
*/

/*
Font Awesome(Code License)
https://fontawesome.com/v4.7.0/
Released under the MIT license
https://fontawesome.com/v4.7.0/license/
http://opensource.org/licenses/mit-license.php
*/



/*基本*/

* {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    word-break: break-all;
    -webkit-appearance: none;
    -moz-appearance: none;
    /*フォーム周辺のデザインをリセット*/
}

html {}

body {
    font-family: 'Nunito', "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS P Gothic", Verdana, Arial, Helvetica, sans-serif;
    font-size: 12px;
    line-height: 1.5;
    color: #333;
    letter-spacing: 0.04em;
    text-align: left;
    background: #ffffff;
    /*モバイル端末でのテキストサイズの自動調整対策*/
    -webkit-text-size-adjust: 100%;
    -moz-text-size-adjust: 100%;
    -ms-text-size-adjust: 100%;
    text-size-adjust: 100%;
}

/*フロート解除*/
.clearfix:after {
    content: "";
    display: block;
    clear: both;
}

a {
    color: #333;
    -webkit-transition: 0.2s;
    transition: 0.2s;
    /*アニメーション*/
}

a:hover {
    color: #f6ae54;
}

img {
    max-width: 100%;
    /*フルードイメージ（親要素の幅に応じて縦横比を保持したまま自動的に画像の拡大縮小をする）*/
    height: auto;
    vertical-align: bottom;
    /*ディセンダー対策（画像の下の隙間を無くす）*/
}

a img {
    /*アニメーション*/
    -webkit-transition: 0.2s;
    transition: 0.2s;
    /*画像リンクの枠線を消す*/
    border: 0;
}

a img:hover {
    opacity: 0.7;
}

strong {
    font-weight: normal;
    padding: 0 0.5em;
    background: #dff0eb;
}

ul {
    list-style-type: none;
    /*リストマークを非表示*/
    list-style-position: inside;
    /*リストマークを内側に表示*/
}

.ul1 {
    /*ulリスト用1（縦リスト/テキスト用）*/
}

.ul1 li {
    margin-top: 0.25em;
}

.ul1 li:first-child {
    margin-top: 0;
}

.ul1 span {
    margin-right: 1em;
}

.dl1 {
    /*dlリスト用1（テキスト用/dtとddで一組*/
}

.dl1 dt {
    margin-top: 0.25em;
}

.dl1 dt:first-child {
    margin-top: 0;
}

.dl1 dt span::before {
    /*FontAwesome*/
    content: "\f105";
    margin-right: 0.5em;
    font-family: FontAwesome;
}

.ul1 span,
.dl1 dt span {
    /*span共通 マーカー風ライン*/
    background: -webkit-gradient(linear, left top, left bottom, color-stop(40%, transparent), color-stop(0%, #fdede4));
    background: linear-gradient(transparent 40%, #fdede4 0%);
}

.pagetop {
    /*ページトップボタン*/
    position: fixed;
    /*固定*/
    bottom: 8px;
    right: 8px;
    z-index: 2;
    /*リボンと重ならないための対策*/
}

.pagetop a {
    display: block;
    /*リンク範囲の拡張*/
    background: #f6ae54;
    color: white;
    text-align: center;
    width: 30px;
    height: 30px;
    line-height: 30px;
    /*heightの値と揃える*/
    border-radius: 15px;
    /*widthとheightの値の半分にすると円になる*/
}

.pagetop a:hover {
    color: white;
    background: #80d0c1;
}


/*フォント*/

header h1,
section h1,
nav h1 {
    font-family: 'Nunito', sans-serif;
    font-weight: 600;
}


/*テキスト 行の高さ*/

.text,
footer {
    line-height: 1.7;
}


/*テキスト 文字間隔*/

header h1 {
    letter-spacing: 0.25em;
}

header h1 + span,
section h1,
nav h1 {
    letter-spacing: 0.14em;
}

nav ul li {
    letter-spacing: 0.08em;
}

.pagetop {
    letter-spacing: 0;
}


/*ページの枠組み*/

#all {}

.wrap1 {
    padding: 40px 20px;
}

.wrap2 {
    width: 100%;
    max-width: 700px;
    margin-right: auto;
}


/*ヘッダー*/

header {}

.title {
    /*フレックスコンテナ*/
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    /*フレックスボックス*/
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: flex-end;
    /*縦配置 下揃え*/
}

.title::before {
    /*タイトル画像 フレックスアイテム*/
    
    margin-right: 25px;
    line-height: 1;
    /*画像の隙間対策*/
    -ms-flex-negative: 0;
    flex-shrink: 0;
    /*縮小を無効*/
}

.title a {
    /*タイトル部分をまとめてリンク指定*/
    display: block;
    /*リンク範囲の拡張*/
    color: #333;
    text-decoration: none;
}

.title a:hover {
    color: #f99c28;
}

header h1 {
    font-size: 14px;
}

header h1 + span {
    display: block;
    margin-top: 1.2em;
}


/*メイン*/

main {
    margin-top: 50px;
}

section {
    margin-top: 50px;
}

section:first-child {
    margin-top: 0;
}

section h1 {
    font-size: 13px;
    margin-bottom: 1.2em;
}

section h1::before {
    /*FontAwesome*/
    color: #f6ae54;
    content: "\f004";
    margin-right: 0.8em;
    font-family: FontAwesome;
}


/*本文エリア*/

.text {
    border-top: solid 1px transparent;
    /*マージンの相殺対策*/
    border-left: solid 1px #fdd35c;
    padding-left: 1.5em;
    margin-left: 0.5em;
}

.text > p,
.text > ul,
.text > dl {
    /*本文エリア タグ間の余白*/
    margin-top: 1em;
}

.text > p:first-child,
.text > ul:first-child,
.text > dl:first-child {
    /*本文エリア タグ間の余白 先頭の要素を無効*/
    margin-top: 0;
}


/*全体*/
.hidden_box {
    margin: 2em 0;/*前後の余白*/
    padding: 0;
}

/*ボタン装飾*/
.hidden_box label {
    padding: 15px;
    font-weight: bold;
    border: solid 2px black;
    cursor :pointer;
}

/*ボタンホバー時*/
.hidden_box label:hover {
    background: #efefef;
}

/*チェックは見えなくする*/
.hidden_box input {
    display: none;
}

/*中身を非表示にしておく*/
.hidden_box .hidden_show {
    height: 0;
    padding: 0;
    overflow: hidden;
    opacity: 0;
    transition: 0.8s;
}

/*クリックで中身表示*/
.hidden_box input:checked ~ .hidden_show {
    padding: 10px 0;
    height: auto;
    opacity: 1;
}







/*ナビ*/

nav {
    margin-top: 50px;
}

nav h1 {
    margin-bottom: 1.2em;
}

nav ul {
    margin-top: 0.25em;
}

nav ul li {
    float: left;
    margin: 0.5em 0.5em 0 0;
}

nav ul li:last-child {
    margin-right: 0;
}

nav ul li a {
    display: block;
    /*リンク範囲の拡張*/
    text-decoration: none;
    padding: 0.25em 1em;
    background: #80d0c1;
    color: white;
}

nav ul li a:hover {
    color: white;
    background: #f6ae54;
}

nav p span:first-child {
    margin-right: 1em;
}

nav p span:first-child::before {
    /*FontAwesome*/
    color: #f6ae54;
    content: "\f177";
    margin-right: 0.8em;
    font-family: FontAwesome;
}

nav p span:last-child::after {
    /*FontAwesome*/
    color: #f6ae54;
    content: "\f178";
    margin-left: 0.8em;
    font-family: FontAwesome;
}


/*ナビ リボン*/

.ribbon {
    display: inline-block;
    position: relative;
    height: 28px;
    /*高さ*/
    line-height: 28px;
    /*高さ*/
    vertical-align: middle;
    padding: 0 30px 0 18px;
    /*文字の左右の余白*/
    background: #f6ae54;
    color: white;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

.ribbon:after {
    position: absolute;
    content: '';
    width: 0px;
    height: 0px;
    z-index: 1;
}

.ribbon:after {
    top: 0;
    right: 0;
    border-width: 14px 15px 14px 0px;
    /*1番目と3番目の数値は.ribbonのheightの半分の数値を指定する*/
    border-color: transparent #f7f6f5 transparent transparent;
    /*2番目の色はbodyの色と揃える*/
    border-style: solid;
}


/*フッター*/

footer {
    margin-top: 50px;
}

footer ul {}

footer ul li {
    float: left;
    margin-right: 1em;
}

footer ul li:last-child {
    margin-right: 0;
}

/*------------画面サイズ768px以上用（大きい画面サイズ向け）------------*/

@media screen and (min-width:768px) {
    .wrap1 {
        padding: 50px;
    }

    header h1 {
        font-size: 16px;
    }
}


/*ベンダープレフィックス記述済*/
/*エラーチェック済*/
