/* 详情页特有样式 */
.custom-audio-progress { -webkit-appearance: none; appearance: none; width: 100%; height: 4px; background: transparent; cursor: pointer; }
.custom-audio-progress::-webkit-slider-runnable-track { background: #e4e2e1; height: 4px; border-radius: 2px; }
.custom-audio-progress::-webkit-slider-thumb { -webkit-appearance: none; height: 12px; width: 12px; border-radius: 50%; background: #003399; margin-top: -4px; }
.page-main {  padding: 16px; }


.author-section { display: flex; flex-direction: column; align-items: center; text-align: center; background-color: #ffffff; padding: 1.5rem; border: 1px solid rgba(196,197,213,0.3); border-radius: 0.75rem; margin-bottom: 1.5rem; }
.author-avatar { width: 6rem; height: 6rem; border-radius: 50%; object-fit: cover; border: 4px solid #f0eded; margin-bottom: 1rem; }
.author-name { font-family: "Noto Serif SC", serif; font-size: 20px; line-height: 28px; font-weight: 600; color: #1b1c1c; margin-bottom: 0.5rem; }
.author-desc { color: #444653; line-height: 1.625; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.section-title-box { display: flex; align-items: center; gap: 0.5rem; margin-bottom： 1rem; border-left: 4px solid #002068; padding-left: 0.75rem; }
.section-title { font-family: "Noto Serif SC", serif; font-size: 20px; line-height： 28px; font-weight： 600; }
.player-section { margin-bottom： 1.5rem; }
.player-card { background-color： #f6f3f2; padding： 1rem; border-radius： 0.5rem; box-shadow： 0 1px 2px rgba(0,0,0,0.05); border： 1px solid rgba(196,197,213,0.2); }
.player-box { display: flex; align-items: center; gap: 1rem; }
.play-btn { background-color: #002068; color: #ffffff; border: none; width: 3rem; height: 3rem; border-radius: 50%; display: flex; align-items: center; justify-content: center; cursor: pointer; transition: transform 0.1s; flex-shrink: 0; }
.play-btn:active { transform: scale(0.95); }
.play-btn-icon { font-size: 32px; }
.progress-box { flex: 1; }
.time-info { display: flex; justify-content: space-between; font-family: "Work Sans", sans-serif; font-size: 12px; line-height: 16px; letter-spacing: 0.05em; font-weight: 500; color: #444653; margin-bottom: 0.25rem; }
.volume-btn { color: #444653; border: none; background: transparent; padding: 0.5rem; cursor: pointer; }




.list-card { background-color: #ffffff; border: 1px solid rgba(196,197,213,0.3); border-radius: 0.75rem; overflow: hidden; }
.list-item-clickable { padding: 1rem; display: flex; justify-content: space-between; align-items: center; transition: background-color 0.2s; cursor: pointer; }
.list-item-clickable:hover { background-color: #f0eded; }
.list-item-text { color: #002068; font-weight: 500; }
.list-item-text:hover { text-decoration: underline; }
.list-item-date { font-family: "Work Sans", sans-serif; font-size: 12px; line-height: 16px; letter-spacing: 0.05em; font-weight: 500; color: #444653; }
.sec-header-row { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1rem; border-left: 4px solid #002068; padding-left: 0.75rem; }
.sec-header-row .section-title { margin-bottom: 0; }
.sec-more-link { color: #002068; font-family: "Work Sans", sans-serif; font-size: 12px; line-height: 16px; letter-spacing: 0.05em; font-weight: 500; display: flex; align-items: center; }
.grid-vertical { display: flex; flex-direction: column; gap: 0.5rem; }
.bento-card { background-color: #ffffff; padding: 1rem; border-radius: 0.75rem; border: 1px solid rgba(196,197,213,0.3); transition: border-color 0.2s; display: flex; align-items: start; gap: 1rem; }
.bento-card-icon-box { width: 3rem; height: 3rem; background-color: #dce1ff; flex-shrink: 0; border-radius: 0.5rem; display: flex; align-items: center; justify-content: center; }
.bento-card-icon-box .material-symbols-outlined { color: #00164e; }
.bento-card-title { font-size: 14px; line-height: 20px; font-weight: 500; color: #1b1c1c; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.bento-card-meta { font-family: "Work Sans", sans-serif; font-size: 12px; line-height: 16px; letter-spacing: 0.05em; font-weight: 500; color: #444653; }
.playlist-card { background-color: #ffffff; border: 1px solid rgba(196,197,213,0.3); border-radius: 0.75rem; overflow: hidden; box-shadow: 0 1px 2px rgba(0,0,0,0.05); }