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


/* Common */
#page-title { width: 100%; height: 94px; margin-top: 1px; background: url("../images2025/common/title_base.jpg") no-repeat center center; background-size: cover; position: relative; }
#page-title::after { content: ""; width: 280px; height: 94px; background: url("../images2025/common/title_hands.png") no-repeat; background-size: cover; position: absolute; top: 0; right: 0; }
#title-box { width: 960px; height: 94px; margin: 0 auto; display: flex; align-items: center; justify-content: center; }
#title-box h1 { width: 250px; z-index: 5; }

article {  }
.basic-column { width: min(92%,820px); margin: 0 auto; padding: 2.5rem 0 3.5rem 0; }
.blue-column { background: #D9E6EE; }
.gray-column { background: #E2E3DD; }
.blue-column .inner-box, .gray-column .inner-box { width: min(92%,820px); margin: 0 auto; padding: 2.5rem 0 3.5rem 0; }


/* Overview */
#outline ul li { line-height: 1.4; padding: .4rem .5rem .4rem 9rem; border-bottom: dotted 1px #999; position: relative; }
#outline ul li:last-child { border-bottom: none; }
#outline ul li h3 { font-weight: bold; color: #005A8E; position: absolute; left: .5rem; }
#outline ul li a { color: #333; }
#outline ul li a:hover { color: #F63; }
#outline ul li a.link-btn { line-height: 1.2; text-align: center; color: #FFF; width: 9em; padding: .4em 0 .3em; border-radius: 1em; background: #F63; display: block; position: absolute; top: 50%; right: 0; transform: translateY(-50%); }
#outline ul li a.link-btn:hover { background: #C00; }
#outline ul li ul { display: flex; flex-wrap: wrap; }
#outline ul li ul li { padding: 0; border-bottom: none; }
#outline ul li ul li::after { content: "／"; }
#outline ul li ul li:last-child::after { content: ""; }

#event-summary { margin-bottom: 1rem; }
#event-summary h2 { font-size: 1.5rem; line-height: 1.2; text-align: center; letter-spacing: .3rem; color: #005A8E; height: 1.7rem; margin-bottom: 2rem; position: relative; }
#event-summary h2::before { content: ""; width: 100%; height: 1px; background: #005A8E; position: absolute; top: 50%; left: 0; transform: translateY(-2px); }
#event-summary h2::after { content: ""; width: 100%; height: 1px; background: #005A8E; position: absolute; top: 50%; left: 0; transform: translateY(2px); }
#event-summary h2 strong { font-weight: normal; padding: 0 .4rem 0 .7rem; background: #D9E6EE; display: block; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); z-index: 3; }
#event-section1 { padding-bottom: 3rem; }
.event-section h3 { color: #FFF; padding: .2em 0; background: #005A8E; display: flex; align-items: center; justify-content: center; }
.event-section h3 strong { font-size: 135%; line-height: 1.2; font-weight: normal; padding-right: 1em; }
.event-section ul { display: flex; flex-wrap: wrap; align-items: stretch; justify-content: space-between; }
.event-section ul li { width: calc(((100% - 40px) / 3) - 22px); margin-top: 20px; padding: 10px; border: solid 1px #005A8E; background: #FFF; }
.event-section ul li dl { height: 100%; }
.event-section ul li dl dt { line-height: 1.2; text-align: center; color: #005A8E; margin-bottom: 10px; padding: .2em 0; background: #D9E6EE; position: relative; }
.event-section ul li.ceremony dl dd { width: 100%; height: 100%; display: flex; flex-direction: column; align-items: center; justify-content: center; transform: translateY(-1.5em); }
.event-section ul li.ceremony dl dd strong { font-size: 135%; line-height: 1.2; font-weight: normal; }
.event-section ul li.ceremony dl dd span { font-size: 93%; line-height: 1.2; font-weight: normal; margin-left: .3em; }
.event-section ul li.keynote { width: calc((((100% - 40px) / 3) *2) - 2px); display: flex; justify-content: space-between; position: relative; }
.event-section ul li.keynote dl { width: 64%; }
.event-section ul li.keynote dl dd { position: absolute; bottom: 5px; }
.event-section ul li.keynote strong { width: 100px; height: 100px; border-radius: 50%; border: solid 2px #005A8E; background: #FF6; position: absolute; top: -40px; right: -40px; z-index: 5; }
.event-section ul li.keynote .photo { width: calc(36% - 10px); }
.event-section ul li.subcommittee dl dd h4 { font-size: 175%; line-height: 1.2; text-align: center; color: #005A8E; padding-bottom: .4em; border-bottom: solid 1px #999; }
.event-section ul li.subcommittee dl dd h4 span { font-size: 60%; line-height: 1.2; color: #333; margin-left: .3em; padding-top: .2em; display: block; }
.event-section ul li.subcommittee dl dd p { line-height: 1.4; text-align: justify; padding-top: .6em; }
.event-section ul li.subevent dl dt { color: #FFF; background: #005A8E; }
.event-section ul li.subevent dl dt strong { font-size: 105%; line-height: 1.2em; color: #FFF; width: 3.5em; height: 3.5em; border: solid 1px #FFF; border-radius: 50%; background: #F63; display: flex; align-items: center; justify-content: center; position: absolute; top: 50%; left: -1.5em; transform: translateY(-50%); }
.event-section ul li.subevent dl dd { padding: .4em 0; }
.event-section ul li.subevent dl dd span { font-size: 105%; line-height: 1.2; text-align: center; color: #333; margin-left: .3em; padding-top: .5em; display: block; }


/* Program */
#program1 { padding-bottom: 2rem; }
.program h2 { line-height: 1.2; color: #FFF; height: 40px; margin-bottom: 1.2rem; padding: 0 .7rem; background: url(../images2025/program/title_base.jpg); display: flex; align-items: center; }
.program h2 strong { font-size: 1.3rem; line-height: 1.2; vertical-align: middle; padding-right: 1rem; }
.program ul li { line-height: 1.4; padding: .6rem .5rem .5rem 10rem; border-bottom: dotted 1px #CCC; position: relative; }
.program ul li:first-child { padding-top: 0; }
.program ul li:last-child { padding-bottom: 0; border-bottom: none; }
.program ul li h5 { color: #005A8E; position: absolute; left: .5rem; }
.program ul li strong { font-size: 115%; line-height: 1.3; padding-bottom: .1rem; display: block; }
.program ul li span { font-size: 93%; line-height: 1.2; color: #666; }
#keynote { margin-top: 1.2rem; padding: 1.2rem; border: solid 1px #005A8E; background: #E8F0F1; }
#keynote-title { padding-bottom: 1.2rem; position: relative; }
#keynote-title strong { position: absolute; bottom: -30px; right: -30px; z-index: 2; }
#keynote-title strong a { width: 120px; height: 120px; border-radius: 50%; background: #F63; display: block; }
#keynote-title strong a:hover { background: #C00; }
#keynote dl#keynote-read { display: flex; flex-direction: row-reverse; align-items: stretch; justify-content: space-between; }
#keynote dl#keynote-read dt { width: 240px; position: relative; overflow: hidden; }
#keynote dl#keynote-read dt img { width: 100%; height: auto; position: absolute; top: 0; }
#keynote dl#keynote-read dd { width: 520px; }
#keynote dl#keynote-read dd p { line-height: 1.6; text-align: justify; padding-bottom: .8rem; }
#keynote dl#keynote-read dd p:last-child { padding-bottom: 0; }
#keynote dl#profile { margin-top: 1rem; display: flex; align-items: stretch; justify-content: space-between; }
#keynote dl#profile dt { line-height: 1.2; color: #FFF; width: 8rem; background: #82AEC8; display: flex; align-items: center; justify-content: center; }
#keynote dl#profile dd { width: calc(100% - 10rem); padding: .7rem 1rem;  background: #FFF; }
#keynote dl#profile dd p { font-size: .8rem; line-height: 1.4; text-align: justify; }
.program-box { margin-bottom: 2rem; }
.program h3 { line-height: 1.2; color: #FFF; height: 30px; padding-left: 11rem; background: #7FACC6; display: flex; align-items: center; position: relative; }
.program h3::after { content: ""; width: calc(10.5rem + 5px); height: 30px; background: #FFF; clip-path: polygon(0 0,100% 0,80% 100%,0 100%); position: absolute; top: 0; left: 0; z-index: 2; }
.program h3 strong { font-size: 1.2rem; line-height: 1.2; font-weight: normal; color: #FFF; width: 10rem; height: 30px; padding-left: .5rem; background: #005A8E; clip-path: polygon(0 0,100% 0,80% 100%,0 100%); display: flex; align-items: center; position: absolute; top: 0; left: 0; z-index: 3; }
.program h4 { font-size: 1.15rem; line-height: 1.2; color: #005A8E; margin-bottom: 1.2rem; margin-top: 3px; padding: .5rem .5rem .4rem .5rem; border-bottom: solid 1px #005A8E; background: #E2E3DD; }
#closing { padding: .5rem 0 .4rem 0; border-top: solid 1px #005A8E; border-bottom: solid 1px #005A8E; }

.consul-box { width: min(92%,820px); margin: 0 auto; padding-bottom: 2rem; }
#consul-title { position: relative; }
#consul-title dt { font-size: 1.5rem; line-height: 1.4; font-weight: bold; text-align: center; color: #FFF; width: 140px; height: 140px; background: #005A8E; display: flex; align-items: center; justify-content: center; position: absolute; bottom: 0; left: 0; }
#consul-title dd { padding-left: 170px; }
#consul-title dd h3 { font-size: 1.1rem; line-height: 1.2; margin-bottom: .5rem; padding: .7rem 0 .6rem 0; border-bottom: solid 1px #005A8B; }
#consul-title dd p { line-height: 1.6; text-align: justify; }
#consul1, #consul2 { padding-top: 1rem; }
#consul1 dl { width: 100%; }
.consul-list dt { font-size: 1.1rem; line-height: 1.2; color: #005A8E; padding: .4rem .5rem .3rem .5rem; background: #FFF; }  
.consul-list dd { padding-top: .5rem; }
#consul1 dl dd { display: flex; justify-content: space-between; }
#consul1 dl dd ul { width: 47%; }
.consul-list dd ul li { line-height: 1.4; padding-bottom: .2rem; }
.consul-list dd ul li span { color: #005A8E; padding-right: .2rem; }
#consul2 { display: flex; justify-content: space-between; }
#consul2 dl { width: 47%; }
#consul2 .link-btn { text-align: center; width: 47%; }
#consul2 .link-btn a { color: #FFF; height: 5.2rem; border-radius: .7rem; background: #F63; box-shadow: 0 0 .3rem rgba(0,0,0,.5); display: flex; flex-direction: column; align-items: center; justify-content: center; }
#consul2 .link-btn a:hover { background: #C00; }
#consul2 .link-btn a strong { font-size: 1.4rem; line-height: 1.4; text-align: center; display: block; }
#consul2 .link-btn a span { line-height: 1.4; display: block; }

#senryu {  }
#senryu h3 { line-height: 1.2; color: #FFF; height: 30px; padding-left: 11rem; background: #7FACC6; display: flex; align-items: center; position: relative; }
#senryu h3::after { content: ""; width: calc(10.5rem + 5px); height: 30px; background: #FFF; clip-path: polygon(0 0,100% 0,80% 100%,0 100%); position: absolute; top: 0; left: 0; z-index: 2; }
#senryu h3 strong { font-size: 1.2rem; line-height: 1.2; font-weight: normal; color: #FFF; width: 10rem; height: 30px; padding-left: .5rem; background: #005A8E; clip-path: polygon(0 0,100% 0,80% 100%,0 100%); display: flex; align-items: center; position: absolute; top: 0; left: 0; z-index: 3; }
#senryu h4 { font-size: 1.15rem; line-height: 1.2; color: #005A8E; margin-bottom: 1.2rem; margin-top: 3px; padding: .5rem .5rem .4rem .5rem; border-bottom: solid 1px #005A8E; background: #E2E3DD; }
#senryu h4 span { font-size: .85rem; line-height: 1.2; vertical-align: middle; }
#senryu ul li { line-height: 1.4; padding: .6rem .5rem .5rem 10rem; border-bottom: dotted 1px #CCC; position: relative; }
#senryu ul li:first-child { padding-top: 0; }
#senryu ul li:last-child { padding-bottom: 0; border-bottom: none; }
#senryu ul li h5 { color: #005A8E; position: absolute; left: .5rem; }
#senryu ul li ul li { padding: .6rem .5rem .5rem 0; }
#senryu ul li strong { font-size: 115%; line-height: 1.3; padding-bottom: .1rem; display: block; }
#senryu ul li span { font-size: 85%; line-height: 1.2; text-align: justify; }
#senryu ul li i { font-weight: bold; font-style: normal; color: #005A8E; }
#senryu-period { font-size: 123%; line-height: 1.2; text-align: center; color: #FFF; margin: 1.2rem 0 .6rem 0; padding: .6rem 0 .5rem 0; border-radius: .5rem; background: #669CBB; }
#senryu .attention { font-size: 93%; line-height: 1.3; text-indent: -1em; padding-left: 1rem; }
#senryu .attention a { color: #08D; }
#senryu .attention a:hover { color: #F63; }


/* Access */
#access { width: min(92%,820px); margin: 0 auto; padding: 2.5rem 0 3.5rem 0; }
#map { margin: 0 auto; position: relative; }
#map a { line-height: 1.2; text-align: center; color: #FFF; width: 14em; padding: 1rem 0; border-radius: 0 .5rem .5rem 0; background: #005A8E; position: absolute; bottom: 5rem; left: 0; }
#map a:hover { opacity: .8; }
#access-column { margin: 2rem auto 0 auto; display: flex; justify-content: space-between; }
#access-column dl { width: 47%; }
#access-column dl dt { line-height: 1.2; color: #FFF; margin-bottom: .6rem; padding: .4rem .5rem .3rem .5rem; background: #005A8E; }
#access-column dl dd ul li { line-height: 1.4; text-indent: -1em; padding: 0 0 .2em 1em;}
#access-column dl dd ul li span { color: #669CBB; }
#access-column dl dd p { line-height: 1.6; }


/* Contact */
#contact { width: min(92%,820px); margin: 0 auto; padding: 4rem 0; }
#contact h2 { font-size: 200%; line-height: 1.2; text-align: center; color: #005A8E; padding-bottom: 2rem; }
#contact p { font-size: 115%; line-height: 1.6; text-align: center; }



