@charset "UTF-8";
/*
Theme Name:オンラインコーチング
Theme URI:https://picture.takane-baikyaku.com/
Description:オンラインコーチング専門です。
Author:koshimizu ayako
Version:1.0 24.08.08
*/

/* http://meyerweb.com/eric/tools/css/reset/ 
v2.0 | 20110126
License: none (public domain)
*/
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed, 
figure, figcaption, footer, header, hgroup, 
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
margin: 0;
padding: 0;
border: 0;
font-size: 100%;
font: inherit;
vertical-align: baseline;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section {
display: block;
}
body {
line-height: 1;
}
ol, ul {
list-style: none;
}
blockquote, q {
quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
content: '';
content: none;
}
table {
border-collapse: collapse;
border-spacing: 0;
}
img{vertical-align: bottom;}


/* iphone リセット*/
input[type="submit"],
input[type="button"] {
  border-radius: 0;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  appearance: button;
  border: none;
  box-sizing: border-box;
  cursor: pointer;
}
input[type="submit"]::-webkit-search-decoration,
input[type="button"]::-webkit-search-decoration {
  display: none;
}
input[type="submit"]::focus,
input[type="button"]::focus {
  outline-offset: -2px;
}

select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}

input, select, textarea{
    border: none;
    outline: none;
}

iframe{
    width: 100%;
    height: 100%;
}

*{
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}


/********* base *********/

html{font-size: 62.5%; /* sets the base font to 10px for easier math */}

body{
	color: #212121;
	font-size: 1.8rem;
    line-height: 1.7;    
}

body, table, input, textarea, select, option, h1, h2, h3, h4, h5, h6{
    font-family: 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', Meiryo, メイリオ, Osaka, 'MS PGothic', arial, helvetica, sans-serif;
}

a{text-decoration: none;
    color: #202020;}
a:hover{opacity: 0.8;}

img{
    max-width: 100%;
    max-height: 100%;}

.sp{display: none!important;}


@font-face {
    font-family: "agencyfb";
    src:
      url("font/agencyfb_reg.woff") format("woff"),
      url("font/agencyfb_reg.ttf") format("ttf");
  }


@media screen and (max-width: 768px){
    body{font-size: 1.6rem;}
    img{
        max-width: 100%;    
        width: 100%;
        vertical-align: bottom;}
	.sp{display: block!important;}
	.pc{display: none!important;}
}




@media screen and (max-width: 768px){
}

/********* header *********/
header {    
    padding: 36px 10px 67px;
    position: absolute;
    left: 0;
    right: 0;
    z-index: 1;
}

header h1.logo {
    width: 28%;
    max-width: 429px;
    border-radius: 50px;
}
header h1.logo a{
    padding: 6px 30px 7px;
    background: #fff;
    display: block;
    box-shadow: 0 1px 1px #D6D6D6;
    border-radius: 50px;
}

#header-inner {
    max-width: 1460px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
}

#header-inner nav#global-navi-pc{
    max-width: 704px;
    width: 50%;
}

#header-inner ul#menu-g-nav {
    padding: 0 3%;
    display: flex;
    background: linear-gradient(90deg, rgba(255,148,40,1) 0%, rgba(255,186,118,1) 100%);
    border: 5px solid #fff;
    border-radius: 50px;
    box-shadow: 0 0 10px 0 #bababaab;
    justify-content: center;
}
#header-inner ul#menu-g-nav li {
    width: 33%;
    max-width: 200px;
    font-size: 2.0rem;
    font-size: clamp(1.6rem, 1.2vw, 2.0rem);
    font-weight: 600;
    text-align: center;
}
#header-inner ul#menu-g-nav li a{
    /*padding: 20px 40px 21px;*/
    padding: 20px 1% 21px;
    display: block;
    color: #fff;
}
#header-inner ul#menu-g-nav li a:hover{
    background: #ffc82f;
    opacity: 0.7;
}

#header-inner .lineBtn {
    width: 22%;
    max-width: 270px;
    font-size: 1.8rem;
    font-size: clamp(1.2rem, 1.2vw, 1.8rem);
    font-weight: 600;
}
#header-inner .lineBtn a{
    padding: 20px 2% 21px;
    background: linear-gradient(90deg, rgba(3, 196, 75, 1) 0%, rgba(33, 202, 53, 1) 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    border: 5px solid #fff;
    border-radius: 50px;
    box-shadow: 0 0 10px 0 #bababaab;
}
#header-inner .lineBtn a:after{
    content: '';
    background: url(img/icon_arrow.png);
    width: 15px;
    height: 22px;
    display: block;
    margin-left: 13px;
}

@media screen and (max-width:1024px) {

}
@media screen and (max-width:768px) {
    header{
        padding: 5px 0 8px 5px;
        position: relative;
        box-shadow: 0 1px 3px #e8e8eb;
    }

    #header-inner{
        align-items: center;
    }
    header h1.logo{width: 45%;}
    header h1.logo a{
        padding: 6px 10px 7px;
    }

    nav#global-navi-pc {
        display: none;
    }

}


/********* footer *********/	
footer{
    padding: 40px 0 100px;
    background: #F4F4F2;
    display: flex;
    justify-content: center;
    align-items: flex-start;
    gap: 298px;
}

footer h1.logo {
    max-width: 330px;
    border-radius: 50px;
}
footer h1.logo a {
    background: #fff;
    padding: 6px 30px 7px;
    display: block;
    box-shadow: 0 1px 1px #D6D6D6;
    border-radius: 50px;
}

footer .site_map h2{
    margin-bottom: 10px;
    padding-bottom: 9px;
    font-family: 'Agency FB',"agencyfb";
    font-size: 3.1rem;
    font-weight: 700;
    border-bottom: 1px solid #000;
    display: block;
    line-height: 1;
}

footer ul#menu-f-nav{
    display: grid;
    grid-template-columns: 1fr 1fr;
}
footer ul#menu-f-nav li {
    margin-bottom: 15px;
}

p.copy {
    padding-bottom: 20px;
    background: #F4F4F2;
    text-align: center;
}

@media screen and (max-width:768px) {
    footer{
        padding: 20px 0 10px;
        display: block;
    }

    footer h1.logo{
        max-width: 280px;
        margin: 0 auto 20px;
    }

    footer .site_map h2{
        font-size: 2.1rem;
    }

    .site_map{
        width: 86%;
        margin: 30px auto 0;
    }

    p.copy{
        padding-bottom: 10px;
        font-size: 1.2rem;
    }
}


/********* spNavi *********/
@media screen and (max-width:768px) {
    #wrapper nav {
        position: fixed;
        top: 0;
        right: -300px;
        width: 300px;
        height: 100%;
        padding-top: 50px;
        background:#333;
        font-size: 16px;
        box-sizing: border-box;
        z-index: 2
    }
    #wrapper nav ul li {
        display: block;
        padding: 25px 28px 0;
        font-weight: 600;
        font-size: 1.8rem;
        line-height: 1;
    }
    #wrapper nav ul li a {
        text-decoration: none;
        color: #fff;
    }
    #wrapper .btn-gnavi {
    /*    position: fixed; */
        position: relative;
        right: 3px;
        width: 54px;
        height: 57px;
        z-index: 3;
        box-sizing: border-box;
        cursor: pointer;
        -webkit-transition: all 400ms;
        transition: all 400ms;
        display: block;
    }
    #wrapper .btn-gnavi span {
        position: absolute;
        width: 30px;
        height: 4px;
        background: #666;
        border-radius: 10px;
        -webkit-transition: all 400ms;
        transition: all 400ms
    }
    #wrapper .btn-gnavi span:nth-child(1) {
        top: 0
    }
    #wrapper .btn-gnavi span:nth-child(2) {
        top: 10px
    }
    #wrapper .btn-gnavi span:nth-child(3) {
        top: 20px
    }
    #wrapper .btn-gnavi.open span {
        background: #fff
    }
    #wrapper .btn-gnavi.open span {
        width: 24px;
    }
    #wrapper .contents section p {
        position: absolute;
        top: 50%;
        width: 30%;
        line-height: 1.4;
        font-size: 20px;
        color: #fff;
    }
    #wrapper .contents section:nth-child(odd) p {
        left: 10%
    }
    #wrapper .contents section:nth-child(even) p {
        right: 10%
    }
    
    nav#global-navi .header_right_wrap{
        display: block;
    }

    nav#global-navi .contactBtn, .requestBtn{
        width: 80%;
        max-width: 240px;
    }
    nav#global-navi .contactBtn a, .requestBtn a{
        font-size: 1.6rem;
        padding: 10px 10px 10px;
        margin-top: 20px;
    }
}
