@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

:root {
    --clinic-teal: #10c7c7;
    --clinic-teal-dark: #0f555d;
    --clinic-teal-deep: #123f46;
    --clinic-ink: #24383c;
    --clinic-muted: #687b80;
    --clinic-bg: #f5f8f8;
    --clinic-panel: #ffffff;
    --clinic-soft: #eefafa;
    --clinic-line: #d8e8e8;
    --clinic-line-strong: #bed6d7;
    --clinic-shadow: 0 8px 24px rgba(18, 63, 70, 0.07);
    --clinic-radius: 14px;
}

* {
    box-sizing: border-box;
}

html,
body {
    margin: 0;
    min-height: 100vh;
    overflow-x: hidden;
}

body {
    font-family: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    color: var(--clinic-ink);
    background: var(--clinic-bg);
}

.app-shell {
    min-height: 100vh;
    max-width: 100vw;
    overflow-x: hidden;
}

.clinic-navbar {
    position: sticky;
    top: 0;
    z-index: 1000;
    background: rgba(255, 255, 255, .97) !important;
    border-bottom: 1px solid var(--clinic-line);
    box-shadow: 0 4px 16px rgba(18, 63, 70, .05);
    backdrop-filter: blur(10px);
}

.clinic-navbar .container {
    min-height: 74px;
}

.clinic-navbar .navbar-brand {
    margin-right: 28px;
    text-decoration: none;
}

.clinic-navbar .navbar-brand img {
    width: 48px !important;
    height: 48px !important;
    border-radius: 10px !important;
    object-fit: cover;
    border: 1px solid var(--clinic-line);
}

.brand-title {
    display: block;
    color: var(--clinic-teal-deep);
    font-size: 1.05rem;
    font-weight: 800;
    letter-spacing: -.02em;
    line-height: 1.05;
}

.brand-subtitle {
    display: block;
    margin-top: 2px;
    color: var(--clinic-muted);
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .13em;
    text-transform: uppercase;
}

.clinic-navbar .nav-link {
    color: var(--clinic-teal-deep) !important;
    font-size: .92rem;
    font-weight: 650;
    border-radius: 8px;
    padding: .55rem .78rem !important;
    transition: background-color .15s ease, color .15s ease;
}

.clinic-navbar .nav-link:hover,
.clinic-navbar .nav-link:focus {
    color: var(--clinic-teal-dark) !important;
    background: var(--clinic-soft);
}

.user-chip {
    display: inline-flex;
    align-items: center;
    color: var(--clinic-teal-deep);
    background: #f8fbfb;
    border: 1px solid var(--clinic-line);
    border-radius: 999px;
    padding: .52rem .85rem;
    font-size: .9rem;
    font-weight: 700;
}

.page-wrap {
    width: min(1180px, calc(100% - 32px));
    margin: 0 auto;
    padding: 36px 0 70px;
}

h1,
h2,
h3,
h4,
h5 {
    color: var(--clinic-teal-deep);
    font-weight: 800;
    letter-spacing: -.03em;
}

h1 {
    font-size: clamp(1.8rem, 3vw, 2.55rem);
}

h2 {
    font-size: clamp(1.35rem, 2vw, 1.85rem);
}

p,
.text-muted {
    color: var(--clinic-muted) !important;
}

a {
    color: var(--clinic-teal-dark);
}

a:hover {
    color: var(--clinic-teal-deep);
}

.card,
.hero-card,
.detail-card,
.search-card,
.form-card,
.table-card {
    background: var(--clinic-panel) !important;
    border: 1px solid var(--clinic-line) !important;
    border-radius: var(--clinic-radius) !important;
    box-shadow: var(--clinic-shadow) !important;
    max-width: 100%;
}

.hero-card,
.detail-card,
.search-card,
.form-card {
    padding: 30px;
}

.card-header {
    background: #f8fcfc !important;
    border-bottom: 1px solid var(--clinic-line) !important;
    color: var(--clinic-teal-deep) !important;
    font-weight: 800;
}

.btn,
button,
input[type='submit'] {
    border-radius: 9px !important;
    font-weight: 750 !important;
    padding: .66rem 1rem !important;
}

.btn-primary,
.btn-success,
input[type='submit'] {
    background: var(--clinic-teal-dark) !important;
    border-color: var(--clinic-teal-dark) !important;
    color: #fff !important;
}

.btn-primary:hover,
.btn-success:hover,
input[type='submit']:hover {
    background: var(--clinic-teal-deep) !important;
    border-color: var(--clinic-teal-deep) !important;
}

.btn-outline,
.btn-outline-primary,
.btn-outline-success,
.btn-secondary {
    background: #fff !important;
    color: var(--clinic-teal-dark) !important;
    border: 1px solid #008c55 !important;
}

.btn-outline:hover,
.btn-outline-primary:hover,
.btn-outline-success:hover,
.btn-secondary:hover {
    background: var(--clinic-soft) !important;
    color: var(--clinic-teal-deep) !important;
}

label,
.form-label {
    color: var(--clinic-teal-deep);
    font-weight: 700;
    margin-bottom: .35rem;
}

input,
select,
textarea,
.form-control,
.form-select {
    border-radius: 9px !important;
    border: 1px solid #cfdfe0 !important;
    padding: .74rem .9rem !important;
    background-color: #fff !important;
    color: var(--clinic-ink) !important;
    max-width: 100%;
}

input:focus,
select:focus,
textarea:focus,
.form-control:focus,
.form-select:focus {
    border-color: var(--clinic-teal) !important;
    box-shadow: 0 0 0 .2rem rgba(16, 199, 199, .12) !important;
}

.table,
table {
    width: 100%;
    max-width: 100%;
    background: #fff;
    border: 1px solid var(--clinic-line);
    border-radius: 14px;
    overflow: hidden;
    box-shadow: var(--clinic-shadow);
    border-collapse: separate;
    border-spacing: 0;
    table-layout: fixed;
}

.table th,
.table td,
table th,
table td {
    padding: .92rem 1rem !important;
    vertical-align: middle;
    border-color: var(--clinic-line) !important;
    overflow-wrap: anywhere;
}

.table thead th {
    background: #f8fcfc !important;
    color: var(--clinic-teal-deep) !important;
    font-size: .78rem;
    text-transform: uppercase;
    letter-spacing: .06em;
    border-bottom: 1px solid var(--clinic-line) !important;
}

.table td {
    background: #fff !important;
}

tbody tr:hover {
    background: #f7fcfc;
}

.appointment-table th:nth-child(1),
.appointment-table td:nth-child(1) {
    width: 30%;
}

.appointment-table th:nth-child(2),
.appointment-table td:nth-child(2) {
    width: 45%;
}

.appointment-table th:nth-child(3),
.appointment-table td:nth-child(3) {
    width: 25%;
}

.status-badge {
    display: inline-flex;
    padding: .35rem .7rem;
    border-radius: 999px;
    font-size: .78rem;
    font-weight: 700;
    background: var(--clinic-soft);
    color: var(--clinic-teal-dark);
    border: 1px solid var(--clinic-line);
}

.alert {
    border-radius: 12px !important;
    border: 1px solid var(--clinic-line) !important;
}

.calendar-shell {
    background: #fff;
    border: 1px solid var(--clinic-line);
    border-radius: 14px;
    padding: 26px;
    box-shadow: var(--clinic-shadow);
    max-width: 100%;
    overflow: hidden;
}

.fc {
    width: 100% !important;
    max-width: 100% !important;
}

.fc .fc-header-toolbar {
    padding: 0 12px 20px;
    margin-bottom: 18px !important;
}

.fc .fc-toolbar-chunk {
    display: flex;
    gap: 10px;
}

.fc .fc-button-primary {
    background: var(--clinic-teal-dark) !important;
    border-color: var(--clinic-teal-dark) !important;
    color: #fff !important;
    border-radius: 9px !important;
}

.fc .fc-button-primary:hover,
.fc .fc-button-primary:focus,
.fc .fc-button-primary.fc-button-active {
    background: var(--clinic-teal-deep) !important;
    border-color: var(--clinic-teal-deep) !important;
}
.fc .fc-button-group {
    display: flex;
    gap: 10px;
}

.fc .fc-col-header,
.fc .fc-col-header-cell,
.fc .fc-scrollgrid-section-header th {
    background: #f7fbfb !important;
}

.fc .fc-col-header-cell-cushion {
    color: var(--clinic-teal-deep) !important;
    font-weight: 800 !important;
    font-size: .82rem;
    letter-spacing: .06em;
    text-transform: uppercase;
    text-decoration: none !important;
    padding: 12px 0 !important;
}

.fc .fc-scrollgrid,
.fc .fc-scrollgrid td,
.fc .fc-scrollgrid th {
    border-color: var(--clinic-line) !important;
}

.fc .fc-daygrid-day-number {
    color: var(--clinic-teal-deep) !important;
    font-weight: 650;
    text-decoration: none !important;
}

.fc .fc-day-today {
    background: #fff9d9 !important;
}

.fc .fc-event,
.fc .fc-daygrid-event {
    background: var(--clinic-teal-dark) !important;
    border: 1px solid var(--clinic-teal-dark) !important;
    color: #fff !important;
    border-radius: 7px !important;
    padding: 3px 6px !important;
    font-weight: 650;
}

.fc .event-complete,
.fc .event-complete .fc-event-main {
    background: #f4f0df !important;
    border-color: #d8c27a !important;
    color: var(--clinic-teal-deep) !important;
}

.fc .event-upcoming,
.fc .event-upcoming .fc-event-main {
    background: var(--clinic-teal-dark) !important;
    border-color: var(--clinic-teal-dark) !important;
    color: #fff !important;
}

@media (max-width: 768px) {
    .clinic-navbar .container {
        min-height: 66px;
    }

    .page-wrap {
        width: calc(100% - 24px);
        padding-top: 22px;
    }

    .hero-card,
    .detail-card,
    .search-card,
    .form-card {
        padding: 22px;
    }

    .table,
    table {
        table-layout: fixed !important;
    }

    .table th,
    .table td,
    table th,
    table td {
        padding: .8rem .65rem !important;
        font-size: .86rem;
    }

    .calendar-shell {
        padding: 12px;
    }

    .fc .fc-header-toolbar {
        display: flex;
        flex-direction: column;
        align-items: stretch;
        gap: 12px;
        padding: 0 2px 14px;
    }

    .fc .fc-toolbar-chunk {
        justify-content: center;
        flex-wrap: wrap;
    }

    .fc .fc-toolbar-title {
        text-align: center;
        font-size: 1.15rem !important;
        white-space: normal;
    }

    .fc .fc-button {
        padding: .5rem .7rem !important;
        font-size: .82rem !important;
    }
}