.katsurahama_park main {
    background-color: #F6F1D6;
    padding: 90px 30px 30px;
}

.katsurahama_park div.contents {
    background-color: #fff;
    box-sizing: border-box;
    margin: 0 auto;
    max-width: 1200px;
    padding: 60px 2.5%;
    text-align: center;
}

.katsurahama_park div.contents > *:not(h2) {
    margin: 0 auto;
    max-width: 800px;
    text-align: left;
}

h2
{
    font-size: 36px;
    text-align: center;
}

h3
{
    border-bottom: solid 1px #000;
    font-size: 21px;
    padding: 20px 0;
    text-align: center;
}

main a:not(.preparation)
{
    /* color: #00A0E9; */
    color: #000;
    text-decoration: none;
}

main a:not(.preparation):hover
{
    text-decoration: underline;
}


.katsurahama_park div.contents > section
{
    margin: 80px auto;
}

.katsurahama_park div.contents > section:first-of-type
{
    margin: 40px auto;
}

dl
{
    font-size: 16px;
    letter-spacing: 0.07em;
    line-height: 28px;
    margin: 30px auto;
}

dl a,
dl .nowrap
{
    white-space: nowrap;
}

dt
{
    box-sizing: border-box;
    font-weight: 700;
    padding-left: 28px;
    position: relative;
}

dt::before
{
    background-color: #00A0E9;
    border-radius: 50%;
    content: "";
    display: inline-block;
    height: 16px;
    left: 25px;
    position: absolute;
    top: 16px;
    transform: translate(-100%, -50%);
    width: 16px;
}

dd
{
    margin-left: 44px;  /* 16px + 28px */
    min-height: 28px;
    position: relative;
}


/* 矢印 */
dd::before,
dd::after
{
    content: "";
    position: absolute;
    left: -16px;
    top: 14px; /* line-height(28px) / 2 */
    transition: 0.3s;
}

dd::before {
    background: #000;
    height: 1px;
    transform: translateY(-50%);
    width: 13px;
}

dd::after{
    border-top: 1px solid #000;
    border-right: 1px solid #000;
    height: 5px;
    left: -9px;
    transform: translateY(-50%) rotate(45deg);
    -webkit-transform: translateY(-50%) rotate(45deg);
    width: 5px;
}




.sp_style div.contents
{
    padding: 5% 2.5%;
}

.sp_style h2
{
    font-size: 28px;
}

.sp_style h3
{
    padding: 12px 0;
}

.sp_style.katsurahama_park div.contents > section
{
    margin: 40px auto;
}

.sp_style.katsurahama_park div.contents > section:first-of-type
{
    margin: 20px auto;
}

.sp_style section > dl:first-of-type
{
    margin-top: 20px;
}