/* ================================
   Doctor Detail Page Styles
   ================================ */

/* Breadcrumb Section */
.doctor-breadcrumb-section {
    padding: 24px 0 0;
}

/*.doctor-breadcrumb-section .container {*/
/*    max-width: var( --container-max-width);*/
/*}*/

.doctor-breadcrumb-section .breadcrumb {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 0;
    padding: 0;
    background: none;
    font-size: 16px;
    max-width: var( --container-max-width);
}

.doctor-breadcrumb-section .breadcrumb a {
    color: var(--text-dark-bg-secondary);
    text-decoration: none;
    transition: color 0.3s ease;
}

.doctor-breadcrumb-section .breadcrumb a:hover {
    color: var(--accent-purple);
}

.doctor-breadcrumb-section .breadcrumb .separator {
    color: var(--text-dark-bg-secondary);
}

.doctor-breadcrumb-section .breadcrumb .current {
    color: var(--accent-purple);
}

/* 锚点定位 - 补偿固定 header 高度，使 sidebar 锚点滚动准确 */
#summary,
#conditions,
#procedures,
#education,
#publications {
    scroll-margin-top: calc(var(--top-bar-height, 60px) + var(--header-height, 80px) + 16px);
}

/* Doctor Header Section */
.doctor-header-section {
    padding: 48px 0 0;
}

.doctor-header-section .container {
    max-width: var(--container-max-width);
}

.doctor-header-content {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 24px;
}

.doctor-header-info {
    flex: 1;
}

.doctor-name {
    font-size: 48px;
    font-weight: 700;
    color: var(--accent-purple);
    margin: 0 0 8px;
    line-height: 1.2;
    font-family: var(--font-heading);
}

.doctor-title {
    font-size: 24px;
    font-weight: bold;
    color: #2A2A2A;
    margin: 0;
}

.doctor-title-appointment {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
}

.doctor-appointment-link {
    display: inline-flex;
    align-items: center;
    gap: 11px;
    color: var(--accent-purple);
    text-decoration: none;
    font-size: 24px;
    font-weight: 500;
    transition: color 0.3s ease;
    line-height: 32px;
}

.doctor-appointment-link:hover {
    color: var(--accent-purple);
    text-decoration: underline;
}

.doctor-appointment-link img,
.doctor-appointment-link svg {
    flex-shrink: 0;
}

.doctor-header-divider {
    height: 1px;
    background-color:var(--accent-purple);
}

/* Summary Section - Full Width */
.doctor-summary-section {
    padding: 48px 0 64px;
}


.summary-content {
    display: flex;
    gap: 40px;
}

.summary-content p {
    color: #2A2A2A;
    font-weight: 300;
}

.summary-content.summary-wrap {
    display: block;
}

.summary-content.summary-wrap::after {
    content: "";
    display: table;
    clear: both;
}

.summary-image-float {
    float: right;
    width: 460px;
    margin: 0 0 56px 48px;
    shape-outside: margin-box;
}

.summary-image-float img {
    width: 100%;
    height: auto;
    display: block;
}

.summary-content.summary-wrap p {
    font-size: 20px;
    line-height: 28px;
    color: var(--text-dark-bg-primary);
    margin-bottom: 20px;
    text-align: justify;
    font-family: 'Lato', sans-serif;
    font-weight: 300;
}

.summary-content.summary-wrap p:last-child {
    margin-bottom: 0;
}

.summary-text {
    flex: 1;
}

.summary-text p {
    font-size: 17px;
    line-height: 1.8;
    color: var(--text-dark-bg-primary);
    margin-bottom: 20px;
}

.summary-text p:last-child {
    margin-bottom: 0;
}

.summary-image {
    flex-shrink: 0;
    width: 280px;
}

.summary-image img {
    width: 100%;
    height: auto;
    border-radius: 8px;
    object-fit: cover;
}

/* Doctor Detail Section with Sidebar */
.doctor-detail-section {
    padding: 0 0 80px;
}


.doctor-detail-layout {
    display: flex;
    justify-content: space-between;
    position: relative;
}

.doctor-main-content {
    flex: 1;
    max-width: 720px;
}

.doctor-sidebar {
    width: 264px;
    flex-shrink: 0;
    margin-left: auto;
}

/* Doctor Section Common Styles */
.doctor-section {
    margin-bottom: 60px;
}

.doctor-section:last-child {
    margin-bottom: 0;
}

.doctor-main-content .doctor-section h2.doctor-section-title {
    font-size: 40px;
    font-weight: bold;
    line-height: 56px;
    color: var(--accent-purple);
    margin: 0 0 24px;
    font-family: var(--font-heading);
}

/* Conditions Treated Section - Flow Layout */
.conditions-flow-list {
    display: flex;
    flex-direction: column;
    gap: 32px;
}

.conditions-flow-category {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.conditions-flow-title {
    font-size: 24px;
    font-weight: bold;
    color: var(--text-dark-bg-primary);
    margin: 0;
    line-height: 32px;
}

.conditions-flow-links {
    display: flex;
    flex-direction: column;
    gap: 8px 0;
}

.conditions-flow-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 32px;
}

.conditions-flow-item {
    display: flex;
    flex-direction: column;
    gap: 4px;
    flex: 0 1 auto;
}

.conditions-flow-link {
    text-decoration: underline;
    transition: color 0.3s ease;


    font-family: Lato, Lato;

    font-style: normal !important;

}
a.conditions-flow-link:hover {
    color: #6F0B65 !important;
}


.conditions-flow-link:hover {
    color: var(--accent-purple);
    /* text-decoration: underline; */
}

.conditions-flow-item:hover {
    border-color: var(--accent-purple);
}

.conditions-flow-subtitle {
    font-size: 18px;
    color: #242424;
    font-style: italic;
    margin-left: 0;
    font-weight: lighter;
}

.condition-link {
    font-size: 18px;
    font-weight: 700;
    color: var(--text-dark-bg-primary);
    text-decoration: none;
    transition: color 0.3s ease, text-decoration 0.3s ease;
}

.condition-link:hover {
    color: var(--accent-purple);
    text-decoration: underline;
    text-underline-offset: 3px;
}

.condition-item {
    margin: 0 0 12px 0;
}

.condition-item:last-child {
    margin-bottom: 0;
}

.condition-name {
    font-size: 18px;
    font-weight: 700;
    color: var(--text-dark-bg-primary);
    margin: 0 0 4px;
}

.condition-desc {
    font-size: 16px;
    color: var(--text-dark-bg-secondary);
    margin: 0;
}

/* Procedures Performed Section */
.procedures-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.procedure-link {
    font-size: 24px;
    font-weight: 700;
    line-height: 32px;
    color: var(--text-dark-bg-primary);
    text-decoration: none;
    transition: color 0.3s ease, text-decoration 0.3s ease;
}

.procedure-link:hover {
    color: var(--accent-purple);
    /* text-decoration: underline; */
    /* text-underline-offset: 3px; */
}

.procedure-item {
    font-size: 18px;
    font-weight: 700;
    color: var(--text-dark-bg-primary);
    margin: 0;
}

/* Education and Training Section */
.education-list {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.education-item {
    display: flex;
    align-items: flex-start;
    gap: 16px;
}

.education-marker {
    width: 12px;
    height: 12px;
    border: 2px solid var(--accent-purple);
    border-radius: 50%;
    margin-top: 5px;
    flex-shrink: 0;
}

.education-content {
    flex: 1;
}

.education-date {
    font-size: 24px;
    color: var(--text-dark-bg-primary);
    margin: 0 0 4px;
    font-family: Lato, Lato;
    font-weight: 500;
    color: #2A2A2A;
    line-height: 32px;
    text-align: left;
    font-style: normal;
}

.education-school {
    font-size: 18px;
    font-weight: 300;
    color: #2A2A2A;
    margin: 0;
}

/* Publications Section */
.publications-list {
    display: flex;
    flex-direction: column;
    gap: 28px;
}

.publication-item {
    border-bottom: none;
}

.publication-title {
    display: inline;
    font-size: 24px;
    font-weight: 700;
    color: #2A2A2A;
    text-decoration: none;
    line-height: 32px;
    margin-bottom: 12px;
    transition: color 0.3s ease;
}

.publication-title:hover {
    color: var(--accent-purple);
}

.publication-icon {
    display: inline;
    vertical-align: middle;
    margin-left: 8px;
    color: var(--text-dark-bg-primary);
    transition: color 0.3s ease;
}

.publication-title:hover .publication-icon {
    color: var(--accent-purple);
}

.publication-authors {
    font-size: 18px;
    color: #2A2A2A;
    margin: 0 0 4px;
    font-weight: lighter
}

.publication-journal {
    font-size: 18px;
    color: #2A2A2A;
    font-weight: lighter;
    margin: 0;
}

.view-all-btn {
    display: inline-block;
    margin-top: 24px;
    padding: 12px 32px;
    background-color: var(--btn-secondary-bg);
    color: #2A2A2A;

    font-size: 18px;
    font-weight: 500;
    text-decoration: none;
    text-align: center;
    transition: all 0.3s ease;
}

.view-all-btn:hover {
    background-color: #d9d7d7;
    color: var(--accent-purple);
}

/* Sidebar Navigation - width and margin defined above in layout section */

.doctor-sidebar-nav {
    position: sticky;
    top: 140px;
    width: 264px;

    background-color: #2d3a31;
    display: flex;
    flex-direction: column;
}

.sidebar-nav-item {
    display: block;
    padding: 16px 0px 16px 0px;
    font-weight: 300;
    font-size: 18px;
    color: var(--text-light-bg-secondary);
    text-decoration: none;
    text-align: center;
    transition: all 0.3s ease;
    line-height: 32px;
    height: 64px;
}

.sidebar-nav-item:last-child {
    border-bottom: none;
}

.sidebar-nav-item:hover {
    color: var(--text-link);
    background-color: var(--btn-secondary-bg);
}

.sidebar-nav-item.active {
    color: #6F0B65;

  
    background-color: var(--btn-secondary-bg);
}

/* Responsive Styles */
@media (max-width: 1200px) {
    .doctor-sidebar {
        width: 180px;
    }
}

@media (max-width: 991px) {
    .summary-content {
        flex-direction: column-reverse;
        gap: 24px;
    }

    .summary-image {
        width: 100%;
        max-width: 300px;
    }

    .summary-image-float {
        width: 280px;
        margin: 0 0 16px 24px;
    }

    .doctor-detail-layout {
        flex-direction: column;
    }

    .doctor-main-content {
        max-width: 100%;
    }

    .doctor-sidebar {
        display: none;
    }

    .doctor-name {
        font-size: 36px;
    }

    .doctor-section-title {
        font-size: 28px;
    }
}

@media (max-width: 767px) {
    .doctor-header-content {
        flex-direction: column;
        gap: 16px;
    }

    .doctor-title-appointment {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }

    .doctor-name {
        font-size: 32px;
    }

    .doctor-section-title {
        font-size: 24px;
    }

    .doctor-section {
        margin-bottom: 40px;
    }

    .doctor-detail-section {
        padding: 32px 0 60px;
    }

    .doctor-sidebar {
        display: none;
    }

    .summary-image-float {
        float: none;
        width: 100%;
        max-width: 300px;
        margin: 0 auto 24px;
    }
}

/* ================================
   Publications Page Styles
   ================================ */

.publications-page .page-wrapper {
    max-width: var(--container-max-width, 1200px);
    margin: 0 auto;
    margin-top: calc(var(--top-bar-height) + var(--header-height));
    margin-bottom: 60px;
}

.publications-page .breadcrumb {
    margin-bottom: 30px;
    font-size: 14px;
    color: #666;
}

.publications-page .breadcrumb a {
    color: #333;
    text-decoration: none;
    transition: color 0.3s ease;
}

.publications-page .breadcrumb a:hover {
    text-decoration: underline;
    color: var(--accent-purple);
}

.publications-page .breadcrumb span {
    color: var(--accent-purple);
}

.publications-page .section-title {
    font-size: 3rem;
    color: var(--accent-purple);
    margin-bottom: 40px;
    font-weight: 600;
    border-bottom: 3px solid var(--accent-purple);
    padding-bottom: 15px;
    display: inline-block;
    font-family: var(--font-heading);
}

.publications-page .publications-list {
    display: flex;
    flex-direction: column;
    gap: 50px;
    width: 75%;
}

.publications-page .publication-item {
    display: block;
    text-decoration: none;
    transition: opacity 0.3s ease;
}

.publications-page .publication-item:hover {
    opacity: 0.9;
}

.publications-page .publication-title {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    margin-bottom: 20px;
}

.publications-page .publication-title h3 {
    font-size: 1.4rem;
    color: #333;
    font-weight: 700;
    line-height: 1.6;
    margin: 0;
    transition: color 0.3s ease;
}

.publications-page .publication-title .arrow-icon {
    flex-shrink: 0;
    width: 2.5rem;
    height: auto;
    margin-top: 4px;
}

.publications-page .publication-item:hover .publication-title h3 {
    color: var(--accent-purple);
}

.publications-page .publication-authors {
    color: #444;
    font-size: 1.2rem;
    margin-bottom: 12px;
    line-height: 1.8;
    font-weight: 300;
}

.publications-page .publication-journal {
    color: var(--accent-purple);
    font-size: 1.2rem;
    font-style: italic;
    line-height: 1.6;
}

.publications-page .publication-item p {
    color: #666;
    margin: 0;
}

/* Publications Page Responsive */
@media (max-width: 1024px) {
    .publications-page .publications-list {
        width: 100%;
    }
}

@media (max-width: 768px) {
    .publications-page .page-wrapper {
        max-width: 95%;
        width: 95%;
        margin: 30px auto 60px auto;
    }

    .publications-page .section-title {
        font-size: 2rem;
    }

    .publications-page .publication-title h3 {
        font-size: 1.2rem;
    }

    .publications-page .publication-authors,
    .publications-page .publication-journal {
        font-size: 1rem;
    }
}