/*
Template Name: Paaras - Doctor Appointment Booking Mobile Template
Author: Askbootstrap
Author URI: https://themeforest.net/user/askbootstrap
Version: 0.1
*/

/*
- Body
- Scroll Bar
- Custom
- Index
- Landing Page
- Country
- Welcome
- Footer Nav
- Home
- Favorte Doctor
- Select Area
- Doctor Profile
- Book Appointment
- Request Appointment
- notification
- Video
- Doctor Profile Two
- Visit Info / Chekout
- Message
- Call
- Call Doctor
- History
- Profile
- My Appointment
- Play Recording
*/

@import url('https://fonts.googleapis.com/css2?family=Karla:wght@200;300;400;500;600;700;800&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Sofia+Sans+Extra+Condensed:wght@200;300;400;500;600;700;800&display=swap');

:root {
    --dark: #1b1e42;
    --primary: #014CC4;
    --light-primary: #01BDF3;
    --lighter-primary: #598fff;
    --lighter-primary-opacity: #e9f2ff;
    --secondary: #595f73;
    --light: #f5f5f5;
    --success: #3dae14;
    --light-success: #93cf88;
    --warning: #fdbe00;
    --light-warning: #fbf2d9;
    --orange: #FF8811;
    --light-orange: #f8efea;
}

/* Body */
body {
    font-family: 'Karla', sans-serif;
    color: var(--dark);
    font-size: 13px;
    overflow-y: auto;
}

/* Scroll Bar */
::-webkit-scrollbar-button {
    width: 0;
    height: 0;
    display: none;
}

::-webkit-scrollbar-corner {
    background-color: transparent;
}

::-webkit-scrollbar-thumb {
    height: 6px;
    border: 4px solid transparent;
    background-clip: padding-box;
    -webkit-border-radius: 7px;
    border-radius: 7px;
    background-color: rgba(0, 0, 0, .15);
    -webkit-box-shadow: inset -1px -1px 0 rgba(0, 0, 0, .05), inset 1px 1px 0 rgba(0, 0, 0, .05);
    box-shadow: inset -1px -1px 0 rgba(0, 0, 0, .05), inset 1px 1px 0 rgba(0, 0, 0, .05);
}

::-webkit-scrollbar {
    width: 4px;
    background-color: #ffffff;
}

::-webkit-scrollbar-thumb {
    height: 50px;
    background: hsla(0, 0%, 53.3%, 0.4);
}

.landing-slider.slick-initialized,
.top-doctors.slick-initialized,
.available-doctor.slick-initialized,
.recent-doctors.slick-initialized {
    visibility: visible;
    opacity: 1;
}

.landing-slider,
.top-doctors,
.available-doctor,
.recent-doctors {
    opacity: 1;
    /* visibility: hidden; */
    transition: opacity 1s ease;
    -webkit-transition: opacity 1s ease;
}

/* Custom */
.osahan-card-body {
    padding: 12px !important;
}

.osahan-card-footer {
    padding-left: 12px;
    padding-right: 12px;
}

.osahan-user-profile img {
    height: 50px;
}

.nav-wrapper.nav-wrapper-0 .nav-content h2 {
    display: none;
}

li.nav-parent.level-open h2 {
    display: block !important;
}

.border-bottom {
    border-color: #eee !important;
}

.text-dark {
    color: var(--dark) !important;
}

.text-primary {
    color: var(--primary) !important;
}

.text-warning {
    color: var(--warning) !important;
}

.text-success {
    color: var(--success) !important;
}

.text-orange {
    color: var(--orange);
}

.text-info {
    color: var(--light-primary);
}

.bg-light {
    background-color: var(--light) !important;
}

.bg-primary {
    background-color: var(--primary) !important;
}

.light-bg-primary {
    background-color: var(--light-primary);
}

.lighter-bg-primary {
    background-color: var(--lighter-primary);
}

.lighter-bg-primary-opacity {
    background-color: var(--lighter-primary-opacity);
}

.light-bg-warning {
    background-color: var(--light-warning);
}

.light-bg-success {
    background-color: var(--light-success);
}

.light-bg-orange {
    background-color: var(--light-orange);
}

.btn-primary,
.btn-outline-primary:hover,
.btn-outline-primary:focus {
    background: #0147ff !important;
    border-color: #0147ff !important;
}

.btn-outline-primary {
    background-color: #ffffff !important;
    border-color: #0147ff !important;
    color: #0147ff !important;
}

.btn-outline-primary:hover,
.btn-outline-primary:focus {
    color: #ffffff !important;
}

.btn-secondary,
.btn-outline-secondary:hover,
.btn-outline-secondary:focus {
    background: var(--orange) !important;
    border-color: var(--orange) !important;
}

.btn-outline-secondary {
    background-color: #ffffff !important;
    border-color: var(--orange) !important;
    color: var(--orange) !important;
}

.btn-outline-secondary:hover,
.btn-outline-secondary:focus {
    color: #ffffff !important;
}

.btn-info,
.btn-outline-info:hover,
.btn-outline-info:focus {
    background: var(--light-primary) !important;
    border-color: var(--light-primary) !important;
    color: #ffffff !important;
}

.btn-outline-info {
    background-color: #ffffff !important;
    border-color: var(--light-primary) !important;
    color: var(--light-primary) !important;
}

.btn-outline-info:hover,
.btn-outline-info:focus {
    color: #ffffff !important;
}

.bg-info {
    background: var(--light-primary) !important;
}

.btn-white {
    background-color: #ffffff !important;
}

.text-muted {
    color: var(--secondary) !important;
}

.doctor-panel-shell {
    max-width: 1200px;
    margin: 0 auto;
    padding: 16px;
    background: #ffffff;
}

.doctor-sidebar-nav {
    min-height: 100%;
    padding: 16px 14px 24px !important;
    background:
        radial-gradient(circle at top, rgba(1, 76, 196, 0.08) 0%, rgba(1, 76, 196, 0) 34%),
        linear-gradient(180deg, #f7fbff 0%, #ffffff 42%, #ffffff 100%);
}

.doctor-sidebar-card-item {
    margin-bottom: 18px;
}

.doctor-sidebar-card {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 18px 16px;
    border-radius: 24px;
    background: linear-gradient(135deg, #014cc4 0%, #01bdf3 100%);
    color: #ffffff;
    box-shadow: 0 18px 34px rgba(1, 76, 196, 0.2);
}

.doctor-sidebar-avatar-ring {
    width: 58px;
    height: 58px;
    padding: 4px;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.18);
    flex-shrink: 0;
}

.doctor-sidebar-avatar {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 14px;
    display: block;
    background: rgba(255, 255, 255, 0.22);
}

.doctor-sidebar-profile-copy {
    min-width: 0;
}

.doctor-sidebar-kicker {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.72);
}

.doctor-sidebar-name {
    font-size: 16px;
    font-weight: 700;
    color: #ffffff;
}

.doctor-sidebar-contact {
    font-size: 12px;
    color: rgba(255, 255, 255, 0.78);
    word-break: break-word;
}

.doctor-sidebar-label-item {
    margin: 18px 0 10px;
}

.doctor-sidebar-label {
    padding: 0 8px;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #7a8699;
}

.hc-offcanvas-nav .doctor-sidebar-nav li:not(.custom-content) a.doctor-sidebar-link {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 8px;
    padding: 12px 14px;
    border: none;
    border-radius: 18px;
    background: transparent;
    color: #24324b;
    font-size: 14px;
    font-weight: 600;
    transition:
        background 0.2s ease,
        color 0.2s ease,
        transform 0.2s ease,
        box-shadow 0.2s ease;
}

.hc-offcanvas-nav:not(.touch-device) .doctor-sidebar-nav li:not(.custom-content) a.doctor-sidebar-link:hover,
.hc-offcanvas-nav .doctor-sidebar-nav li:not(.custom-content) a.doctor-sidebar-link:focus {
    background: rgba(1, 76, 196, 0.08);
    color: #014cc4;
    transform: translateX(2px);
}

.doctor-sidebar-icon {
    width: 38px;
    height: 38px;
    border-radius: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #edf5ff;
    color: #014cc4;
    font-size: 18px;
    flex-shrink: 0;
    transition:
        background 0.2s ease,
        color 0.2s ease;
}

.doctor-sidebar-text {
    line-height: 1.2;
}

.hc-offcanvas-nav .doctor-sidebar-nav li:not(.custom-content) a.doctor-sidebar-link.is-active {
    background: linear-gradient(135deg, #014cc4 0%, #01bdf3 100%);
    color: #ffffff;
    box-shadow: 0 16px 28px rgba(1, 76, 196, 0.16);
}

.hc-offcanvas-nav .doctor-sidebar-nav li:not(.custom-content) a.doctor-sidebar-link.is-active .doctor-sidebar-icon {
    background: rgba(255, 255, 255, 0.16);
    color: #ffffff;
}

.hc-offcanvas-nav .doctor-sidebar-nav li:not(.custom-content) a.doctor-sidebar-link.is-danger {
    color: #c43855;
}

.hc-offcanvas-nav .doctor-sidebar-nav li:not(.custom-content) a.doctor-sidebar-link.is-danger .doctor-sidebar-icon {
    background: #fff1f4;
    color: #c43855;
}

.hc-offcanvas-nav:not(.touch-device) .doctor-sidebar-nav li:not(.custom-content) a.doctor-sidebar-link.is-danger:hover,
.hc-offcanvas-nav .doctor-sidebar-nav li:not(.custom-content) a.doctor-sidebar-link.is-danger:focus {
    background: #fff1f4;
    color: #c43855;
}

.doctor-panel-topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 16px;
    padding: 14px 16px;
    border-radius: 24px;
    background: rgba(255, 255, 255, 0.88);
    border: 1px solid rgba(1, 76, 196, 0.08);
    box-shadow: 0 10px 30px rgba(27, 30, 66, 0.06);
    backdrop-filter: blur(12px);
}

.doctor-panel-title {
    flex: 1;
    min-width: 0;
}

.doctor-panel-topbar-actions {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.doctor-panel-menu-trigger {
    width: 52px;
    height: 52px;
    border-radius: 18px;
    background: linear-gradient(135deg, var(--primary) 0%, var(--light-primary) 100%);
    color: #ffffff !important;
    text-decoration: none;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.doctor-panel-menu-trigger:hover,
.doctor-panel-menu-trigger:focus {
    color: #ffffff !important;
    transform: translateY(-1px);
    box-shadow: 0 14px 26px rgba(1, 76, 196, 0.18);
}

.doctor-panel-kicker {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--primary);
}

.doctor-panel-hero,
.doctor-panel-section-card,
.doctor-panel-stat-card {
    background: #ffffff;
    border: 1px solid rgba(1, 76, 196, 0.08);
    box-shadow: 0 16px 40px rgba(27, 30, 66, 0.06);
}

.doctor-panel-hero {
    border-radius: 24px;
    padding: 20px;
    margin-bottom: 16px;
    background: #ffffff;
}

.doctor-panel-hero-main,
.doctor-panel-highlight-card {
    border-radius: 22px;
    padding: 18px;
    height: 100%;
    border: 1px solid rgba(1, 76, 196, 0.08);
    background: rgba(255, 255, 255, 0.82);
}

.doctor-panel-hero-copy {
    flex: 1;
    min-width: 180px;
}

.doctor-panel-hero-meta {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.doctor-panel-meta-chip {
    padding: 14px;
    border-radius: 18px;
    background: linear-gradient(180deg, #ffffff 0%, #f5f9ff 100%);
    border: 1px solid rgba(1, 76, 196, 0.08);
}

.doctor-panel-meta-chip span {
    display: block;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--secondary);
    margin-bottom: 5px;
}

.doctor-panel-meta-chip strong {
    display: block;
    color: #17233d;
    font-size: 14px;
    line-height: 1.35;
}

.doctor-panel-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 6px 12px;
    border-radius: 999px;
    background: rgba(1, 76, 196, 0.1);
    color: var(--primary);
    font-size: 12px;
    font-weight: 700;
}

.doctor-panel-inline-meta {
    color: var(--secondary);
    font-size: 12px;
}

.doctor-panel-section {
    scroll-margin-top: 90px;
    margin-bottom: 16px;
}

.doctor-panel-section-card {
    border-radius: 24px;
    padding: 20px;
    height: 100%;
}

.doctor-panel-section-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 16px;
}

.doctor-panel-soft-box {
    border-radius: 18px;
    padding: 14px;
    background: #f7fbff;
    border: 1px dashed rgba(1, 76, 196, 0.15);
}

.doctor-panel-highlight-card {
    background:
        radial-gradient(circle at top left, rgba(1, 189, 243, 0.1), transparent 30%),
        linear-gradient(180deg, #ffffff 0%, #f6fbff 100%);
}

.doctor-panel-progress-value {
    font-size: 38px;
    line-height: 1;
    font-weight: 800;
    color: var(--primary);
}

.doctor-panel-progress {
    width: 100%;
    height: 10px;
    border-radius: 999px;
    background: rgba(1, 76, 196, 0.08);
    overflow: hidden;
}

.doctor-panel-progress span {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, var(--primary) 0%, var(--light-primary) 100%);
}

.doctor-panel-checklist {
    display: grid;
    gap: 10px;
}

.doctor-panel-checklist-item {
    display: flex;
    align-items: center;
    gap: 10px;
    color: var(--secondary);
    font-size: 13px;
    font-weight: 600;
}

.doctor-panel-checklist-item i {
    font-size: 15px;
    color: #a6b3c5;
}

.doctor-panel-checklist-item.is-ready {
    color: #16325c;
}

.doctor-panel-checklist-item.is-ready i {
    color: var(--success);
}

.doctor-panel-quick-card {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(245, 251, 255, 0.96) 100%);
}

.doctor-panel-mini-stat {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    padding: 12px 0;
    border-bottom: 1px solid rgba(1, 76, 196, 0.08);
    font-size: 13px;
}

.doctor-panel-mini-stat:last-child {
    border-bottom: 0;
}

.doctor-panel-mini-stat span {
    color: var(--secondary);
}

.doctor-panel-mini-stat strong {
    color: #17233d;
    text-align: right;
}

.doctor-panel-stat-card {
    border-radius: 20px;
    padding: 16px;
    height: 100%;
    position: relative;
    overflow: hidden;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    background:
        radial-gradient(circle at top right, rgba(1, 189, 243, 0.12), transparent 34%),
        linear-gradient(180deg, #ffffff 0%, #f9fcff 100%);
}

.doctor-panel-stat-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 20px 35px rgba(27, 30, 66, 0.08);
}

.doctor-panel-photo {
    width: 88px;
    height: 88px;
    object-fit: cover;
    border-radius: 24px;
    border: 3px solid rgba(255, 255, 255, 0.95);
    box-shadow: 0 12px 28px rgba(27, 30, 66, 0.12);
}

.doctor-panel-section-card .form-control,
.doctor-panel-section-card .form-select,
.doctor-panel-section-card .input-group-text,
.doctor-panel-inner-card .form-control,
.doctor-panel-inner-card .form-select,
.doctor-panel-inner-card .input-group-text {
    border-radius: 14px;
}

.doctor-panel-section-card textarea.form-control {
    min-height: 120px;
}

.doctor-account-layout {
    display: grid;
    grid-template-columns: minmax(250px, 320px) minmax(0, 1fr);
    gap: 22px;
    align-items: start;
}

.doctor-account-summary {
    display: grid;
    gap: 14px;
}

.doctor-account-profile-card,
.doctor-account-status-card,
.doctor-account-mini-card,
.doctor-account-form {
    border-radius: 20px;
    border: 1px solid rgba(1, 76, 196, 0.08);
    background: linear-gradient(180deg, #ffffff 0%, #f7fbff 100%);
    box-shadow: 0 14px 30px rgba(27, 30, 66, 0.05);
}

.doctor-account-profile-card {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 18px;
}

.doctor-account-avatar {
    width: 62px;
    height: 62px;
    border-radius: 18px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    font-weight: 800;
    color: #ffffff;
    background: linear-gradient(135deg, var(--primary) 0%, var(--light-primary) 100%);
    box-shadow: 0 12px 24px rgba(1, 76, 196, 0.2);
}

.doctor-account-name {
    font-size: 18px;
    font-weight: 700;
    color: #17233d;
}

.doctor-account-subtitle {
    font-size: 13px;
    color: #63708a;
}

.doctor-account-status-card {
    padding: 18px;
}

.doctor-account-status-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 10px;
}

.doctor-account-status-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 7px 12px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
}

.doctor-account-status-pill.is-active {
    background: rgba(25, 135, 84, 0.12);
    color: #198754;
}

.doctor-account-status-pill.is-inactive {
    background: rgba(220, 53, 69, 0.1);
    color: #dc3545;
}

.doctor-account-mini-grid {
    display: grid;
    gap: 12px;
}

.doctor-account-mini-card {
    padding: 14px 16px;
}

.doctor-account-mini-card span {
    display: block;
    margin-bottom: 4px;
    font-size: 12px;
    color: #6c7b93;
}

.doctor-account-mini-card strong {
    display: block;
    font-size: 14px;
    color: #17233d;
    word-break: break-word;
}

.doctor-account-form {
    padding: 22px;
}

.doctor-account-form-head {
    margin-bottom: 18px;
}

.doctor-account-save-btn {
    min-width: 170px;
}

.doctor-panel-anchor-bar {
    display: flex;
    gap: 10px;
    overflow-x: auto;
    padding: 4px 2px 10px;
    margin-bottom: 16px;
}

.doctor-panel-anchor-link {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 14px;
    border-radius: 999px;
    background: #ffffff;
    border: 1px solid rgba(1, 76, 196, 0.09);
    color: #16325c;
    font-size: 12px;
    font-weight: 700;
    box-shadow: 0 8px 20px rgba(27, 30, 66, 0.05);
}

.doctor-panel-anchor-link:hover,
.doctor-panel-anchor-link:focus {
    color: #ffffff;
    background: var(--primary);
    border-color: var(--primary);
}

.doctor-panel-anchor-link.is-active {
    color: #ffffff;
    background: linear-gradient(135deg, var(--primary) 0%, var(--light-primary) 100%);
    border-color: transparent;
    box-shadow: 0 12px 24px rgba(1, 76, 196, 0.18);
}

.doctor-panel-page-intro {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 18px 20px;
    border-radius: 22px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(246, 251, 255, 0.96) 100%);
    border: 1px solid rgba(1, 76, 196, 0.08);
    box-shadow: 0 14px 30px rgba(27, 30, 66, 0.05);
}

.doctor-panel-page-intro-actions {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.doctor-panel-page-card {
    display: block;
    height: 100%;
    padding: 18px;
    border-radius: 22px;
    background: linear-gradient(180deg, #ffffff 0%, #f9fbff 100%);
    border: 1px solid rgba(1, 76, 196, 0.08);
    box-shadow: 0 12px 30px rgba(27, 30, 66, 0.05);
    color: #16325c;
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.doctor-panel-page-card:hover,
.doctor-panel-page-card:focus {
    transform: translateY(-3px);
    border-color: rgba(1, 76, 196, 0.22);
    box-shadow: 0 18px 34px rgba(27, 30, 66, 0.08);
    color: #16325c;
}

.doctor-panel-page-card-icon {
    width: 52px;
    height: 52px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 14px;
    border-radius: 18px;
    background: linear-gradient(135deg, rgba(1, 76, 196, 0.12) 0%, rgba(1, 189, 243, 0.18) 100%);
    color: var(--primary);
    font-size: 22px;
}

.doctor-panel-page-card-title {
    font-size: 16px;
    font-weight: 800;
    margin-bottom: 8px;
}

.doctor-panel-page-card-text {
    color: var(--secondary);
    font-size: 13px;
    line-height: 1.55;
}

.doctor-panel-summary-card {
    background:
        radial-gradient(circle at top left, rgba(1, 189, 243, 0.08), transparent 32%),
        linear-gradient(180deg, #ffffff 0%, #f9fbff 100%);
}

.doctor-panel-period-card {
    height: 100%;
    padding: 18px;
    border-radius: 20px;
    background: #ffffff;
    border: 1px solid rgba(1, 76, 196, 0.08);
}

.doctor-panel-period-title {
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--secondary);
    margin-bottom: 10px;
}

.doctor-panel-period-amount {
    font-size: 24px;
    font-weight: 800;
    color: #17233d;
    margin-bottom: 12px;
}

.doctor-panel-period-meta {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    padding: 10px 0;
    border-top: 1px solid rgba(1, 76, 196, 0.08);
    font-size: 13px;
}

.doctor-panel-period-meta span {
    color: var(--secondary);
}

.doctor-panel-period-meta strong {
    color: #17233d;
}

.doctor-panel-inner-card {
    padding: 18px;
    border-radius: 20px;
    background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
    border: 1px solid rgba(1, 76, 196, 0.08);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.75);
}

.doctor-panel-time-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.doctor-panel-time-chip {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 48px;
    padding: 10px 12px;
    border-radius: 16px;
    background: #ffffff;
    border: 1px solid rgba(1, 76, 196, 0.12);
    color: #16325c;
    font-size: 13px;
    font-weight: 700;
    cursor: pointer;
    transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.doctor-panel-time-chip:hover {
    transform: translateY(-1px);
    border-color: rgba(1, 76, 196, 0.22);
    box-shadow: 0 12px 24px rgba(27, 30, 66, 0.08);
}

.doctor-panel-time-chip input {
    margin: 0 !important;
}

.doctor-panel-time-chip.is-selected {
    background: rgba(1, 76, 196, 0.08);
    border-color: rgba(1, 76, 196, 0.35);
}

.doctor-panel-slots-tip {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.doctor-slots-section-card {
    background:
        radial-gradient(circle at top right, rgba(1, 189, 243, 0.08), transparent 24%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(247, 251, 255, 0.98) 100%);
}

.doctor-slots-overview-card,
.doctor-slots-form-card,
.doctor-slots-list-card {
    box-shadow: 0 14px 28px rgba(27, 30, 66, 0.05);
}

.doctor-slots-form-card {
    border-radius: 22px;
    border: 1px solid rgba(1, 76, 196, 0.08);
    background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
}

.doctor-slots-preset-row,
.doctor-slots-template-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.doctor-slots-preset-btn,
.doctor-slots-template-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(1, 76, 196, 0.12);
    background: linear-gradient(180deg, #ffffff 0%, #f6fbff 100%);
    color: #16325c;
    border-radius: 999px;
    padding: 10px 15px;
    font-size: 12px;
    font-weight: 700;
    line-height: 1;
    white-space: nowrap;
    min-height: 40px;
    cursor: pointer;
    box-shadow: 0 8px 18px rgba(27, 30, 66, 0.05);
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease, background 0.2s ease;
}

.doctor-slots-preset-btn:hover,
.doctor-slots-template-btn:hover,
.doctor-slots-preset-btn:focus,
.doctor-slots-template-btn:focus {
    transform: translateY(-1px);
    border-color: rgba(1, 76, 196, 0.28);
    box-shadow: 0 10px 20px rgba(27, 30, 66, 0.08);
}

.doctor-slots-template-btn {
    background: rgba(1, 76, 196, 0.06);
}

.doctor-slots-template-btn.is-light {
    background: #ffffff;
    color: #667085;
}

.doctor-slots-form-card .form-control,
.doctor-slots-form-card .form-select {
    min-height: 48px;
    border-radius: 16px !important;
    border-color: rgba(1, 76, 196, 0.12);
    background: #ffffff;
}

.doctor-slots-form-card .form-control:focus,
.doctor-slots-form-card .form-select:focus {
    border-color: rgba(1, 76, 196, 0.35);
    box-shadow: 0 0 0 0.18rem rgba(1, 76, 196, 0.08) !important;
}

.doctor-slots-form-card .btn {
    min-height: 50px;
}

.doctor-panel-time-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.doctor-panel-time-chip {
    min-height: 54px;
    border-radius: 18px;
    background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
    box-shadow: 0 8px 20px rgba(27, 30, 66, 0.04);
}

.doctor-panel-time-chip span {
    font-weight: 800;
}

.doctor-slots-table-wrap {
    border-radius: 20px;
    overflow: hidden;
    border: 1px solid rgba(1, 76, 196, 0.08);
}

.doctor-workspace-shell {
    padding-bottom: 28px;
}

.doctor-workspace-hero {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 16px;
}

.doctor-workspace-hero-copy {
    max-width: 720px;
}

.doctor-workspace-hero-actions {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.doctor-workspace-toolbar {
    align-items: flex-end;
}

.doctor-workspace-search-form {
    width: min(100%, 420px);
}

.doctor-workspace-search .input-group-text,
.doctor-workspace-search .form-control,
.doctor-workspace-search .btn {
    border-radius: 14px !important;
}

.doctor-workspace-search .input-group-text {
    background: #f7fbff;
    border-color: rgba(1, 76, 196, 0.08);
    color: var(--primary);
}

.doctor-workspace-table table thead th {
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--secondary);
    border-bottom-color: rgba(1, 76, 196, 0.08);
}

.doctor-workspace-table table tbody td {
    padding-top: 16px;
    padding-bottom: 16px;
    border-bottom-color: rgba(1, 76, 196, 0.08);
}

.doctor-workspace-patient-cell,
.doctor-workspace-patient-summary {
    display: flex;
    align-items: center;
    gap: 14px;
}

.doctor-workspace-patient-avatar {
    width: 44px;
    height: 44px;
    border-radius: 16px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, rgba(1, 76, 196, 0.14) 0%, rgba(1, 189, 243, 0.22) 100%);
    color: var(--primary);
    font-size: 18px;
    font-weight: 800;
    flex-shrink: 0;
}

.doctor-workspace-patient-avatar-lg {
    width: 72px;
    height: 72px;
    border-radius: 22px;
    font-size: 28px;
}

.doctor-workspace-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 7px 12px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    background: #edf5ff;
    color: #16325c;
}

.doctor-workspace-pill.is-info {
    background: rgba(1, 76, 196, 0.1);
    color: var(--primary);
}

.doctor-workspace-pill.is-success {
    background: rgba(61, 174, 20, 0.12);
    color: #2d8710;
}

.doctor-workspace-pill.is-warning {
    background: rgba(253, 190, 0, 0.18);
    color: #8d6800;
}

.doctor-workspace-pill.is-danger {
    background: rgba(196, 56, 85, 0.12);
    color: #c43855;
}

.doctor-workspace-pill.is-muted {
    background: #eef2f7;
    color: #667085;
}

.doctor-workspace-empty {
    padding: 32px 20px;
    border-radius: 22px;
    text-align: center;
    background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
    border: 1px dashed rgba(1, 76, 196, 0.16);
}

.doctor-workspace-empty-icon {
    width: 62px;
    height: 62px;
    margin: 0 auto 14px;
    border-radius: 20px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(1, 76, 196, 0.08);
    color: var(--primary);
    font-size: 24px;
}

.doctor-workspace-detail-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.doctor-workspace-detail-item {
    padding: 14px 16px;
    border-radius: 18px;
    background: #f9fbff;
    border: 1px solid rgba(1, 76, 196, 0.08);
}

.doctor-workspace-detail-item span {
    display: block;
    margin-bottom: 6px;
    color: var(--secondary);
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.doctor-workspace-detail-item strong {
    display: block;
    color: #17233d;
    font-size: 14px;
    line-height: 1.55;
}

.doctor-workspace-detail-item-wide {
    grid-column: 1 / -1;
}

.doctor-workspace-stack {
    display: grid;
    gap: 16px;
}

.doctor-workspace-booking-card {
    padding: 18px;
    border-radius: 22px;
    background: linear-gradient(180deg, #ffffff 0%, #f9fbff 100%);
    border: 1px solid rgba(1, 76, 196, 0.08);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.75);
}

.doctor-workspace-booking-top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 16px;
}

.doctor-workspace-badge-row,
.doctor-workspace-tag-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.doctor-workspace-detail-list,
.doctor-workspace-price-card,
.doctor-workspace-action-panel {
    height: 100%;
    padding: 16px;
    border-radius: 18px;
    background: #ffffff;
    border: 1px solid rgba(1, 76, 196, 0.08);
}

.doctor-workspace-detail-row {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    padding: 10px 0;
    border-top: 1px solid rgba(1, 76, 196, 0.08);
    font-size: 13px;
}

.doctor-workspace-detail-row:first-child {
    padding-top: 0;
    border-top: none;
}

.doctor-workspace-detail-row span {
    color: var(--secondary);
}

.doctor-workspace-detail-row strong {
    color: #17233d;
    text-align: right;
}

.doctor-workspace-detail-row-strong strong {
    font-size: 15px;
}

.doctor-workspace-tag {
    display: inline-flex;
    align-items: center;
    padding: 7px 10px;
    border-radius: 999px;
    background: rgba(1, 76, 196, 0.08);
    color: #16325c;
    font-size: 12px;
    font-weight: 700;
}

.doctor-workspace-action-panel {
    display: grid;
    gap: 12px;
}

.doctor-workspace-compact-form {
    padding: 0;
}

.doctor-workspace-document-grid {
    display: grid;
    gap: 12px;
}

.doctor-workspace-document-card {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 16px;
    border-radius: 18px;
    background: linear-gradient(180deg, #ffffff 0%, #f9fbff 100%);
    border: 1px solid rgba(1, 76, 196, 0.08);
}

.doctor-workspace-document-icon {
    width: 50px;
    height: 50px;
    border-radius: 16px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(1, 76, 196, 0.08);
    color: var(--primary);
    font-size: 22px;
    flex-shrink: 0;
}

.doctor-workspace-document-body {
    flex: 1 1 auto;
    min-width: 0;
}

.doctor-workspace-document-action {
    flex-shrink: 0;
}

.doctor-patient-profile-hero {
    display: grid;
    grid-template-columns: minmax(0, 1.5fr) minmax(260px, 0.7fr);
    gap: 18px;
    align-items: stretch;
    background:
        radial-gradient(circle at top left, rgba(1, 189, 243, 0.12), transparent 28%),
        radial-gradient(circle at bottom right, rgba(1, 76, 196, 0.12), transparent 30%),
        linear-gradient(135deg, #ffffff 0%, #f5faff 100%);
}

.doctor-patient-profile-hero-main {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 18px;
}

.doctor-patient-profile-summary {
    align-items: flex-start;
    gap: 18px;
}

.doctor-patient-profile-avatar,
.doctor-patient-profile-avatar-image {
    width: 84px;
    height: 84px;
    border-radius: 24px;
    box-shadow: 0 18px 32px rgba(27, 30, 66, 0.12);
}

.doctor-patient-profile-avatar {
    background: linear-gradient(135deg, var(--primary) 0%, var(--light-primary) 100%);
    color: #ffffff;
}

.doctor-patient-profile-avatar-image {
    object-fit: cover;
    display: block;
    border: 4px solid rgba(255, 255, 255, 0.86);
}

.doctor-patient-profile-summary-copy {
    min-width: 0;
}

.doctor-patient-profile-inline-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 10px;
}

.doctor-patient-profile-inline-meta span {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.82);
    border: 1px solid rgba(1, 76, 196, 0.08);
    color: #29456f;
    font-size: 12px;
    font-weight: 700;
}

.doctor-patient-profile-hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.doctor-patient-profile-hero-side {
    display: grid;
    gap: 12px;
}

.doctor-patient-profile-hero-card {
    padding: 16px 18px;
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.86);
    border: 1px solid rgba(1, 76, 196, 0.08);
    box-shadow: 0 12px 26px rgba(27, 30, 66, 0.06);
}

.doctor-patient-profile-hero-card span {
    display: block;
    margin-bottom: 6px;
    color: var(--secondary);
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.doctor-patient-profile-hero-card strong {
    color: #13284d;
    font-size: 14px;
    line-height: 1.5;
    word-break: break-word;
}

.doctor-patient-profile-stat-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 100%;
}

.doctor-patient-profile-stat-icon {
    width: 48px;
    height: 48px;
    border-radius: 16px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(1, 76, 196, 0.08);
    color: var(--primary);
    font-size: 20px;
    margin-bottom: 4px;
}

.doctor-patient-profile-details-card,
.doctor-patient-profile-summary-card,
.doctor-patient-profile-booking-card,
.doctor-patient-profile-document-card {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(247, 251, 255, 0.98) 100%);
}

.doctor-patient-profile-detail-grid .doctor-workspace-detail-item {
    background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
    box-shadow: 0 10px 24px rgba(27, 30, 66, 0.04);
}

.doctor-patient-profile-soft-box {
    background: linear-gradient(180deg, #f8fbff 0%, #eef6ff 100%);
}

.doctor-patient-profile-booking-card {
    position: relative;
    overflow: hidden;
}

.doctor-patient-profile-booking-card::after {
    content: "";
    position: absolute;
    top: -42px;
    right: -42px;
    width: 120px;
    height: 120px;
    border-radius: 50%;
    background: rgba(1, 76, 196, 0.05);
    pointer-events: none;
}

.doctor-patient-profile-surface {
    background: rgba(255, 255, 255, 0.92);
    box-shadow: 0 12px 22px rgba(27, 30, 66, 0.04);
}

.doctor-patient-profile-booking-card .doctor-workspace-badge-row {
    position: relative;
    z-index: 1;
}

.doctor-patient-profile-booking-card .doctor-workspace-detail-row {
    align-items: center;
}

.doctor-patient-profile-booking-card .doctor-workspace-action-panel .d-flex {
    align-items: center;
}

.doctor-patient-profile-document-card {
    box-shadow: 0 12px 24px rgba(27, 30, 66, 0.05);
}

@media (max-width: 767.98px) {
    .doctor-panel-shell {
        padding: 12px;
    }

    .doctor-sidebar-nav {
        padding: 14px 12px 22px !important;
    }

    .doctor-sidebar-card {
        padding: 16px 14px;
        border-radius: 22px;
    }

    .doctor-sidebar-avatar-ring {
        width: 52px;
        height: 52px;
        border-radius: 16px;
    }

    .doctor-sidebar-avatar {
        border-radius: 12px;
    }

    .doctor-panel-topbar {
        align-items: flex-start;
        flex-wrap: wrap;
    }

    .doctor-panel-topbar .btn,
    .doctor-panel-topbar-actions {
        width: 100%;
    }

    .doctor-panel-topbar-actions {
        justify-content: stretch;
    }

    .doctor-panel-page-intro,
    .doctor-panel-page-intro-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .doctor-panel-hero-meta,
    .doctor-panel-time-grid {
        grid-template-columns: 1fr;
    }

    .doctor-workspace-hero,
    .doctor-workspace-booking-top,
    .doctor-workspace-detail-row,
    .doctor-workspace-document-card {
        flex-direction: column;
        align-items: stretch;
    }

    .doctor-workspace-search-form,
    .doctor-workspace-hero-actions,
    .doctor-workspace-document-action .btn {
        width: 100%;
    }

    .doctor-workspace-detail-grid {
        grid-template-columns: 1fr;
    }

    .doctor-workspace-patient-avatar-lg {
        width: 60px;
        height: 60px;
        font-size: 24px;
    }

    .doctor-panel-progress-value {
        font-size: 30px;
    }

    .doctor-account-layout {
        grid-template-columns: 1fr;
    }

    .doctor-patient-profile-hero {
        grid-template-columns: 1fr;
    }

    .doctor-patient-profile-hero-side {
        grid-template-columns: 1fr;
    }

    .doctor-patient-profile-booking-card .doctor-workspace-badge-row {
        justify-content: flex-start;
    }

    .doctor-patient-profile-booking-card .doctor-workspace-detail-list,
    .doctor-patient-profile-booking-card .doctor-workspace-price-card,
    .doctor-patient-profile-booking-card .doctor-workspace-action-panel {
        padding: 14px;
    }

    .doctor-slots-overview-grid > div,
    .doctor-slots-form-card,
    .doctor-slots-list-card {
        min-width: 0;
    }
}

@media (max-width: 575.98px) {
    .doctor-panel-shell {
        padding: 10px;
    }

    .doctor-panel-topbar,
    .doctor-panel-hero,
    .doctor-panel-page-intro,
    .doctor-panel-section-card,
    .doctor-panel-inner-card,
    .doctor-workspace-booking-card,
    .doctor-workspace-empty {
        padding: 16px;
        border-radius: 18px;
    }

    .doctor-panel-title h4,
    .doctor-panel-page-intro h5 {
        font-size: 1.1rem;
    }

    .doctor-panel-photo {
        width: 72px;
        height: 72px;
        border-radius: 22px;
    }

    .doctor-panel-hero-main .d-flex {
        align-items: flex-start !important;
    }

    .doctor-panel-section-head,
    .doctor-workspace-toolbar,
    .doctor-workspace-search {
        flex-direction: column;
        align-items: stretch;
    }

    .doctor-account-profile-card,
    .doctor-account-status-head {
        flex-direction: column;
        align-items: flex-start;
    }

    .doctor-account-form {
        padding: 18px;
    }

    .doctor-account-save-btn {
        width: 100%;
    }

    .doctor-panel-section-head .btn,
    .doctor-workspace-hero-actions .btn,
    .doctor-workspace-search .btn {
        width: 100%;
    }

    .doctor-panel-period-meta,
    .doctor-panel-mini-stat,
    .doctor-workspace-detail-row {
        flex-direction: column;
        align-items: flex-start;
    }

    .doctor-panel-period-meta strong,
    .doctor-workspace-detail-row strong {
        text-align: left;
    }

    .doctor-panel-anchor-link {
        padding: 9px 12px;
        font-size: 11px;
        gap: 6px;
    }

    .doctor-panel-page-card-icon,
    .doctor-workspace-empty-icon,
    .doctor-workspace-document-icon {
        width: 46px;
        height: 46px;
        border-radius: 14px;
    }

    .doctor-panel-time-chip {
        min-height: 44px;
        font-size: 12px;
        padding: 10px;
    }

    .doctor-workspace-search .input-group-text {
        justify-content: center;
        width: 100%;
    }

    .doctor-workspace-search .form-control,
    .doctor-workspace-search .btn {
        width: 100%;
        border-radius: 14px !important;
    }

    .doctor-workspace-search {
        gap: 8px;
    }

    .doctor-mobile-table {
        min-width: 0 !important;
    }

    .doctor-mobile-table thead {
        display: none;
    }

    .doctor-mobile-table,
    .doctor-mobile-table tbody,
    .doctor-mobile-table tr,
    .doctor-mobile-table td {
        display: block;
        width: 100%;
    }

    .doctor-mobile-table tbody tr {
        margin-bottom: 12px;
        padding: 14px;
        border-radius: 18px;
        background: linear-gradient(180deg, #ffffff 0%, #f9fbff 100%);
        border: 1px solid rgba(1, 76, 196, 0.08);
        box-shadow: 0 10px 24px rgba(27, 30, 66, 0.05);
    }

    .doctor-mobile-table tbody tr:last-child {
        margin-bottom: 0;
    }

    .doctor-mobile-table td {
        padding: 8px 0 !important;
        border: none !important;
        text-align: left !important;
    }

    .doctor-mobile-table td::before {
        content: attr(data-label);
        display: block;
        margin-bottom: 4px;
        color: var(--secondary);
        font-size: 11px;
        font-weight: 800;
        letter-spacing: 0.06em;
        text-transform: uppercase;
    }

    .doctor-mobile-table td .btn,
    .doctor-mobile-table td form {
        width: 100%;
    }

    .doctor-mobile-table td form {
        display: block !important;
    }

    .doctor-mobile-table td form .btn {
        width: 100%;
    }

    .doctor-mobile-table td.text-end {
        text-align: left !important;
    }

    .doctor-workspace-patient-cell,
    .doctor-workspace-patient-summary {
        align-items: flex-start;
    }

    .doctor-workspace-patient-avatar {
        width: 40px;
        height: 40px;
        border-radius: 14px;
        font-size: 16px;
    }

    .doctor-workspace-patient-avatar-lg {
        width: 56px;
        height: 56px;
        border-radius: 18px;
        font-size: 22px;
    }

    .doctor-workspace-tag-row,
    .doctor-workspace-badge-row {
        gap: 6px;
    }

    .doctor-workspace-document-action {
        width: 100%;
    }

    .doctor-patient-profile-summary,
    .doctor-patient-profile-inline-meta {
        flex-direction: column;
        align-items: flex-start;
    }

    .doctor-patient-profile-hero-actions {
        width: 100%;
    }

    .doctor-patient-profile-hero-actions .btn {
        width: 100%;
    }

    .doctor-patient-profile-avatar,
    .doctor-patient-profile-avatar-image {
        width: 68px;
        height: 68px;
        border-radius: 20px;
    }

    .doctor-slots-preset-row,
    .doctor-slots-template-actions {
        gap: 6px;
    }

    .doctor-slots-preset-btn,
    .doctor-slots-template-btn {
        flex: 1 1 calc(50% - 6px);
        width: auto;
        min-width: 0;
    }

    .doctor-slots-form-card .row.g-3.align-items-end {
        row-gap: 12px !important;
    }

    .doctor-slots-table-wrap {
        border-radius: 18px;
    }

    .doctor-panel-time-grid {
        grid-template-columns: 1fr;
        gap: 8px;
    }

    .doctor-patient-profile-booking-card .doctor-workspace-booking-top {
        gap: 12px;
    }

    .doctor-patient-profile-booking-card .doctor-workspace-badge-row {
        flex-direction: row;
        flex-wrap: wrap;
        align-items: center;
    }

    .doctor-patient-profile-booking-card .doctor-workspace-detail-row {
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
        gap: 10px;
        padding: 12px 0;
    }

    .doctor-patient-profile-booking-card .doctor-workspace-detail-row strong {
        text-align: right;
        font-size: 13px;
        line-height: 1.4;
        max-width: 58%;
    }

    .doctor-patient-profile-booking-card .doctor-workspace-detail-row span {
        font-size: 11px;
    }

    .doctor-patient-profile-booking-card .doctor-workspace-action-panel .d-flex {
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) auto;
        gap: 8px;
    }

    .doctor-patient-profile-booking-card .doctor-workspace-action-panel .btn,
    .doctor-patient-profile-booking-card .doctor-workspace-action-panel .form-select {
        min-height: 42px;
    }

    .hc-offcanvas-nav.nav-position-left .nav-container {
        width: min(88vw, 320px) !important;
    }
}

.text-bg-success {
    background-color: var(--success) !important;
    font-weight: 400;
}

.fw-light {
    font-weight: 200;
}

a {
    text-decoration: none;
}

.form-control {
    box-shadow: none !important;
}

.form-select {
    box-shadow: none !important;
}

.rounded-4,
.form-control {
    border-radius: 10px !important;
}

.btn {
    font-size: 13px;
    padding: 13px 15px !important;
    border-radius: 10px !important;
    font-weight: 700 !important;
}

.btn-lg {
    font-size: 16px;
    padding: 15px 20px !important;
    letter-spacing: 0.2px;
}

.btn-sm {
    padding: 7px 12px !important;
}

.rounded-top-4 {
    border-top-left-radius: 1rem;
    border-top-right-radius: 1rem;
}

.rounded-bottom-4 {
    border-bottom-left-radius: 1rem;
    border-bottom-right-radius: 1rem;
}

.chat-rounded-left {
    border-radius: 19px;
    padding: 10px 15px !important;
    font-size: 13px;
}

.chat-rounded-right {
    border-radius: 19px;
    padding: 10px 15px !important;
    font-size: 13px;
}

.small-sm {
    font-size: 12px;
}

.fs-14 {
    font-size: 14px;
}

.border-primary-dotted {
    border: 1px dashed var(--primary);
}

.border-dotted-bottom {
    border-bottom: 1px dashed var(--secondary);
}

.border-dotted-top {
    border-top: 1px dashed var(--secondary);
}

.border-dashed-muted {
    border: 1px dashed var(--secondary);
}

.border-dashed-primary {
    border: 1px dashed var(--primary);
}

.badge-success {
    background-color: var(--light-success);
    color: var(--success);
}

.fix-osahan-footer {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 3px;
}

.shadow {
    box-shadow: rgb(0 0 0 / 7%) 0px 6px 24px 0px, rgb(0 0 0 / 4%) 0px 0px 0px 1px !important;
}

/* Index */
.logo {
    width: 100px;
}

.top-doctor-item,
.recent-doctor-item,
.available-doctor-item {
    margin: 4px 5px;
}

/* Landing Page */
.landing ul.slick-dots {
    bottom: auto;
    margin: auto;
    text-align: center;
}

.landing ul.slick-dots li {
    margin: 0px;
    padding: 0px;
    width: auto !important;
    height: auto !important;
}

.landing ul.slick-dots li button {
    margin: 3px;
    padding: 0px;
    width: 12px;
    height: 12px;
    background: #fff;
    border-radius: 50px;
    border: 1px solid #ffffff;
    box-shadow: 0px 0px 1px #6e6e6e;
}

.landing ul.slick-dots li button:before {
    display: none;
}

.landing ul.slick-dots li.slick-active button {
    background: var(--primary);
    border-color: var(--primary);
}

.landing-slider-item img {
    height: 230px;
    object-fit: contain;
    margin: auto;
}

/* Country */
.flag-img {
    width: 35px;
}

/* Welcome */
.blue-logo {
    left: 155px;
    width: 80px;
    top: 55px;
    position: absolute;
    text-align: center;
    justify-content: center;
    display: flex;
    align-items: center;
}

.welcome{
    background-image: url(../img/background-paaras.gif);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
}

/* Footer Nav */
.body-fix-osahan-footer {
    padding-bottom: 82px;
}

.footer-bottom-nav {
    text-align: center;
    display: flex;
    align-items: center;
    flex-direction: column;
    color: #989898;
    padding: 5px 0 9px 0;
    position: relative;
}

.footer-bottom-nav span {
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
}

.footer-bottom-nav i {
    font-size: 20px;
}

.footer-bottom-nav.active {
    color: #0148ff;
}

.footer-bottom-nav.active:after {
    content: "";
    width: 40px;
    height: 10px;
    background: #0148ff;
    border-radius: 50px;
    position: absolute;
    bottom: -7px;
}

.bottom-nav-main {
    background: #fff;
}

/* Home */
.icon {
    min-width: 35px;
    width: 35px;
    height: 35px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.icon-lg {
    width: 38px;
    height: 38px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 25px;
}

.doctor-book-back {
    position: relative;
    overflow: hidden;
}

.doctor-book-back-title {
    font-family: 'Sofia Sans Extra Condensed', sans-serif;
    padding-right: 77px;
    letter-spacing: 0.8px;
    line-height: 28px !important;
}

.doctor-book-img {
    position: absolute;
    bottom: 0;
    width: 140px;
    right: 0;
}

.btn-book {
    font-weight: 500 !important;
    padding: 6px 11px !important;
    font-size: 11px;
    z-index: 99 !important;
    border-radius: 50px !important;
    letter-spacing: 0.4px;
}

.btn-book i {
    margin-left: 6px;
}

/* Favorte Doctor */
.favorite-img {
    width: 50px;
}

.cf-btn a.btn {
    border-radius: 0px !important;
}

/* Doctor Profile */
.appointment-doctor-img {
    width: 90px;
}

/* Book Appointment */
.appointment-banner {
    background: url(../img/background-blob.svg);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
}

/* Request Appointment */
.request-appointment-shell {
    min-height: 100vh;
    min-height: 100dvh;
    height: auto;
}

.request-appointment-content {
    min-height: 0;
    padding-bottom: 110px !important;
    overscroll-behavior: contain;
    overflow: visible !important;
}

.request-appointment .tab-content {
    min-height: 120px;
}

.request-appointment .tab-pane {
    min-height: 1px;
}

.request-day-tabs {
    display: flex;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 12px;
}

.request-day-tab-item {
    min-width: 0;
}

.request-day-tab-btn {
    min-height: 96px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 4px;
    padding: 14px 10px !important;
    border: 1px solid rgba(1, 76, 196, 0.1);
    background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
    box-shadow: 0 12px 24px rgba(27, 30, 66, 0.05);
    color: #15407c;
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.request-day-tab-btn:hover,
.request-day-tab-btn:focus {
    transform: translateY(-1px);
    border-color: rgba(1, 76, 196, 0.2);
    box-shadow: 0 16px 28px rgba(27, 30, 66, 0.08);
}

.request-day-tab-btn.active {
    background: linear-gradient(135deg, #0d6efd 0%, #20b8ea 100%) !important;
    border-color: transparent;
    box-shadow: 0 18px 30px rgba(13, 110, 253, 0.22);
    color: #ffffff !important;
}

.request-day-tab-day {
    font-size: 13px;
    letter-spacing: 0.02em;
}

.request-day-tab-date {
    font-size: 14px;
    font-weight: 700;
}

.request-day-tab-count {
    color: #6d7d95 !important;
}

.request-day-tab-btn.active .request-day-tab-count {
    color: rgba(255, 255, 255, 0.82) !important;
}

.custom-check-day .btn {
    border: none;
    border-radius: 0;
    border-top-left-radius: 1rem;
    border-bottom-right-radius: 1rem;
    background: #ffffff;
    color: var(--dark);
}

.custom-check .btn {
    background: #ffffff;
    font-size: 13px;
    color: var(--secondary);
    padding: 7px 9px !important;
    width: 100%;
    line-height: 20px;
    border-color: #d9d9d9;
    min-height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.custom-check .btn span.fs-5 {
    font-size: 19px !important;
    font-weight: 600;
}

.custom-check .btn-check:checked+.btn,
.custom-check .btn.active,
.custom-check .btn.show,
.custom-check .btn:first-child:active,
:not(.btn-check)+.btn:active {
    background: #16bef0 !important;
    border-color: #16bef0 !important;
    color: #fff !important;
}

@media (max-width: 575.98px) {
    .request-appointment-content {
        padding-bottom: 96px !important;
    }

    .request-day-tabs {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 8px;
    }

    .custom-check .row-cols-4 {
        --bs-columns: 2;
    }
}

.fee-icon {
    height: 45px;
    width: 45px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
}

/* Notification */
.notification-icon {
    width: 50px;
    height: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 25px;
}

/* Video */
.video-tabs button {
    border: none;
    background-color: #ffffff;
    color: var(--dark) !important;
    font-size: 15px;
    border-bottom: 3px solid #fff;
    border-top: 3px solid #fff;
    padding: 12px 10px;
}

.video-tabs button.active {
    color: #14BEF0 !important;
    border-bottom: 3px solid;
    font-weight: 500;
    background: #eefbff;
    border-top: 3px solid #eefbff;
}

/* Doctor Profile Two */
.doctor-profile-tabs button {
    border: none;
    background-color: #ffffff;
    color: var(--dark) !important;
    font-size: 15px;
    border-bottom: 3px solid #fff;
    border-top: 3px solid #fff;
    padding: 12px 10px;
}

.doctor-profile-tabs button.active {
    color: #14BEF0 !important;
    border-bottom: 3px solid;
    font-weight: 500;
    background: #eefbff;
    border-top: 3px solid #eefbff;
}

.review-profile {
    width: 35px;
}

.offcanvas {
    border-top-left-radius: 2rem;
    border-top-right-radius: 2rem;
}

.offcanvas-footer {
    padding: 1rem 1rem;
}

/* Visit Info / Chekout */
.upload-file {
    position: relative;
    overflow: hidden;
    z-index: -1;
}

.upload-file-icon {
    position: absolute;
    top: -34px;
    right: -32px;
    height: 100px;
    width: 100px;
    border-bottom-left-radius: 60%;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1;
}

/* Message */
.plus-icon {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 30px;
}

.message-profile {
    width: 40px;
}

/* Call */
.call-img {
    width: 150px;
}

.call-display {
    height: calc(100vh - 87px);
    border-bottom-left-radius: 40px;
    border-bottom-right-radius: 40px;
}

.call-icons a {
    height: 50px;
    width: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
    color: #ffffff;
}

/* Call Doctor */
.call-doctor {
    height: calc(100vh - 87px);
    border-bottom-left-radius: 40px;
    border-bottom-right-radius: 40px;
    background: url(../img/favorite/favorite-4.jpg);
    background-position: center;
    background-size: cover;
}

.patient-icon {
    width: 55px;
    height: 55px;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* History */
.voice-img {
    width: 70px;
    height: 70px;
    object-fit: cover;
}

/* Profile */
.edit-profile-back {
    position: relative;
}

.edit-profile-icon {
    position: absolute;
    top: -30px;
    right: -25px;
    height: 100px;
    width: 100px;
    border-bottom-left-radius: 60%;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2;
}

/* My Appointment */
.btn-rounded {
    border-radius: 50%;
    height: 40px;
    width: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Play Recording */
.play-recording-background {
    background: url(../img/favorite/favorite-4.jpg);
    background-position: center;
    background-size: cover;
    height: calc(100vh - 87px);
    border-bottom-left-radius: 40px;
    border-bottom-right-radius: 40px;
}

.home-top-shell {
    background:
        radial-gradient(circle at top left, rgba(255, 255, 255, 0.22), transparent 28%),
        radial-gradient(circle at bottom right, rgba(255, 190, 0, 0.18), transparent 24%),
        linear-gradient(135deg, #101b4d 0%, #014cc4 52%, #01bdf3 100%);
    border-bottom-left-radius: 28px;
    border-bottom-right-radius: 28px;
    box-shadow: 0 16px 34px rgba(16, 27, 77, 0.18);
}

.home-top-shell .osahan-header p,
.home-top-shell .osahan-header h6,
.home-top-shell .osahan-header .text-primary,
.home-top-shell .osahan-header .text-orange {
    color: #fff !important;
}

.home-top-shell .icon {
    background: rgba(255, 255, 255, 0.16) !important;
    box-shadow: none !important;
    backdrop-filter: blur(6px);
}

.home-top-shell .icon .mdi,
.home-top-shell .icon .bi {
    color: #fff !important;
}

.home-location-pill {
    background: rgba(255, 255, 255, 0.16);
    border: 1px solid rgba(255, 255, 255, 0.18);
    color: rgba(255, 255, 255, 0.92) !important;
    backdrop-filter: blur(8px);
    padding-top: 0px !important;
    padding-bottom: 0px !important;
    min-height: 0;
    line-height: 1.2;
}

.home-search-wrap {
    background: rgba(255, 255, 255, 0.96) !important;
    border: 1px solid rgba(255, 255, 255, 0.46);
    box-shadow: 0 10px 28px rgba(16, 27, 77, 0.16) !important;
    padding-top: 0px !important;
    padding-bottom: 0px !important;
    min-height: 0;
}

.home-search-wrap .input-group-text {
    min-height: 0;
}

.home-search-wrap .form-control {
    min-height: 0;
    padding-top: 6px;
    padding-bottom: 6px;
}

.home-search-wrap .form-control::placeholder {
    color: #6b7897;
}

.home-top-note {
    color: rgba(255, 255, 255, 0.88) !important;
}

.wishlist-btn {
    width: 38px;
    height: 38px;
    border: 0;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.96);
    box-shadow: 0 10px 18px rgba(16, 27, 77, 0.14);
}

.wishlist-btn-dark {
    background: rgba(16, 27, 77, 0.08);
    box-shadow: none;
}

.mdi-map-marker-outline {
    color: #fff !important;
}

.home-hero-caption {
    margin: 14px 16px 0;
    padding: 14px 16px;
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.14);
    backdrop-filter: blur(10px);
}

.home-hero-caption .hero-stat {
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.14);
    padding: 10px 12px;
}

.home-section-head {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 12px;
}

.home-section-head p {
    margin: 0;
    color: #6f7891;
    font-size: 12px;
}

.home-section-head h6 {
    margin: 0 0 3px;
    font-weight: 800;
    color: #101b4d;
}

.home-action-card {
    padding: 12px 8px !important;
    border: 1px solid rgba(1, 76, 196, 0.07);
    box-shadow: 0 12px 24px rgba(16, 27, 77, 0.06) !important;
}

.home-action-card p {
    font-weight: 700;
    color: #24325a;
    font-size: 10px;
}

.home-top-doctor-card {
    border-radius: 22px !important;
    overflow: hidden;
    box-shadow: 0 16px 28px rgba(16, 27, 77, 0.08) !important;
}

.home-top-doctor-card .card-body {
    background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
}

.home-top-doctor-card .card-title {
    color: #16224c;
}

.home-listing-card {
    border-radius: 24px !important;
    box-shadow: 0 16px 34px rgba(16, 27, 77, 0.08) !important;
}

.home-listing-card .card-footer .btn {
    border-bottom-left-radius: 24px !important;
    border-bottom-right-radius: 24px !important;
}

.specialty-pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 10px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.92);
    color: #ff8811;
    font-weight: 700;
}

.available-doctor .slick-track {
    display: flex !important;
}

.available-doctor .slick-slide {
    height: inherit !important;
}

.available-doctor-item>div {
    min-height: 205px;
}
 .specialization-shell {
      background:
         radial-gradient(circle at top left, rgba(1, 76, 196, 0.18), transparent 34%),
         radial-gradient(circle at bottom right, rgba(255, 136, 17, 0.12), transparent 28%),
         linear-gradient(180deg, #f7fbff 0%, #eef4fb 48%, #f5f7fb 100%);
   }
   .specialization-hero {
      position: relative;
      overflow: hidden;
      border-radius: 32px;
      background: linear-gradient(135deg, #0f1b53 0%, #014cc4 52%, #01bdf3 100%);
      box-shadow: 0 24px 54px rgba(14, 26, 77, 0.18);
   }
   .specialization-hero::before {
      content: "";
      position: absolute;
      width: 220px;
      height: 220px;
      border-radius: 50%;
      top: -90px;
      right: -70px;
      background: rgba(255, 255, 255, 0.1);
   }
   .specialization-hero::after {
      content: "";
      position: absolute;
      width: 180px;
      height: 180px;
      border-radius: 32px;
      bottom: -80px;
      left: -60px;
      background: rgba(255, 255, 255, 0.1);
      transform: rotate(28deg);
   }
   .specialization-kicker {
      letter-spacing: 0.18em;
      text-transform: uppercase;
      color: rgba(255, 255, 255, 0.68);
      font-size: 11px;
      font-weight: 700;
   }
   .specialization-icon-badge {
      width: 56px;
      height: 56px;
      border-radius: 18px;
      background: rgba(255, 255, 255, 0.14);
      display: inline-flex;
      align-items: center;
      justify-content: center;
      font-size: 24px;
      flex-shrink: 0;
   }
   .specialization-chip {
      border-radius: 999px;
      padding: 8px 14px;
      background: rgba(255, 255, 255, 0.14);
      color: #fff;
      display: inline-flex;
      align-items: center;
      gap: 8px;
      font-weight: 600;
      backdrop-filter: blur(8px);
   }
   .specialization-hero-image {
      min-height: 330px;
      position: relative;
      display: flex;
      align-items: center;
      justify-content: center;
   }
   .specialization-photo-main {
      width: min(100%, 320px);
      height: 330px;
      border-radius: 28px;
      object-fit: cover;
      box-shadow: 0 26px 54px rgba(9, 18, 57, 0.3);
      position: relative;
      z-index: 1;
      border: 4px solid rgba(255, 255, 255, 0.12);
   }
   .specialization-photo-float {
      position: absolute;
      width: 108px;
      height: 108px;
      border-radius: 24px;
      object-fit: cover;
      box-shadow: 0 18px 34px rgba(9, 18, 57, 0.24);
      border: 4px solid rgba(255, 255, 255, 0.14);
   }
   .specialization-photo-float.one {
      top: 14px;
      left: 6px;
      transform: rotate(-8deg);
   }
   .specialization-photo-float.two {
      right: 8px;
      bottom: 12px;
      transform: rotate(8deg);
   }
   .specialization-stat {
      border-radius: 20px;
      background: rgba(255, 255, 255, 0.12);
      backdrop-filter: blur(8px);
      min-height: 76px;
   }
   .specialization-panel {
      border: 0;
      border-radius: 28px;
      background: rgba(255, 255, 255, 0.92);
      box-shadow: 0 14px 34px rgba(27, 30, 66, 0.08);
   }
   .specialization-section-icon {
      width: 48px;
      height: 48px;
      border-radius: 16px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      background: rgba(1, 76, 196, 0.1);
      color: var(--primary);
      font-size: 22px;
      flex-shrink: 0;
   }
   .specialization-list {
      display: grid;
      gap: 12px;
      margin: 0;
      padding: 0;
      list-style: none;
   }
   .specialization-list li {
      border-radius: 18px;
      padding: 14px 16px;
      background: #f8fbff;
      border: 1px solid rgba(1, 76, 196, 0.08);
   }
   .therapy-media-panel {
      background: linear-gradient(180deg, #f7fbff 0%, #edf5ff 100%);
   }
   .therapy-media-card {
      min-height: 100%;
      border-radius: 28px;
      background: #0f1b53;
      padding: 18px;
      box-shadow: 0 18px 40px rgba(14, 26, 77, 0.16);
   }
   .therapy-media-title {
      color: rgba(255, 255, 255, 0.72);
      font-size: 11px;
      text-transform: uppercase;
      letter-spacing: 0.14em;
      font-weight: 700;
      margin-bottom: 14px;
   }
   .therapy-media-grid {
      display: grid;
      gap: 12px;
   }
   .therapy-media-tile {
      position: relative;
      border-radius: 22px;
      overflow: hidden;
      min-height: 132px;
      box-shadow: 0 12px 28px rgba(6, 11, 34, 0.2);
   }
   .therapy-media-tile img {
      width: 100%;
      height: 132px;
      object-fit: cover;
      display: block;
   }
   .therapy-media-tile::after {
      content: "";
      position: absolute;
      inset: 0;
      background: linear-gradient(180deg, transparent 15%, rgba(7, 14, 43, 0.7) 100%);
   }
   .therapy-media-tile strong {
      position: absolute;
      left: 12px;
      right: 12px;
      bottom: 12px;
      color: #fff;
      font-size: 12px;
      line-height: 1.3;
      z-index: 1;
   }
   .therapy-product-card {
      border-radius: 22px;
      background: #fff;
      border: 1px solid rgba(1, 76, 196, 0.08);
      padding: 16px;
      height: 100%;
      box-shadow: 0 10px 24px rgba(27, 30, 66, 0.05);
   }
   .therapy-product-icon {
      width: 100%;
      height: 148px;
      border-radius: 18px;
      overflow: hidden;
      background: #edf5ff;
      margin-bottom: 14px;
   }
   .therapy-product-icon img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
   }
   .specialization-cta {
      background: #101b4d;
      color: #fff;
      border-radius: 28px;
      position: relative;
      overflow: hidden;
   }
   .specialization-cta::after {
      content: "";
      position: absolute;
      right: -40px;
      bottom: -40px;
      width: 150px;
      height: 150px;
      background: rgba(1, 189, 243, 0.14);
      border-radius: 50%;
   }
   @media (max-width: 575.98px) {
      .specialization-hero-image {
         min-height: 260px;
         margin-top: 6px;
      }
      .specialization-photo-main {
         height: 260px;
      }
      .specialization-photo-float {
         width: 82px;
         height: 82px;
      }
      .therapy-product-icon {
         height: 120px;
      }
   }
.hero-health{
    text-align:center;
    padding-bottom:50px;
}

/* logo box */
.logo-box{
    background:#fff;
    padding:18px;
    border-radius:50px;
    display:inline-block;
    margin-bottom:25px;
    box-shadow:0 10px 30px rgba(0,0,0,0.08);
    animation: logoZoom 1.2s ease;
}

.logo{
    width:80px;
}

/* title */
.health-title{
    font-family: math;
    font-weight:600;
    color:#0d6efd;
    font-size:30px;
    opacity:0;
    transform:translateY(30px);
    animation: titleFade 1.5s ease forwards;
    animation-delay:0.6s;
}

/* logo animation */
@keyframes logoZoom{
    0%{
        transform:scale(0.5);
        opacity:0;
    }
    100%{
        transform:scale(1);
        opacity:1;
    }
}

/* text animation */
@keyframes titleFade{
    0%{
        opacity:0;
        transform:translateY(30px);
        letter-spacing:2px;
    }
    100%{
        opacity:1;
        transform:translateY(0);
        letter-spacing:0;
    }
}

/* hover effect */
.health-link:hover .health-title{
    text-shadow:0 0 10px rgba(13,110,253,0.3);
    transition:0.3s;
}
.top-doctor-img{
    height: 165px;
    object-fit: cover;
}
