h1 {
    padding: 32px;
    margin: 0 auto;
    max-width: 1200px
}

img {
    max-width: 100%
}

.intro, .category-code, .category-stats, .specialty-intro {
    padding: 0 32px;
    margin: 0 auto;
    max-width: 1200px;
    display: block
}

main.container {
    padding: 60px 0 0;
    max-width: 100%
}

.container > section {
    max-width: 1200px;
    padding: 0 32px;
    margin: 60px auto
}

a:hover {
    text-decoration: none
}

.sources-list {
    list-style: none
}

@media (max-width: 768px) {
    .container > section {
        margin: 30px auto
    }
}

.header {
    background: #4a90e2;
    color: #fff;
    height: 60px;
    box-shadow: none;
    padding: 0
}

.header .nav {
    height: 60px;
    max-width: 100%
}

.header .nav-menu {
    visibility: hidden;
    position: absolute;
    left: auto;
    right: 0;
    top: 60px;
    width: 100%;
    height: calc(100vh - 60px);
    text-align: right;
    transition: all 50ms linear;
    opacity: 0;
    display: block
}

.header .nav-menu li {
    width: 300px;
    padding: 0 40px;
    border-top: 1px solid rgb(255 255 255 / .2);
    border-left: 1px solid rgb(255 255 255 / .2);
    background: #4a90e2;
    float: right;
    position: relative;
    z-index: 2;
    clear: both
}

.header .nav-menu:after {
    content: "";
    width: 300px;
    height: calc(100vh - 60px);
    background: #4a90e2;
    right: 0;
    position: absolute;
    z-index: 1;
    opacity: 0;
    visibility: hidden
}

.header .nav-menu.active {
    display: block;
    visibility: visible;
    opacity: 1
}

.header .nav-menu.active:after {
    visibility: visible;
    opacity: 1;
    transition: all 300ms linear
}

.header .nav-menu.active:before {
    content: "";
    width: 100%;
    height: calc(100vh - 60px);
    background: rgb(255 255 255 / .7);
    right: 0;
    position: absolute;
    z-index: -1
}

.header .nav-menu a {
    color: #fff;
    white-space: nowrap;
    font-size: 16px
}

.header .nav-menu a:hover, .header .nav-menu a.active {
    color: #fff
}

.header .nav-menu a.active {
    font-weight: 700
}

.header .nav-menu a.active:after {
    transform: translate(24px, 50%);
    width: 10px;
    height: 10px;
    bottom: 50%;
    background: #50ddbc;
    right: 0;
    left: auto;
    display: block
}

.stats-box ul, .stats-box ol {
    list-style: none
}

@media (max-width: 768px) {
    .header .nav-menu li, .header .nav-menu.active:after {
        width: 90%
    }

    .header .nav-menu {
        padding: 0;
        width: 100%
    }

    .header .nav-menu a:hover, .header .nav-menu a.active {
        color: #fff
    }

    .header .nav-menu a.active:after {
        background: #50ddbc
    }
}

.mobile-menu-toggle {
    display: block
}

.mobile-menu-toggle, .header .logo {
    color: #fff
}

.container .hero-unified {
    background: url(/medical/assets/images/bg-hp.jpg);
    background-size: cover;
    max-width: 100%;
    padding: 60px 0;
    margin: 0
}

.hero-unified:before {
    animation: none;
    display: none
}

.hero-subtitle {
    color: #fff;
    font-weight: 500;
    padding: 0 20px
}

.hero-unified h1 {
    font-weight: 900;
    padding: 0 20px
}

.hero-stat {
    backdrop-filter: blur(1px);
    padding: 20px 10px;
    border: 0
}

.hero-unified * {
    text-shadow: 1px 1px 1px rgb(0 0 0)
}

.stat-label {
    opacity: 1;
    font-weight: 500
}

.example-code, .subcategory-code {
    font-family: "Courier Sans", sans-serif;
    font-weight: 700
}

.subcategory-code {
    font-size: 20px
}

.subcategory-card-home, .ccam-chapter-card {
    text-decoration: none !important
}

.subcategory-card-home:hover, .ccam-chapter-card:hover {
    box-shadow: none
}

.ccam-chapter-card:hover::before {
    display: none
}

.example-label {
    margin: 0 10px
}

.ccam-chapter-card {
    border: 1px solid
}

.header-mg {
    min-height: auto
}

.header-mg {
    max-width: 100% !important;
    height: auto;
    padding: 0;
    margin: 0
}

.search-section {
    margin-bottom: 100px !important
}

.search-section .search-form {
    display: flex
}

.search-section .search-input {
    width: calc(100% - 60px);
    border-radius: 8px 0 0 8px
}

.search-section .search-button {
    border-radius: 0 8px 8px 0
}

h2 {
    font-size: 1.6rem
}

.author-section {
    background: #fff;
    padding: 30px 40px !important;
    border-radius: 8px;
    max-width: 1140px !important
}

.author-section h2 {
    margin-top: 0
}

.author-content {
    display: flex;
    align-items: flex-start
}

.author-content .author-text {
    padding-left: 30px
}

.footer {
    background: unset;
    color: unset;
    padding: unset;
    margin: unset
}

.footer__sitemap--urls {
    font-size: 14px;
    line-height: 2
}

.footer .teleconsultation-urgence {
    padding: 30px
}

.subcategory-card:hover::before {
    display: none
}

.subcategories-grid, .articles-grid {
    display: grid;
    grid-template-columns:repeat(auto-fill, minmax(280px, 1fr));
    gap: 20px
}

.nav-grid {
    padding: 0 32px;
    margin-left: auto;
    margin-right: auto;
    max-width: 1200px
}

.nav-card::before {
    display: none
}

.info-grid, .families-grid {
    display: grid;
    grid-template-columns:repeat(auto-fill, minmax(280px, 1fr));
    gap: 20px
}

.info-grid .info-card, .families-grid .family-card {
    background: #fff;
    padding: 20px;
    border-radius: 8px;
    border: 1px solid #e8eef5
}

.families-grid .family-card h3 {
    font-size: 20px
}

.chapter-header {
    display: flex;
    align-items: center;
    padding: 0 32px;
    flex-wrap: wrap;
    margin: 0 auto;
    max-width: 1200px
}

.chapter-header h1 {
    margin: 0
}

.chapter-header p {
    width: 100%;
    margin: 0
}

.chapter-header .chapter-icon {
    font-size: 40px !important;
    background: none !important
}

.actes-list {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 32px;
    grid-template-columns:repeat(auto-fill, minmax(380px, 1fr));
    gap: 20px;
    display: grid
}

.actes-list h3 {
    margin-top: 0;
    font-weight: 500;
    font-size: 18px
}

.actes-list .acte-info {
    font-size: 14px
}

.acte-card, .acte-card:hover {
    box-shadow: none
}

.content.article-content {
    max-width: 1200px;
    padding: 20px 32px;
    margin: 0 auto 40px
}

.article-content h1 {
    padding-left: 0;
    padding-right: 0;
    padding-top: 0
}

.chapter-badge {
    padding: 8px 20px;
    border-radius: 24px;
    font-weight: 600;
    text-transform: uppercase
}

.introduction {
    border-radius: 0
}

.article-meta {
    margin-top: 20px;
    justify-content: center
}

.author-info {
    margin: 20px;
    max-width: 500px;
    flex-wrap: wrap;
    background: none;
    padding: 0;
    border: 0
}

.author-details p {
    margin-top: 0
}

.author-details p:last-child {
    margin-bottom: 0
}

.about-author-box {
    background: none;
    padding: 0;
    margin-bottom: 30px
}

.about-author-box h4 {
    color: #000
}

.medical-specialties-box {
    display: flex
}

.medical-specialties-box h4:after {
    content: ":"
}

.medical-specialties-box .specialty-tags {
    margin-left: 20px
}

.medical-specialties-box .specialty-tags .specialty-tag {
    border: 1px solid #4a90e2;
    margin: 0 15px 15px 0;
    border-radius: 100px;
    padding: 5px 15px;
    font-weight: 500;
    display: inline-block
}

.sources-section {
    font-size: 14px
}

.medical-references-list {
    list-style: none
}

.medical-references-list li {
    margin-bottom: 10px
}

.mesh-terms-section h3, .toc h3, .tarif-box h3, .info-grid .info-card h3, .families-grid .family-card h3, .article-item h3 {
    margin-top: 0
}

.mesh-term-link {
    border-width: 1px
}

.related-grid h4 {
    font-weight: 500;
    font-size: 18px
}

.author-profile {
    max-width: 1200px;
    padding: 30px 32px;
    margin: 0 auto
}

.author-profile h1 {
    padding: 0
}

.author-profile ul, .author-profile ol {
    list-style: none
}

.author-links h2 {
    margin-bottom: 30px
}

.author-links .links-grid {
    grid-template-columns:repeat(auto-fill, minmax(280px, 1fr));
    gap: 20px;
    display: grid
}

.author-links .links-grid h3 {
    font-size: 18px;
    margin-top: 0;
    margin-bottom: 10px
}

.author-articles ul {
    margin-bottom: 20px
}

.specialty-grid {
    max-width: 1200px;
    margin: 0 auto;
    padding: 30px 32px 60px;
    display: grid;
    grid-template-columns:repeat(auto-fill, minmax(280px, 1fr));
    gap: 40px
}

.specialty-grid h3 {
    font-size: 1.3rem
}

.specialty-grid ul {
    list-style: none
}

.search-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 30px 32px 60px
}

.search-container .search-box {
    gap: 0;
    margin-top: 0
}

.search-container .search-input {
    border-radius: 8px 0 0 8px
}

.search-container .search-button {
    border-radius: 0 8px 8px 0
}

.search-filters {
    flex-wrap: wrap
}

.filter-button {
    height: 40px;
    white-space: nowrap;
    padding: 10px 20px
}

.subcategory-grid {
    display: grid;
    grid-template-columns:repeat(auto-fill, minmax(280px, 1fr));
    gap: 20px
}

.sitemap-category {
    padding: 0
}

.sitemap-category h3 {
    font-size: 1.3rem
}

.sitemap-chapter {
    margin-bottom: 20px
}

.sitemap-chapter h3 {
    font-size: 18px
}

.source-snippet {
    margin-bottom: 0
}

.source-item {
    margin: 0 0 1.25rem
}

.medical-reference-item a {
    margin-left: 10px;
    color: transparent;
}

.medical-reference-item a:after {
    content: "🔗";
    margin-left: 10px;
}



@media (max-width: 768px) {
    .article-item {
        padding-left: 20px;
        padding-right: 20px
    }

    .search-container .search-input {
        min-width: 100%;
        margin-bottom: 20px;
        border-radius: 8px
    }

    .search-container .search-button {
        border-radius: 8px;
        height: 40px;
        width: auto
    }

    .search-box {
        flex-direction: unset;
        flex-wrap: wrap;
        justify-content: center
    }

    .specialty-grid, .search-container {
        padding: 20px
    }

    .medical-specialties-box h4 {
        margin-bottom: 20px
    }

    .medical-specialties-box {
        flex-wrap: wrap
    }

    .medical-specialties-box .specialty-tags {
        margin: 0;
        width: 100%
    }

    .content.article-content {
        padding: 20px
    }

    h1 {
        padding: 20px
    }

    .intro, .category-code, .category-stats {
        padding: 0 20px
    }

    .container .hero-unified {
        padding: 40px 0 10px
    }

    .hero-subtitle {
        margin-bottom: 0
    }

    .container > section {
        padding: 0 20px
    }

    .hero-grid {
        grid-template-columns:repeat(2, 1fr) !important;
        padding: 0 10px
    }

    .section-header-main h2 {
        font-size: 1.6rem
    }

    .ccam-chapter-card {
        padding: 20px
    }

    .chapter-examples-list li {
        flex-wrap: wrap
    }

    .chapter-examples-list li .example-code {
        width: 100%
    }

    .example-label {
        margin: 0 10px 0 0
    }

    .section-intro, .category-section-home {
        margin-bottom: 24px
    }

    .header-mg__title {
        font-size: 25px
    }

    .header-mg__cta {
        position: relative;
        background: none;
        padding: 0
    }

    .search-section {
        margin-bottom: 50px !important
    }

    .search-section .search-form {
        flex-wrap: wrap;
        justify-content: center
    }

    .search-section .search-input {
        width: auto;
        border-radius: 8px
    }

    .search-section .search-button {
        border-radius: 8px;
        height: 50px;
        margin-top: 20px;
        width: auto
    }

    .author-section {
        max-width: calc(100vw - 40px) !important
    }

    .author-content {
        flex-wrap: wrap
    }

    .author-content .author-text {
        padding: 0
    }

    .author-avatar {
        margin: 0 auto 20px
    }

    .nav-grid {
        padding: 0 20px
    }

    .chapter-header {
        padding: 0 20px
    }

    .actes-list {
        padding: 0 20px
    }
}