/* --------------------
 Topics Detail
-------------------- */
.topics {
    margin: 0 0 10.6666666667vw;
    padding: 3.2vw 0 0;
}

@media (min-width: 768px) {
    .topics {
        margin: 0 0 40px;
        padding: 24px 0 0;
    }
}

.topics-container {
    margin: 0 auto;
    max-width: calc(var(--container-width) + var(--c-pad)*2);
    padding: 0 var(--c-pad);
    width: 100%;
}

.topics__head {
    border-bottom: 1px solid var(--color-onyx);
    padding: 0 0 4.2666666667vw;
}

@media (min-width: 768px) {
    .topics__head {
        padding: 0 20px 16px;
    }
}

.topics__head__meta {
    align-items: center;
    display: flex;
    flex-flow: row nowrap;
    justify-content: flex-start;
    margin: 0 0 6.4vw;
}

@media (min-width: 768px) {
    .topics__head__meta {
        margin: 0 0 24px;
    }
}

.topics__head__meta__date {
    display: block;
    flex: 0 0 29.3333333333vw;
    font-size: var(--fs16);
    font-weight: 500;
    letter-spacing: 0.1em;
    line-height: 1.4;
    margin: 0;
    padding: 0.05em 0 0;
}

@media (min-width: 768px) {
    .topics__head__meta__date {
        flex: 0 0 120px;
        font-size: var(--fs18);
        padding: 0.075em 0 0;
    }
}

.topics__head__meta__category {
    align-items: center;
    display: flex;
    flex: 0 0 auto;
    flex-flow: row wrap;
    gap: 2.1333333333vw;
    justify-content: flex-start;
    margin: 0;
}

@media (min-width: 768px) {
    .topics__head__meta__category {
        gap: 8px;
        margin-right: 20px;
    }
}

.topics__head__meta__category span, .topics__head__meta__category a {
    align-items: center;
    background-color: var(--color-sage);
    border: 0.5333333333vw solid var(--color-umber);
    border-radius: 4vw;
    color: inherit;
    display: flex;
    flex-flow: row nowrap;
    font-size: var(--fs14);
    font-weight: 700;
    height: 6.4vw;
    justify-content: center;
    letter-spacing: 0.1em;
    line-height: 1.05;
    padding: 0 2.1333333333vw;
    text-align: center;
    text-decoration: none;
    width: -webkit-fit-content;
    width: fit-content;
}

@media (min-width: 768px) {
    .topics__head__meta__category span, .topics__head__meta__category a {
        border-radius: 17px;
        border-width: 2px;
        font-size: var(--fs16);
        height: 34px;
        padding: 0 12px;
    }
}

.topics__head__meta__category a {
    transition: background-color var(--duration) var(--cubic) 0s;
}

.topics__head__meta__category a:focus {
    background-color: var(--color-peach);
}

@media (hover: hover) and (pointer: fine) {
    .topics__head__meta__category a:hover {
        background-color: var(--color-peach);
    }
}

.topics__head__title {
    font-size: var(--fs24);
    font-weight: 700;
    letter-spacing: 0.1em;
    line-height: 1.23;
    margin: 0;
}

@media (min-width: 768px) {
    .topics__head__title {
        font-size: var(--fs26);
    }
}

.topics__content {
    font-weight: 500;
    margin: 0 0 13.3333333333vw;
    padding: 4.2666666667vw 0 0;
}

@media (min-width: 768px) {
    .topics__content {
        margin: 0 0 50px;
        padding: 16px 20px 0;
    }
}

.topics__content h1 {
    display: block;
    font-size: var(--fs24);
    line-height: 1.4;
    margin: 16vw 0 5.3333333333vw;
}

@media (min-width: 768px) {
    .topics__content h1 {
        font-size: var(--fs26);
        margin: 60px 0 20px;
    }
}

.topics__content h1:first-child {
    margin-top: 0;
}

.topics__content h2 {
    background-color: var(--color-cream);
    border-bottom: 1px solid var(--color-onyx);
    display: block;
    font-size: var(--fs22);
    letter-spacing: 0.1em;
    line-height: 1.4;
    margin: 16vw 0 5.3333333333vw;
    padding: 1.6vw 1.0666666667vw 1.6vw calc(2.13333vw + 1.15em);
    position: relative;
}

@media (min-width: 768px) {
    .topics__content h2 {
        font-size: var(--fs24);
        margin: 90px 0 20px;
        padding: 6px 4px 6px calc(12px + 1.15em);
    }
}

.topics__content h2:before {
    background-color: var(--color-peach);
    border-radius: 50%;
    content: "";
    display: block;
    height: 0.9em;
    left: 2.1333333333vw;
    position: absolute;
    top: 3.2vw;
    width: 0.9em;
}

@media (min-width: 768px) {
    .topics__content h2:before {
        left: 12px;
        top: 12px;
    }
}

.topics__content h2:first-child {
    margin-top: 0;
}

.topics__content h3 {
    border-bottom: 1px solid var(--color-onyx);
    display: block;
    font-size: var(--fs20);
    letter-spacing: 0.1em;
    line-height: 1.4;
    margin: 16vw 0 5.3333333333vw;
    padding: 0 0 2.1333333333vw 4.2666666667vw;
    position: relative;
}

@media (min-width: 768px) {
    .topics__content h3 {
        font-size: var(--fs22);
        margin: 66px 0 20px;
        padding: 0 0 8px 16px;
    }
}

.topics__content h3:before {
    background-color: var(--color-peach);
    border-radius: 0.8vw;
    bottom: calc(0.15em + 2.13333vw);
    content: "";
    display: block;
    height: auto;
    left: 0;
    position: absolute;
    top: 0.15em;
    width: 1.3333333333vw;
}

@media (min-width: 768px) {
    .topics__content h3:before {
        border-radius: 3px;
        bottom: calc(0.15em + 8px);
        width: 5px;
    }
}

.topics__content h3:first-child {
    margin-top: 0;
}

.topics__content h4 {
    font-size: var(--fs18);
    letter-spacing: 0.1em;
    line-height: 1.4;
    margin: 8vw 0 4.2666666667vw;
}

@media (min-width: 768px) {
    .topics__content h4 {
        font-size: var(--fs20);
        margin: 30px 0 16px;
    }
}

.topics__content h4:first-child {
    margin-top: 0;
}

.topics__content h5, .topics__content h6 {
    font-size: var(--fs16);
    letter-spacing: 0.1em;
    line-height: 1.4;
    margin: 8vw 0 1.0666666667vw;
}

@media (min-width: 768px) {
    .topics__content h5, .topics__content h6 {
        font-size: var(--fs18);
        margin: 30px 0 4px;
    }
}

.topics__content h5:first-child, .topics__content h6:first-child {
    margin-top: 0;
}

.topics__content p {
    font-size: var(--fs16);
    letter-spacing: 0.025em;
    line-height: 2;
    margin: 0 0 2em;
}

@media (min-width: 768px) {
    .topics__content p {
        font-size: var(--fs18);
    }
}

.topics__content b, .topics__content strong {
    font-weight: 700;
}

.topics__content i {
    font-style: italic;
}

.topics__content s {
    text-decoration: line-through;
}

.topics__content a {
    color: inherit;
    text-decoration: underline;
    transition: -webkit-text-decoration-color var(--duration) var(--cubic) 0s;
    transition: text-decoration-color var(--duration) var(--cubic) 0s;
    transition: text-decoration-color var(--duration) var(--cubic) 0s, -webkit-text-decoration-color var(--duration) var(--cubic) 0s;
}

.topics__content a:focus {
    -webkit-text-decoration-color: transparent;
    text-decoration-color: transparent;
}

@media (hover: hover) and (pointer: fine) {
    .topics__content a:hover {
        -webkit-text-decoration-color: transparent;
        text-decoration-color: transparent;
    }
}

.topics__content table {
    border: none;
    border-collapse: collapse;
    border-spacing: 0;
    margin: 0 0 6.4vw;
    max-width: 100%;
    width: 100%;
}

@media (min-width: 768px) {
    .topics__content table {
        margin: 0 0 30px;
    }
}

.topics__content table > tbody > tr > th, .topics__content table > tbody > tr > td {
    border-bottom: 1px solid var(--color-onyx);
    border-right: 1px solid var(--color-onyx);
    font-size: var(--fs16);
    letter-spacing: 0.025em;
    line-height: 2;
    padding: 2.1333333333vw;
    text-align: left;
    vertical-align: middle;
    width: auto;
}

@media (min-width: 768px) {
    .topics__content table > tbody > tr > th, .topics__content table > tbody > tr > td {
        font-size: var(--fs16);
        padding: 12px;
    }
}

.topics__content table > tbody > tr > th:first-child, .topics__content table > tbody > tr > td:first-child {
    border-left: 1px solid var(--color-onyx);
}

.topics__content table > tbody > tr > th {
    font-weight: inherit;
}

.topics__content table > tbody > tr > td {
    word-break: break-all;
}

.topics__content table > tbody > tr:first-child > th, .topics__content table > tbody > tr:first-child > td {
    border-top: 0.2666666667vw solid var(--color-onyx);
}

@media (min-width: 768px) {
    .topics__content table > tbody > tr:first-child > th, .topics__content table > tbody > tr:first-child > td {
        border-top-width: 1px;
    }
}

.topics__fig {
    margin: 0 0 16vw;
    text-align: center;
}

@media (min-width: 768px) {
    .topics__fig {
        margin: 0 0 60px;
    }
}

.topics__action {
    margin: 16vw 0 0;
}

@media (min-width: 768px) {
    .topics__action {
        margin: 60px 0 0;
    }
}