/* Shared component styles.
   Keep Razor partials mostly markup-only; put reusable visual rules here. */

.main-content {
    --site-page-bottom-space: clamp(2rem, 4vw, 3rem);
    min-height: calc(100vh - 470px);
    background: linear-gradient(180deg, #fdfdfd 0%, #fafafa 100%);
}

.main-content > :where(section, div):last-child:not(.global-breadcrumb-wrapper):not(.pb-5):not(.summit-article-page):not(.summit-sites-page):not(.summit-program-page):not(.oif-overview-page):not(.summit-logo-page):not(.search-results-section) {
    padding-bottom: var(--site-page-bottom-space);
}

.page-title-labelName {
    padding: 20px;
    justify-content: center;
    display: flex;
}

.accent-line {
    display: block;
    width: 180px;
    height: auto;
    margin: 0.5rem auto 1rem auto;
}

.main-content .page-title-wrapper {
    padding: 0 0 40px;
    text-align: center;
}

.main-content .page-title-wrapper .page-title {
    position: relative;
    display: inline-block;
    margin: 0;
    padding-bottom: 1.1rem;
    color: var(--fr-purple);
    font-size: var(--summit-title-font-size, clamp(2.25rem, 4vw, 3.05rem));
    font-weight: 760;
    line-height: var(--summit-title-line-height, 1.08);
    letter-spacing: 0;
    text-transform: none !important;
}

.main-content .page-title-wrapper .page-title::after,
.main-content .brand-page-title::after {
    content: "";
    position: absolute;
    bottom: 0;
    height: 3px;
    width: 170px;
    background: linear-gradient(
        90deg,
        var(--fr-yellow) 0 20%,
        var(--fr-green) 20% 40%,
        var(--fr-purple) 40% 60%,
        var(--fr-red) 60% 80%,
        var(--fr-cyan) 80% 100%
    );
    border-radius: 0;
}

.main-content .page-title-wrapper .page-title::after {
    left: 50%;
    transform: translateX(-50%);
}

.main-content .brand-page-title {
    position: relative;
    display: inline-block;
    padding-bottom: 1.1rem;
    color: var(--fr-purple);
    font-size: var(--summit-title-font-size, clamp(2.25rem, 4vw, 3.05rem));
    font-weight: 760;
    line-height: var(--summit-title-line-height, 1.08);
    letter-spacing: 0;
}

.main-content .brand-page-title::after {
    left: 0;
}

.main-content .detail-post-title,
.main-content .label-meeting-title,
.main-content .comingsoon-title {
    position: relative;
    display: inline-block;
    padding-bottom: 1.1rem;
    color: var(--fr-purple);
    font-size: var(--summit-title-font-size, clamp(2.25rem, 4vw, 3.05rem));
    font-weight: 760;
    line-height: var(--summit-title-line-height, 1.08);
    letter-spacing: 0;
}

.main-content .detail-post-title::after,
.main-content .label-meeting-title::after,
.main-content .comingsoon-title::after {
    content: "";
    position: absolute;
    bottom: 0;
    width: 170px;
    height: 3px;
    background: linear-gradient(
        90deg,
        var(--fr-yellow) 0 20%,
        var(--fr-green) 20% 40%,
        var(--fr-purple) 40% 60%,
        var(--fr-red) 60% 80%,
        var(--fr-cyan) 80% 100%
    );
}

.main-content .detail-post-title::after,
.main-content .comingsoon-title::after {
    left: 50%;
    transform: translateX(-50%);
}

.main-content .label-meeting-title::after {
    left: 0;
}

.main-content .label-meeting-title.text-center::after {
    left: 50%;
    transform: translateX(-50%);
}

@media (min-width: 768px) {
    .main-content .label-meeting-title.text-md-start::after {
        left: 0;
        transform: none;
    }
}

.fr-pagination__list {
    list-style: none;
    padding-left: 0;
    margin: 0 auto;
    display: flex;
    justify-content: center;
    gap: 8px;
}

.fr-pagination__link {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    width: 30px;
    height: 30px;
    line-height: 1;
    padding: 0;
    text-align: center;
    border-radius: 3px;
    box-sizing: border-box;
    background-color: #e0e0e0;
    border: 1px solid #e0e0e0;
    color: #000;
    text-decoration: none;
    transition: background-color 0.2s, border-color 0.2s;
}

.fr-pagination__link svg.fr-icon {
    width: 16px;
    height: 16px;
}

.fr-pagination__link:hover:not(.fr-pagination__link--disabled):not(.fr-pagination__link--current) {
    background-color: #c0c0c0;
    border-color: #c0c0c0;
    cursor: pointer;
}

.fr-pagination__link--current {
    background-color: #ffffff;
    border: 1px solid #e0e0e0;
    color: #000;
    cursor: default;
    font-weight: bold;
}

.fr-pagination__link--disabled {
    background-color: #f5f5f5;
    border: 1px solid #e0e0e0;
    color: #8c8c8c;
    pointer-events: none;
    cursor: default;
}

#footer {
    background: #f8f9fa;
    border-top: 1px solid rgba(var(--fr-dark-rgb), 0.12);
    color: #212529;
}

#footer a {
    color: inherit;
}

#footer a:hover,
#footer a:focus {
    color: var(--fr-purple);
    text-decoration: underline;
    text-underline-offset: 0.18em;
}

#footer ul {
    list-style: none;
    padding-left: 0;
    margin: 0;
}

.footer-content {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 1px minmax(320px, 1.05fr);
    align-items: start;
    gap: clamp(1.25rem, 4vw, 4rem);
    padding-block: 1.45rem;
    text-align: left;
}

.footer-section {
    display: grid;
    gap: 0.65rem;
    justify-items: start;
    min-width: 0;
}

.footer-contact {
    justify-self: end;
    width: min(100%, 560px);
}

.footer-section-title {
    margin: 0;
    color: var(--fr-dark);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    line-height: 1.2;
    text-transform: uppercase;
}

.footer-rule {
    width: 1px;
    height: 100%;
    min-height: 4.25rem;
    background: linear-gradient(180deg, transparent, rgba(var(--fr-dark-rgb), 0.22), transparent);
}

.exchange-links-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    gap: 0.65rem 1.35rem;
    width: 100%;
}

.footer-exchange-link {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    color: #121212;
    font-size: 0.9rem;
    font-weight: 600;
    line-height: 1.35;
    text-decoration: none;
}

.footer-exchange-link i {
    color: var(--fr-purple);
    font-size: 0.72rem;
}

.hotline-content {
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    flex-wrap: wrap;
    gap: .35rem .75rem;
    width: 100%;
    color: #121212;
    font-family: "Inter", "Hanuman", sans-serif;
    font-size: .82rem;
    line-height: 1.35;
    text-align: left;
}

.hotline-content a {
    color: #121212;
    text-decoration: none;
}

.hotline-content i {
    color: var(--fr-purple);
    font-size: .78rem;
    justify-self: center;
    line-height: 1;
    width: 1rem;
}

.hotline-label {
    color: rgba(var(--fr-dark-rgb), 0.78);
    font-weight: 500;
    padding-top: .08rem;
    white-space: nowrap;
}

.hotline-contact-list {
    display: grid;
    gap: .25rem;
    min-width: 0;
}

.hotline-contact-row {
    display: grid;
    grid-template-columns: 1rem minmax(0, 1fr);
    align-items: center;
    column-gap: .48rem;
    line-height: 1.25;
}

.hotline-contact-row span {
    min-width: 0;
    overflow-wrap: anywhere;
}

.hotline-phone {
    font-weight: 700;
    white-space: nowrap;
}

.hotline-email {
    overflow-wrap: anywhere;
    word-break: normal;
}

.social-follow-section {
    background-color: #ffffff;
    border-top: 1px solid var(--fr-border-muted);
    border-bottom: 2px solid var(--fr-purple);
    box-shadow: 0 -3px 10px -2px rgba(0, 0, 0, 0.1);
}

.social-follow-section .btn {
    border-color: var(--fr-purple);
    color: var(--fr-purple);
    border-radius: 0;
    text-transform: capitalize;
    display: flex;
    align-items: center;
    justify-content: center;
    white-space: nowrap;
    margin-right: 5px;
    transition: none;
}

.social-follow-section .btn i {
    width: 10px;
    min-height: 20px;
    align-items: center;
    padding-top: 2px;
    margin-right: 0.5rem;
}

.fa-youtube:before {
    justify-content: center;
    display: flex;
}

.social-follow-section .icon-col {
    margin-left: 0.25rem;
}

.social-follow-header h5 {
    color: var(--fr-dark);
}

.link-facebook {
    --social-link-color: #1877f2;
}

.link-youtube {
    --social-link-color: #ff0000;
}

.link-default {
    --social-link-color: var(--fr-purple);
}

.social-follow-section .social-link-btn {
    border-color: var(--social-link-color);
    color: var(--social-link-color);
}

.link-facebook:hover {
    background-color: #1877f2;
    color: white !important;
    border-color: #1877f2 !important;
}

.link-youtube:hover {
    background-color: #ff0000;
    color: white !important;
    border-color: #ff0000 !important;
}

.link-default:hover {
    background-color: var(--fr-dark);
    color: white !important;
    border-color: var(--fr-dark) !important;
}

.error-page-center {
    min-height: 45vh;
}

.comingsoon-container {
    min-height: 60vh;
}

.comingsoon-icon {
    font-size: 5rem;
    color: #f0ad4e;
}

.comingsoon-title {
    font-weight: 600;
    color: var(--fr-dark);
}

.comingsoon-message {
    color: #6c757d;
    font-size: 1.05rem;
}

.comingsoon-content a.btn {
    padding: 0.6rem 1.5rem;
    border-radius: 0.5rem;
    font-weight: 500;
}
