:root {
    --bg: #eef0f3;
    --bg-grad-1: #d7dbe2;
    --bg-grad-2: #f1f3f6;
    --bg-grad-3: #e3e6ec;
    --panel: #ffffff;
    --panel-2: #f2f4f7;
    --ink: #1f242b;
    --muted: #5c6572;
    --line: #cfd5de;
    --brand: #3a4657;
    --brand-dark: #2a3443;
    --accent: #4b5563;
    --danger: #dc2626;
    --soft: #e6e9ef;
    --soft-border: #c5ccd8;
    --soft-ink: #303847;
    --table-head: #3b4452;
    --table-head-ink: #f8fafc;
    --chip-bg: #e3e7ef;
    --chip-border: #c6cedc;
    --chip-ink: #2f3a4b;
    --toast-bg: #0f2a36;
    --input-bg: #ffffff;
    --input-border: #c7cfdc;
    --input-ink: #1f242b;
    --head-ink: #2a3342;
    --head-subtle: #5f6876;
    --row-border: #d9dee6;
    --btn-secondary-bg: #e6e9ef;
    --btn-secondary-border: #c5ccd8;
    --btn-secondary-ink: #2f394a;
    --btn-primary-ink: #ffffff;
    --header-bg: #3a4657;
    --header-border: #2a3443;
    --header-tab-bg: #4a5769;
    --header-tab-border: #66758a;
    --header-tab-ink: #f2f5f9;
    --radius: 14px;
    --shadow: 0 12px 24px rgba(24, 40, 72, 0.08);
}

body[data-theme="dark"] {
    --bg: #0c151d;
    --bg-grad-1: #0f1e29;
    --bg-grad-2: #0c151d;
    --bg-grad-3: #12212c;
    --panel: #13212c;
    --panel-2: #152733;
    --ink: #e3edf4;
    --muted: #9eb2c2;
    --line: #27404f;
    --brand: #17a29b;
    --brand-dark: #12867f;
    --accent: #1bb5b3;
    --danger: #ef4444;
    --soft: #1a2c39;
    --soft-border: #2b495a;
    --soft-ink: #d4e7f1;
    --table-head: #1a303e;
    --table-head-ink: #e3edf4;
    --chip-bg: #153340;
    --chip-border: #2f6678;
    --chip-ink: #a9d7e8;
    --toast-bg: #102734;
    --input-bg: #122330;
    --input-border: #365261;
    --input-ink: #e6f0f6;
    --head-ink: #e3edf4;
    --head-subtle: #9eb2c2;
    --row-border: #2c4657;
    --btn-secondary-bg: #244050;
    --btn-secondary-border: #3d6174;
    --btn-secondary-ink: #e6f1f6;
    --btn-primary-ink: #ffffff;
    --header-bg: #0f2230;
    --header-border: #244255;
    --header-tab-bg: #173042;
    --header-tab-border: #2e5168;
    --header-tab-ink: #d4e7f3;
    --shadow: 0 14px 30px rgba(1, 7, 12, 0.55);
}

* {
    box-sizing: border-box;
}

html,
body {
    margin: 0;
    padding: 0;
    background: radial-gradient(circle at top left, var(--bg-grad-1), var(--bg-grad-2) 48%, var(--bg-grad-3));
    color: var(--ink);
    font-family: "Trebuchet MS", "Segoe UI", sans-serif;
}

.hidden {
    display: none !important;
}

button,
input,
select,
textarea {
    font: inherit;
}

label {
    display: grid;
    gap: 6px;
    color: var(--muted);
    font-size: 0.9rem;
    position: relative;
}

input,
select,
textarea {
    width: 100%;
    border: 1px solid var(--input-border);
    border-radius: 10px;
    padding: 9px 10px;
    background: var(--input-bg);
    color: var(--input-ink);
}

button {
    border: 0;
    border-radius: 10px;
    padding: 10px 14px;
    background: var(--brand);
    color: var(--btn-primary-ink);
    cursor: pointer;
    font-weight: 700;
}

button:hover {
    filter: brightness(0.96);
}

button.secondary {
    background: var(--btn-secondary-bg);
    color: var(--btn-secondary-ink);
    border: 1px solid var(--btn-secondary-border);
}

button.accent {
    background: var(--accent);
}

button.danger {
    background: var(--danger);
}

main {
    width: min(1500px, 96vw);
    margin: 14px auto;
}

.login-screen {
    min-height: 100vh;
    width: 100vw;
    margin: 0;
    display: grid;
    place-items: center;
    background:
        radial-gradient(1200px 620px at -8% -12%, rgba(47, 123, 176, 0.34), transparent 62%),
        radial-gradient(980px 520px at 108% 110%, rgba(21, 173, 154, 0.26), transparent 58%),
        radial-gradient(420px 220px at 50% 18%, rgba(156, 215, 255, 0.16), transparent 70%),
        linear-gradient(160deg, #091019, #0d1823 44%, #0b131c);
    position: relative;
    overflow: hidden;
    padding: 18px;
}

.login-screen {
    background-image:
        radial-gradient(1200px 620px at -8% -12%, rgba(47, 123, 176, 0.34), transparent 62%),
        radial-gradient(980px 520px at 108% 110%, rgba(21, 173, 154, 0.26), transparent 58%),
        radial-gradient(420px 220px at 50% 18%, rgba(156, 215, 255, 0.16), transparent 70%),
        linear-gradient(160deg, #091019, #0d1823 44%, #0b131c);
}

body[data-theme="dark"] .login-screen {
    background-image:
        radial-gradient(1200px 620px at -10% -8%, rgba(35, 125, 190, 0.26), transparent 62%),
        radial-gradient(980px 520px at 110% 108%, rgba(30, 176, 154, 0.2), transparent 58%),
        radial-gradient(380px 220px at 50% 22%, rgba(133, 214, 255, 0.14), transparent 70%),
        linear-gradient(160deg, #08111a, #0b1723 42%, #0a131d);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.login-screen::before,
.login-screen::after {
    content: "";
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
}

.login-screen::before {
    width: 720px;
    height: 720px;
    left: -240px;
    top: 50%;
    transform: translateY(-50%);
    border: 1px solid rgba(133, 187, 221, 0.15);
    box-shadow: inset 0 0 120px rgba(34, 103, 151, 0.16);
}

.login-screen::after {
    width: 520px;
    height: 520px;
    right: -180px;
    top: -140px;
    border: 1px solid rgba(94, 193, 179, 0.16);
    box-shadow: inset 0 0 120px rgba(21, 173, 154, 0.14);
}

.login-card {
    width: min(520px, 94vw);
    background: linear-gradient(158deg, rgba(18, 30, 44, 0.58), rgba(18, 33, 48, 0.48));
    border-radius: 22px;
    padding: 32px;
    box-shadow: 0 30px 70px rgba(2, 9, 18, 0.62);
    border: 1px solid rgba(170, 211, 236, 0.34);
    backdrop-filter: blur(14px);
    position: relative;
    z-index: 1;
}

.login-layout {
    width: min(560px, 96vw);
    display: grid;
    grid-template-columns: 1fr;
    place-items: center;
    z-index: 1;
}

.login-visual {
    display: none !important;
}

.login-brand {
    display: inline-flex;
    align-items: center;
    margin-bottom: 4px;
}

.login-card h1 {
    margin: 0;
    font-size: 2.05rem;
    color: #eef6ff;
    letter-spacing: 0.2px;
}

.login-tagline {
    margin: 0 0 14px;
    color: #b8d0df;
    font-size: 0.95rem;
}

.login-card label {
    color: #b7ccdc;
}

.login-card input {
    background: rgba(10, 20, 29, 0.52);
    border-color: rgba(121, 156, 178, 0.44);
    color: #ecf4fb;
}

.login-card button {
    background: linear-gradient(145deg, #1a8dc9, #1a74bf);
    border: 1px solid rgba(156, 215, 248, 0.35);
}

.remember-row {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: #c7dced;
}

.remember-row input[type="checkbox"] {
    width: 14px;
    height: 14px;
    margin: 0;
}

#dbSetupWrap a {
    color: #8fd8ff;
    text-decoration: underline;
}

@media (max-width: 980px) {
    .login-layout {
        width: min(620px, 96vw);
    }

    .login-card {
        width: 100%;
    }
}

.stack {
    display: grid;
    gap: 12px;
}

.app {
    display: grid;
    gap: 12px;
    width: 100vw;
    min-height: 100vh;
    margin: 0;
    padding: 10px 12px 14px;
    align-content: start;
    grid-auto-rows: min-content;
}

.topbar {
    background: var(--panel);
    color: var(--ink);
    border: 1px solid var(--line);
    border-radius: 10px;
    padding: 10px 14px;
    display: flex;
    align-items: center;
    box-shadow: none;
}

.topbar h2 {
    margin: 0;
}

.topbar small {
    color: var(--muted);
}

.tabs-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
    justify-content: space-between;
    position: sticky;
    top: 0;
    z-index: 40;
    background: var(--header-bg);
    border-bottom: 1px solid var(--header-border);
    padding: 6px 0;
    backdrop-filter: blur(2px);
    box-shadow: 0 10px 24px rgba(22, 26, 34, 0.24);
}

.topbar-actions {
    display: flex;
    gap: 8px;
}

.tabs-actions {
    flex-shrink: 0;
}

.tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    flex: 1;
    min-width: 0;
}

.tabs button {
    background: var(--header-tab-bg);
    color: var(--header-tab-ink);
    border: 1px solid var(--header-tab-border);
    transition: all 0.18s ease;
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.tabs button::before {
    content: "";
    width: 14px;
    height: 14px;
    display: inline-block;
    background-color: currentColor;
    mask-repeat: no-repeat;
    mask-position: center;
    mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
    -webkit-mask-size: contain;
}

.tabs button[data-tab="dashboard"]::before {
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M4 13h7V4H4v9Zm0 7h7v-5H4v5Zm9 0h7V11h-7v9Zm0-18v7h7V2h-7Z'/%3E%3C/svg%3E");
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M4 13h7V4H4v9Zm0 7h7v-5H4v5Zm9 0h7V11h-7v9Zm0-18v7h7V2h-7Z'/%3E%3C/svg%3E");
}

.tabs button[data-tab="secretary"]::before {
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M4 5a2 2 0 0 1 2-2h9l5 5v11a2 2 0 0 1-2 2H6a2 2 0 0 1-2-2V5Zm2 0v14h12V9h-4a2 2 0 0 1-2-2V5H6Zm3 7h6a1 1 0 1 0 0-2H9a1 1 0 1 0 0 2Zm0 4h6a1 1 0 1 0 0-2H9a1 1 0 1 0 0 2Z'/%3E%3C/svg%3E");
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M4 5a2 2 0 0 1 2-2h9l5 5v11a2 2 0 0 1-2 2H6a2 2 0 0 1-2-2V5Zm2 0v14h12V9h-4a2 2 0 0 1-2-2V5H6Zm3 7h6a1 1 0 1 0 0-2H9a1 1 0 1 0 0 2Zm0 4h6a1 1 0 1 0 0-2H9a1 1 0 1 0 0 2Z'/%3E%3C/svg%3E");
}

.tabs button[data-tab="patients"]::before {
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12 12a5 5 0 1 0-5-5a5 5 0 0 0 5 5Zm0 2c-4.42 0-8 2.24-8 5v1h16v-1c0-2.76-3.58-5-8-5Z'/%3E%3C/svg%3E");
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12 12a5 5 0 1 0-5-5a5 5 0 0 0 5 5Zm0 2c-4.42 0-8 2.24-8 5v1h16v-1c0-2.76-3.58-5-8-5Z'/%3E%3C/svg%3E");
}

.tabs button[data-tab="doctor"]::before {
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M19 8h-3V5a1 1 0 0 0-1-1h-2V2h-2v2H9a1 1 0 0 0-1 1v3H5v2h3v3a1 1 0 0 0 1 1h2v2h2v-2h2a1 1 0 0 0 1-1v-3h3V8Z'/%3E%3C/svg%3E");
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M19 8h-3V5a1 1 0 0 0-1-1h-2V2h-2v2H9a1 1 0 0 0-1 1v3H5v2h3v3a1 1 0 0 0 1 1h2v2h2v-2h2a1 1 0 0 0 1-1v-3h3V8Z'/%3E%3C/svg%3E");
}

.tabs button[data-tab="reports"]::before {
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M4 4h16v2H4V4Zm2 4h2v10H6V8Zm5 3h2v7h-2v-7Zm5-5h2v12h-2V6Z'/%3E%3C/svg%3E");
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M4 4h16v2H4V4Zm2 4h2v10H6V8Zm5 3h2v7h-2v-7Zm5-5h2v12h-2V6Z'/%3E%3C/svg%3E");
}

.tabs button[data-tab="report-design"]::before {
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M3 4h18v3H3V4Zm2 5h14v11H5V9Zm3 2v2h8v-2H8Zm0 4v2h5v-2H8Z'/%3E%3C/svg%3E");
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M3 4h18v3H3V4Zm2 5h14v11H5V9Zm3 2v2h8v-2H8Zm0 4v2h5v-2H8Z'/%3E%3C/svg%3E");
}

.tabs button[data-tab="admin"]::before {
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M19.14 12.94c.04-.31.06-.63.06-.94s-.02-.63-.06-.94l2.03-1.58a.5.5 0 0 0 .12-.64l-1.92-3.32a.5.5 0 0 0-.6-.22l-2.39.96a7.23 7.23 0 0 0-1.63-.94L14.5 2.8a.5.5 0 0 0-.49-.4h-4.02a.5.5 0 0 0-.49.4l-.36 2.52c-.58.23-1.12.54-1.63.94l-2.39-.96a.5.5 0 0 0-.6.22L2.6 8.84a.5.5 0 0 0 .12.64l2.03 1.58c-.04.31-.06.63-.06.94s.02.63.06.94L2.72 14.52a.5.5 0 0 0-.12.64l1.92 3.32c.13.22.39.31.6.22l2.39-.96c.51.4 1.05.71 1.63.94l.36 2.52c.04.24.25.4.49.4h4.02c.24 0 .45-.16.49-.4l.36-2.52c.58-.23 1.12-.54 1.63-.94l2.39.96c.22.09.47 0 .6-.22l1.92-3.32a.5.5 0 0 0-.12-.64l-2.03-1.58ZM12 15.5A3.5 3.5 0 1 1 12 8a3.5 3.5 0 0 1 0 7.5Z'/%3E%3C/svg%3E");
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M19.14 12.94c.04-.31.06-.63.06-.94s-.02-.63-.06-.94l2.03-1.58a.5.5 0 0 0 .12-.64l-1.92-3.32a.5.5 0 0 0-.6-.22l-2.39.96a7.23 7.23 0 0 0-1.63-.94L14.5 2.8a.5.5 0 0 0-.49-.4h-4.02a.5.5 0 0 0-.49.4l-.36 2.52c-.58.23-1.12.54-1.63.94l-2.39-.96a.5.5 0 0 0-.6.22L2.6 8.84a.5.5 0 0 0 .12.64l2.03 1.58c-.04.31-.06.63-.06.94s.02.63.06.94L2.72 14.52a.5.5 0 0 0-.12.64l1.92 3.32c.13.22.39.31.6.22l2.39-.96c.51.4 1.05.71 1.63.94l.36 2.52c.04.24.25.4.49.4h4.02c.24 0 .45-.16.49-.4l.36-2.52c.58-.23 1.12-.54 1.63-.94l2.39.96c.22.09.47 0 .6-.22l1.92-3.32a.5.5 0 0 0-.12-.64l-2.03-1.58ZM12 15.5A3.5 3.5 0 1 1 12 8a3.5 3.5 0 0 1 0 7.5Z'/%3E%3C/svg%3E");
}

.report-design-layout {
    align-items: start;
}

.report-designer-panel {
    margin: 0;
}

.rd-field-inline {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 6px;
    align-items: center;
}

.rd-clear-btn {
    min-width: 64px;
    height: 34px;
    padding: 0 10px;
}

.doctor-report-preview {
    margin-top: 10px;
    border: 1px solid var(--line);
    border-radius: 10px;
    background: var(--panel-2);
    padding: 10px;
}

.rd-paper {
    position: relative;
    width: 100%;
    max-width: 420px;
    height: 594px;
    margin: 0 auto;
    border: 1px solid var(--rd-border, var(--line));
    border-radius: 8px;
    background: #fff;
    overflow: hidden;
    font-family: var(--rd-font, "Trebuchet MS", "Segoe UI", sans-serif);
}

.rd-table-head {
    position: absolute;
    left: 6%;
    top: 38%;
    width: 88%;
    height: 6%;
    background: var(--rd-head-bg, #f2f4f7);
    color: var(--rd-head-ink, #1f242b);
    border: 1px solid var(--rd-border, var(--line));
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 700;
}

.rd-item {
    position: absolute;
    border: 1px dashed rgba(0, 0, 0, 0.2);
    color: var(--rd-primary, var(--brand));
    padding: 2px 4px;
    overflow: hidden;
    cursor: move;
    user-select: none;
}

.rd-item.active {
    border-color: var(--brand);
    box-shadow: 0 0 0 1px var(--brand) inset;
}

.rd-resize-handle {
    position: absolute;
    right: 0;
    bottom: 0;
    width: 10px;
    height: 10px;
    background: var(--brand);
    border: 1px solid #fff;
    border-radius: 2px;
    cursor: nwse-resize;
}

.rd-image {
    object-fit: contain;
    background: transparent;
}

.rd-image-wrap {
    padding: 0;
    border: 0;
    box-shadow: none;
}

.rd-image-wrap .rd-image {
    width: 100%;
    height: 100%;
    display: block;
}

.rd-image-wrap.active {
    border: 0;
    box-shadow: none;
}

.rd-watermark {
    text-align: center;
}

.rd-text[data-rd-el="footer_text"] {
    color: var(--rd-accent, #4b5563);
}

.tabs button.active {
    background: var(--brand);
    color: #fff;
    border-color: var(--brand);
}

.tabs button:hover {
    transform: translateY(-1px);
    border-color: var(--brand);
    border-color: color-mix(in srgb, var(--brand) 50%, var(--soft-border));
}

.status-badge {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: 3px 9px;
    font-size: 0.78rem;
    font-weight: 700;
    border: 1px solid transparent;
    white-space: nowrap;
}

.status-waiting {
    color: #1e40af;
    background: #dbeafe;
    border-color: #bfdbfe;
}

.status-in_consultation {
    color: #92400e;
    background: #ffedd5;
    border-color: #fed7aa;
}

.status-done {
    color: #166534;
    background: #dcfce7;
    border-color: #bbf7d0;
}

.status-cancelled {
    color: #991b1b;
    background: #fee2e2;
    border-color: #fecaca;
}

.queue-order-no {
    display: inline-block;
    font-weight: 800;
    color: #0b4ecb;
    background: #e6efff;
    border: 1px solid #bfd3ff;
    border-radius: 999px;
    padding: 3px 9px;
    letter-spacing: 0.25px;
}

.tab-content {
    display: none;
    align-self: start;
}

.tab-content.active {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.section-hero {
    border-radius: 14px;
    border: 1px solid #dbe4f6;
    padding: 14px 16px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    box-shadow: 0 6px 18px rgba(39, 75, 140, 0.08);
}

/* User requested removing tab hero cards on all pages. */
.section-hero {
    display: none !important;
}

.section-hero h1 {
    margin: 0;
    font-size: 1.2rem;
    letter-spacing: 0.2px;
}

.section-hero p {
    margin: 5px 0 0;
    color: var(--head-subtle);
    font-size: 0.9rem;
}

.section-chip {
    border-radius: 999px;
    padding: 5px 11px;
    font-size: 0.78rem;
    font-weight: 700;
    border: 1px solid transparent;
    white-space: nowrap;
}

.section-hero-dashboard {
    background: linear-gradient(130deg, #eaf2ff, #f4f8ff 58%, #f9fbff);
}

.section-hero-dashboard .section-chip {
    background: #dbeafe;
    border-color: #bfdbfe;
    color: #1d4ed8;
}

.section-hero-secretary {
    background: linear-gradient(130deg, #ecfdf5, #f5fff9 58%, #fbfffd);
}

.section-hero-secretary .section-chip {
    background: #d1fae5;
    border-color: #a7f3d0;
    color: #047857;
}

.section-hero-doctor {
    background: linear-gradient(130deg, #fff7ed, #fffaf4 58%, #fffdf9);
}

.section-hero-doctor .section-chip {
    background: #ffedd5;
    border-color: #fed7aa;
    color: #9a3412;
}

.section-hero-reports {
    background: linear-gradient(130deg, #f5f3ff, #faf8ff 58%, #fcfbff);
}

.section-hero-reports .section-chip {
    background: #ede9fe;
    border-color: #ddd6fe;
    color: #6d28d9;
}

.section-hero-admin {
    background: linear-gradient(130deg, #fef2f2, #fff7f7 58%, #fffafa);
}

.section-hero-admin .section-chip {
    background: #fee2e2;
    border-color: #fecaca;
    color: #b91c1c;
}

.panel {
    background: var(--panel);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    padding: 14px;
}

.panel h3,
.panel h4 {
    margin: 0 0 10px;
    color: var(--head-ink);
}

.panel-title-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 8px;
    margin-bottom: 10px;
}

.grid {
    display: grid;
    gap: 12px;
}

.grid.two {
    grid-template-columns: 1fr 1fr;
}

.grid.two-col-mini {
    grid-template-columns: 1fr 1fr;
    gap: 10px;
}

.grid-form {
    display: grid;
    grid-template-columns: repeat(2, minmax(150px, 1fr));
    gap: 10px;
}

.grid-form .wide {
    grid-column: 1 / -1;
}

.actions-row {
    display: flex;
    gap: 8px;
    align-items: center;
    flex-wrap: wrap;
}

.field-visibility-control {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 0.75rem;
    color: var(--head-subtle);
    margin-left: 8px;
    vertical-align: middle;
}

.field-visibility-control input[type="checkbox"] {
    width: 14px;
    height: 14px;
}

[data-sec-field],
[data-doc-field] {
    position: relative;
}

div[data-sec-field] > .field-visibility-control,
div[data-doc-field] > .field-visibility-control {
    position: absolute;
    top: 6px;
    right: 8px;
    background: var(--panel-2);
    border: 1px solid var(--line);
    border-radius: 999px;
    padding: 2px 8px;
    margin: 0;
}

.typeahead-wrap {
    position: relative;
}

.typeahead-list {
    position: absolute;
    left: 0;
    right: 0;
    top: calc(100% + 4px);
    z-index: 80;
    background: var(--panel);
    border: 1px solid var(--line);
    border-radius: 10px;
    box-shadow: 0 12px 24px rgba(21, 45, 90, 0.14);
    max-height: 220px;
    overflow: auto;
}

.typeahead-item {
    display: grid;
    gap: 2px;
    width: 100%;
    border: 0;
    border-bottom: 1px solid var(--row-border);
    background: var(--panel);
    text-align: left;
    padding: 8px 10px;
    cursor: pointer;
}

.typeahead-item:last-child {
    border-bottom: 0;
}

.typeahead-item:hover,
.typeahead-item:focus {
    background: var(--panel-2);
}

.typeahead-main {
    font-weight: 700;
    color: var(--head-ink);
}

.typeahead-sub {
    font-size: 0.8rem;
    color: var(--head-subtle);
}

.secretary-tag-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(100px, 1fr));
    gap: 8px;
    border: 1px solid var(--line);
    border-radius: 10px;
    padding: 8px;
    background: var(--panel-2);
}

.secretary-tag-grid label {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 0.9rem;
    color: var(--ink);
}

.secretary-tag-grid input[type="checkbox"] {
    width: auto;
}

.modern-checks {
    background: var(--panel-2);
    border: 1px solid var(--line);
    border-radius: 10px;
    padding: 8px;
}

.modern-checks label {
    display: flex;
    align-items: center;
    gap: 8px;
    color: var(--ink);
    font-weight: 600;
}

.modern-checks input[type="checkbox"] {
    width: 18px;
    height: 18px;
}

.cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 10px;
}

.card {
    background: var(--panel);
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 12px;
    box-shadow: var(--shadow);
}

.card strong {
    font-size: 1.5rem;
}

.table-wrap {
    overflow: auto;
    border: 1px solid var(--line);
    border-radius: 10px;
}

.table-wrap.tall {
    max-height: 360px;
}

.patients-browser-panel {
    border: 1px solid var(--line);
    background: linear-gradient(180deg, var(--panel-2) 0%, var(--panel) 38%);
}

.patients-browser-header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 10px;
}

.patients-browser-header h3 {
    margin: 0;
    font-size: 1.08rem;
}

.patients-browser-header small {
    color: var(--head-subtle);
    font-size: 0.82rem;
}

.patients-browser-meta {
    background: var(--chip-bg);
    color: var(--chip-ink);
    border: 1px solid var(--chip-border);
    border-radius: 999px;
    padding: 6px 12px;
    font-weight: 700;
    white-space: nowrap;
}

.patients-browser-controls {
    margin-bottom: 10px;
}

.patients-browser-controls input {
    border: 1px solid var(--input-border);
    border-radius: 12px;
    background: var(--input-bg);
    box-shadow: inset 0 1px 2px rgba(33, 67, 128, 0.08);
}

.patients-browser-table-wrap {
    border-color: var(--line);
    border-radius: 12px;
}

.patients-browser-table thead th {
    background: var(--table-head);
    border-bottom-color: var(--line);
}

.patients-browser-pagination {
    margin-top: 10px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
}

.patients-browser-page-info {
    color: var(--head-subtle);
    font-weight: 700;
    min-width: 120px;
    text-align: center;
}

table {
    width: 100%;
    border-collapse: collapse;
    background: var(--panel);
}

th,
td {
    border-bottom: 1px solid var(--row-border);
    padding: 9px;
    text-align: left;
    font-size: 0.9rem;
    vertical-align: top;
}

th {
    background: var(--table-head);
    color: var(--table-head-ink);
    position: sticky;
    top: 0;
    z-index: 1;
    letter-spacing: 0.2px;
}

.report-summary {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
    gap: 8px;
    margin: 10px 0;
}

.summary-chip {
    background: var(--panel-2);
    border: 1px solid var(--line);
    border-radius: 10px;
    padding: 10px;
}

.toast {
    position: fixed;
    right: 15px;
    bottom: 15px;
    background: var(--toast-bg);
    color: #fff;
    padding: 10px 14px;
    border-radius: 8px;
    transform: translateY(120%);
    transition: transform .25s ease;
    z-index: 99;
}

.toast.show {
    transform: translateY(0);
}

.doctor-shell {
    display: grid;
    grid-template-columns: 260px 1fr;
    gap: 10px;
    background: transparent;
    border: 0;
    border-radius: 12px;
    overflow: hidden;
    min-height: calc(100vh - 170px);
}

.doctor-side.panel,
.doctor-work.panel {
    margin: 0;
    border: 1px solid var(--line);
    border-radius: 12px;
    box-shadow: var(--shadow);
    background: var(--panel);
    padding: 10px;
}

.doctor-side {
    display: grid;
    grid-template-rows: auto auto auto 1fr auto;
    gap: 8px;
}

.doctor-side-title {
    font-weight: 800;
    color: var(--head-ink);
    font-size: 1rem;
}

.doctor-side input {
    border: 1px solid var(--input-border);
    border-radius: 9px;
    background: var(--input-bg);
    color: var(--input-ink);
    height: 34px;
}

.doctor-side select {
    border: 1px solid var(--input-border);
    border-radius: 9px;
    background: var(--input-bg);
    color: var(--input-ink);
    height: 34px;
    width: 100%;
}

.doctor-side-list-head {
    background: var(--table-head);
    border: 1px solid var(--line);
    color: var(--table-head-ink);
    font-weight: 700;
    border-radius: 8px;
    padding: 7px 10px;
}

.doctor-side-list {
    border: 1px solid var(--line);
    background: var(--panel-2);
    border-radius: 10px;
    overflow: auto;
    min-height: 280px;
}

.doctor-side-item {
    padding: 10px;
    border-bottom: 1px solid var(--row-border);
    cursor: pointer;
    background: var(--panel);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
}

.doctor-side-item-name {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.doctor-side-item-actions {
    display: inline-flex;
    gap: 6px;
}

.doctor-med-mini-btn {
    font-size: 0.72rem;
    padding: 4px 7px;
    border-radius: 7px;
    line-height: 1.1;
}

.doctor-side-item:hover {
    background: var(--panel-2);
}

.doctor-side-item.active {
    background: var(--brand);
    color: #fff;
}

.doctor-add-category {
    width: 100%;
    border-radius: 9px;
    justify-self: stretch;
}

.doctor-side-queue {
    border-top: 1px solid var(--line);
    padding-top: 8px;
}

.doctor-side-queue .panel-title-row {
    margin-bottom: 6px;
}

.doctor-queue-list {
    display: grid;
    gap: 4px;
    max-height: 180px;
    overflow: auto;
}

.doctor-queue-row {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: 4px;
    border: 1px solid var(--line);
    background: var(--panel-2);
    padding: 4px 6px;
}

.doctor-queue-row small {
    color: var(--head-subtle);
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.doctor-queue-row button {
    padding: 5px 9px;
    border-radius: 0;
}

.doctor-work {
    display: grid;
    align-content: start;
}

.doctor-form {
    display: grid;
    gap: 6px;
}

.doctor-top-strip {
    display: grid;
    grid-template-columns: minmax(340px, 1fr) 80px 110px auto auto auto;
    gap: 8px;
    align-items: end;
}

.doctor-patient-field input,
.doctor-mini-field input {
    border-radius: 9px;
    border: 1px solid var(--input-border);
    background: var(--input-bg);
    color: var(--input-ink);
    height: 34px;
}

.doctor-mini-field {
    font-size: 0.85rem;
}

.doctor-top-strip button {
    border-radius: 9px;
    padding: 8px 10px;
    min-height: 34px;
}

.doctor-medicine-wrap {
    border-radius: 10px;
    border: 1px solid var(--line);
    background: var(--panel-2);
    max-height: 420px;
}

.doctor-medicine-wrap th [data-doc-col-toggle] {
    margin-left: 6px;
    transform: translateY(1px);
    width: 12px;
    height: 12px;
    vertical-align: middle;
}

.doctor-medicine-wrap th {
    background: var(--table-head);
    border-bottom: 1px solid var(--line);
    color: var(--table-head-ink);
}

.doctor-medicine-wrap td {
    border-bottom: 1px solid var(--row-border);
    background: var(--panel);
    padding: 4px;
}

.doctor-medicine-wrap .med-line-no {
    text-align: center;
    font-weight: 700;
}

.doctor-medicine-wrap input {
    border-radius: 8px;
    border: 1px solid var(--input-border);
    background: var(--input-bg);
    color: var(--input-ink);
    height: 30px;
}

.doctor-medicine-wrap button {
    border-radius: 8px;
    padding: 6px 10px;
    width: 100%;
}

.doctor-comment-label textarea {
    border-radius: 10px;
    border: 1px solid var(--input-border);
    background: var(--input-bg);
    color: var(--input-ink);
    min-height: 98px;
}

.doctor-bottom-inputs {
    display: grid;
    grid-template-columns: 1fr;
    gap: 6px;
}

.doctor-bottom-inputs input {
    border-radius: 9px;
    border: 1px solid var(--input-border);
    background: var(--input-bg);
    color: var(--input-ink);
}

.doctor-hidden-fields {
    display: none;
}

.doctor-history-wrap {
    border: 1px solid var(--line);
    border-radius: 10px;
    margin-top: 4px;
}

.doctor-history-wrap th {
    background: var(--table-head);
    border-bottom: 1px solid var(--line);
    color: var(--table-head-ink);
}

.doctor-history-wrap td {
    background: var(--panel);
    border-bottom: 1px solid var(--row-border);
}

.modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(15, 30, 58, 0.45);
    display: grid;
    place-items: center;
    z-index: 120;
}

.modal-card {
    width: min(460px, 92vw);
    background: var(--panel);
    border: 1px solid var(--line);
    border-radius: 14px;
    box-shadow: 0 24px 44px rgba(12, 30, 61, 0.24);
    padding: 16px;
}

.modal-card h3 {
    margin: 0 0 10px;
}

.medicine-manager-modal {
    width: min(980px, 96vw);
}

.medicine-manager-grid {
    display: grid;
    grid-template-columns: minmax(320px, 1fr) minmax(340px, 1fr);
    gap: 14px;
}

.medicine-manager-list-wrap {
    border: 1px solid var(--line);
    border-radius: 10px;
    padding: 10px;
    background: var(--panel-2);
    display: grid;
    grid-template-rows: auto 1fr;
    gap: 8px;
    min-height: 420px;
}

.medicine-manager-list-wrap input {
    border: 1px solid var(--input-border);
    background: var(--input-bg);
    color: var(--input-ink);
    border-radius: 8px;
    height: 34px;
}

.medicine-manager-list {
    overflow: auto;
    display: grid;
    gap: 6px;
    align-content: start;
}

.medicine-manager-item {
    border: 1px solid var(--line);
    border-radius: 9px;
    background: var(--panel);
    padding: 8px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
}

.medicine-manager-item-main {
    min-width: 0;
    display: grid;
    gap: 2px;
}

.medicine-manager-item-main strong,
.medicine-manager-item-main small {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.medicine-manager-item-main small {
    color: var(--head-subtle);
}

.medicine-manager-item-actions {
    display: inline-flex;
    gap: 6px;
}

.medicine-manager-form {
    border: 1px solid var(--line);
    border-radius: 10px;
    padding: 10px;
    background: var(--panel);
}

.medicine-manager-empty {
    border: 1px dashed var(--line);
    border-radius: 8px;
    padding: 10px;
    color: var(--head-subtle);
    background: var(--panel);
}

.refresh-btn {
    background: linear-gradient(135deg, #22c55e, #16a34a);
    color: #fff;
    border: 1px solid #15803d;
}

.refresh-btn:hover {
    filter: brightness(1.05);
}

body[data-theme="dark"] .refresh-btn {
    background: linear-gradient(135deg, #22c55e, #1ea34a);
    border-color: #22c55e;
}

/* Table action buttons: distinct color per action */
.table-wrap [data-queue-open],
.table-wrap [data-doctor-open],
.table-wrap [data-dashboard-open-history] {
    background: #0f766e;
    border: 1px solid #0f5f59;
    color: #fff;
}

.table-wrap [data-queue-edit],
.table-wrap [data-user-edit],
.table-wrap [data-patient-select],
.table-wrap [data-show-visit] {
    background: #2563eb;
    border: 1px solid #1e4fbf;
    color: #fff;
}

.table-wrap [data-queue-print],
.table-wrap [data-print-visit] {
    background: #d97706;
    border: 1px solid #b45309;
    color: #fff;
}

.table-wrap [data-queue-cancel] {
    background: #64748b;
    border: 1px solid #475569;
    color: #fff;
}

.table-wrap [data-queue-delete],
.table-wrap [data-patient-delete],
.table-wrap [data-delete-visit] {
    background: #dc2626;
    border: 1px solid #b91c1c;
    color: #fff;
}

/* Doctor tab actions in dark-gray modern style */
#tab-doctor .table-wrap [data-doctor-open] {
    background: #3a4657;
    border: 1px solid #2a3443;
    color: #fff;
}

#tab-doctor .table-wrap [data-show-visit] {
    background: #4b5563;
    border: 1px solid #374151;
    color: #fff;
}

#tab-doctor .table-wrap [data-print-visit] {
    background: #6b7280;
    border: 1px solid #4b5563;
    color: #fff;
}

#tab-doctor .status-waiting,
#tab-doctor .status-in_consultation,
#tab-doctor .status-done,
#tab-doctor .status-cancelled {
    color: #f3f5f8;
    background: #4b5563;
    border-color: #374151;
}

#tab-doctor .queue-order-no {
    color: #f8fafc;
    background: #3a4657;
    border-color: #2a3443;
}

.icon-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.icon-btn::before {
    content: "";
    width: 14px;
    height: 14px;
    display: inline-block;
    background-color: currentColor;
    mask-repeat: no-repeat;
    mask-position: center;
    mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
    -webkit-mask-size: contain;
}

.icon-refresh::before {
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12 4a8 8 0 1 1-7.45 10.89a1 1 0 1 1 1.87-.7A6 6 0 1 0 12 6h-2.6a1 1 0 1 1 0-2H12Zm7 1v4a1 1 0 0 1-1 1h-4a1 1 0 1 1 0-2h1.85A8.96 8.96 0 0 0 12 5a1 1 0 1 1 0-2c2.42 0 4.62.96 6.24 2.51L18 5a1 1 0 1 1 2 0Z'/%3E%3C/svg%3E");
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12 4a8 8 0 1 1-7.45 10.89a1 1 0 1 1 1.87-.7A6 6 0 1 0 12 6h-2.6a1 1 0 1 1 0-2H12Zm7 1v4a1 1 0 0 1-1 1h-4a1 1 0 1 1 0-2h1.85A8.96 8.96 0 0 0 12 5a1 1 0 1 1 0-2c2.42 0 4.62.96 6.24 2.51L18 5a1 1 0 1 1 2 0Z'/%3E%3C/svg%3E");
}

.icon-theme::before {
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12.5 3a9 9 0 1 0 8.5 12a1 1 0 0 0-1.24-1.25A7 7 0 0 1 10.25 4.24A1 1 0 0 0 9 3.01A9.1 9.1 0 0 0 12.5 3Z'/%3E%3C/svg%3E");
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12.5 3a9 9 0 1 0 8.5 12a1 1 0 0 0-1.24-1.25A7 7 0 0 1 10.25 4.24A1 1 0 0 0 9 3.01A9.1 9.1 0 0 0 12.5 3Z'/%3E%3C/svg%3E");
}

body[data-theme="dark"] .icon-theme::before {
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12 4a1 1 0 0 1 1 1v1a1 1 0 1 1-2 0V5a1 1 0 0 1 1-1Zm0 13a1 1 0 0 1 1 1v1a1 1 0 1 1-2 0v-1a1 1 0 0 1 1-1Zm8-6a1 1 0 0 1 0 2h-1a1 1 0 1 1 0-2h1ZM6 12a1 1 0 0 1-1 1H4a1 1 0 1 1 0-2h1a1 1 0 0 1 1 1Zm10.95-5.54a1 1 0 0 1 1.41 1.42l-.7.7a1 1 0 1 1-1.42-1.41l.71-.71Zm-9.2 9.2a1 1 0 0 1 1.41 1.42l-.7.7a1 1 0 0 1-1.42-1.41l.71-.71Zm9.2 2.12a1 1 0 0 1-1.41 0l-.71-.71a1 1 0 1 1 1.42-1.41l.7.7a1 1 0 0 1 0 1.42Zm-9.2-9.2a1 1 0 0 1-1.41 0l-.71-.71A1 1 0 1 1 7.05 6.46l.7.7a1 1 0 0 1 0 1.42ZM12 8a4 4 0 1 1 0 8a4 4 0 0 1 0-8Z'/%3E%3C/svg%3E");
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12 4a1 1 0 0 1 1 1v1a1 1 0 1 1-2 0V5a1 1 0 0 1 1-1Zm0 13a1 1 0 0 1 1 1v1a1 1 0 1 1-2 0v-1a1 1 0 0 1 1-1Zm8-6a1 1 0 0 1 0 2h-1a1 1 0 1 1 0-2h1ZM6 12a1 1 0 0 1-1 1H4a1 1 0 1 1 0-2h1a1 1 0 0 1 1 1Zm10.95-5.54a1 1 0 0 1 1.41 1.42l-.7.7a1 1 0 1 1-1.42-1.41l.71-.71Zm-9.2 9.2a1 1 0 0 1 1.41 1.42l-.7.7a1 1 0 0 1-1.42-1.41l.71-.71Zm9.2 2.12a1 1 0 0 1-1.41 0l-.71-.71a1 1 0 1 1 1.42-1.41l.7.7a1 1 0 0 1 0 1.42Zm-9.2-9.2a1 1 0 0 1-1.41 0l-.71-.71A1 1 0 1 1 7.05 6.46l.7.7a1 1 0 0 1 0 1.42ZM12 8a4 4 0 1 1 0 8a4 4 0 0 1 0-8Z'/%3E%3C/svg%3E");
}

.icon-logout::before {
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M14 3a1 1 0 1 1 0 2h-6v14h6a1 1 0 1 1 0 2H7a1 1 0 0 1-1-1V4a1 1 0 0 1 1-1h7Zm2.7 4.3a1 1 0 0 1 1.4 0l4 4a1 1 0 0 1 0 1.4l-4 4a1 1 0 1 1-1.4-1.4L19 13h-8a1 1 0 1 1 0-2h8l-2.3-2.3a1 1 0 0 1 0-1.4Z'/%3E%3C/svg%3E");
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M14 3a1 1 0 1 1 0 2h-6v14h6a1 1 0 1 1 0 2H7a1 1 0 0 1-1-1V4a1 1 0 0 1 1-1h7Zm2.7 4.3a1 1 0 0 1 1.4 0l4 4a1 1 0 0 1 0 1.4l-4 4a1 1 0 1 1-1.4-1.4L19 13h-8a1 1 0 1 1 0-2h8l-2.3-2.3a1 1 0 0 1 0-1.4Z'/%3E%3C/svg%3E");
}

.icon-save::before {
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M5 3h11l3 3v13a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2Zm2 2v4h8V5H7Zm5 14a4 4 0 1 0 0-8a4 4 0 0 0 0 8Z'/%3E%3C/svg%3E");
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M5 3h11l3 3v13a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2Zm2 2v4h8V5H7Zm5 14a4 4 0 1 0 0-8a4 4 0 0 0 0 8Z'/%3E%3C/svg%3E");
}

.icon-print::before {
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M7 3h10v4H7V3Zm10 16H7v-5h10v5Zm2-10H5a2 2 0 0 0-2 2v5h2v-2h2v7h10v-7h2v2h2v-5a2 2 0 0 0-2-2Zm-3 1a1 1 0 1 1 0 2a1 1 0 0 1 0-2Z'/%3E%3C/svg%3E");
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M7 3h10v4H7V3Zm10 16H7v-5h10v5Zm2-10H5a2 2 0 0 0-2 2v5h2v-2h2v7h10v-7h2v2h2v-5a2 2 0 0 0-2-2Zm-3 1a1 1 0 1 1 0 2a1 1 0 0 1 0-2Z'/%3E%3C/svg%3E");
}

.icon-reset::before {
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12 5a7 7 0 1 1-6.32 10H3l3.5-4L10 15H7.8A5 5 0 1 0 12 7a1 1 0 1 1 0-2Z'/%3E%3C/svg%3E");
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12 5a7 7 0 1 1-6.32 10H3l3.5-4L10 15H7.8A5 5 0 1 0 12 7a1 1 0 1 1 0-2Z'/%3E%3C/svg%3E");
}

.icon-medicine::before {
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M6.2 5.8a4 4 0 1 1 5.6 5.6l-2.4 2.4L3.8 8.2l2.4-2.4Zm7.8 4.8L8.6 16l-2 2a3.5 3.5 0 0 0 5 5l2-2l5.4-5.4a3.5 3.5 0 1 0-5-5Z'/%3E%3C/svg%3E");
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M6.2 5.8a4 4 0 1 1 5.6 5.6l-2.4 2.4L3.8 8.2l2.4-2.4Zm7.8 4.8L8.6 16l-2 2a3.5 3.5 0 0 0 5 5l2-2l5.4-5.4a3.5 3.5 0 1 0-5-5Z'/%3E%3C/svg%3E");
}

.icon-note::before {
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M5 3h10l4 4v12a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2Zm2 6h10V7h-3a2 2 0 0 1-2-2H7v4Zm0 4h10v-2H7v2Zm0 4h7v-2H7v2Z'/%3E%3C/svg%3E");
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M5 3h10l4 4v12a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2Zm2 6h10V7h-3a2 2 0 0 1-2-2H7v4Zm0 4h10v-2H7v2Zm0 4h7v-2H7v2Z'/%3E%3C/svg%3E");
}

@media (max-width: 1100px) {
    .grid.two {
        grid-template-columns: 1fr;
    }

    .doctor-shell {
        grid-template-columns: 1fr;
        min-height: auto;
    }

    .doctor-side {
        border-right: 0 !important;
        border-bottom: 1px solid var(--line);
    }

    .doctor-top-strip {
        grid-template-columns: 1fr 1fr;
    }

    .medicine-manager-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 760px) {
    .grid-form,
    .grid.two-col-mini {
        grid-template-columns: 1fr;
    }

    .secretary-tag-grid {
        grid-template-columns: repeat(2, minmax(110px, 1fr));
    }

    .topbar {
        padding: 10px;
    }

    .tabs-toolbar {
        flex-direction: column;
        align-items: stretch;
    }

    .tabs-actions {
        width: 100%;
    }

    .tabs-actions button {
        flex: 1;
    }

    .section-hero {
        flex-direction: column;
        align-items: flex-start;
    }

    th,
    td {
        font-size: 0.83rem;
    }

    .doctor-top-strip {
        grid-template-columns: 1fr;
    }

    .patients-browser-header,
    .patients-browser-pagination {
        flex-direction: column;
        align-items: stretch;
    }

    .patients-browser-page-info {
        text-align: left;
    }
}
