@font-face {
    font-family: 'gothamblack';
    src: url('../webfonts/gotham-black-webfont.woff2') format('woff2'),
         url('../webfonts/gotham-black-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}
@font-face {
    font-family: 'gothambold';
    src: url('../webfonts/gothambold-webfont.woff2') format('woff2'),
         url('../webfonts/gothambold-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}
@font-face {
    font-family: 'gothambook';
    src: url('../webfonts/gothambook-webfont.woff2') format('woff2'),
         url('../webfonts/gothambook-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}
@font-face {
    font-family: 'gothamlight';
    src: url('../webfonts/gothamlight-webfont.woff2') format('woff2'),
         url('../webfonts/gothamlight-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}
@font-face {
    font-family: 'gothammedium';
    src: url('../webfonts/gothammedium-webfont.woff2') format('woff2'),
         url('../webfonts/gothammedium-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}
@font-face {
    font-family: 'gothamthin';
    src: url('../webfonts/gotham-thin-webfont.woff2') format('woff2'),
         url('../webfonts/gotham-thin-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}
@font-face {
    font-family: 'gothamxlight';
    src: url('../webfonts/gotham-xlight-webfont.woff2') format('woff2'),
         url('../webfonts/gotham-xlight-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}

/* EndoExpert Light Modern Palette — Design Tokens
   Change colors HERE only. All rules below use var() references. */
:root {
    /* Primary — Brand Red */
    --color-primary-700: #B52525;
    --color-primary-600: #C92A2A;
    --color-primary-500: #E03E3E;
    --color-primary-400: #EB6B6B;
    --color-primary-100: #FEE7E7;
    --color-primary-50:  #FFF8F8;
    --color-primary-600-rgb: 201, 42, 42;
    --color-primary-500-rgb: 224, 62, 62;

    /* Accent — Terracotta / Copper */
    --color-accent-700: #8B4332;
    --color-accent-600: #B5594D;
    --color-accent-500: #C87A6F;
    --color-accent-400: #DCAA9F;
    --color-accent-100: #FBEEEB;
    --color-accent-50:  #FDF7F5;
    --color-accent-600-rgb: 181, 89, 77;
    --color-accent-500-rgb: 200, 122, 111;
    --color-accent-400-rgb: 220, 170, 159;

    /* Neutrals */
    --color-black-950: #141719;
    --color-black-900: #1A1D21;
    --color-black-800: #252A2F;
    --color-black-700: #333940;
    --color-black-600: #474E56;
    --color-gray-500:  #5F656E;
    --color-gray-400:  #A0A5AD;
    --color-gray-300:  #C1C5CA;
    --color-gray-200:  #E2E4E8;
    --color-gray-100:  #F1F2F4;
    --color-gray-50:   #F8F9FA;
    --color-white:     #FFFFFF;
    --color-black-800-rgb: 37, 42, 47;
    --color-warning-rgb: 245, 158, 11;

    /* Page */
    --color-bg:      #FBFBFC;
    --color-surface: #FFFFFF;

    /* Semantic */
    --color-success: #22C55E;
    --color-warning: #F59E0B;
    --color-error:   var(--color-primary-500);
    --color-info:    var(--color-accent-600);

    --bs-border-radius: 0.188rem;
}
.active>.page-link, .page-link.active {
    color: #fff;
    background-color: var(--color-primary-500);
    border-color: var(--color-primary-500);
}
.page-link {
    color: var(--color-black-800);
}
.page-link:hover {
    color: var(--color-primary-500);
}
body {
    font-family: 'Switzer', sans-serif;
    font-optical-sizing: auto;
    font-weight: 400;
    font-style: normal;
    font-size: 1rem;
    color: var(--color-black-700);
}
p {
    margin-bottom: 1rem;
}
p:last-of-type {
    margin-bottom: 0;
}
h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6,
.display-1, .display-2, .display-3, .display-4, .display-5, .display-6 {
    font-weight: 700;
}
.text-muted {
    color: var(--color-gray-400) !important;
}
.fw-bold, strong {
    font-weight: 700 !important;
}
.form-control:focus, .form-select:focus, textarea.form-control:focus, .btn-close:focus, .accordion-button:focus {
    box-shadow: none;
}
.n-fixed-top {
    position: fixed !important;
    top: 0;
    z-index: 9999 !important;
}
span.n-icon-poi {
    background: url('../gfx/icons/general/poi.svg') no-repeat center;
    background-size: contain;
    min-width: 18px;
    min-height: 18px;
    width: 18px;
    height: 18px;
    display: inline-block;
}
span.n-icon-phone {
    background: url('../gfx/icons/general/phone.svg') no-repeat center;
    background-size: contain;
    min-width: 18px;
    min-height: 18px;
    width: 18px;
    height: 18px;
    display: inline-block;
}
span.n-icon-mail {
    background: url('../gfx/icons/general/mail.svg') no-repeat center;
    background-size: contain;
    min-width: 18px;
    min-height: 18px;
    width: 18px;
    height: 18px;
    display: inline-block;
}
span.n-icon-user {
    background: url('../gfx/icons/general/user.svg') no-repeat center;
    background-size: contain;
    min-width: 18px;
    min-height: 18px;
    width: 18px;
    height: 18px;
    display: inline-block;
}
span.n-icon-lang {
    background: url('../gfx/icons/general/lang.svg') no-repeat center;
    background-size: contain;
    min-width: 16px;
    min-height: 16px;
    width: 16px;
    height: 16px;
    display: inline-block;
}
span.n-icon-search {
    background: url('../gfx/icons/general/search.svg') no-repeat center;
    background-size: contain;
    min-width: 16px;
    min-height: 16px;
    width: 16px;
    height: 16px;
    display: inline-block;
}
span.n-icon-search-green {
    background: url('../gfx/icons/general/search-green.svg') no-repeat center;
    background-size: contain;
    min-width: 18px;
    min-height: 18px;
    width: 18px;
    height: 18px;
    display: inline-block;
}
span.n-icon-calendar-check {
    background: url('../gfx/icons/general/calendar-check.svg') no-repeat center;
    background-size: contain;
    min-width: 18px;
    min-height: 18px;
    width: 18px;
    height: 18px;
    display: inline-block;
}
span.n-icon-fonendoscop {
    background: url('../gfx/icons/general/fonendoscop.svg') no-repeat center;
    background-size: contain;
    min-width: 18px;
    min-height: 18px;
    width: 18px;
    height: 18px;
    display: inline-block;
}
span.n-icon-warning-bubble {
    background: url('../gfx/icons/general/warning-bubble.svg') no-repeat center;
    background-size: contain;
    min-width: 24px;
    min-height: 24px;
    width: 24px;
    height: 24px;
    display: inline-block;
}
span.n-icon-services, span.n-icon-patients, span.n-icon-about {
    display: inline-block;
}
span.n-icon-services.n-icon-services-01 {
    background: url('../gfx/icons/services/01.svg') no-repeat center;
    background-size: contain;
}
span.n-icon-services.n-icon-services-02 {
    background: url('../gfx/icons/services/02.svg') no-repeat center;
    background-size: contain;
}
span.n-icon-services.n-icon-services-03 {
    background: url('../gfx/icons/services/03.svg') no-repeat center;
    background-size: contain;
}
span.n-icon-services.n-icon-services-04 {
    background: url('../gfx/icons/services/04.svg') no-repeat center;
    background-size: contain;
}
span.n-icon-services.n-icon-services-05 {
    background: url('../gfx/icons/services/05.svg') no-repeat center;
    background-size: contain;
}
span.n-icon-services.n-icon-services-06 {
    background: url('../gfx/icons/services/06.svg') no-repeat center;
    background-size: contain;
}
span.n-icon-services.n-icon-patients-01 {
    background: url('../gfx/icons/patients/01.svg') no-repeat center;
    background-size: contain;
}
span.n-icon-services.n-icon-patients-02 {
    background: url('../gfx/icons/patients/02.svg') no-repeat center;
    background-size: contain;
}
span.n-icon-services.n-icon-patients-03 {
    background: url('../gfx/icons/patients/03.svg') no-repeat center;
    background-size: contain;
}
span.n-icon-services.n-icon-patients-04 {
    background: url('../gfx/icons/patients/04.svg') no-repeat center;
    background-size: contain;
}
span.n-icon-services.n-icon-patients-05 {
    background: url('../gfx/icons/patients/05.svg') no-repeat center;
    background-size: contain;
}
span.n-icon-services.n-icon-about-01 {
    background: url('../gfx/icons/about/01.svg') no-repeat center;
    background-size: contain;
}
span.n-icon-services.n-icon-about-02 {
    background: url('../gfx/icons/about/02.svg') no-repeat center;
    background-size: contain;
}
span.n-icon-services.n-icon-about-03 {
    background: url('../gfx/icons/about/03.svg') no-repeat center;
    background-size: contain;
}
span.n-icon-services.n-icon-about-04 {
    background: url('../gfx/icons/about/04.svg') no-repeat center;
    background-size: contain;
}
span.n-icon-services.n-icon-about-05 {
    background: url('../gfx/icons/about/05.svg') no-repeat center;
    background-size: contain;
}
span.n-icon-services.n-icon-about-06 {
    background: url('../gfx/icons/about/06.svg') no-repeat center;
    background-size: contain;
}
span.n-icon-fb-1 {
    background: url('../gfx/icons/footer/fb-1.svg') no-repeat center;
    background-size: contain;
    min-width: 32px;
    min-height: 32px;
    width: 32px;
    height: 32px;
    display: inline-block;
}
span.n-icon-yt-1 {
    background: url('../gfx/icons/footer/yt-1.svg') no-repeat center;
    background-size: contain;
    min-width: 32px;
    min-height: 32px;
    width: 32px;
    height: 32px;
    display: inline-block;
}
span.n-icon-ig-1 {
    background: url('../gfx/icons/footer/ig-1.svg') no-repeat center;
    background-size: contain;
    min-width: 32px;
    min-height: 32px;
    width: 32px;
    height: 32px;
    display: inline-block;
}
span.n-icon-arrow-up {
    background: url('../gfx/icons/footer/arrow-up.svg') no-repeat center;
    background-size: contain;
    min-width: 32px;
    min-height: 36px;
    width: 32px;
    height: 36px;
    display: inline-block;
}
span.n-icon-parking {
    background: url('../gfx/icons/general/parking.svg') no-repeat center;
    background-size: contain;
    min-width: 16px;
    min-height: 16px;
    width: 16px;
    height: 16px;
    display: inline-block;
}
span.n-icon-quote {
    background: url('../gfx/icons/general/quote.svg') no-repeat center;
    background-size: contain;
    min-width: 24px;
    min-height: 24px;
    width: 24px;
    height: 24px;
    display: inline-block;
}
span.n-icon-star {
    background: url('../gfx/icons/general/star.svg') no-repeat center;
    background-size: contain;
    min-width: 28px;
    min-height: 28px;
    width: 28px;
    height: 28px;
    display: inline-block;
}
span.n-icon-star-active {
    background: url('../gfx/icons/general/star-active.svg') no-repeat center;
    background-size: contain;
    min-width: 28px;
    min-height: 28px;
    width: 28px;
    height: 28px;
    display: inline-block;
}
span.n-icon-home {
    background: url('../gfx/icons/general/home.svg') no-repeat center;
    background-size: contain;
    min-width: 18px;
    min-height: 18px;
    width: 18px;
    height: 18px;
    display: inline-block;
}
span.n-circle-check-green {
    background: url('../gfx/icons/general/circle-check-green.svg') no-repeat center;
    background-size: contain;
    min-width: 24px;
    min-height: 24px;
    width: 24px;
    height: 24px;
    display: block;
}
.n-list-arrow-right {
    list-style: none;
    padding: 0 1rem !important;
    margin: 1rem 0 1.5rem 0 !important;
}
.n-list-arrow-right li {
    display: flex;
    align-items: center;
    margin-bottom: 1rem;
}
.n-list-arrow-right li::before {
    content: '';
    background: url('../gfx/icons/general/list-arrow-circle-right.svg') no-repeat center;
    background-size: contain;
    min-width: 18px;
    min-height: 18px;
    width: 18px;
    height: 18px;
    margin-right: 0.75rem;
    display: inline-block;
}
ol, .text ol {
    list-style: number;
    padding: 0 1rem;
    margin: 1rem 1rem 1.5rem 1rem;
}
ol li, .text ol li {
    padding-left: 0.75rem;
    margin-bottom: 0.75rem;
}
blockquote {
    font-weight: 400;
    font-size: 1.25rem;
    color: var(--color-accent-600);
    border-left: 3px solid var(--color-accent-600);
    padding: 0.25rem 1rem;
    margin: 1.5rem 0 1.5rem 0;
}
.text-primary {
    color: var(--color-accent-600) !important;
}
.btn.btn-primary {
    color: #fff;
    background-color: var(--color-primary-500);
    border-color: var(--color-primary-500);
}
.btn.btn-primary:hover {
    color: #fff;
    background-color: var(--color-primary-600);
    border-color: var(--color-primary-600);
}
.btn.btn-secondary {
    color: #fff;
    background-color: var(--color-black-800);
    border-color: var(--color-black-800);
    transition: all 0.2s ease;
}
.btn.btn-secondary:hover {
    color: #fff;
    background-color: var(--color-black-900);
    border-color: var(--color-black-900);
}
.btn.btn-outline-success {
    color: var(--color-accent-600);
    border: 2px solid var(--color-accent-600);
}
.btn.btn-outline-success:hover {
    color: var(--color-accent-600);
    background-color: transparent;
    border: 2px solid var(--color-accent-600);
}
.n-header-logo {
    display: inline-block;
}
.n-header-logo img {
    height: 55px;
    width: auto;
    object-fit: contain;
}
.n-header {
    position: relative;
    /* overflow: hidden; */
}
.n-header .container {
    flex-direction: row;
    justify-content: center;
}
.n-header video {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: 100%;
    max-height: 530px;
    object-fit: cover;
    object-position: center;
}
.n-header > img {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: 100%;
    max-height: 530px;
    object-fit: cover;
    object-position: center;
}
.n-header-overlay {
    position: relative;
    z-index: 1;
}
.wrapper--frontpage .n-header-overlay {
    background: linear-gradient(180deg, rgba(0, 0, 0, 0.35) 0%, rgba(0, 0, 0, 0.25) 60%, rgba(0, 0, 0, 0.45) 100%);
}

/* =========================================
   STRIPE-INSPIRED HEADER & HERO — LIGHT THEME
   ========================================= */

/* ── Animated Gradient Background — Light ── */
.n-header--stripe {
    position: relative;
    overflow: hidden;
    background: var(--color-bg);
}
.n-header--stripe > video,
.n-header--stripe > img {
    display: none !important;
}
.n-header--stripe .n-header-overlay {
    display: none !important;
}
.n-hero-gradient {
    position: absolute;
    inset: 0;
    z-index: 0;
    overflow: hidden;
}
.n-hero-gradient__mesh {
    position: absolute;
    inset: -40%;
    width: 180%;
    height: 180%;
    background:
        radial-gradient(ellipse 55% 45% at 15% 25%, rgba(var(--color-accent-600-rgb), 0.15) 0%, transparent 65%),
        radial-gradient(ellipse 45% 55% at 85% 15%, rgba(var(--color-primary-500-rgb), 0.08) 0%, transparent 55%),
        radial-gradient(ellipse 60% 45% at 55% 85%, rgba(var(--color-accent-500-rgb), 0.1) 0%, transparent 50%),
        radial-gradient(ellipse 35% 35% at 75% 55%, rgba(var(--color-warning-rgb), 0.06) 0%, transparent 55%),
        radial-gradient(ellipse 50% 50% at 25% 65%, rgba(var(--color-accent-400-rgb), 0.08) 0%, transparent 45%);
    animation: meshFloat 24s ease-in-out infinite;
}
@keyframes meshFloat {
    0%, 100% { transform: translate(0, 0) rotate(0deg) scale(1); }
    25% { transform: translate(2%, -2%) rotate(0.5deg) scale(1.01); }
    50% { transform: translate(-1%, 1.5%) rotate(-0.3deg) scale(0.99); }
    75% { transform: translate(-1.5%, -1%) rotate(0.3deg) scale(1.005); }
}
.n-hero-gradient__noise {
    position: absolute;
    inset: 0;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.02'/%3E%3C/svg%3E");
    background-repeat: repeat;
    background-size: 128px 128px;
    opacity: 0.4;
    pointer-events: none;
}

/* ── Floating Glass Navigation — White ── */
.n-floating-nav {
    position: fixed;
    top: 1rem;
    left: 50%;
    transform: translateX(-50%);
    width: calc(100% - 2rem);
    max-width: 1200px;
    z-index: 9999;
    transition: top 0.3s ease;
}
.n-floating-nav__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    background: transparent;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    border: 1px solid transparent;
    border-radius: 1rem;
    padding: 0.625rem 1.25rem;
    box-shadow: none;
    transition: background 0.35s ease, border-color 0.35s ease, box-shadow 0.35s ease, backdrop-filter 0.35s ease;
}
/* Show background once user scrolls */
.n-floating-nav--scrolled .n-floating-nav__inner {
    background: rgba(255, 255, 255, 0.78);
    backdrop-filter: blur(20px) saturate(1.6);
    -webkit-backdrop-filter: blur(20px) saturate(1.6);
    border-color: rgba(0, 0, 0, 0.06);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04), 0 8px 24px rgba(0, 0, 0, 0.06);
}
.n-floating-nav__logo {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    gap: 0.75rem;
    text-decoration: none;
    color: inherit;
}
.n-floating-nav__logo-img {
    height: 38px;
    width: auto;
    object-fit: contain;
    display: block;
}
.n-floating-nav__emblem {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 0.0625rem;
    letter-spacing: 0.02em;
}
.n-floating-nav__emblem-line {
    font-family: Switzer, "Open Sans", Helvetica, Arial, sans-serif;
    font-size: 1.0625rem;
    font-weight: 600;
    line-height: 1.2;
    color: var(--color-black-800);
    letter-spacing: 0.01em;
}
.n-floating-nav__emblem-tagline {
    font-family: Switzer, "Open Sans", Helvetica, Arial, sans-serif;
    font-size: 0.6875rem;
    font-weight: 400;
    line-height: 1.2;
    color: var(--color-gray-500);
    text-transform: uppercase;
    letter-spacing: 0.12em;
}
.n-floating-nav__menu {
    display: flex;
    align-items: center;
    gap: 0.25rem;
    flex: 1;
    justify-content: center;
}
.n-floating-nav__link {
    color: var(--color-black-600);
    font-size: 0.875rem;
    font-weight: 500;
    text-decoration: none;
    padding: 0.5rem 0.875rem;
    border-radius: 0.5rem;
    transition: color 0.2s ease, background 0.2s ease;
    white-space: nowrap;
    background: none;
    border: none;
    cursor: pointer;
    font-family: inherit;
    line-height: 1.4;
}
.n-floating-nav__link:hover {
    color: var(--color-black-800);
    background: rgba(0, 0, 0, 0.04);
}
.n-floating-nav__link.is-active {
    color: var(--color-black-800);
    font-weight: 600;
}
/* Dropdown inside floating nav */
.n-floating-nav__dropdown {
    position: relative;
}
.n-floating-nav__link--dropdown::after {
    content: '';
    display: inline-block;
    width: 0;
    height: 0;
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 4px solid currentColor;
    margin-left: 0.375rem;
    vertical-align: middle;
    opacity: 0.4;
    transition: transform 0.2s ease;
}
.n-floating-nav__dropdown-panel {
    display: none;
    position: absolute;
    top: calc(100% + 0.75rem);
    left: 50%;
    transform: translateX(-50%);
    min-width: 540px;
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid rgba(0, 0, 0, 0.08);
    border-radius: 1rem;
    padding: 0.75rem;
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.1);
}
.n-floating-nav__dropdown:hover .n-floating-nav__dropdown-panel {
    display: block;
}
.n-floating-nav__dropdown:hover .n-floating-nav__link--dropdown::after {
    transform: rotate(180deg);
}
.n-floating-nav__dropdown-panel .n-mega-menu-row {
    display: flex;
    flex-wrap: wrap;
}
.n-floating-nav__dropdown-panel .n-mega-menu-col {
    width: 50%;
    padding: 0;
}
.n-floating-nav__dropdown-panel .n-mega-menu-col a {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    padding: 0.75rem 1rem;
    border-radius: 0.625rem;
    text-decoration: none;
    color: var(--color-black-600);
    border: none;
    transition: background 0.2s ease;
}
.n-floating-nav__dropdown-panel .n-mega-menu-col a:hover {
    background: rgba(0, 0, 0, 0.04);
    color: var(--color-black-800);
}
.n-floating-nav__dropdown-panel .n-mega-menu-title {
    font-weight: 600;
    font-size: 0.875rem;
    color: var(--color-black-800);
}
.n-floating-nav__dropdown-panel .n-mega-menu-description {
    font-size: 0.75rem;
    color: var(--color-gray-500);
}
.n-floating-nav__dropdown-panel .n-mega-menu-icon {
    display: none;
}

/* Nav actions */
.n-floating-nav__actions {
    display: flex;
    align-items: center;
    gap: 1.25rem;
    flex-shrink: 0;
}
.n-floating-nav__lang {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}
.n-floating-nav__lang a {
    color: var(--color-gray-400);
    font-size: 0.75rem;
    font-weight: 600;
    text-decoration: none;
    letter-spacing: 0.05em;
    transition: color 0.2s ease;
}
.n-floating-nav__lang a:hover,
.n-floating-nav__lang a.is-active {
    color: var(--color-black-800);
}
.n-floating-nav__lang-sep {
    width: 1px;
    height: 12px;
    background: var(--color-gray-200);
}
.n-floating-nav__cta {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 1.25rem;
    font-size: 0.8125rem;
    font-weight: 600;
    color: #fff;
    background: var(--color-black-800);
    border: 1px solid var(--color-black-800);
    border-radius: 0.625rem;
    text-decoration: none;
    transition: all 0.25s ease;
    white-space: nowrap;
}
.n-floating-nav__cta:hover {
    background: var(--color-black-700);
    border-color: var(--color-black-700);
    color: #fff;
    box-shadow: 0 4px 12px rgba(var(--color-black-800-rgb), 0.2);
}

/* ── Mobile hamburger toggle buttons ── */
.n-floating-nav__actions .n-hamburger-menu,
.n-floating-nav__actions .n-hamburger-menu-close {
    width: 36px;
    height: 36px;
    position: relative;
    cursor: pointer;
}
.n-floating-nav__actions .n-hamburger-menu::before {
    background: url('../gfx/icons/general/hamburger-menu.svg') no-repeat center;
    background-size: 22px;
    min-width: 36px;
    min-height: 36px;
    width: 36px;
    height: 36px;
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    filter: brightness(0);
}
.n-floating-nav__actions .n-hamburger-menu-close::before {
    background: url('../gfx/icons/general/hamburger-menu-close.svg') no-repeat center;
    background-size: 22px;
    min-width: 36px;
    min-height: 36px;
    width: 36px;
    height: 36px;
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    filter: brightness(0);
}

/* ── Mobile dropdown (full-screen overlay, outside <header>) ── */
.n-mobile-dropdown {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: #fff;
    z-index: 9998;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    display: none;
    flex-direction: column;
    padding: 5.5rem 1.5rem 2rem;
}
/* Nav links */
.n-mobile-dropdown__nav {
    display: flex;
    flex-direction: column;
    gap: 0;
    flex: 1;
}
.n-mobile-dropdown__link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem 0;
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--color-black-800);
    text-decoration: none;
    border-bottom: 1px solid var(--color-gray-100);
    background: none;
    border-left: 0;
    border-right: 0;
    border-top: 0;
    width: 100%;
    cursor: pointer;
    font-family: inherit;
    line-height: 1.4;
    transition: color 0.15s ease;
}
.n-mobile-dropdown__link:hover,
.n-mobile-dropdown__link.is-active {
    color: var(--color-accent-600);
}
.n-mobile-dropdown__link--parent svg {
    transition: transform 0.25s ease;
    color: var(--color-gray-400);
    flex-shrink: 0;
}
.n-mobile-dropdown__link--parent[aria-expanded="true"] svg {
    transform: rotate(180deg);
}
/* Submenu */
.n-mobile-dropdown__submenu {
    display: flex;
    flex-direction: column;
    padding: 0.25rem 0 0.5rem 1rem;
}
.n-mobile-dropdown__sublink {
    display: block;
    padding: 0.625rem 0;
    font-size: 1rem;
    font-weight: 500;
    color: var(--color-black-600);
    text-decoration: none;
    transition: color 0.15s ease;
}
.n-mobile-dropdown__sublink:hover {
    color: var(--color-accent-600);
}
/* Footer area */
.n-mobile-dropdown__footer {
    margin-top: auto;
    padding-top: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}
.n-mobile-dropdown__cta {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.875rem 1.5rem;
    font-size: 1rem;
    font-weight: 600;
    color: #fff;
    background: var(--color-black-800);
    border-radius: 0.75rem;
    text-decoration: none;
    transition: background 0.2s ease;
}
.n-mobile-dropdown__cta:hover {
    background: var(--color-black-700);
    color: #fff;
}
.n-mobile-dropdown__contact {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}
.n-mobile-dropdown__contact a {
    display: inline-flex;
    align-items: center;
    gap: 0.625rem;
    color: var(--color-black-600);
    text-decoration: none;
    font-size: 0.9375rem;
    font-weight: 500;
    transition: color 0.15s ease;
}
.n-mobile-dropdown__contact a svg {
    color: var(--color-accent-600);
    flex-shrink: 0;
}
.n-mobile-dropdown__contact a:hover {
    color: var(--color-accent-600);
}
.n-mobile-dropdown__lang {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding-top: 0.75rem;
    border-top: 1px solid var(--color-gray-100);
}
.n-mobile-dropdown__lang a {
    color: var(--color-gray-400);
    font-size: 0.875rem;
    font-weight: 600;
    text-decoration: none;
    transition: color 0.15s ease;
}
.n-mobile-dropdown__lang a.is-active {
    color: var(--color-black-800);
}
.n-mobile-dropdown__lang a:hover {
    color: var(--color-accent-600);
}
.n-mobile-dropdown__lang-sep {
    color: var(--color-gray-300);
    font-size: 0.875rem;
}
/* When mobile menu is open, ensure nav is visually solid */
.n-floating-nav--menu-open .n-floating-nav__inner {
    background: #fff;
    border-color: var(--color-gray-200);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06);
}

/* ── Hero Section — Light ── */
.n-hero {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    height: min(92svh, 750px);
    padding: 8rem 1.5rem 5rem;
    text-align: center;
}
.n-hero__container {
    max-width: 820px;
    margin: 0 auto;
}
.n-hero__badge {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.375rem 1rem;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--color-accent-600);
    background: rgba(var(--color-accent-600-rgb), 0.08);
    border: 1px solid rgba(var(--color-accent-600-rgb), 0.15);
    border-radius: 100px;
    margin-bottom: 2rem;
    letter-spacing: 0.02em;
}
.n-hero__title {
    font-family: inherit;
    font-weight: 700;
    font-size: clamp(2.25rem, 5.5vw, 4rem);
    line-height: 1.1;
    color: var(--color-black-800);
    letter-spacing: -0.035em;
    margin: 0 0 1.5rem;
}
.n-hero__title-accent {
    background: linear-gradient(135deg, var(--color-accent-600) 0%, var(--color-accent-500) 50%, var(--color-accent-400) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}
.n-hero__subtitle {
    font-size: clamp(1rem, 1.5vw, 1.1875rem);
    font-weight: 400;
    line-height: 1.75;
    color: var(--color-gray-500);
    max-width: 620px;
    margin: 0 auto 5rem;
}
.n-hero__actions {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    flex-wrap: wrap;
    margin-top: 2rem;
}
.n-hero__btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.8125rem 1.75rem;
    font-size: 0.9375rem;
    font-weight: 600;
    border-radius: 0.75rem;
    text-decoration: none;
    transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
    white-space: nowrap;
}
.n-hero__btn--primary {
    color: #fff;
    background: var(--color-black-800);
    border: 1px solid var(--color-black-800);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1), 0 4px 12px rgba(var(--color-black-800-rgb), 0.15);
}
.n-hero__btn--primary:hover {
    color: #fff;
    background: var(--color-black-700);
    border-color: var(--color-black-700);
    box-shadow: 0 4px 16px rgba(var(--color-black-800-rgb), 0.25);
    transform: translateY(-1px);
}
.n-hero__btn--primary svg {
    transition: transform 0.2s ease;
}
.n-hero__btn--primary:hover svg {
    transform: translateX(3px);
}
.n-hero__btn--ghost {
    color: var(--color-black-600);
    background: transparent;
    border: 1px solid var(--color-gray-300);
}
.n-hero__btn--ghost:hover {
    color: var(--color-black-800);
    background: rgba(0, 0, 0, 0.03);
    border-color: var(--color-gray-400);
}

/* ── Override wrapper--frontpage styles for new header ── */
.wrapper--frontpage .n-header--stripe + .n-frontpage-content {
    margin-top: 0;
}
.wrapper--frontpage .n-header--stripe .n-header-bottom,
.wrapper--frontpage .n-header--stripe .n-header-bottom-panels {
    display: none !important;
}

/* ── Responsive — Tablet ── */
@media (max-width: 1199.98px) {
    .n-floating-nav__inner {
        padding: 0.5rem 1rem;
    }
    .n-floating-nav__logo-img {
        height: 34px;
    }
    .n-floating-nav__emblem-line {
        font-size: 1rem;
    }
    .n-floating-nav__emblem-tagline {
        font-size: 0.625rem;
        letter-spacing: 0.1em;
    }
    .n-hero {
        min-height: 75vh;
        min-height: 75svh;
        padding: 7.5rem 2rem 4rem;
    }
}
/* ── Responsive — Mobile ── */
@media (max-width: 767.98px) {
    .n-floating-nav {
        top: 0.625rem;
        width: calc(100% - 1.25rem);
    }
    .n-floating-nav__inner {
        padding: 0.5rem 0.75rem;
        border-radius: 0.75rem;
    }
    .n-floating-nav__logo-img {
        height: 30px;
    }
    .n-floating-nav__emblem-line {
        font-size: 0.9375rem;
    }
    .n-floating-nav__emblem-tagline {
        font-size: 0.5625rem;
        letter-spacing: 0.08em;
    }
    .n-floating-nav__cta {
        padding: 0.4375rem 0.875rem;
        font-size: 0.75rem;
        border-radius: 0.5rem;
    }
    .n-mobile-dropdown {
        padding: 4.5rem 1.25rem 1.5rem;
    }
    .n-hero {
        padding: 6.5rem 1.25rem 3.5rem;
        min-height: auto;
    }
    .n-hero__badge {
        font-size: 0.75rem;
        padding: 0.3125rem 0.75rem;
        margin-bottom: 1.5rem;
    }
    .n-hero__title {
        font-size: 1.875rem;
        line-height: 1.15;
        letter-spacing: -0.025em;
    }
    .n-hero__subtitle {
        font-size: 0.9375rem;
        line-height: 1.65;
        margin-bottom: 3.5rem;
    }
    .n-hero__actions {
        flex-direction: column;
        gap: 0.75rem;
        margin-top: 2rem;
    }
    .n-hero__btn {
        padding: 0.75rem 1.5rem;
        font-size: 0.875rem;
        width: 100%;
        justify-content: center;
    }
}
/* ── Responsive — Small phones ── */
@media (max-width: 374.98px) {
    .n-floating-nav__cta {
        display: none;
    }
    .n-hero__title {
        font-size: 1.625rem;
    }
}
/* END STRIPE-INSPIRED HEADER & HERO */
@media (min-width: 1200px) {
    .pp-header {
        width: 100%;
        max-width: 1164px;
    }
    .wrapper--patient-portal .n-patient-portal-container {
        width: 100%;
        max-width: 1164px;
    }
    .wrapper--patient-portal .sidebar {
        padding-left: 28px;
    }
}
@media (min-width: 1400px) {
    .pp-header {
        width: 100%;
        max-width: 1206px;
    }
    .wrapper--patient-portal .n-patient-portal-container {
        width: 100%;
        max-width: 1206px;
    }
    .wrapper--patient-portal .sidebar {
        padding-left: 28px;
    }
}
@media (min-width: 1500px) {
    .pp-header {
        width: 100%;
        max-width: 1242px;
    }
    .wrapper--patient-portal .n-patient-portal-container {
        width: 100%;
        max-width: 1242px;
    }
    .wrapper--patient-portal .sidebar {
        padding-left: 28px;
    }
}
.n-top-stripe {
    position: relative;
    width: 100%;
    height: 5px;
    background-color: var(--color-black-800);
}
.n-top-stripe::before,
.n-top-stripe::after {
    content: '';
    position: absolute;
    top: 0;
    height: 100%;
}
.n-top-stripe::before {
    left: 0;
    width: 33.33%;
    background-color: var(--color-primary-500);
}
.n-top-stripe::after {
    left: 33.33%;
    width: 33.33%;
    background-color: var(--color-accent-600);
}
/* ── Glassmorphism Navigation ── */
.n-navigation {
    color: #fff;
    background: rgba(var(--color-black-800-rgb), 0.65);
    backdrop-filter: blur(20px) saturate(1.4);
    -webkit-backdrop-filter: blur(20px) saturate(1.4);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-top: none;
    border-radius: 0 0 0.75rem 0.75rem;
    width: 100%;
    position: relative;
    z-index: 2;
    padding: 0;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.15);
}
.n-navigation .n-navigation-top {
    font-size: 0.813rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    padding: 0.5rem 1rem;
}
.n-navigation .n-navigation-top a,
.n-navigation .n-navigation-top span {
    color: rgba(255, 255, 255, 0.85);
    font-size: 0.813rem;
    text-decoration: none;
}
.n-navigation .n-navigation-top a:hover {
    color: #fff;
}
.n-navigation .n-navigation-top .btn.btn-link {
    color: rgba(255, 255, 255, 0.85);
    font-size: 0.813rem;
    text-decoration: none;
    padding: 0;
}
.n-navigation .n-navigation-top .btn.btn-link.active {
    font-weight: 700;
    color: #fff;
}
.n-navigation .n-navigation-top .btn.btn-link:hover {
    color: #fff;
}
.n-nav-contact-link {
    color: rgba(255, 255, 255, 0.7);
    font-size: 0.813rem;
    text-decoration: none;
    transition: color 0.2s ease;
}
.n-nav-contact-link:hover {
    color: #fff;
}
.n-navigation .n-navigation-bottom {
    padding: 1rem 1rem 0 1rem;
}
.n-navigation .n-navigation-bottom .btn, .n-navigation .n-navigation-bottom .btn span {
    font-weight: 600;
    font-size: 0.875rem;
}
.n-navigation .n-navigation-bottom .btn.btn-primary.n-btn-booking {
    background: var(--color-primary-500);
    border-color: var(--color-primary-500);
    color: #fff;
    border-radius: 0.5rem;
    padding: 0.5rem 1.25rem;
    transition: all 0.25s ease;
}
.n-navigation .n-navigation-bottom .btn.btn-primary.n-btn-booking:hover {
    background: var(--color-primary-600);
    border-color: var(--color-primary-600);
    box-shadow: 0 4px 16px rgba(var(--color-primary-500-rgb), 0.35);
}
.n-navigation .n-navigation-bottom .n-header-logo {
    margin-bottom: 0.6rem;
}
.n-navigation .n-navigation-bottom .n-mega-menu {
    display: flex;
    flex-direction: row;
    align-items: center;
    overflow: hidden;
}
.n-navigation .n-navigation-bottom .n-mega-menu a {
    font-weight: 600;
    font-size: 1rem;
    color: rgba(255, 255, 255, 0.9);
    float: left;
    text-align: center;
    line-height: 1;
    padding: 1rem 1rem 2rem 1rem;
    transition: color 0.2s ease;
}
.n-navigation .n-navigation-bottom .n-mega-menu a.active::after {
    background-color: var(--color-primary-500);
    width: 100%;
    min-height: 3px;
    height: 3px;
    content: '';
    position: relative;
    bottom: -6px;
    display: block;
}
.n-navigation .n-navigation-bottom .n-mega-menu-dropdown {
    float: left;
    overflow: hidden;
}
.n-navigation .n-navigation-bottom .n-mega-menu-dropdown .n-mega-menu-dropdown-btn {
    font-weight: 600;
    font-size: 1rem;
    color: rgba(255, 255, 255, 0.9);
    background: transparent;
    border: none;
    outline: none;
    line-height: 1;
    padding: 1rem 1rem 2rem 1rem;
    margin: 0;
    transition: color 0.2s ease;
}
.n-navigation .n-navigation-bottom .n-mega-menu a:hover {
    color: #fff;
}
.n-navigation .n-navigation-bottom .n-mega-menu-dropdown:hover .n-mega-menu-dropdown-btn, .n-navigation .n-navigation-bottom .n-mega-menu-dropdown .n-mega-menu-dropdown-btn.active {
    color: #fff;
    background-color: var(--color-primary-500);
    border-radius: 3px 3px 0 0;
    position: relative;
}
.n-navigation .n-navigation-bottom .n-mega-menu-dropdown:hover .n-mega-menu-dropdown-btn::after {
    background: url('../gfx/icons/general/menu-arrow-down-1.svg') no-repeat center;
    background-size: contain;
    min-width: 12px;
    min-height: 12px;
    width: 12px;
    height: 12px;
    display: inline-block;
    content: '';
    position: absolute;
    transform: translateX(-50%);
    left: 50%;
    bottom: 12px;
}
.n-navigation .n-navigation-bottom .n-mega-menu-dropdown-content {
    color: #fff;
    background: rgba(var(--color-black-800-rgb), 0.92);
    backdrop-filter: blur(24px) saturate(1.4);
    -webkit-backdrop-filter: blur(24px) saturate(1.4);
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 0 0 0.75rem 0.75rem;
    display: none;
    position: absolute;
    width: 100%;
    left: 0;
    right: 0;
    z-index: 10000;
    padding: 1rem;
}
.n-navigation .n-navigation-bottom .n-mega-menu-dropdown:hover .n-mega-menu-dropdown-content {
    display: block;
}
.n-navigation .n-navigation-bottom .n-mega-menu-row::after {
    content: '';
    display: table;
    clear: both;
}
.n-navigation .n-navigation-bottom .n-mega-menu-col {
    float: left;
    width: 33.33%;
    display: flex;
    flex-direction: column;
}
.n-navigation .n-navigation-bottom .n-mega-menu-col a {
    text-align: initial;
    border-right: 1px solid rgba(255, 255, 255, 0.06);
    float: none;
    display: block;
    padding: 0;
    margin: 1rem;
}
.n-navigation .n-navigation-bottom .n-mega-menu-col:nth-child(3n) a {
    border-right: 0;
}
.n-navigation .n-navigation-bottom .n-mega-menu-col .n-mega-menu-icon {
    min-width: 24px;
    min-height: 24px;
    width: 24px;
    height: 24px;
}
.n-navigation .n-navigation-bottom .n-mega-menu-col .n-mega-menu-title {
    font-weight: 600;
    font-size: 0.875rem;
    margin: 0.5rem 0 0.25rem 0;
    color: rgba(255, 255, 255, 0.9);
}
.n-navigation .n-navigation-bottom .n-mega-menu-col .n-mega-menu-description {
    font-weight: 400;
    font-size: 0.75rem;
    color: rgba(255, 255, 255, 0.5);
}
.n-navigation .n-navigation-bottom .n-hamburger-menu {
    width: 44px;
    height: 44px;
    position: relative;
}
.n-navigation .n-navigation-bottom .n-hamburger-menu::before {
    background: url('../gfx/icons/general/hamburger-menu.svg') no-repeat center;
    background-size: contain;
    min-width: 38px;
    min-height: 38px;
    width: 38px;
    height: 38px;
    content: '';
    position: absolute;
    transform: translate(-50%, -50%);
    top: 50%;
    left: 50%;
}
.n-navigation .n-navigation-bottom .n-hamburger-menu-close {
    width: 44px;
    height: 44px;
    position: relative;
}
.n-navigation .n-navigation-bottom .n-hamburger-menu-close::before {
    background: url('../gfx/icons/general/hamburger-menu-close.svg') no-repeat center;
    background-size: contain;
    min-width: 44px;
    min-height: 44px;
    width: 44px;
    height: 44px;
    content: '';
    position: absolute;
    transform: translate(-50%, -50%);
    top: 50%;
    left: 50%;
}
.n-navigation .n-hamburger-menu-dropdown {
    background-color: #fff;
    width: 100%;
    height: 100%;
    max-height: calc(100vh - 119px);
    display: none;
    flex-direction: column;
    position: fixed;
    top: 119px;
    left: 0;
    z-index: 9999;
    overflow-y: auto;
    padding: 0.5rem 1rem 1rem 1rem;
    margin: 0;
}
.n-navigation .n-hamburger-menu-dropdown .accordion {
    --bs-accordion-border-width: 0;
}
.n-navigation .n-hamburger-menu-dropdown .accordion-item {
    border: 0;
}
.n-navigation .n-hamburger-menu-dropdown .accordion-button, .n-navigation .n-hamburger-menu-dropdown .btn.accordion-link {
    font-weight: 600;
    font-size: 1.25rem;
    padding: 1rem 0 0 0;
}
.n-navigation .n-hamburger-menu-dropdown .accordion-button::after {
    width: 42px;
    height: 42px;
    content: '';
    background-image: url('../gfx/icons/general/arrow-down.svg');
    background-repeat: no-repeat;
    background-size: contain;
}
.n-navigation .n-hamburger-menu-dropdown .accordion-button:not(.collapsed)::after {
    width: 42px;
    height: 42px;
    content: '';
    background-image: url('../gfx/icons/general/close-mobile.svg');
    background-repeat: no-repeat;
    background-size: contain;
    transform: none;
}
.n-navigation .n-hamburger-menu-dropdown .accordion-button:not(.collapsed) {
    background-color: #fff;
}
.n-navigation .n-hamburger-menu-dropdown .accordion-collapse {
    padding: 0;
}
.n-navigation .n-hamburger-menu-dropdown .n-menu-icon {
    min-width: 24px;
    min-height: 24px;
    width: 24px;
    height: 24px;
}
.n-navigation .n-hamburger-menu-dropdown .n-menu-link {
    display: block;
    padding: 1rem;
}
.n-navigation .n-hamburger-menu-dropdown .n-menu-title {
    font-weight: 600;
    font-size: 0.875rem;
    margin: 0.25rem 0 0 0;
}
.n-navigation .n-hamburger-menu-dropdown .n-menu-description {
    font-weight: 400;
    font-size: 0.75rem;
    color: var(--color-gray-400);
}
.n-navigation .n-hamburger-menu-dropdown .n-hamburger-menu-contact {
    font-size: 0.813rem;
    margin-top: auto;
}
.n-mega-menu-col a {
    text-align: initial;
    display: block;
    padding: 0;
    margin: 1rem;
}
.n-navigation .n-navigation-bottom .n-mega-menu-col:nth-child(3n) a {
    border-right: 0;
}
.n-navigation .n-navigation-bottom .n-mega-menu-col .n-mega-menu-icon {
    min-width: 24px;
    min-height: 24px;
    width: 24px;
    height: 24px;
}
.n-navigation .n-navigation-bottom .n-mega-menu-col .n-mega-menu-title {
    font-weight: 600;
    font-size: 0.875rem;
    margin: 0.5rem 0 0.25rem 0;
    color: rgba(255, 255, 255, 0.9);
}
.n-navigation .n-navigation-bottom .n-mega-menu-col .n-mega-menu-description {
    font-weight: 400;
    font-size: 0.75rem;
    color: rgba(255, 255, 255, 0.5);
}
.n-navigation .n-navigation-bottom .n-btn-search {
    min-width: 36px;
    min-height: 36px;
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.n-navigation .n-navigation-bottom .n-mega-menu-dropdown .n-btn-search {
    font-weight: 600;
    font-size: 1rem;
    color: var(--color-black-700);
    background-color: transparent;
    border: none;
    border-radius: 50rem 50rem 0 0;
    outline: none;
    line-height: 1;
    position: relative;
    top: 0.45rem;
    z-index: 1;
    padding: 1rem 0.5rem 3rem 0.5rem;
    margin: 0;
}
.n-navigation .n-navigation-bottom .n-mega-menu-dropdown .n-btn-search:hover {
    border-radius: 50rem 50rem 0 0;
    padding: 1rem 0.5rem 3rem 0.5rem;
}
.n-navigation .n-navigation-bottom .n-mega-menu-dropdown .n-btn-search::before {
    color: #fff;
    background-color: var(--color-primary-500);
    border-color: var(--color-primary-500);
    border-radius: 50rem;
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    min-width: 36px;
    min-height: 36px;
    width: 36px;
    height: 36px;
    display: inline-block;
    z-index: 1;
}
.n-navigation .n-navigation-bottom .n-mega-menu-dropdown .n-btn-search .n-icon-search {
    position: relative;
    z-index: 2;
}
.n-navigation .n-navigation-bottom .n-mega-menu-dropdown .n-btn-search::before:hover {
    color: #fff;
    background-color: var(--color-primary-600);
    border-color: var(--color-primary-600);
}
.n-navigation .n-navigation-bottom .n-mega-menu-dropdown:hover .n-btn-search {
    color: #fff;
    background-color: var(--color-primary-500);
    border-radius: 50rem 50rem 0 0;
    position: relative;
}
.n-navigation .n-navigation-bottom .n-mega-menu-dropdown:hover .n-btn-search::after {
    background: url('../gfx/icons/general/menu-arrow-down-1.svg') no-repeat center;
    background-size: contain;
    min-width: 12px;
    min-height: 12px;
    width: 12px;
    height: 12px;
    display: inline-block;
    content: '';
    position: absolute;
    transform: translateX(-50%);
    left: 50%;
    bottom: 18px;
    z-index: 2;
}
.n-navigation .n-navigation-bottom .n-btn-booking {
    margin: 0 0 1rem 0;
}
.n-navigation .n-navigation-bottom .n-mega-menu-dropdown-content.n-mega-menu-search {
    font-size: 0.875rem;
    padding: 2rem;
}
.n-navigation .n-navigation-bottom .n-mega-menu-dropdown-content.n-mega-menu-search span.n-icon-search-green {
    min-width: 32px;
    min-height: 32px;
    width: 32px;
    height: 32px;
}
.n-navigation .n-navigation-bottom .n-mega-menu-dropdown-content.n-mega-menu-search .form-control, .n-navigation .n-navigation-bottom .n-mega-menu-dropdown-content.n-mega-menu-search .form-control:focus {
    font-size: 0.75rem;
    color: var(--color-black-700);
    border: 0;
    border-bottom: 1px solid var(--color-gray-400);
    border-radius: 0;
    padding: 0.5rem 0 0.5rem 0;
}
.n-navigation .n-navigation-bottom .n-mega-menu-dropdown-content.n-mega-menu-search .form-control::placeholder {
    color: var(--color-gray-400);
}
.n-navigation .n-navigation-bottom .n-mega-menu-dropdown-content.n-mega-menu-search .btn.btn-secondary {
    padding: 0.5rem 2rem 0.5rem 2rem;
}
.n-search {
    font-size: 0.875rem;
}
.n-search span.n-icon-search-green {
    min-width: 32px;
    min-height: 32px;
    width: 32px;
    height: 32px;
}
.n-search .form-control, .n-search .form-control:focus {
    font-size: 0.75rem;
    color: var(--color-black-700);
    border: 0;
    border-bottom: 1px solid var(--color-gray-400);
    border-radius: 0;
    padding: 0.5rem 0 0.5rem 0;
}
.n-search .form-control::placeholder {
    color: var(--color-gray-400);
}
.n-search .btn.btn-secondary {
    padding: 0.5rem 2rem 0.5rem 2rem;
}
.n-header-bottom {
    color: #fff;
    position: relative;
    min-height: 340px;
    height: auto;
    padding: 2rem 3rem 2rem 3rem;
}
.n-header-bottom h1 {
    font-family: 'gothambold';
}
.n-header-bottom-lead {
    color: rgba(255, 255, 255, 0.85);
    font-size: 1.125rem;
    font-weight: 400;
    line-height: 1.7;
    max-width: 560px;
    margin-top: 0.75rem;
}
.n-btn-booking-hero {
    background: var(--color-primary-500);
    border-color: var(--color-primary-500);
    color: #fff;
    font-weight: 600;
    border-radius: 0.5rem;
    padding: 0.75rem 1.75rem;
    font-size: 1rem;
    transition: all 0.25s ease;
}
.n-btn-booking-hero:hover {
    background: var(--color-primary-600);
    border-color: var(--color-primary-600);
    color: #fff;
    box-shadow: 0 6px 20px rgba(var(--color-primary-500-rgb), 0.35);
}
.n-header-bottom .btn.btn-outline-light {
    border-radius: 0.5rem;
    padding: 0.75rem 1.75rem;
    font-size: 1rem;
    font-weight: 500;
}
.n-header-bottom-subtitle {
    color: var(--color-primary-500);
    text-transform: uppercase;
    background-color: #fff;
    border-radius: 0.188rem;
    display: inline-block;
    padding: 0.5rem 0.75rem;
    font-weight: 600;
    letter-spacing: 1px;
}
.n-header-bottom .n-header-bottom-panels {
    position: absolute;
    width: calc(100% - 80px);
    top: 118%;
    left: 50%;
    transform: translate(-50%, -50%);
    margin: 0 auto;
}
.n-header-bottom-row {
    height: 100%;
}
.n-header .alert.alert-warning {
    color: #fff;
    background-color: var(--color-primary-500);
    border: 0;
    line-height: initial;
    position: absolute;
    top: 4px;
    left: 12px;
    right: 12px;
    z-index: 1;
    padding: 0.25rem 0.5rem;
}
.n-header .alert.alert-warning h6 {
    font-size: 0.938rem;
    margin: 0;
}
.n-header .alert.alert-warning p {
    font-size: 0.813rem;
    margin: 0;
}
.n-header .alert.alert-warning .btn-close {
    font-weight: 700;
    --bs-btn-close-bg: url('../gfx/icons/general/close-white.svg');
    background-size: contain;
    position: relative;
    min-width: 0.875em;
    min-height: 0.875em;
    width: 0.875em;
    height: 0.875em;
    opacity: 1;
    padding: 0;
    margin-left: auto;
}
.n-header-bottom .btn {
    font-weight: 500;
}
.n-header-bottom .btn.btn-outline-light, .n-header-bottom .btn.btn-outline-light:hover {
    color: #fff;
    background-color: transparent;
    border: 2px solid #fff;
}
.n-header-bottom .n-header-bottom-search {
    background-color: #fff;
    border-radius: 0.188rem;
    padding: 0.75rem 1rem;
}
.n-header-bottom .n-header-bottom-search .form-control, .n-header-bottom .n-header-bottom-search .form-control:focus {
    font-size: 0.938rem;
    color: var(--color-black-700);
    border: 0;
    border-bottom: 1px solid var(--color-gray-400);
    border-radius: 0;
    position: relative;
    padding: 0.4rem 0 0.4rem 0;
}
.n-header-bottom .n-header-bottom-search .form-control::placeholder {
    color: var(--color-gray-400);
}
.n-header-bottom .n-header-bottom-search .input-group-text {
    background-color: #fff;
    border-radius: 0;
    border: 0;
    border-bottom: 1px solid var(--color-gray-400);
    padding-left: 0;
}
.n-header-bottom .n-header-bottom-search .btn {
    padding: 0.4rem 2rem 0.4rem 2rem;
}
.n-header-bottom .card {
    background-color: var(--color-gray-100);
    border: 0;
    padding: 1rem;
}
.n-header-bottom .card .card-badge .card-badge-new {
    font-weight: 700;
    font-size: 0.75rem;
    color: #fff;
    text-transform: uppercase;
    background-color: var(--color-primary-500);
    border-radius: 0.188rem;
    display: inline-block;
    padding: 0.25rem 0.5rem;
}
.n-header-bottom .card .card-date {
    font-size: 0.875rem;
    color: var(--color-accent-600);
    margin: 0 0 0.25rem 0;
}
.n-header-bottom .card .card-title, .n-header-bottom .card .card-title:hover {
    font-weight: 600;
    font-size: 1rem;
    color: var(--color-black-800);
    margin: 0.25rem 0 1rem 0;
}
.n-header-bottom .card .card-body {
    font-size: 0.875rem;
    padding: 0;
}
.n-frontpage-content {
    position: relative;
    margin: calc(174px + 48px) 0 0 0;
}
.wrapper--frontpage .n-frontpage-content {
    margin-top: 0;
}
/* Hide the news panel cards on frontpage hero to keep the hero clean */
.wrapper--frontpage .n-header-bottom .n-header-bottom-panels {
    display: none;
}
.wrapper--frontpage > .n-header-bottom {
    display: none;
}
.wrapper--frontpage .n-header .n-header-bottom {
    min-height: auto;
    height: auto;
    padding: 3rem 3rem 4rem;
}
/* =========================================
   FRONTPAGE REDESIGN
   "Surgical Precision Meets Human Warmth"
   Refined luxury-medical editorial aesthetic
   ========================================= */

/* ── Scroll Reveal Animations ── */
@keyframes fp-reveal {
    from { opacity: 0; transform: translateY(36px); }
    to { opacity: 1; transform: translateY(0); }
}
@keyframes fp-child-reveal {
    from { opacity: 0; transform: translateY(24px); }
    to { opacity: 1; transform: translateY(0); }
}
.frontpage > * {
    opacity: 0;
    transform: translateY(36px);
    transition: opacity 0.75s cubic-bezier(0.16, 1, 0.3, 1),
                transform 0.75s cubic-bezier(0.16, 1, 0.3, 1);
}
.frontpage > *.is-visible {
    opacity: 1;
    transform: translateY(0);
}
/* Staggered children (cards) within revealed sections */
.frontpage > *.is-visible .col {
    opacity: 0;
    animation: fp-child-reveal 0.65s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}
.frontpage > *.is-visible .col:nth-child(1) { animation-delay: 0.06s; }
.frontpage > *.is-visible .col:nth-child(2) { animation-delay: 0.14s; }
.frontpage > *.is-visible .col:nth-child(3) { animation-delay: 0.22s; }
.frontpage > *.is-visible .col:nth-child(4) { animation-delay: 0.30s; }

/* ── Section Title Blocks ── */
.frontpage .n-title-section {
    padding: 5rem 0 1.75rem;
}
.frontpage .fp-section--services {
    padding-top: 3rem;
}
.frontpage .n-section-title {
    font-weight: 800;
    font-size: 2.375rem;
    color: var(--color-black-800);
    background: none;
    border-radius: 0;
    display: block;
    padding: 0;
    margin: 0 0 0.75rem;
    letter-spacing: -0.035em;
    line-height: 1.15;
}
.frontpage .n-section-title::after {
    content: '';
    display: block;
    width: 52px;
    height: 4px;
    background: var(--color-primary-500);
    border-radius: 2px;
    margin-top: 1rem;
}
.frontpage .n-section-subtitle {
    font-weight: 400;
    font-size: 1.125rem;
    color: var(--color-gray-500);
    margin: 0.5rem 0 0;
    letter-spacing: 0;
    max-width: 560px;
    line-height: 1.5;
}

/* ── Section Backgrounds ── */
/* Services: white */
.frontpage .fp-section--services { background: #fff; }
.frontpage .n-services { background: #fff; }
/* About: warm gray */
.frontpage .fp-section--about { background: var(--color-gray-100); }
.frontpage .n-mixed { background: var(--color-gray-100); }
/* Why Choose: white */
.frontpage .fp-section--why { background: #fff; }
.frontpage > .n-about { background: #fff; }
/* FAQ: subtle accent tint */
.frontpage .fp-section--faq { background: var(--color-accent-50); padding-top: 4rem; }
.frontpage > .n-accordion { background: var(--color-accent-50); max-width: none; }
/* Reviews: dark */
.frontpage .n-reviews-section {
    background: linear-gradient(180deg, var(--color-black-800) 0%, var(--color-black-950) 100%);
}
/* Partners: light gray */
.frontpage .n-partners-section-title {
    background-color: var(--color-gray-100);
    padding: 4.5rem 0 0;
    margin: 0;
    display: block;
}

/* ═══════════════════════════════════════════
   1. SERVICES CARDS
   ═══════════════════════════════════════════ */
.frontpage .n-services {
    padding: 0 0 5.5rem;
    margin: 0;
}
.frontpage .n-services .container {
    margin-top: 0;
}
.frontpage .n-services .row {
    --bs-gutter-x: 1.25rem;
    --bs-gutter-y: 1.25rem;
}
.frontpage .n-services .n-services-item {
    border-radius: 0.875rem;
    min-height: 310px;
    padding: 2.25rem 1.75rem;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    position: relative;
    overflow: hidden;
    text-decoration: none;
    transition: transform 0.5s cubic-bezier(0.16, 1, 0.3, 1),
                box-shadow 0.5s cubic-bezier(0.16, 1, 0.3, 1);
}
/* Rich gradient backgrounds */
.frontpage .n-services .col:nth-child(1) .n-services-item {
    background: linear-gradient(160deg, var(--color-black-800) 0%, var(--color-black-700) 55%, var(--color-black-600) 100%) !important;
    background-image: linear-gradient(160deg, var(--color-black-800) 0%, var(--color-black-700) 55%, var(--color-black-600) 100%) !important;
}
.frontpage .n-services .col:nth-child(2) .n-services-item {
    background: linear-gradient(160deg, var(--color-accent-700) 0%, var(--color-accent-600) 55%, var(--color-accent-500) 100%) !important;
    background-image: linear-gradient(160deg, var(--color-accent-700) 0%, var(--color-accent-600) 55%, var(--color-accent-500) 100%) !important;
}
.frontpage .n-services .col:nth-child(3) .n-services-item {
    background: linear-gradient(160deg, var(--color-primary-700) 0%, var(--color-primary-500) 55%, var(--color-primary-400) 100%) !important;
    background-image: linear-gradient(160deg, var(--color-primary-700) 0%, var(--color-primary-500) 55%, var(--color-primary-400) 100%) !important;
}
.frontpage .n-services .col:nth-child(4) .n-services-item {
    background: linear-gradient(160deg, var(--color-black-700) 0%, var(--color-black-600) 55%, var(--color-black-700) 100%) !important;
    background-image: linear-gradient(160deg, var(--color-black-700) 0%, var(--color-black-600) 55%, var(--color-black-700) 100%) !important;
}
.frontpage .n-services .n-services-item:hover {
    transform: translateY(-10px) scale(1.02);
    box-shadow: 0 28px 56px rgba(0, 0, 0, 0.22);
}
/* Decorative circle — top right */
.frontpage .n-services .n-services-item::before {
    content: '';
    position: absolute;
    top: -50px;
    right: -50px;
    width: 180px;
    height: 180px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.05);
    z-index: 0;
    transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}
.frontpage .n-services .n-services-item:hover::before {
    transform: scale(1.3);
}
/* Decorative circle — bottom left */
.frontpage .n-services .n-services-item::after {
    content: '';
    position: absolute;
    bottom: -30px;
    left: -30px;
    width: 100px;
    height: 100px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.03);
    z-index: 0;
}
.frontpage .n-services .n-services-item h6 {
    font-weight: 700;
    font-size: 1.375rem;
    color: #fff;
    background: none;
    border-radius: 0;
    display: block;
    position: relative;
    z-index: 1;
    padding: 0;
    margin: 0 0 0.75rem;
    letter-spacing: -0.01em;
    line-height: 1.2;
}
.frontpage .n-services .n-services-item p {
    font-size: 0.9375rem;
    color: rgba(255, 255, 255, 0.75);
    position: relative;
    z-index: 1;
    line-height: 1.7;
    padding: 0;
    margin: 0;
}

/* ═══════════════════════════════════════════
   2. MIXED / ABOUT US TEXT BLOCK
   ═══════════════════════════════════════════ */
.frontpage .n-mixed {
    padding: 0 0 5rem;
    margin: 0;
}
.frontpage .n-mixed .mixed__title {
    font-weight: 700;
    font-size: 1.75rem;
    color: var(--color-black-800);
    line-height: 1.3;
    margin-bottom: 2rem;
    letter-spacing: -0.02em;
    padding-left: 1.75rem;
    border-left: 4px solid var(--color-primary-500);
}
.frontpage .n-mixed .mixed__body {
    font-size: 1.0625rem;
    line-height: 1.9;
    color: var(--color-black-600);
}
.frontpage .n-mixed .mixed__body p {
    margin-bottom: 1.5rem;
}
.frontpage .n-mixed .mixed__body p:last-child {
    margin-bottom: 0;
}

/* ═══════════════════════════════════════════
   3. ABOUT BOXES — VALUE PROPOSITIONS
   ═══════════════════════════════════════════ */
.frontpage .n-about {
    padding: 0 0 5.5rem;
    margin: 0;
}
.frontpage .n-about .container {
    margin-top: 0;
}
.frontpage .n-about .row {
    --bs-gutter-x: 1.5rem;
    --bs-gutter-y: 1.5rem;
    counter-reset: value-counter;
}
.frontpage .n-about .col {
    counter-increment: value-counter;
}
.frontpage .n-about .n-about-item {
    border-radius: 1rem;
    min-height: 300px;
    padding: 2.5rem 2rem 2rem;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    position: relative;
    overflow: hidden;
    text-decoration: none;
    transition: transform 0.45s cubic-bezier(0.16, 1, 0.3, 1),
                box-shadow 0.45s cubic-bezier(0.16, 1, 0.3, 1),
                border-color 0.45s ease;
    background-image: none !important;
}
/* Large decorative counter number */
.frontpage .n-about .n-about-item::before {
    display: block !important;
    content: counter(value-counter, decimal-leading-zero);
    font-weight: 900;
    font-size: 5.5rem;
    line-height: 1;
    position: absolute;
    top: 0.75rem;
    right: 1.25rem;
    opacity: 0.06;
    z-index: 0;
    pointer-events: none;
    letter-spacing: -0.05em;
}
/* Card 1: Teal accent */
.frontpage .n-about .col:nth-child(1) .n-about-item {
    background: linear-gradient(175deg, var(--color-accent-50) 0%, #fff 100%) !important;
    border: 1px solid var(--color-accent-100);
    border-top: 4px solid var(--color-accent-600);
}
.frontpage .n-about .col:nth-child(1) .n-about-item::before { color: var(--color-accent-600); }
.frontpage .n-about .col:nth-child(1) .n-about-item h5 { color: var(--color-accent-600); }
/* Card 2: Red accent */
.frontpage .n-about .col:nth-child(2) .n-about-item {
    background: linear-gradient(175deg, var(--color-primary-50) 0%, #fff 100%) !important;
    border: 1px solid var(--color-primary-100);
    border-top: 4px solid var(--color-primary-500);
}
.frontpage .n-about .col:nth-child(2) .n-about-item::before { color: var(--color-primary-500); }
.frontpage .n-about .col:nth-child(2) .n-about-item h5 { color: var(--color-primary-600); }
/* Card 3: Dark accent */
.frontpage .n-about .col:nth-child(3) .n-about-item {
    background: linear-gradient(175deg, var(--color-gray-100) 0%, #fff 100%) !important;
    border: 1px solid var(--color-gray-200);
    border-top: 4px solid var(--color-black-800);
}
.frontpage .n-about .col:nth-child(3) .n-about-item::before { color: var(--color-black-800); }
.frontpage .n-about .col:nth-child(3) .n-about-item h5 { color: var(--color-black-800); }
/* Hover state */
.frontpage .n-about .n-about-item:hover {
    transform: translateY(-8px);
    box-shadow: 0 24px 48px rgba(0, 0, 0, 0.08);
}
.frontpage .n-about .n-about-item h5 {
    font-weight: 700;
    font-size: 1.3rem;
    position: relative;
    z-index: 1;
    padding: 0;
    margin: 0 0 1rem;
    letter-spacing: -0.01em;
    background: none;
    border-radius: 0;
    display: block;
}
.frontpage .n-about .n-about-item p {
    font-size: 0.9375rem;
    line-height: 1.75;
    color: var(--color-black-600);
    position: relative;
    z-index: 1;
    margin: 0;
}

/* ═══════════════════════════════════════════
   4. FAQ ACCORDION
   ═══════════════════════════════════════════ */
.frontpage .n-accordion {
    padding: 0 0 5rem;
    margin: 0 auto;
    max-width: none;
    padding-left: 1rem;
    padding-right: 1rem;
}
.frontpage .n-accordion .accordion {
    max-width: 900px;
    margin: 0 auto;
    background: #fff;
    border-radius: 1rem;
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.06);
    overflow: hidden;
    border: 1px solid rgba(var(--color-accent-600-rgb), 0.08);
}
.frontpage .n-accordion .accordion .accordion-item {
    border: 0;
    border-bottom: 1px solid rgba(var(--color-accent-600-rgb), 0.08);
    border-radius: 0;
    background: transparent;
    transition: background 0.2s ease;
}
.frontpage .n-accordion .accordion .accordion-item:last-child {
    border-bottom: 0;
}
.frontpage .n-accordion .accordion .accordion-item:hover {
    background: rgba(var(--color-accent-600-rgb), 0.03);
}
.frontpage .n-accordion .accordion .accordion-item .accordion-button {
    font-weight: 600;
    font-size: 1.0625rem;
    color: var(--color-black-700);
    padding: 1.375rem 1.75rem;
    background: transparent;
    border-radius: 0;
    border-bottom: none;
    position: relative;
    transition: color 0.3s ease;
    line-height: 1.5;
}
.frontpage .n-accordion .accordion .accordion-item .accordion-button:not(.collapsed) {
    color: var(--color-accent-600);
    background: rgba(var(--color-accent-600-rgb), 0.04);
    box-shadow: none;
}
.frontpage .n-accordion .accordion .accordion-item .accordion-button::after {
    width: 20px;
    height: 20px;
    flex-shrink: 0;
    transition: transform 0.3s ease;
}
.frontpage .n-accordion .accordion .accordion-item .accordion-body {
    color: var(--color-black-600);
    font-size: 0.9375rem;
    line-height: 1.85;
    padding: 0 1.75rem 1.5rem;
    max-width: 700px;
}

/* ═══════════════════════════════════════════
   5. REVIEWS / TESTIMONIALS SECTION
   ═══════════════════════════════════════════ */
.frontpage .n-reviews-section {
    padding: 5rem 0 0;
}
/* Section title on dark background */
.frontpage .n-reviews-section .n-section-title {
    color: #fff;
    font-weight: 800;
    font-size: 2.375rem;
    background: none;
    border-radius: 0;
    display: block;
    padding: 0;
    margin: 0 0 0.75rem;
    letter-spacing: -0.035em;
}
.frontpage .n-reviews-section .n-section-title::after {
    content: '';
    display: block;
    width: 52px;
    height: 4px;
    background: var(--color-primary-400);
    border-radius: 2px;
    margin-top: 1rem;
}
/* Arrow buttons on dark bg */
.frontpage .n-reviews-section .n-reviews-arrows .swiper-button-prev:after,
.frontpage .n-reviews-section .n-reviews-arrows .swiper-button-next:after {
    filter: brightness(0) invert(1);
}
.frontpage .n-reviews-section .n-reviews {
    background: transparent;
    padding: 1.5rem 0 4.5rem;
    margin: 0;
}
/* Glass-morphism review cards on dark bg */
.frontpage .n-reviews-section .n-reviews .swiper-reviews .swiper-slide {
    background: rgba(255, 255, 255, 0.04);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 1rem;
    padding: 2.5rem 2rem;
    color: rgba(255, 255, 255, 0.9);
    transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1),
                box-shadow 0.4s ease,
                background 0.4s ease;
}
.frontpage .n-reviews-section .n-reviews .swiper-reviews .swiper-slide:hover {
    transform: translateY(-4px);
    background: rgba(255, 255, 255, 0.07);
    box-shadow: 0 24px 48px rgba(0, 0, 0, 0.3);
}
.frontpage .n-reviews-section .n-reviews .swiper-reviews p.mb-3 {
    color: rgba(255, 255, 255, 0.8);
    font-size: 0.9375rem;
    line-height: 1.75;
}
.frontpage .n-reviews-section .n-reviews .n-reviews-name {
    color: var(--color-primary-400);
    font-weight: 600;
    font-size: 0.875rem;
}
/* Stars on dark bg */
.frontpage .n-reviews-section .n-reviews .n-icon-star {
    opacity: 0.3;
}
.frontpage .n-reviews-section .n-reviews .n-icon-star-active {
    opacity: 1;
}
/* Quote icon on dark bg */
.frontpage .n-reviews-section .n-reviews .n-icon-quote {
    opacity: 0.4;
}
/* CTA button on dark bg */
.frontpage .n-reviews-section .n-reviews .btn-outline-success {
    color: rgba(255, 255, 255, 0.8);
    border-color: rgba(255, 255, 255, 0.2);
    background: transparent;
    font-weight: 600;
    font-size: 1rem;
    padding: 0.625rem 1.75rem;
    border-radius: 0.5rem;
    transition: all 0.35s ease;
}
.frontpage .n-reviews-section .n-reviews .btn-outline-success:hover {
    background: var(--color-primary-500);
    border-color: var(--color-primary-500);
    color: #fff;
}

/* END FRONTPAGE REDESIGN */
.n-section-title {
    font-weight: 600;
    color: var(--color-accent-600);
    background-color: #fff;
    border-radius: 0.188rem;
    display: inline-block;
    padding: 0.5rem 0.75rem;
    margin: 2.5rem 0 0.25rem 0;
}
.n-section-subtitle {
    font-weight: 600;
    font-size: 1.188rem;
    color: var(--color-gray-400);
    margin: 0.25rem 0 1.5rem 0;
}
.n-services .n-services-item {
    background-position: center;
    background-size: cover;
    border-radius: 0.188rem;
    width: 100%;
    min-height: 200px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    position: relative;
    overflow: hidden;
    text-decoration: none;
    padding: 1.5rem;
    transition: transform 0.25s ease, box-shadow 0.25s ease;
}
/* When no background image, use palette gradient */
.n-services .n-services-item:not([style*="background-image: url()"]) {
    background-position: center;
    background-size: cover;
}
.n-services .n-services-item[style*="background-image: url();"],
.n-services .n-services-item[style*="background-image: url()"] {
    background-image: none !important;
}
.n-services .n-services-item:nth-child(1) .n-services-item {
    background: linear-gradient(135deg, var(--color-black-800) 0%, var(--color-black-700) 100%);
}
.n-services .col:nth-child(1) .n-services-item {
    background-color: var(--color-black-800);
    background-image: linear-gradient(135deg, var(--color-black-800) 0%, var(--color-black-700) 100%);
}
.n-services .col:nth-child(2) .n-services-item {
    background-color: var(--color-accent-600);
    background-image: linear-gradient(135deg, var(--color-accent-600) 0%, var(--color-accent-500) 100%);
}
.n-services .col:nth-child(3) .n-services-item {
    background-color: var(--color-primary-500);
    background-image: linear-gradient(135deg, var(--color-primary-600) 0%, var(--color-primary-400) 100%);
}
.n-services .col:nth-child(4) .n-services-item {
    background-color: var(--color-black-600);
    background-image: linear-gradient(135deg, var(--color-black-700) 0%, var(--color-black-600) 100%);
}
.n-services .n-services-item:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
}
.n-services .n-services-item::before {
    background: linear-gradient(180deg, rgba(0, 0, 0, 0) 42%, rgba(13, 13, 13, 0.75) 100%);
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
}
.n-services .n-services-item h6 {
    font-weight: 700;
    font-size: 1.125rem;
    color: #fff;
    background-color: transparent;
    border-radius: 0;
    display: block;
    position: relative;
    z-index: 1;
    padding: 0;
    margin: 0 0 0.5rem 0;
}
.n-services .n-services-item p {
    font-size: 0.875rem;
    color: rgba(255,255,255,0.85);
    position: relative;
    z-index: 1;
    line-height: 1.5;
    padding: 0;
    margin: 0;
}
.n-about .n-about-item {
    background-position: center;
    background-size: cover;
    border-radius: 0.188rem;
    width: 100%;
    min-height: 240px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    position: relative;
    overflow: hidden;
    text-decoration: none;
    padding: 1.5rem;
    transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.n-about .n-about-item:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
}
/* Colored backgrounds when no image */
.n-about .col:nth-child(1) .n-about-item {
    background-color: var(--color-accent-50);
    border: 1px solid var(--color-accent-100);
}
.n-about .col:nth-child(2) .n-about-item {
    background-color: var(--color-primary-50);
    border: 1px solid var(--color-primary-100);
}
.n-about .col:nth-child(3) .n-about-item {
    background-color: var(--color-gray-100);
    border: 1px solid var(--color-gray-200);
}
.n-about .n-about-item::before {
    display: none;
}
.n-about .n-about-item h5 {
    font-weight: 700;
    font-size: 1.125rem;
    color: var(--color-black-800);
    background-color: transparent;
    border-radius: 0;
    display: block;
    position: relative;
    z-index: 1;
    padding: 0;
    margin: 0 0 0.75rem 0;
}
.n-about .col:nth-child(1) .n-about-item h5 {
    color: var(--color-accent-600);
}
.n-about .col:nth-child(2) .n-about-item h5 {
    color: var(--color-primary-600);
}
.n-about .col:nth-child(3) .n-about-item h5 {
    color: var(--color-black-800);
}
.n-about .n-about-item p {
    font-weight: 400;
    font-size: 0.938rem;
    color: var(--color-black-600);
    position: relative;
    z-index: 1;
    line-height: 1.6;
    margin: 0;
}
.n-prices .n-prices-item {
    background-position: center;
    background-size: cover;
    border-radius: 0.188rem;
    width: 100%;
    min-height: 280px;
    display: block;
    position: relative;
    overflow: hidden;
}
.n-prices .n-prices-item::before {
    background: rgba(0, 0, 0, 0.2);
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: 100%;
}
.n-prices .n-prices-item h5 {
    font-weight: 600;
    color: var(--color-black-800);
    background-color: #fff;
    border-radius: 0.188rem;
    display: inline-block;
    position: absolute;
    top: 16px;
    left: 16px;
    padding: 0.5rem 0.75rem;
    margin: 0 16px 0 0;
}
.n-logos .n-logos-img {
    max-width: 100%;
    height: auto;
    object-fit: contain;
    object-position: center;
}
.n-logos .n-logos-item:nth-of-type(8) .n-logos-img {
    max-width: 128px;
    max-height: 128px;
}
.n-partners-section-title {
    background-color: var(--color-gray-100);
    display: block;
    padding: 1rem 0 0 0;
    margin: 2.5rem 0 0 0;
}
.partners {
    padding: 0 !important;
    margin: 0 !important;
}
.n-partners {
    background-color: var(--color-gray-100);
}
.n-partners .n-partners-wrapper {
    flex-wrap: wrap;
}
.n-partners .n-partners-item {
    flex: 1 1 calc(20% - 1.5rem);
}
.n-partners .n-partners-img {
    max-width: 100%;
    height: auto;
    object-fit: contain;
    object-position: center;
}
.n-partners img {
    background-image: none !important;
    max-width: 100%;
    height: auto;
    max-height: 64px;
    object-fit: contain;
    object-position: center;
    mix-blend-mode: multiply;
}
.n-contact {
    position: relative;
    width: 100%;
    min-height: 320px;
    height: 100%;
    overflow: hidden;
    z-index: 0;
    padding: 2rem 0 2rem 0;
    margin-top: -20px;
}
.n-contact #map {
    width: 100%;
    height: 100%;
    position: initial !important;
}
.n-contact .n-contact-container {
    display: inline-block;
    position: relative;
    z-index: 1;
    padding-left: 0.75rem;
}
.n-contact .card {
    font-size: 1rem;
    color: var(--color-black-700);
    border: 0;
    border-radius: 0;
}
.n-contact a, .n-contact a:hover {
    color: var(--color-black-700);
    text-decoration: underline;
}
.n-contact h3 {
    font-weight: 600;
    color: var(--color-accent-600);
    background-color: #fff;
    display: inline-block;
    padding: 0.5rem 0.75rem;
}
.n-contact h5 {
    color: var(--color-black-800);
}
.n-contact .n-contact-label {
    font-weight: 700;
    font-size: 0.75rem;
    color: var(--color-accent-600);
    text-transform: uppercase;
    min-width: 60px;
}
.n-contact .n-btn-booking, .n-contact .btn-outline-success {
    font-weight: 600;
    font-size: 1.125rem;
    text-align: center;
}
.n-contact .btn-outline-success {
    color: var(--color-accent-600);
    border: 2px solid var(--color-accent-600);
}
.n-contact .btn-outline-success:hover {
    color: var(--color-accent-600);
    background-color: transparent;
    border: 2px solid var(--color-accent-600);
}
.n-reviews .btn-outline-success {
    font-weight: 600;
    font-size: 1.125rem;
}
.n-reviews-arrows {
    display: flex;
    flex-direction: row;
    align-items: center;
    position: absolute;
    bottom: 8px;
    right: 0;
}
.n-reviews-arrows .swiper-button-next:after, .n-reviews .swiper-button-prev:after {
    font-family: initial;
    font-size: initial;
    content: '';
}
.n-reviews-arrows .swiper-button-prev:after, .n-reviews-arrows .swiper-rtl .swiper-button-next:after {
    content: '';
}
.n-reviews-arrows .swiper-button-next.swiper-button-disabled, .n-reviews-arrows .swiper-button-prev.swiper-button-disabled {
    opacity: 1;
}
.n-reviews-arrows .swiper-button-prev:after {
    background: url('../gfx/icons/general/arrow-circle-left.svg') no-repeat center;
    background-size: contain;
    min-width: 28px;
    min-height: 28px;
    width: 28px;
    height: 28px;
    display: inline-block;
}
.n-reviews-arrows .swiper-button-next:after {
    background: url('../gfx/icons/general/arrow-circle-right.svg') no-repeat center;
    background-size: contain;
    min-width: 28px;
    min-height: 28px;
    width: 28px;
    height: 28px;
    display: inline-block;
}
.n-reviews-arrows .swiper-button-prev {
    position: relative;
    left: -18px;
}
.n-reviews-arrows .swiper-button-next {
    position: relative; 
}
.n-reviews .swiper-reviews {
    z-index: 0;
}
.n-reviews .swiper-reviews .swiper-slide {
    font-size: 1rem;
    color: var(--color-black-700);
    background-color: #fff;
    border: 1px solid var(--color-gray-200);
    border-radius: 0.5rem;
    padding: 2rem;
    transition: box-shadow 0.2s ease;
}
.n-reviews .swiper-reviews .swiper-slide:hover {
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
}
.n-reviews .swiper-reviews .n-reviews-name {
    font-weight: 700;
    font-size: 0.875rem;
    color: var(--color-primary-500);
}
.n-wrapper-sidebar .breadcrumb {
    color: var(--color-gray-400);
    font-size: 0.875rem;
    align-items: center;
    margin: 1.5rem 0 0 0;
}
.n-wrapper-sidebar .breadcrumb .breadcrumb-item {
    margin-bottom: 0;
}
.n-wrapper-sidebar .n-breadcrumb-title {
    color: var(--color-black-800);
    margin: 1rem 0 1.5rem 0;
}
.n-breadcrumb-title {
    margin: 1rem 0 1.5rem 0;
}
.n-wrapper-sidebar .breadcrumb .n-icon-home {
    margin-bottom: -4px;
}
.n-wrapper-sidebar .breadcrumb a, .n-wrapper-sidebar .breadcrumb a:hover {
    color: var(--color-gray-400);
    text-decoration: none;
}
.breadcrumb-item + .breadcrumb-item::before {
    color: var(--color-gray-300);
}
.breadcrumb-item:last-child::after {
    float: right;
    padding-left: var(--bs-breadcrumb-item-padding-x);
    color: var(--color-gray-300);
    content: var(--bs-breadcrumb-divider, "/");
}
.n-wrapper-sidebar .n-contact {
    margin-top: 0;
}
.n-wrapper-sidebar .n-header {
    background-color: var(--color-gray-100);
    overflow: initial;
}
.n-wrapper-sidebar .n-header .alert.alert-warning {
    position: relative;
    top: initial;
    left: initial;
    right: initial;
    margin-top: 8px;
}
.n-wrapper-sidebar .n-page {
    margin: 3rem 0;
}
.n-wrapper-sidebar h2, .n-wrapper-sidebar .mixed__title {
    font-weight: 500;
    font-size: 1.375rem;
    color: var(--color-accent-600);
    background-color: #fff;
    border-radius: 0.188rem;
    display: inline-block;
    padding: 0;
    margin: 0 0 1.5rem 0;
}
.n-wrapper-sidebar .n-page hr {
    border-color: rgba(0, 0, 0, 0.05);
    opacity: 1;
    margin: 0 0 1.5rem 0;
}
.n-wrapper-sidebar .n-page .container {
    padding-left: 0;
    padding-right: 0;
}
.n-wrapper-sidebar .n-page, .n-page .text, .n-page .text p {
    font-size: 1.125rem;
}
.n-wrapper-sidebar .n-page .n-section-title {
    font-weight: 500;
    font-size: 1.375rem;
    padding: 0;
    margin: 0 0 1.5rem 0;
}
.n-wrapper-sidebar .n-page .text p, .n-wrapper-sidebar .n-page .text {
    margin: 0 0 1.5rem 0;
}
.n-wrapper-sidebar .n-page .text p:last-of-type {
    margin-bottom: 0;
}
.n-wrapper-sidebar .n-sidebar .nav .nav-item {
    margin: 0;
}
.n-wrapper-sidebar .n-sidebar .nav .nav-item .nav-link {
    font-size: 1.125rem;
    color: var(--color-gray-500);
    border-left: 1px solid rgba(0, 0, 0, 0.05);
    padding: 0.25rem 0.25rem 0.25rem 1.5rem;
}
.n-wrapper-sidebar .n-sidebar .nav .nav-item .nav-link:hover {
    color: var(--color-gray-500);
}
.n-wrapper-sidebar .n-sidebar .nav .nav-item .nav-link.active {
    font-weight: 700;
    font-size: 1.125rem;
    color: var(--color-black-800);
    border-left: 1px solid var(--color-black-800);
}
.n-n-doctors .card img, .n-n-doctors .card .doctors__image {
    /* filter: grayscale(100%); */
    object-fit: cover;
    object-position: center top;
    border-radius: 0;
    min-height: 246px;
    //height: 246px;
    height: 100%;
    padding: 0;
}
.n-n-doctors .card .card-img-large img, .n-n-doctors .card .card-img-large .doctors__image {
    min-height: 380px;
    /* height: 380px; */
    height: 100%;
}
.n-n-doctors .card .card-img-overlay, .n-n-doctors .card .card-img-overlay {
    background: linear-gradient(180deg, rgba(0, 0, 0, 0) 48.5%, rgba(13, 13, 13, 0.75) 100%);
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    height: 100%;
    padding: 0.75rem;
}
.n-n-doctors .card {
    border: 0;
    overflow: hidden;
    position: relative;
    height: 100%;
}
.n-n-doctors .card .card-title {
    font-weight: 600;
    font-size: 1rem;
    color: var(--color-black-800);
    background-color: #fff;
    border-radius: 0.188rem;
    display: inline-flex;
    padding: 0.5rem 0.75rem;
    margin: 0 0 0.25rem 0;
}
.n-n-doctors .card .card-text {
    font-weight: 400;
    font-size: 1rem;
    color: #fff;
    margin: 0;
}
.n-n-doctors .card .card-heading {
    color: #fff;
    background-color: var(--color-black-800);
    padding: 0.75rem;
}
@media (min-width: 1000px)  {
    .n-n-doctors .card .card-img-large {
        height: 100%;
    }
    .n-n-doctors .card .card-img-large img, .n-n-doctors .card .card-img-large .doctors__image {
        height: 100%;
    }
}
.n-doctor {
    color: var(--color-black-700);
    margin: 3rem 0;
}
.n-doctor p, .n-doctor .text {
    margin: 0 0 1rem 0;
}
.n-doctor .n-doctor-img {
    position: relative;
}
.n-doctor .n-doctor-img img {
    /* filter: grayscale(100%); */
    object-fit: cover;
    object-position: center;
    border-radius: 0.188rem;
    min-height: 380px;
    height: 380px;
    position: relative;
    padding: 0;
}
.n-doctor .n-doctor-img-overlay {
    background: linear-gradient(180deg, rgba(0, 0, 0, 0) 48.5%, rgba(13, 13, 13, 0.75) 100%);
    border-radius: 0.188rem;
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: 100%;
}
.n-publishings {
    margin: 3rem 0;
}
.n-publishings .card img, .n-publishings .card .publishings__image {
    object-fit: cover;
    object-position: center;
    border-radius: 0.188rem;
    max-height: 480px;
    padding: 0;
}
.n-publishings .card {
    background-color: var(--color-gray-100);
    border: 0;
}
.n-publishings .card .card-title {
    font-weight: 600;
    font-size: 1.25rem;
    color: var(--color-black-800);
    background-color: #fff;
    border-radius: 0.188rem;
    display: inline-block;
    padding: 0.5rem 0.75rem;
}
.n-publishings .card .card-img-overlay {
    background: linear-gradient(180deg, rgba(0, 0, 0, 0) 48.5%, rgba(13, 13, 13, 0.75) 100%);
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    align-items: flex-start;
    height: 100%;
    padding: 0.75rem;
}
.n-publishings .card .card-date {
    font-weight: 400;
    font-size: 1rem;
    color: #fff;
    margin: 0 0 0.75rem 0;
}
.n-publishings .card p {
    font-weight: 400;
    font-size: 0.875rem;
    color: #fff;
    margin: 0;
}
.n-publishings .card .card-body {
    padding: 0.75rem;
}
.n-publishings .card .card-body .card-title {
    font-weight: 600;
    font-size: 1.25rem;
    color: #fff;
    background-color: var(--color-black-800);
    border-radius: 0.188rem;
    display: inline-block;
    padding: 0.5rem 0.75rem;
}
.n-publishings .card .card-body .card-date {
    font-weight: 400;
    font-size: 1rem;
    color: var(--color-gray-400);
    margin: 0 0 0.75rem 0;
}
.n-publishings .card .card-body p {
    font-weight: 400;
    font-size: 0.875rem;
    color: var(--color-black-700);
    margin: 0;
}
.n-publishing {
    margin: 3rem 0;
}
.n-publishing .n-publishing-date {
    color: var(--color-gray-400);
    margin: 0 0 1.5rem 0;
}
.n-publishing .n-publishing-title {
    font-weight: 500;
    color: var(--color-accent-600);
    margin: 0 0 1.5rem 0;
}
.n-publishing p {
    font-size: 1.125rem;
    margin: 0 0 1.5rem 0;
}
.n-posts {
    margin: 3rem 0;
}
.n-posts .n-index .n-index-title {
    color: var(--color-black-800);
    display: inline-block;
    margin: 0 0 1rem 0;
}
.n-posts .n-index .n-index-date {
    font-size: 1rem;
    color: var(--color-black-700);
    margin: 0 0 0.5rem 0;
}
.n-posts .n-index .n-index-lead p {
    font-size: 0.875rem;
    color: var(--color-black-700);
    margin: 0 0 1rem 0;
}
.n-post .n-index-title {
    font-weight: 500;
    font-size: 1.375rem;
    color: var(--color-accent-600);
    background-color: #fff;
    border-radius: 0.188rem;
    display: inline-block;
    padding: 0;
    margin: 0 0 1.5rem 0;
}
.n-post .n-index-date {
    font-size: 1rem;
    color: var(--color-gray-400);
    margin: 0 0 1rem 0;
}
.n-post .n-index-lead p {
    font-size: 1.125rem;
    color: var(--color-black-700);
    margin: 0 0 1.5rem 0;
}
.n-post .n-section-title {
    font-weight: 500;
    font-size: 1.375rem;
    color: var(--color-accent-600);
    background-color: #fff;
    border-radius: 0.188rem;
    display: inline-block;
    padding: 0;
    margin: 0 0 1.5rem 0;
}
.n-wrapper-sidebar .n-card-sidebar {
    --bs-card-border-color: var(--color-gray-300);
    border-top: 4px solid var(--color-primary-500);
}
.n-wrapper-sidebar .n-card-sidebar .card-header {
    font-weight: 600;
    font-size: 1.125rem;
    background-color: #fff;
    padding: 0.5rem 1rem;
}
.n-wrapper-sidebar .n-card-sidebar .card-body {
    padding: 0;
}
.n-wrapper-sidebar .n-card-sidebar .n-card-sidebar-content {
    border-bottom: 1px solid var(--color-gray-400);
    padding: 1rem;
    margin: 0 0 -1px 0;
}
.n-wrapper-sidebar .n-card-sidebar > .n-card-sidebar-content:last-child {
    border-bottom: none;
}
.n-wrapper-sidebar .n-card-sidebar .n-card-sidebar-content img {
    object-fit: cover;
    object-position: center;
    border-radius: 0.188rem;
    min-height: 232px;
    height: 232px;
}
.n-wrapper-sidebar .n-card-sidebar .n-card-sidebar-content .card-img-overlay {
    background: linear-gradient(180deg, rgba(0, 0, 0, 0) 48.5%, rgba(13, 13, 13, 0.75) 100%);
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    align-items: flex-start;
    height: 100%;
}
.n-wrapper-sidebar .n-card-sidebar .n-card-sidebar-content .card-img-overlay .card-title {
    color: #fff;
    background-color: var(--color-black-800);
    border-radius: 0.188rem;
    display: inline-block;
    padding: 0.5rem 0.75rem;
    margin: 0;
}
.n-wrapper-sidebar .n-card-sidebar .nav .nav-item {
    border-top: 1px solid var(--color-gray-400);
    margin: 0;
}
.n-wrapper-sidebar .n-card-sidebar .nav .nav-item:first-child {
    border-top: 0;
}
.n-wrapper-sidebar .n-card-sidebar .nav .nav-item .nav-link {
    font-weight: 600;
    color: var(--color-gray-500);
    background-color: #fff;
    border: 0;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    padding: 0.75rem 1rem;
}
.n-wrapper-sidebar .n-card-sidebar-secondary .nav .nav-item .nav-link:hover, .n-wrapper-sidebar .n-card-sidebar-secondary .nav .nav-item .nav-link.active {
    color: var(--color-primary-500);
    background-color: var(--color-gray-100);
    border: 0;
    outline: 0;
}
.n-wrapper-sidebar .n-card-sidebar .nav .nav-item .nav-link:hover::after, .n-wrapper-sidebar .n-card-sidebar .nav .nav-item .nav-link.active::after {
    background-color: var(--color-primary-500);
    border-radius: 50rem;
    content: '';
    min-width: 13px;
    min-height: 13px;
    width: 13px;
    height: 13px;
    display: inline-block;
    margin: 0 0 0 1rem;
}
.n-medical-appointment {
    border-top: 1px solid rgba(0, 0, 0, 0.05);
}
.n-medical-appointment h3 {
    color: var(--color-accent-600);
    margin: 0.5rem 0 1rem 0;
}
.n-medical-appointment a, .n-medical-appointment a:hover {
    font-weight: 700;
    color: var(--color-black-800);
    text-decoration: none;
}
.n-medical-appointment .list-group {
    border-radius: 0;
}
.n-medical-appointment .list-group .list-group-item {
    border-left: 0;
    border-right: 0;
    border-color: rgba(0, 0, 0, 0.05);
    padding: 0.5rem 0;
}
.n-medical-appointment .list-group .list-group-item:first-child {
    border-top: 0;
}
.n-medical-appointment .list-group .list-group-item:last-child {
    border-bottom: 0;
}
.n-listbox-check {
    font-size: 1.125rem;
    color: var(--color-black-700);
    text-align: center;
    background-color: var(--color-gray-100);
    border-radius: 0.188rem;
    border-left: 3px solid var(--color-accent-600);
    padding: 1rem;
}
.n-listbox-check h6 {
    font-weight: 700;
    font-size: 1.125rem;
    color: var(--color-black-800);
    margin: 0;
}
.n-listbox-check .col-12.col-lg-3.col-xl-3 {
    font-weight: 700;
    color: var(--color-black-800);
}
.n-box-button {
    background-color: var(--color-gray-100);
    border-radius: 0.188rem;
    padding: 1rem;
}
.n-box-button h5 {
    font-weight: 700;
    color: var(--color-black-800);
    margin: 0;
}
.n-box-button .btn {
    font-weight: 600;
    font-size: 1.125rem;
    color: #fff;
    background-color: var(--color-black-800);
    border-radius: 0.188rem;
    padding: 0.25rem 0.5rem;
}
.n-consultation-fees h5 {
    font-weight: 500;
    color: var(--color-accent-600);
    margin: 0 0 2rem 0;
}
.n-consultation-fees .n-consultation-fees-profile-img {
    border-radius: 50rem;
    object-fit: cover;
    object-position: center;
    min-width: 57px;
    min-height: 57px;
    width: 57px;
    height: 57px;
}
.n-consultation-fees .n-consultation-fees-name {
    font-weight: 700;
    font-size: 1rem;
    color: var(--color-black-800);
}
.n-consultation-fees .n-consultation-fees-title {
    font-size: 1rem;
    color: var(--color-gray-500);
}
.n-consultation-fees h6, .n-consultation-fees .n-consultation-fees-price {
    font-weight: 700;
    font-size: 1rem;
}
.n-consultation-fees .small {
    font-size: 0.875rem;
    margin: 0;
}
.n-consultation-fees .n-consultation-fees-time {
    font-weight: 700;
    font-size: 0.875rem;
    color: var(--color-accent-600);
}
.n-laboratory-fees .n-laboratory-fees-content {
    border-bottom: 1px solid rgba(0, 0, 0, 0.05);
    padding: 1rem 0 1rem 0;
}
.n-laboratory-fees h6 {
    font-weight: 700;
    font-size: 1rem;
    color: var(--color-black-800);
    line-height: 1;
    margin: 0;
}
.n-laboratory-fees p {
    font-size: 1rem;
    color: var(--color-black-800);
}
.n-laboratory-fees h6, .n-laboratory-fees .n-laboratory-fees-price {
    font-weight: 700;
    font-size: 1rem;
}
.n-laboratory-fees .n-laboratory-fees-time {
    font-weight: 700;
    font-size: 0.875rem;
    color: var(--color-accent-600);
}
.n-search {
    margin: 3rem 0;
}
.n-search .n-index-date {
    font-size: 1rem;
    color: var(--color-black-700);
}
.n-search .n-index-title {
    font-weight: 600;
    font-size: 1.25rem;
    color: var(--color-black-800);
    display: inline-block;
    margin: 0.5rem 0 1rem 0;
}
.n-search .n-index-lead, .n-search .n-index-lead p {
    font-weight: 500;
    font-size: 0.875rem;
    color: var(--color-black-700);
    margin: 0 0 1rem 0;
}
.n-search .n-index-lead p:last-of-type {
    margin-bottom: 0;
}
.n-search .col.mt-4.mt-lg-5 {
    margin-top: 1rem !important;
}
.accordion-button:not(.collapsed), .accordion-button:focus {
    box-shadow: none;
}
.n-accordion .accordion .accordion-item {
    border: 0;
    border-bottom: 1px solid rgba(0, 0, 0, 0.05);
    border-radius: 0;
}
.n-accordion .accordion .accordion-item .accordion-button {
    font-weight: 700;
    font-size: 1.25rem;
    color: var(--color-accent-600);
    border-radius: 0;
    border-bottom: 1px solid rgba(0, 0, 0, 0.05);
    padding: 1rem 0;
}
.n-accordion .accordion .accordion-item .accordion-body {
    color: var(--color-black-700);
    padding: 1rem 0;
}
.n-accordion .accordion .accordion-item .accordion-button:not(.collapsed) {
    background-color: transparent;
}
.n-accordion .accordion .accordion-item .accordion-button::after {
    width: 24px;
    height: 24px;
    background-image: url('../gfx/icons/general/plus.svg');
    background-size: contain;
}
.n-accordion .accordion .accordion-item .accordion-button:not(.collapsed)::after {
    width: 20px;
    height: 20px;
    background-image: url('../gfx/icons/general/close-2.svg');
    background-size: contain;
}
.n-footer-logo {
    display: inline-block;
}
.n-footer-logo img {
    height: 38px;
    width: auto;
    object-fit: contain;
}
.n-footer {
    color: #fff;
    background-color: var(--color-black-900);
    padding: 2rem 0 0 0;
}
.n-footer h6 {
    font-size: 1.125rem;
}
.n-footer p {
    font-size: 1rem;
}
.n-footer .n-footer-menu .n-footer-menu-title {
    font-weight: 700;
    font-size: 0.813rem;
    position: relative;
    margin: 0 0 1rem 0;
}
.n-footer .n-footer-menu .n-footer-menu-title::after {
    background-color: var(--color-primary-500);
    content: '';
    position: absolute;
    bottom: -8px;
    left: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 1px;
}
.n-footer .n-footer-menu .nav .nav-item:first-child {
    margin-top: 0;
}
.n-footer .n-footer-menu .nav .nav-item {
    margin: 0.25rem 0 0 0;
}
.n-footer .n-footer-menu .nav .nav-item .nav-link {
    font-size: 0.813rem;
    color: var(--color-gray-400);
    padding: 0;
    transition: color 0.2s ease;
}
.n-footer .n-footer-menu .nav .nav-item .nav-link:hover {
    color: var(--color-primary-500);
}
.n-footer .n-footer-bottom-menu .nav .nav-item:first-child {
    margin-top: 0;
}
.n-footer .n-footer-bottom-menu .nav .nav-item {
    margin: 0;
}
.n-footer .n-footer-bottom-menu .nav .nav-item .nav-link {
    font-weight: 600;
    font-size: 0.813rem;
    color: rgba(255,255,255,0.85);
    padding: 0;
    transition: color 0.2s ease;
}
.n-footer .n-footer-bottom-menu .nav .nav-item .nav-link:hover {
    color: var(--color-primary-500);
}
.n-footer .n-copyright {
    font-weight: 400;
    font-size: 0.75rem;
    color: rgba(255,255,255,0.7);
    background-color: var(--color-black-800);
    margin: 2rem 0 0 0;
}
.n-footer .n-copyright .n-copyright-left {
    font-weight: 600;
}
.n-footer .n-copyright a, .n-footer .n-copyright a:hover {
    font-weight: 700;
    color: #fff;
    text-decoration: underline;
}
.n-footer .n-copyright .n-copyright-right {
    font-weight: 400;
    position: absolute;
    right: 1rem;
    top: 50%;
    transform: translateY(-50%);
}
.n-footer .n-scroll-up-hr {
    background-color: rgba(255, 255, 255, 0.33);
    display: inline-block;
    width: 50%;
    height: 1px;
    position: relative;
    bottom: 2px;
}
.reset__title, .resend__title, .register__title, .login__title, .forgot__title, .activate__title {
    display: none;
}

/* ── Frontpage Responsive ── */
@media (max-width: 991.98px) {
    .frontpage .n-title-section {
        padding: 3.5rem 0 1.25rem;
    }
    .frontpage .n-section-title {
        font-size: 1.875rem;
    }
    .frontpage .n-section-subtitle {
        font-size: 1rem;
    }
    .frontpage .n-services {
        padding-bottom: 3.5rem;
    }
    .frontpage .n-services .n-services-item {
        min-height: 220px;
    }
    .frontpage .n-mixed {
        padding-bottom: 3.5rem;
    }
    .frontpage .n-mixed .mixed__title {
        font-size: 1.5rem;
    }
    .frontpage .n-about {
        padding-bottom: 3.5rem;
    }
    .frontpage .n-about .n-about-item {
        min-height: 220px;
    }
    .frontpage .n-accordion {
        padding-bottom: 3.5rem;
        padding-left: 1.25rem;
    }
    .frontpage .n-reviews-section {
        padding-top: 3.5rem;
    }
    .frontpage .n-reviews-section .n-section-title {
        font-size: 1.875rem;
    }
    .frontpage .n-reviews-section .n-reviews {
        padding-bottom: 3rem;
    }
}
@media (max-width: 575.98px) {
    .frontpage .n-title-section {
        padding: 3rem 0 1rem;
    }
    .frontpage .n-section-title {
        font-size: 1.625rem;
        letter-spacing: -0.02em;
    }
    .frontpage .n-section-subtitle {
        font-size: 0.9375rem;
    }
    .frontpage .n-services .n-services-item {
        min-height: 180px;
        padding: 1.5rem 1.25rem;
        border-radius: 0.625rem;
    }
    .frontpage .n-services .n-services-item h6 {
        font-size: 1.125rem;
    }
    .frontpage .n-mixed .mixed__title {
        font-size: 1.375rem;
        padding-left: 1.25rem;
    }
    .frontpage .n-mixed .mixed__body {
        font-size: 1rem;
        line-height: 1.75;
    }
    .frontpage .n-about .n-about-item {
        min-height: 180px;
        padding: 2rem 1.5rem 1.5rem;
        border-radius: 0.75rem;
    }
    .frontpage .n-about .n-about-item::before {
        font-size: 4rem;
    }
    .frontpage .n-accordion .accordion .accordion-item .accordion-button {
        font-size: 0.9375rem;
        padding: 1.125rem 1.25rem;
    }
    .frontpage .n-accordion .accordion .accordion-item .accordion-body {
        padding: 0 1.25rem 1.25rem;
    }
    .frontpage .n-reviews-section .n-section-title {
        font-size: 1.625rem;
    }
    .frontpage .n-reviews-section .n-reviews .swiper-reviews .swiper-slide {
        padding: 1.75rem 1.5rem;
        border-radius: 0.75rem;
    }
    .frontpage .n-partners-section-title {
        padding-top: 3rem;
    }
}

@media (min-width: 0px) and (max-width: 767.98px) {
    .n-n-doctors .card img, .n-n-doctors .card .doctors__image {
        min-height: 400px;
        height: 400px;
    }
    .container {
        max-width: 100%;
    }
    .n-fixed-top {
        position: fixed !important;
        top: 0;
        left: 0;
        right: 0;
        z-index: 9999 !important;
    }
    .n-header-logo img {
        height: 45px;
    }
    .n-navigation {
        border-radius: 0;
    }
    .n-navigation .n-navigation-bottom .btn, .n-navigation .n-navigation-bottom .btn span {
        font-size: 0.75rem;
    }
    .n-navigation .n-navigation-bottom .n-mega-menu-dropdown .n-btn-search {
        font-size: 0.75rem;
    }
    .n-header {
        min-height: initial;
    }
    .n-header video {
        object-position: top;
        max-height: initial;
    }
    .n-header .alert.alert-warning p {
        font-size: 0.75rem;
    }
    .n-header-bottom {
        min-height: initial;
        height: initial;
        padding: 7rem 0.5rem 2rem 0.5rem;
    }
    .n-logos .n-logos-wrapper {
        flex-wrap: wrap;
    }
    .n-logos .n-logos-item {
        flex: 1 1 calc(33.33% - 1.5rem);
    }
    .n-frontpage-content {
        margin: 0;
    }
    .n-partners .n-partners-wrapper {
        flex-wrap: wrap;
    }
    .n-partners .n-partners-item {
        flex: 1 1 calc(33.33% - 1.5rem);
    }
    .n-contact .n-contact-container {
        width: 100%;
        padding-left: 1rem;
        padding-right: 1rem;
    }
    .n-contact .btn {
        font-size: 0.75rem;
        width: 50%;
    }
    .n-publishings .card img, .n-publishings .card .publishings__image {
        max-height: 100%;
    }
    .n-publishings .card .card-title, .n-publishings .card .card-body .card-title {
        font-size: 1rem;
    }
    .n-publishings .card p, .n-publishings .card .card-date, .n-publishings .card .card-body .card-date {
        margin: 0;
    }
    .n-footer .n-copyright .n-copyright-right {
        text-align: center;
        position: relative;
        right: initial;
        top: initial;
        transform: initial;
        margin: 0.5rem 0 0 0;
    }
}
@media (min-width: 768px) and (max-width: 991.98px) {
    .container {
        max-width: 100%;
    }
    .n-fixed-top {
        position: fixed !important;
        top: 0;
        left: 0;
        right: 0;
        z-index: 9999 !important;
    }
    .n-header-bottom {
        min-height: initial;
        height: initial;
    }
    .n-navigation {
        border-radius: 0;
    }
    .n-navigation .n-navigation-bottom {
        padding: 1rem 1rem 2px 1rem;
    }
    .n-logos .n-logos-wrapper {
        flex-wrap: wrap;
    }
    .n-logos .n-logos-item {
        flex: 1 1 calc(20% - 1.5rem);
    }
    .n-frontpage-content {
        margin: 0;
    }
    .n-partners .n-partners-wrapper {
        flex-wrap: wrap;
    }
    .n-partners .n-partners-item {
        flex: 1 1 calc(20% - 1.5rem);
    }
    .n-publishings .card img, .n-publishings .card .publishings__image {
        max-height: 320px;
    }
    .n-publishings .card .card-title, .n-publishings .card .card-body .card-title {
        font-size: 1rem;
    }
    .n-publishings .card p, .n-publishings .card .card-date, .n-publishings .card .card-body .card-date {
        margin: 0;
    }
    .n-footer .n-copyright .n-copyright-right {
        text-align: center;
        position: relative;
        right: initial;
        top: initial;
        transform: initial;
        margin: 0.5rem 0 0 0;
    }
}
@media (min-width: 992px) and (max-width: 1199.98px) {
    .container {
        max-width: 100%;
    }
    .n-navigation {
        border-radius: 0;
    }
    .n-navigation .n-navigation-top, .n-navigation .n-navigation-top a, .n-navigation .n-navigation-top .btn.btn-link {
        font-size: 0.75rem;
    }
    .n-navigation .n-navigation-top span.n-icon-poi, .n-navigation .n-navigation-top span.n-icon-phone, .n-navigation .n-navigation-top span.n-icon-mail, .n-navigation .n-navigation-top span.n-icon-user, .n-navigation .n-navigation-top span.n-icon-lang {
        min-width: 14px;
        min-height: 14px;
        width: 14px;
        height: 14px;
    }
    .n-navigation .n-navigation-bottom {
        padding: 1rem 1rem 2px 1rem;
    }
    .n-header {
        min-height: initial;
    }
    .n-header .alert.alert-warning {
        left: 16px;
        right: 16px;
    }
    .n-header-bottom {
        padding: 3rem 0.5rem 4rem 0.5rem;
    }
    .n-logos .n-logos-wrapper {
        flex-wrap: wrap;
    }
    .n-logos .n-logos-item {
        flex: 1 1 calc(10% - 1.5rem);
    }
    .n-frontpage-content {
        margin: 230px 0 0 0;
    }
    .n-header-bottom .n-header-bottom-panels {
        width: 100%;
    }
    .n-partners .n-partners-wrapper {
        flex-wrap: wrap;
    }
    .n-partners .n-partners-item {
        flex: 1 1 calc(18% - 1.5rem);
    }
}
@media (min-width: 1200px) and (max-width: 1399.98px) {
    .n-header-bottom .n-header-bottom-panels {
        top: 124%;
    }
    .n-frontpage-content {
        position: relative;
        margin: 260px 0 0 0;
    }
}
@media (min-width: 992px) {
    .n-navigation.n-fixed-top {
        top: 6px;
    }
}
@media (min-width: 1200px) {
    .n-navigation {
        max-width: 1116px;
    }
}
@media (min-width: 1400px) {
    .container {
        max-width: 1220px;
    }
    .n-navigation {
        max-width: 1196px;
    }
}

/* ══════════════════════════════════════════════════════════════
   BOOKING PAGES — Redesigned header & cards
   ══════════════════════════════════════════════════════════════ */

/* ── Booking wrapper — override old reservation layout ── */
.wrapper--booking-redesign {
    background: var(--color-bg);
}
.wrapper--booking-redesign .n-header--booking {
    position: relative;
    overflow: hidden;
    background: var(--color-bg);
}

/* ── Compact hero for booking pages ── */
.n-hero--booking {
    height: auto;
    min-height: auto;
    padding: 9rem 1.5rem 3.5rem;
}
.n-hero--booking .n-hero__subtitle {
    margin-bottom: 2rem;
}

/* ── Spacer when no hero content ── */
.n-hero--spacer {
    padding-top: 6rem;
}

/* ── Booking choice cards section ── */
.n-booking-choices {
    position: relative;
    z-index: 1;
    max-width: 820px;
    margin: 0 auto;
    padding: 0 1.5rem 5rem;
}
.n-booking-choices__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
}
@media (min-width: 640px) {
    .n-booking-choices__grid {
        grid-template-columns: 1fr 1fr;
        gap: 1.25rem;
    }
    /* When only one card, make it full-width and centered */
    .n-booking-choices__grid .n-booking-card:only-child {
        grid-column: 1 / -1;
        max-width: 480px;
        margin: 0 auto;
    }
}

/* ── Individual booking card ── */
.n-booking-card {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
    padding: 2rem 1.75rem;
    background: var(--color-surface);
    border: 1px solid var(--color-gray-200);
    border-radius: 1rem;
    text-decoration: none;
    color: inherit;
    transition: all 0.35s cubic-bezier(0.16, 1, 0.3, 1);
    position: relative;
    overflow: hidden;
}
.n-booking-card::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(var(--color-accent-600-rgb), 0.03) 0%, transparent 60%);
    opacity: 0;
    transition: opacity 0.35s ease;
}
.n-booking-card:hover {
    border-color: rgba(var(--color-accent-600-rgb), 0.25);
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.06), 0 1px 4px rgba(0, 0, 0, 0.04);
    transform: translateY(-2px);
    color: inherit;
    text-decoration: none;
}
.n-booking-card:hover::before {
    opacity: 1;
}

/* Card icon */
.n-booking-card__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    border-radius: 0.875rem;
    background: rgba(var(--color-accent-600-rgb), 0.08);
    color: var(--color-accent-600);
    flex-shrink: 0;
    position: relative;
    z-index: 1;
}

/* Card content */
.n-booking-card__content {
    flex: 1;
    position: relative;
    z-index: 1;
}
.n-booking-card__title {
    font-family: Switzer, "Open Sans", Helvetica, Arial, sans-serif;
    font-size: 1.125rem;
    font-weight: 650;
    line-height: 1.3;
    color: var(--color-black-800);
    margin: 0 0 0.5rem;
    letter-spacing: -0.01em;
}
.n-booking-card__desc {
    font-size: 0.875rem;
    font-weight: 400;
    line-height: 1.6;
    color: var(--color-gray-500);
    margin: 0;
}

/* Card arrow */
.n-booking-card__arrow {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--color-gray-100);
    color: var(--color-gray-400);
    flex-shrink: 0;
    transition: all 0.3s ease;
    position: relative;
    z-index: 1;
    align-self: flex-end;
}
.n-booking-card:hover .n-booking-card__arrow {
    background: var(--color-accent-600);
    color: #fff;
    transform: translateX(2px);
}

/* ── Responsive — Tablet ── */
@media (max-width: 1199.98px) {
    .n-hero--booking {
        padding: 8rem 2rem 3rem;
    }
}

/* ── Responsive — Mobile ── */
@media (max-width: 767.98px) {
    .n-hero--booking {
        padding: 6.5rem 1.25rem 2.5rem;
    }
    .n-hero--booking .n-hero__title {
        font-size: 1.75rem;
    }
    .n-hero--spacer {
        padding-top: 5rem;
    }
    .n-booking-choices {
        padding: 0 1rem 3.5rem;
    }
    .n-booking-card {
        padding: 1.5rem 1.25rem;
    }
    .n-booking-card__icon {
        width: 48px;
        height: 48px;
        border-radius: 0.75rem;
    }
    .n-booking-card__icon svg {
        width: 26px;
        height: 26px;
    }
    .n-booking-card__title {
        font-size: 1rem;
    }
}

/* ── Override old reservation header in booking-redesign wrapper ── */
.wrapper--booking-redesign .res-header {
    background-image: none !important;
    background-color: var(--color-surface);
    padding-top: 1rem;
}
.wrapper--booking-redesign .res-header__title--create {
    color: var(--color-black-800);
    margin-top: 2rem;
}
.wrapper--booking-redesign .res-header__lead {
    color: var(--color-gray-500);
}