@charset "utf-8";
/* CSS Document */

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, button {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
}

*, *:before, *:after {
	border: 0;
	outline: 0;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-ms-box-sizing: border-box;
	-o-box-sizing: border-box;
	box-sizing: border-box;
}

/*
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Zen+Maru+Gothic&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Jost:ital,wght@0,100..900;1,100..900&display=swap');
*/

:root {
    --base-bg-color: #FFFFFF;
    --base-content-bg-color:#FFFFFF;
    --base-text-color: #333333;
    --base-main-blue: #285676;
    --base-main-orange: #f29200;
    --base-main-magenta: #e95464;
    --base-bg-blue:#ecf5f5;
    --base-bg-gray:#f9f9f2;
    --base-bg-lightgray:#fbfbfb;
    --base-bg-footer:#f6f5f3;
    --base-bg-yellow:#fffdcc;    
}


html {
    font-size: 125%;   /* 20px */
    -webkit-text-size-adjust: 100%;
    -ms-text-size-adjust: 100%;
    text-size-adjust:100%;
}

body{
    font-size: 0.8rem;
    line-height:1.6em;  
    position:relative;
    font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN","Hiragino Sans","メイリオ",sans-serif;
    
    color:var(--base-text-color);
    background-color:var(--base-bg-color);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

a:link, a:visited {
    color: var(--base-main-blue);
    text-decoration:underline;
}
a:focus {
    border-color: #e95464 !important;
}
:focus {
    outline: none;
}
:focus-visible {
    outline: -webkit-focus-ring-color auto 1px;
}

a.noline:link, a.noline:visited {
    text-decoration:none;
}

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

a img:hover {
    opacity: 0.8;
}

button{
    background-color: transparent;
}

button:hover{
    cursor:pointer;
    opacity: 0.8;
}

.sp{
    display:none;
}



header{
    width:100%;
    height:2.85rem;
    margin:0 auto;
    position:fixed;
    left:0;
    top:0;
    line-height:0;
    z-index:100;
    background-color: #ffffff;
}

.tokyologo{
    width:4rem;
    width:3.95rem;
    width:4rem;
    height:auto;
    position:absolute;
    left:1.5rem;
    top:1rem;
}

.titlelogo{
    width:21.5rem;
    width:20.5rem;
    position:absolute;
    left:7.05rem;
    top:0.9rem;
    cursor:pointer;
}

.titlelogo:hover{
    opacity: 0.8;
}

.menu, .menu_sp{
    font-weight:500;
}

.menu{
    display:flex;
    justify-content:flex-start;
    position: absolute;
    right:1.9rem;
    top:1.05rem;
    column-gap: 1.15rem;
}

.menu li{
    list-style-type: none;
    cursor: pointer;
    font-size:0.685rem;
    font-feature-settings: "palt";
    letter-spacing: 0.025em;
    line-height: 1em;
    position:relative;
}

.menu li:hover{
    opacity: 0.8;
}

.menu_02{
    margin-right:0.95rem;
}

.menu_03{
    margin-right:0.95rem;
}

.menu_04{
    margin-right:0.95rem;
}

.menu_05{
    width:10rem;
    margin-right:0;
    position:relative;
    top:-0.2rem;
}


.menu_02::after,.menu_03::after, .menu_04::after{
    content:"";
    position:absolute;
    right:-0.95rem;
    top:0.2rem;
    width:0.75rem;
    height:0.4rem;
    background-image:url(../img/menu-arrow.svg) ;
    background-size:0.75rem 0.4rem;
    background-repeat: no-repeat;
}

.hamburger{
    display:none;
}

.menu_sp{
    display:none;
}

.top_area{
    margin-top:2.85rem;   
}

.keyvisual{
    background: url(../img/kv-back.jpg) no-repeat center top;
    background-size: cover;
    background-color:#e1efef;
    width:100%;
    height:21.05rem; 
    position:relative;
}

.keyvisual_pc{
    width:60rem;
    margin:0 auto;
    height:100%;
    position:relative;
}

.keyvisual_pc img{
    width:60rem;
    position:absolute;
    left:0;
    top:0;
}

.event_info_area{
    background-color: var(--base-main-blue);
    width:100%;
    height:8.7rem;
}

.event_info_area_container{
    width:60rem;
    margin:0 auto;
    position:relative;
}

.event_info_text{
    width:18.25rem;
    position:absolute;
    left:11.95rem;
    top:2.1rem;
}

.event_info_btn{
    width:10rem;
    position:absolute;
    left:1.0rem;
    top:-0.5rem;
    background-color:transparent;
}

.news_area_container{
    width:50rem;
    margin:0 auto 3.6rem;
}

.news_area{
    border-radius:1rem;
    margin-top:3.6rem;
    padding-top:2.55rem;
    padding-bottom:2.55rem;
    padding-left:15.05rem;
    padding-right:2rem;
    background-color: var(--base-bg-blue);
    position:relative;
}

.news_heading{
    width:6.2rem;
    line-height:0;
    position:absolute;
    left:3.85rem;
    top:50%;
    transform: translateY(-50%);
}

.news_record{
    font-size:0.75rem;
    line-height:1.2rem;
    margin-bottom:0.8rem;
    display: flex;
    color: var(--base-main-blue);
}

.news_record_date{
    margin-right:1.2rem;
    font-family: "Jost", sans-serif;
    font-weight:800;
    position:relative;
    top:0.1rem;
}

.btn_01_area{
    width:50rem;
    height:auto;
    padding:1rem;
    border-radius:1rem;
    background-color:var(--base-main-magenta);
    margin:1.3rem auto 1.3rem;
    display:block;
}

.btn_01_content{
    height:auto;
    border-radius:0.5rem;
    background-color:var( --base-bg-color);
    padding:1.1rem 0;
}

.btn-01-content-text{
    width:17.45rem;
    margin:0 auto 0.25rem;
    line-height:0;
}

.btn_01{
    width:26rem;
    height:auto;
    margin:0 auto;
    padding: 0.6rem 0;
    border-radius:100px;
    border:solid 0.2rem var( --base-bg-color);
    background-color:var(--base-main-magenta);
    box-shadow: 0.15rem 0.15rem 0.35rem rgba(0,0,0,0.2);
    text-align:center;
    color:#fff;
    font-family: "Noto Sans JP", sans-serif;
    font-weight:500;
    line-height:1em;
    display:block;
}

.btn_01.sec {
    margin-top: 0.8rem;
    padding-top: 1rem;
    background-color:#f47f8c;
}

.btn_02{
    width:26rem;
    height:auto;
    margin:0 auto;
    border-radius:2.6rem;
    border:solid 0.2rem var( --base-bg-color);
    background-color:var(--base-main-magenta);
    box-shadow: pagetop0.15rem 0.15rem 0.35rem rgba(0,0,0,0.2);
    text-align:center;
    color:#fff;
    font-family: "Noto Sans JP", sans-serif;
    font-weight:500;
    line-height:1em;
    display:block;
}

.btn_01:hover{
    opacity:0.8;
}

.btn_01_text_01{
    font-size:2.2rem;
    margin-top:-0.2rem;
    margin-bottom:0.25rem;
    line-height: 1.1;
}
.btn_01_text_01.sec {
    font-size: 1.2rem;
}

.btn_02 .btn_01_text_01{
    margin-top:-0.2rem;
}

.btn_01_text_02{
    font-size:1.2rem;
    margin-bottom:0.25rem;
    line-height: 1.2;
}
.btn_01_text_03{
    font-size:1.2rem;
    line-height: 1.1;
}

.btn_01_content_heading {
    display: block;
    color: var(--base-main-magenta);
    font-size: 1.0rem;
    font-weight: 600;
    line-height: 1.4;
    width: 90%;
    margin: 0.5rem auto 1rem auto;
    text-align: center;
}
.btn_01_content_heading span {
    font-size: 0.8rem;
}
.btn_01_content_note {
    display: block;
    text-align: center;
    max-width: 90%;
    margin: 0.8rem auto 0 auto;
}
.btn_01_content iframe {
    display: block;
    margin: 0 auto;
    width: 90%;
    aspect-ratio: 16/9;
}

.lead{
    width:100%;
    background-color:#f8f5b7;
    padding-top:1.35rem;
    padding-bottom:3.65rem;
    position:relative;
}

.lead .arc{
    width:100%;
    position:absolute;
    left:0;
    bottom:0;
    line-height: 0;
}

.lead_container{
    width:50rem;
    margin:0 auto;
    position: relative;
}

.lead_title{
    width:25.8rem;
    margin-bottom:1.35rem;
    line-height:0;
}

.lead_image_area{
    width:20.9rem;
    position:absolute;
    top:1.4rem;
    right:-0.45rem;
}

.lead_text{
    width:27.5rem;
    font-size:1rem;
    line-height:1.7rem;
    font-feature-settings: "palt";
    letter-spacing: -0.01em;
}

.lead_text p{ 
    margin-bottom:1.7rem;
}

.lead_text_strong{
    font-weight:600;
    color:#007e5a;
}

.program_heading{
    width:7rem;
    margin:0 auto 1.5rem;
}

.program_kind{
    text-align:center;
    font-size:1.8rem;
    line-height:1em;
    font-weight:500;
    font-feature-settings: "palt";
    letter-spacing: -0.025em;
    position:relative;
    margin-bottom:4.1rem;
}
.program_kind span {
    display: block;
    font-size: 0.8rem;
    line-height: 2.2;
}

.program_kind::after{
    content:"";
    width:4.45rem;
    height:0.25rem;
    background-color: #0eb288;
    border-radius:0.125rem;
    position:absolute;
    bottom:-1.4rem;
    left:50%;
    transform:translateX(-50%)
}

.program_unit{
    width:50rem;
    margin:0 auto 3.2rem;
    border-radius:1rem;
    background-color: var(--base-bg-blue);
    position:relative;
    padding-left:1.9rem;
    padding-right:1.9rem;
    padding-bottom:1.0rem;    
}

.program_unit_time{
    width:14.05rem;
    height:2.55rem;
    border:solid 0.05rem #000;
    border-radius: 1.275rem;
    background-color: #fff;
    position:absolute;
    left:1rem;
    top:-1.3rem;
    text-align: center;
    font-size:1.55rem;
    line-height: 2.45rem;
    font-family: "Jost", sans-serif;
    font-weight:700;
    color: var(--base-main-blue);
    letter-spacing:0.025em ;
}

.program_unit_time_text{
    position:relative;
    top:-0.05rem;
}

.program_unit_time_colon{
    display:inline-block;
    font-weight:500;
    margin:0 0.1rem;
    position:relative;
    top:-0.15rem;
}

.program_unit_time_kara{
    display:inline-block;
    font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN","Hiragino Sans","メイリオ",sans-serif;
    font-weight:600;
    margin:0 0.15rem;
    font-size:1.4rem;
}

.program_unit_kind{
    font-size:1.2rem;
    line-height:1em;
    font-weight: 500;
    font-feature-settings: "palt";
    letter-spacing: 0.2em;
    color:var(--base-main-magenta);
    padding-top:2.0rem;
    margin-bottom:0.5rem;
}

.program_unit_participants{
    font-weight: 600;
    color:#187e61;
    font-feature-settings: "palt";
    letter-spacing:0.025em;
    display: flex;
    justify-content: flex-start;
    margin-bottom:1.1rem;
}

.program_unit_participants:nth-last-child(1 of .program_unit_participants) {
    margin-bottom:1.4rem;
}


.program_unit_participants_name{
    font-size: 1.3rem;
    margin-right:0.55rem;
    line-height:1em;
}

.program_unit_participants_title{
    margin-top:0.15rem;
    font-size: 0.8rem;
    font-weight: 700;
}

.san, .uji, .host{
    font-size: 0.8rem;
    font-weight: 700;
}

.uji{
    margin-left:0.5em;
}

.host{
    margin-right:0.5em;
}

.btn_program_profile{
    width:32rem;
    height:3.1rem;
    background-color: var(--base-main-blue);
    color:#fff;
    border-radius:0.2875rem;
    text-align: center;
    position: relative;
    cursor: pointer;
    transition: all 0.5s cubic-bezier(0.19, 1, 0.22, 1);
}

.btn_program_profile:hover{
    opacity:0.8;
}

.close.btn_program_profile{
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
}

.btn_program_profile_see_text, .btn_program_profile_close_text{
    font-size:1.05rem;
    line-height: 3.1rem;
    font-weight:800;
    display:none;
}

.see .btn_program_profile_see_text{
    display:block;
}

.close .btn_program_profile_see_text{
    display:none;
}

.close .btn_program_profile_close_text{
    display:block;
}

.see .btn_program_profile_close_text{
    display:none;
}

.btn_program_profile_see_icon, .btn_program_profile_close_icon{
    width:1.575rem;
    height:1.575rem;
    line-height:0;
    position:absolute;
    right:0.65rem;
    top:0.75rem;
    display:none;
}

.see .btn_program_profile_see_icon{
    display:block;
}

.close .btn_program_profile_see_icon{
    display:none;
}

.close .btn_program_profile_close_icon{
    display:block;
}
.see .btn_program_profile_close_icon{
    display:none;
}

.btn_program_profile_see, .btn_program_profile_see_icon{
    display:block;
}

.hide .btn_program_profile_close,  .hide .btn_program_profile_close_icon{
    display:none;
}

.program_unit_title{
    font-size:1.8rem;
    line-height: 2.2rem;
    font-family: "Zen Maru Gothic", sans-serif;
    font-weight: 900;
    color: var(--base-main-blue);
    margin-bottom:1.2rem;
}

.program_unit_participants_photo{
    width:12.5rem;
    height:12.5rem;
    position:absolute;
    right:1.7rem;
    top:1.7rem;
    border:solid 0.05rem #e9eef1;
}

.program_unit_participants_photo_networking{
    width:14rem;
    height:12.35rem;
}

.colon{
    display: inline-block;
    margin-left:-0.25em;
    margin-right:-0.25em;
}

.btn_program_profile_detail_area{
    border:solid 0.05rem var(--base-main-blue);
    background-color:#fff;
    border-radius:0.5rem;
    border-top-left-radius:0;    
    padding:1.65rem 3.6rem 1.65rem 3.2rem;
    display:none;
}


.hide .btn_program_profile_detail_area{
    display:none;
}

.btn_program_profile_detail_lead{
    display: block;
    width: 60%;
    font-size:0.8rem;
    line-height:1.4rem;
    font-feature-settings: "palt";
    margin-bottom:1.2rem;
}

.btn_program_profile_detail_unit{
    display:flex;
    justify-content: space-between;
    margin-bottom:1.1rem;
}

.btn_program_profile_detail_unit_photo{
    width:5rem;
    height:5rem;
    border-radius:0.05rem;
    overflow:hidden;
}

.btn_program_profile_detail_unit_text{
    width:32.4rem;
    font-size:0.9rem;
    line-height:1.6rem;
    font-feature-settings: "palt";
    color: var(--base-main-blue);
    font-weight:300;
    letter-spacing:0.025em;
    margin-top:-0.15rem;
}

.photo_panel_discussion{
    width:17.5rem;
    height:17.5rem;
    background-color:transparent;
}

.photo_panel_discussion_01,
.photo_panel_discussion_02,
.photo_panel_discussion_03,
.photo_panel_discussion_04{
    width:8.2rem;
    height:8.2rem;
    position:absolute;
    border:solid 0.05rem #e9eef1;
}

.photo_panel_discussion_01{
    left:0;
    top:0;
}

.photo_panel_discussion_02{
    right:0;
    top:0;
}

.photo_panel_discussion_03{
    left:0;
    bottom:0;
}

.photo_panel_discussion_04{
    right:0;
    bottom:0;
}

.program_unit_tenji{
    background-color:var(--base-bg-blue);
    padding-top:1.4rem;
    padding-left:2.3rem;
    padding-right:2rem;   
}

.program_unit_tenji_description{
    text-align: center;
    font-size:1.1rem;
    line-height:1.6;
    font-feature-settings: "palt";
    letter-spacing:0.075em;
    font-weight:500;
    margin-bottom:0.5rem;
}

.program_unit_tenji_heading{
    font-size:1.2rem;
    line-height: 1em;
    font-feature-settings: "palt";
    letter-spacing:0.075em;
    font-weight:500;
    margin-bottom:1rem;
    margin-left:0.2rem;
}

.program_unit_tenji_company{
    margin-left:0.2rem;
    display:flex;
    flex-wrap:wrap; 
    column-gap:1.5rem;
    row-gap:1em;
}

.program_unit_tenji_company li{
    list-style-type: none;
    font-size:1.0rem;
    font-weight:500;
    font-feature-settings: "palt";
    letter-spacing:0.075em;
    white-space: nowrap;
    position:relative;
    padding-left:1.3em;
}

.program_unit_tenji_company li::before{
    content:"●";
    color:var(--base-main-magenta);
    width:1em;
    height:1em;
    position:absolute;
    left:0;
    top:0;
}

.overview_area_container{
    display:flex;
    width:49.1rem;
    margin:0 auto 2.6rem;
    justify-content: space-between;
}

.overview_heading{
    width:7.1rem;
    margin-left:5.2rem;
    margin-bottom:1.15rem;
    line-height: 0;
}

.overview_image{
    width:17rem;
    line-height: 0;
}

.overview_area{
    background-color: var(--base-bg-gray);
    padding-top:5.35rem;
    padding-bottom: 2.7rem;
    position: relative;
}

.overview_area .arc{
    width:100%;
    position:absolute;
    left:0;
    top:0;
    line-height: 0;
    transform: rotate(180deg);
}

.overview_heading_area{
    width:18rem;
}

.overview_text_area{
    width:30rem;
}

.overview_text_area ul{
    list-style-type: none;
    margin-top:1.05rem;
}

.overview_text_area li{
    padding-left:1.05rem;
    padding-top:0.5rem;
    padding-bottom:0.5rem;
    border-bottom:solid 0.05rem #93aaba;
    display: flex;
    font-feature-settings: "palt";
}

.overview_text_area li:first-of-type{
    padding-top:0;
}

.overview_text_area li:last-of-type{
    padding-bottom:0;
    border-bottom:none;
}

.overview_text_area_heading{
    width:6.45rem;
    font-size:1.05rem;
    line-height:1.4em;
    font-weight: 600;
    color:#2b8068;
}

.overview_text_area_text{
    font-size:1.05rem;
    line-height:1.4em;
    color:#232323;
}

.overview_text_area_text_sub{
    font-size: 0.95rem;
    line-height:1em;
    display: block;
    margin-top:0.65rem;
}

.overview_area .note {
    display: block;
    width: calc(100% - 2rem);
    max-width: 44rem;
    text-align: center;
    font-size: 1.05rem;
    color: var(--base-main-magenta);
    font-weight: 600;
    margin: 0 auto;
    line-height: 1.6;
}

.childcare_area{
    width:44rem;
    margin: 3.5rem auto 0;
    background-color: #fff;   
    border-radius: 1rem;
    box-shadow: 0.2rem 0.35rem 0px #f3f3e6;
    padding-top:1.0rem;
    padding-left:2.9rem;
    padding-right:2.9rem;
    padding-bottom:1.0rem;
}

.childcare_reservation{
    width:9.4rem;
    height:2.35rem;
    margin:0 auto 0.65rem;
    background-color: #fff6f7;
    border: solid 1px #e60014;
    border-radius: 0.2rem;
    font-size: 1.3rem;
    font-weight:500;
    color:#e60014;
    text-align: center;
    line-height: 2.2rem;
}

.childcare_title{
    text-align: center;
    font-family: "Zen Maru Gothic", sans-serif;
    font-size: 1.7rem;
    letter-spacing: 0.025em;
    line-height: 1.2;
    font-weight: 600;
    color:#232323;
    margin-bottom:1.2rem;
}

.childcare_deadline{
    width:17.65rem;
    height:1.6rem;
    margin: 0 auto;
    border:solid 0.05rem #e60014;
    text-align: center;
    font-size: 0.8rem;
    line-height: 1.5rem;
    letter-spacing: 0.025em;
    font-feature-settings: "palt";
    font-weight:700;
    color:#e60014;
    margin-bottom:0.7rem;
}

.childcare_text{
    width:70%;
    margin:0 auto;
    font-size:0.7rem;
    line-height:1.2rem;
    text-align: center;
    font-feature-settings: "palt";
    letter-spacing: 0.025em;
}

.childcare_doc_container{
    display: flex;
    flex-wrap: wrap;
    column-gap: 0.85rem;
    row-gap: 0.6rem;
    margin-top:0.6rem;
    margin-bottom:1.7rem;
}

.childcare_doc{
    width:18.6rem;
    min-width:18.6rem;
    height:2.4rem;
    border:solid 0.05rem var(--base-main-blue);
    background-color: #fff;
    border-radius:1.2rem;
    font-size:0.7rem;
    line-height: 2.3rem;
    color: var(--base-main-blue);
    font-weight: 600;
    text-align: center;
    margin:0 auto;
    display:block;
}

.doc_kind{
    font-size:0.75em;
    display:inline-block;
    position:relative;
    top:-0.1rem;
    margin-left:0.25rem;
}

.childcare_contact{
    font-size:0.7rem;
    line-height:1.2rem;
    color:#232323;    
    text-align: center;
    font-feature-settings: "palt";
    letter-spacing: 0.025em;
    font-weight: 500;
}

.childcare_contact_mail{
    font-size:0.8rem;
}

.access_area{
    padding-top:1.5rem;
    padding-bottom:1.5rem;
}

.access_heading{
    width:6.1rem;
    margin: 0 auto 1.5rem;
    line-height: 0;
}

.access_area_container{
    width:36rem;
    margin:0 auto;
    display: flex;
    justify-content: space-between;
}

.access_place_info{
    width:17.5rem;
    font-feature-settings: "palt";
}

.access_place{
    font-size: 1.1rem;
    line-height: 1em;
    font-family: "Jost", sans-serif;
    font-weight:500;
    font-feature-settings: "palt";
    margin-bottom:0.2rem;
}

.access_address{
    width:16.5rem;
    font-size: 0.7rem;
    line-height: 1.2rem;
    font-feature-settings: "palt";
    font-weight: 500;
}

.access_time{
    width:16.5rem;
    font-size: 0.7rem;
    line-height: 2em;
    font-feature-settings: "palt";
    margin-top:-0.5rem;
}

.access_map{
    width:40rem;
    height:27rem;
    margin:1.9rem auto 0;
    line-height: 0;
}

.access_map iframe{
    margin:0;
    width:100%;
    height:100%;
}

.officeinfo{
    background-color:#fbfbfb;
    padding-top:1.7rem;
    padding-bottom:1.45rem;
}

.officeinfo_container{
    width:40rem;
    margin:0 auto;
    display: flex;
    justify-content: space-between;
}

.officeinfo_text_area{
    text-align: center;
    margin: 0 auto;
}

.officeinfo_logomark{
    width:7.55rem;
    line-height: 0;
}

.officeinfo_name{
    font-size:1.3rem;
    line-height: 1.4em;
    color:#42967e;
    font-weight:600;
    margin-bottom: 1.55rem;
}

.officeinfo_contact{
    font-size:0.9rem;
    line-height:1.45rem;
}

.officeinfo_tel{
    font-size:0.9rem;
    line-height:1em;   
    margin-bottom:0.75rem;
    color:#232323;

}

.officeinfo_mail{
    font-size:0.9rem;
    line-height:1em;   
    margin-bottom:0.65rem;
    color:#232323;
}

.officeinfo_time{
    font-size:0.7rem;
    line-height:1.1rem;
    color:#232323;
}

footer{
    height:7rem;
    padding-top:2.3rem;
    background-color: var(--base-bg-footer);
    position:relative;
}

.footer_tokyologo{
    width:8.75rem;
}

.footer_tokyologo_container{
    width:40rem;
    margin:0 auto;
}

.footer_contact{
    width:9.95rem;
    display: flex;
    justify-content: flex-end;
    position:absolute;
    right:4.45rem;
    top:3rem;
}

.footer_contact li{
    list-style-type: none;
    font-size:0.7rem;
    line-height:1em;
    color: var(--base-main-blue);
    font-feature-settings: "palt";
}

.sns{
    width:4.15rem;
    display: flex;
    justify-content: flex-end;
    position:absolute;
    right:1rem;
    top:2.55rem;
}

.sns_facebook{
    width:1.8rem;
}

.sns_instagram{
    width:1.7rem;
    padding-top:0.05rem;
}

small{
    font-size: 0.6rem;
    line-height: 1em;
    color: var(--base-main-blue);
    position:absolute;
    right:0.95rem;
    bottom:0.65rem;
}

#pagetop{
    position:fixed;
    right:1.8rem;
    bottom:1.8rem;
    z-index:10;
    display: none;
    cursor:pointer;
    width:3.25rem;
    height:3.25rem;
    border-radius:50%;
    background-color: #fff;
    border:solid 0.05rem #0eb288;
    box-shadow: 0.2rem 0.2rem 0.4rem rgba(0,0,0,0.15);
}

#pagetop img{
    max-width:100%;
    height:auto;
}

.sitepolicy_wrap h2 {
    font-size: 1.4rem;
    font-weight: 800;
    margin: 2rem 0 0.8rem 0;
    color: #42967e;
}
.sitepolicy_wrap h3 {
    font-size: 1.0rem;
    font-weight: 800;
    margin: 0.8rem 0 0.3rem 0;
}



@media (max-width: 430px) {
    .pc{display:none;}
    .sp{display:block;}

    .hamburger{
        display:block;
        width:1.9rem;
        height:0.55rem;
        position:absolute;
        right:0.85rem;
        top:1.15rem;
    }

    .hamburger_top{
        width:1.9rem;
        height:0.1rem;
        background-color:#0eb288;
        position:absolute;
        top:0;
        left:0;
    }

    .hamburger_bottom{
        width:1.9rem;
        height:0.1rem;
        background-color:#0eb288;
        position:absolute;
        bottom:0;
        left:0;
    }

    .keyvisual{
        width:100%;
        height:auto; 
        position:relative;
    }

    .keyvisual_pc{
        width:100%;
        margin:0 auto;
        height:100%;
        position:relative;
        line-height:0;
    }

    .keyvisual_pc img{
        width:100%;
        position:relative;
        left:0;
        top:0;
    }
    .keyvisual_sp {
        line-height: 0;
        width: 90%;
        margin: 0 auto;
    }

    .tokyologo{
        width:3.2rem;
        height:auto;
        position:absolute;
        left:0.66rem;
        top:1.1rem;
    }

    .titlelogo{
        width:9.7rem;
        position:absolute;
        left:4.6rem;
        top:0.48rem;
        cursor:pointer;
    }

    .menu{display:none;}

    .event_info_area{
        height:auto;
    }

    .event_info_area_container{
        width:80%;
        margin:0 auto;
        position:relative;
        padding-top:0.5rem;
        padding-bottom:1rem;
    }

    .event_info_text{
        width:100%;
        position:relative;
        left:0;
        top:0;
        margin-bottom:0.5rem;
    }

    .event_info_btn{
        width:11.5rem;
        position:relative;
        left:0;
        top:0;
        margin:0 auto;
    }

    .news_area_container{
        width:17rem;
        margin:0 auto 2rem;
    }

    .news_area{
        border-radius:1rem;
        margin-top:2.55rem;
        padding-top:2.55rem;
        padding-bottom:2rem;
        padding-left:1rem;
        padding-right:1rem;
    }

    .news_record{
        font-size:0.7rem;
        line-height:1.2rem;
        margin-bottom:0.35rem;
        display: block;
    }

    .news_heading{
        width:6.2rem;
        line-height:0;
        position:relative;
        left:0;
        top:0;
        transform:none;
        margin:0 auto 2.55rem;
    }

    .news_record_date{
        margin-right:1rem;
        position:relative;
        top:0.1rem;
    }


    .btn_01_area{
        width:17rem;
        height:auto;
        padding:0.7rem;
        border-radius:0.7rem;
        margin:1.0rem auto 1.0rem;
    }

    .btn_01_content{
        height:auto;
        border-radius:0.35rem;
        padding:0.8rem 0;
    }

    .btn_01_content_heading {
        font-size: 0.8rem;
        line-height: 1.4;
        margin: 0rem auto 0.8rem auto;
        text-align: center;
    }
    .btn_01_content_heading span {
        font-size: 0.6rem;
    }

    .btn-01-content-text{
        width:80%;
        margin:0 auto 0.5rem;
        line-height:0;
    }

    .btn_01{
        width:13.8rem;
        height:auto;
        margin:0 auto;
        padding: 0.8rem 0 0.4rem 0;
        border-radius:100px;
        border:solid 0.15rem var( --base-bg-color);
        box-shadow: 0.15rem 0.15rem 0.35rem rgba(0,0,0,0.2);
        line-height:1.4;
    }
    .overview_area .btn_01.sec {
        margin-top: 2rem;
    }

    .btn_01_text_01{
        font-size:1.2rem;
        margin-top:-0.15rem;
        margin-bottom:0.3rem;
    }
    .btn_01_text_01.sec {
        font-size: 0.8rem;
    }

    .btn_01_text_02{
        font-size:0.8rem;
        margin-bottom:0.3rem;
        line-height: 1.4;
    }
    
    .btn_01_text_03{
        font-size:0.8rem;
    }

    .lead{
        width:100%;
        background-color:#fffb8d;
        padding-top:2.5rem;
        padding-bottom:6.65rem;
        padding-bottom:4rem;
        position:relative;
    }

    .lead_container{
        width:17rem;
        margin:0 auto;
    }

    .lead_title{
        width:100%;
        margin-bottom:1.35rem;
        line-height:0;
    }

    .lead_image_area{
        width:100%;
        position:relative;
        top:0;
        right:0;
    }

    .lead_text{
        width:100%;
        font-size:0.8rem;
        line-height: 1.8;
        margin-bottom:1rem;
    }

    .lead_text p{ 
        margin-bottom:1.0rem;
    }

    .program_area{
        padding-top:1.5rem;
    }
    
    .program_kind{
        margin-bottom:5rem;
    }

    .program_unit{
        width:17rem;
        margin:0 auto 3.2rem;
        border-radius:1rem;
        background-color: var(--base-bg-blue);
        position:relative;
        padding: 1.5rem 0.875rem;
    }

    .program_unit_time{
        width:11rem;
        height:2.25rem;
        border:solid 0.05rem #000;
        border-radius:1.125rem;
        position:absolute;
        left:0.5rem;
        top:-1.15rem;
        font-size:1.3rem;
        line-height: 2.2rem;
    }

    .program_unit_time_text{
        top:-0.15rem;
    }

    .program_unit_title{
        font-size:1.2rem;
        line-height: 1.6rem;
        margin-bottom:1.2rem;
    }

    .program_unit_kind{
        font-size:0.9rem;
        padding-top: 1.2rem;
        margin-bottom: 0.6rem;
    }

    .program_unit_participants{
        font-weight: 600;
        color:#42967e;
        font-feature-settings: "palt";
        letter-spacing:0.025em;
        display: flex;
        justify-content: flex-start;
        margin-bottom:1.1rem;
    }

    .program_unit_participants_photo{
        width:100%;
        height:auto;
        position:relative;
        right:0;
        top:0;
        border:solid 0.05rem #e9eef1;
        margin-bottom:1rem;
    }

    .photo_panel_discussion{
        width:15.25rem;
        height:15.25rem;
    }

    .photo_panel_discussion_01,
    .photo_panel_discussion_02,
    .photo_panel_discussion_03,
    .photo_panel_discussion_04{
        width:7.35rem;
        height:7.35rem;
        position:absolute;
        border:solid 0.05rem #e9eef1;
    }

    .program_unit_participants{
        display: block;
        margin-bottom:1.1rem;
    }

    .btn_program_profile{
        width:100%;
        height:3.1rem;
        position: relative;
        text-align:center;
        padding-top:0.4rem;
    }
    .program_unit.panel .btn_program_profile {
        padding-top: 0.95rem;
    }

    .btn_program_profile_see_text, .btn_program_profile_close_text{
        font-size:0.9rem;
        line-height: 1.2em;
        position: relative;
        top: 0.5rem;
    }

    .btn_program_profile_see_icon, .btn_program_profile_close_icon{
        width:1.3rem;
        height:1.3rem;
        position:absolute;
        right:0.5rem;
        top:0.75rem;
    }

    .btn_program_profile_detail_area{
        padding:1rem 0.75rem 1.25rem 0.75rem;
            border-top-right-radius:0; 
    }

    .btn_program_profile_detail_unit{
        display:block;
        margin-bottom:1.6rem;
    }

    .btn_program_profile_detail_unit:nth-last-child(1 of .btn_program_profile_detail_unit) {
        margin-bottom:0;
    }
    .program_unit_participants:nth-last-child(1 of .program_unit_participants){
        margin-bottom: 1.0rem;
    }
    .program_unit_participants_name{
        font-size: 0.9rem;
        margin-right:0.55rem;
        line-height:1em;
    }
    .program_unit_participants_title{
        font-size: 0.7rem;
    }

    .btn_program_profile_detail_lead{
        width: 100%;
        font-size:0.7rem;
        line-height:1.71428571em;
        margin-bottom:1.3rem;
    }

    .btn_program_profile_detail_unit_photo{
        width:100%;
        height:auto;
        border-radius:0.05rem;
        margin-bottom:0.6rem;
    }

    .btn_program_profile_detail_unit_text{
        width:100%;
        font-size:0.7rem;
        line-height:1.6;
        margin-top:-0.15rem;
    }

    .program_unit_tenji_description{
        font-size:1.0rem;
        line-height:1.5em;
        text-align: left;
    }

    .program_unit_tenji_heading{
        font-size:1.1rem;
        line-height: 1em;
        font-feature-settings: "palt";
        letter-spacing:0.075em;
        font-weight:500;
        margin-bottom:1rem;
        margin-left:0.2rem;
    }

    .program_unit_tenji_company{
        margin-left:0;
        display:flex;
        flex-direction: column;
        flex-wrap:wrap; 
        row-gap:1em;
    }

    .program_unit_tenji_company li{
        font-size:0.8rem;
        line-height: 1.3em;
        white-space: wrap;
    }

    .overview_area{
        padding-top:4.5rem;        
        padding-bottom: 2.7rem;
    }

    .overview_area_container{
        display:block;
        width:17rem;
        margin:0 auto 2rem;
    }

    .overview_heading_area{
        width:100%;
        margin-bottom:2.5rem;
    }

    .overview_heading{
        width:7.1rem;
        margin-left:auto;
        margin-right:auto;
        margin-bottom:2.5rem;
    }

    .overview_image{
        width:17rem;
        height:auto;
        line-height: 0;
    }

    .overview_text_area{
        width:100%;
        margin-top:1rem;
    }

    .overview_text_area ul{
        list-style-type: none;
        margin-top:1.05rem;
    }

    .overview_text_area li{
        padding-left:0.1rem;
        padding-top:0.65rem;
        padding-bottom:0.9rem;
        border-bottom:solid 0.05rem #93aaba;
        display: flex;
        font-feature-settings: "palt";
    }

    .overview_text_area li:first-of-type{
        padding-top:0.65rem;
        border-top:solid 0.05rem #93aaba;
    }

    .overview_text_area li:last-of-type{
        padding-bottom:0.9rem;
        border-bottom:solid 0.05rem #93aaba;
    }

    .overview_text_area_heading{
        width:6.5rem;
        font-size:0.95rem;
        line-height:1.5em;
    }

    .overview_text_area_text{
        width:226px;
        font-size:0.95rem;
        line-height:1.5em;
    }

    .overview_text_area_text_sub{
        font-size: 0.9rem;
        line-height:1.5em;
        margin-top:0rem;
    }

    .overview_area .btn_01{
        transform:scale(1.3);
    }

    .childcare_area{
        width:17rem;
        margin: 3.5rem auto 0;
        border-radius: 1rem;
        box-shadow: 0.2rem 0.35rem 0px #f3f3e6;
        padding-top:1.9rem;
        padding-left:0.7rem;
        padding-right:0.7rem;
        padding-bottom:3.0rem;
    }

    .childcare_deadline{
        width:100%;
        height:1.6rem;
        margin: 0 auto;
        font-size: 0.75rem;
        line-height: 1.5rem;
        margin-bottom:0.8rem;
    }

    .childcare_text{
        width:100%;
        margin:0 auto 1.2rem;
        font-size:0.75rem;
        line-height:2em;
        text-align: left;
    }

    .childcare_doc{
        width:100%;
        min-width:100%;
        height:2.4rem;
        margin:0 auto;
    }

    .childcare_contact{
        font-size:0.8rem;
        line-height:1.8em;
        color:#232323;    
        text-align: center;
        font-feature-settings: "palt";
        letter-spacing: 0.025em;
        font-weight: 500;
    }

    .childcare_doc{
        width:100%;
        height:auto;
        border-radius:50px;
        font-size:0.8rem;
        line-height: 1.4;
        margin:0 auto;
        padding: 0.6rem 0;
        display:block;
    }

    .childcare_contact_mail{
        font-size:0.9rem;
    }

    .access_area{
        padding-top:3rem;
        padding-bottom:3.5rem;
    }

    .access_heading{
        margin: 0 auto 3rem;
    }

    .access_area_container{
        width:17rem;
        margin:0 auto;
        display: block;
    }

    .access_place_info{
        width:100%;
    }

    .access_place{
        font-size: 1.05rem;
        margin-bottom:0.5rem;
    }

    .access_address{
        width:90%;
        font-size: 0.8rem;
        line-height: 1.5em;
        margin-bottom:1rem;
    }

    .access_time{
        width:90%;
        font-size: 0.8rem;
        line-height: 2em;
        margin-top:0;
    }

    .access_map{
        width:17rem;
        height:17rem;
        margin:2.5rem auto 0;
    }

    .officeinfo_container{
        width:17rem;
        margin:0 auto;
        display: block;
    }
    
    .officeinfo_logomark{
        width:9.75rem;
        margin:0 auto 2.5rem;
    }

    .officeinfo_logomark img{
        max-width:100%;
        height:auto;
    }

    .officeinfo_text_area{
        text-align: left;
        position:relative;
        top:0;
    }

    footer{
        height:auto;
        padding-top:2.3rem;
    }

    .sns{
        width:5.3rem;
        position:relative;
        right:0;
        top:0;
        margin: 0 auto 1.5rem;
    }

    .sns_facebook{
        width:2.2rem;
    }

    .sns_instagram{
        width:2.1rem;
        padding-top:0.05rem;
    }

    .footer_contact{
        width:11rem;
        position:relative;
        right:0;
        top:0;
        margin:0 auto 3rem;
        justify-content: center;
    }

    .footer_contact li{
        font-size:0.8rem;
    }

    .footer_tokyologo_container{
        width:auto;
        margin:0 auto 2.6rem;
    }

    .footer_tokyologo{
        width:10.15rem;
        margin:0 auto;
    }

    small{
        font-size: 0.5rem;
        line-height: 1em;
        position:relative;
        right:0;
        bottom:0;
        text-align:center;
        width:100%;
        display:block;
        padding-bottom:0.6rem;
    }

    .menu_sp_area{
        width:100vw;
        height:100vh;
        overflow-y:scroll;
        background-color: var(--base-bg-blue);
        position:fixed;
        left:0;
        top:0;
        display:none;
    }

    .menu_sp{
        width:auto;
        display:flex;
        flex-direction:column;
        row-gap: 2rem;
        position: absolute;
        left:50%;
        top:50%;
        transform: translate(-50%, -50%);
    }

    .menu_sp li{
        list-style-type: none;
        cursor: pointer;
        font-size:1.1rem;               
        line-height:1em;
        position:relative;
    }

    .menu_sp .menu_02{
        width:5.125em;
    }

    .menu_sp .menu_03{
        width:4.1em;
    }

    .menu_sp .menu_04{
        width:4.1em;
    }

    .menu_sp .menu_05{
        width:14rem;
        line-height:0;
    }

    .menu_sp .menu_02::after, .menu_sp .menu_03::after, .menu_sp .menu_04::after{
        content:"";
        position:absolute;
        right:-1.5rem;
        top:0.3rem;
        width:1.3125rem;
        height:0.7rem;
        background-image:url(../img/menu-arrow.svg) ;
        background-size:1.3125rem 0.7rem;
        background-repeat: no-repeat;
    }

    .menu_sp_close{
        display:block;
        width:1.9rem;
        height:0.55rem;
        position:absolute;
        right:0.8rem;
        top:1.2rem;
    }

    .menu_sp_close_top{    
        width:1.9rem;
        height:0.1rem;
        background-color:#0eb288;
        position:absolute;
        top:0.25rem;
        left:0;
        transform: rotate(45deg);
    }

    .menu_sp_close_bottom{
        width:1.9rem;
        height:0.1rem;
        background-color:#0eb288;
        position:absolute;
        bottom:0.2rem;
        left:0;
        transform: rotate(-45deg);
    }

    #pagetop{
        width:2.7rem;
        height:2.7rem;
        right:0.85rem;
        bottom:0.85rem;
    }
}


.closing {
    font-size: 1.4rem;
    text-align: center;
    font-weight: 800;
    color: var(--base-main-magenta);
    line-height: 1.4;
    display: block;
    margin: 3rem auto;
}
.closing span {
    display: inline-block;
    border-bottom: solid 2px var(--base-main-magenta);
}
@media (max-width: 430px) {
    .closing {
        font-size: 1.0rem;
        margin: 3rem auto;
        width: 90%;
    }
    .closing span {
        border-bottom: none;
        display: inline;
    }
}
