/* Mediora design system v3 — "Bold modern"
   2026-06-11 — основан на C:\SourceCode\Mediora\Design\2026-06-11-redesign\
   Один CSS-набор переменных для всех ~39 страниц (главная, dashboard,
   admin, doctor cabinet, report, etc.). Манроп 800 для display, IBM Plex
   Mono для цифр, Heebo для HE. Поддерживает dark + light theme через
   html[data-theme="..."]. RTL поддерживается через [dir="rtl"]. */

:root {
    --teal:#00D4AA; --teal-2:#00B894;
    --green:#2FD08A; --amber:#F2A20C; --red:#FF5C5C; --purple:#7F77DD;

    --r-sm:8px; --r-md:12px; --r-lg:16px; --r-xl:22px;
    --r-tag:8px; --r-pill:999px;

    --font-display:"Manrope", system-ui, sans-serif;
    --font-ui:"Manrope", system-ui, sans-serif;
    --font-mono:"IBM Plex Mono", "SF Mono", Consolas, monospace;

    --maxw:1160px;
    --ease:cubic-bezier(.22, .61, .36, 1);

    --space-1:4px; --space-2:8px; --space-3:12px; --space-4:16px;
    --space-5:24px; --space-6:32px; --space-7:48px; --space-8:64px;
}

/* Hebrew font swap в RTL */
:root[dir="rtl"] {
    --font-display:"Heebo", system-ui, sans-serif;
    --font-ui:"Heebo", system-ui, sans-serif;
}

/* DARK THEME (default) */
:root[data-theme="dark"], :root {
    --bg:#0A1628;
    --bg-2:#0C1A2E;
    --surface:#102140;
    --surface-2:#15294A;
    --elevated:#1B3358;

    --line:rgba(255,255,255,.10);
    --line-2:rgba(255,255,255,.19);

    --text:#FFFFFF;
    --text-2:#AEBDCE;
    --text-3:#6F8298;

    --teal-tint:rgba(0,212,170,.14);
    --teal-ink:#3FE3C2;
    --green-tint:rgba(47,208,138,.15);
    --green-ink:#5FE0A8;
    --amber-tint:rgba(242,162,12,.16);
    --amber-ink:#FFC766;
    --red-tint:rgba(255,92,92,.16);
    --red-ink:#FF8585;
    --purple-tint:rgba(127,119,221,.18);
    --purple-ink:#AFA9EC;

    --on-teal:#04261F;
    --shadow:0 24px 60px rgba(0,0,0,.55);
    --shadow-sm:0 4px 18px rgba(0,0,0,.4);
}

/* LIGHT THEME */
:root[data-theme="light"] {
    --bg:#FFFFFF;
    --bg-2:#F1F6F8;
    --surface:#FFFFFF;
    --surface-2:#EEF3F6;
    --elevated:#FFFFFF;

    --line:#E3EAEF;
    --line-2:#CCD8DF;

    --text:#0A1628;
    --text-2:#41546A;
    --text-3:#74879A;

    --teal-tint:rgba(0,184,148,.13);
    --teal-ink:#067A63;
    --green-tint:rgba(23,160,107,.13);
    --green-ink:#0C8A57;
    --amber-tint:rgba(242,162,12,.15);
    --amber-ink:#9A6A0A;
    --red-tint:rgba(229,72,77,.11);
    --red-ink:#C0383C;
    --purple-tint:rgba(83,74,183,.12);
    --purple-ink:#3C3489;

    --on-teal:#04261F;
    --shadow:0 24px 58px rgba(20,42,67,.14);
    --shadow-sm:0 4px 18px rgba(20,42,67,.08);
}

/* ── reset + base ── */
.mv3 { box-sizing:border-box; }
.mv3 *,
.mv3 *::before,
.mv3 *::after { box-sizing:border-box; }

.mv3 {
    background:var(--bg);
    color:var(--text);
    font-family:var(--font-ui);
    font-size:17px;
    line-height:1.6;
    -webkit-font-smoothing:antialiased;
    transition:background .35s var(--ease), color .25s;
}

.mv3 h1, .mv3 h2, .mv3 h3 {
    font-family:var(--font-display);
    font-weight:800;
    line-height:1.04;
    letter-spacing:-.03em;
    margin:0;
}

.mv3 .mono {
    font-family:var(--font-mono);
    font-variant-numeric:tabular-nums;
}

.mv3 a { color:inherit; text-decoration:none; }

.mv3 :focus-visible {
    outline:3px solid var(--teal);
    outline-offset:2px;
    border-radius:6px;
}

.mv3-wrap { max-width:var(--maxw); margin:0 auto; padding:0 28px; }

/* ── eyebrow / titles / lead ── */
.mv3-eyebrow {
    display:inline-block;
    background:var(--teal);
    color:var(--on-teal);
    font-family:var(--font-ui);
    font-weight:800;
    font-size:11.5px;
    letter-spacing:.08em;
    text-transform:uppercase;
    padding:6px 12px;
    border-radius:var(--r-tag);
    margin:0 0 18px;
}

.mv3-title {
    font-size:clamp(2.1rem, 4vw, 3.1rem);
    letter-spacing:-.035em;
}

.mv3-lead {
    color:var(--text-2);
    max-width:54ch;
    font-size:1.1rem;
    font-weight:500;
}

/* ── buttons (pill) ── */
.mv3-btn {
    font-family:var(--font-ui);
    font-size:15px;
    font-weight:700;
    border-radius:var(--r-pill);
    padding:13px 26px;
    border:2px solid transparent;
    cursor:pointer;
    display:inline-flex;
    align-items:center;
    gap:8px;
    transition:transform .15s var(--ease), background .2s, box-shadow .2s, border-color .2s;
    text-decoration:none;
}
.mv3-btn:hover { transform:translateY(-2px); }
.mv3-btn:active { transform:translateY(0); }
.mv3-btn[disabled] { opacity:.5; cursor:not-allowed; }
.mv3-btn[disabled]:hover { transform:none; box-shadow:none; }

.mv3-btn--primary { background:var(--teal); color:var(--on-teal); }
.mv3-btn--primary:hover { background:var(--teal-2); box-shadow:0 12px 30px var(--teal-tint); }

.mv3-btn--secondary { background:transparent; color:var(--text); border-color:var(--line-2); }
.mv3-btn--secondary:hover { background:var(--surface-2); border-color:var(--text-3); }

.mv3-btn--ghost { background:transparent; color:var(--text-2); padding:10px 14px; border:none; font-weight:600; }
.mv3-btn--ghost:hover { color:var(--text); }

.mv3-btn--danger { background:transparent; color:var(--red-ink); border-color:color-mix(in srgb, var(--red) 50%, transparent); }
.mv3-btn--danger:hover { background:var(--red-tint); }

.mv3-btn--onteal { background:var(--on-teal); color:#fff; }
.mv3-btn--onteal:hover { background:#06352B; }

.mv3-btn--sm { padding:9px 17px; font-size:14px; }

/* ── form fields ── */
.mv3-field { display:block; margin-bottom:18px; max-width:380px; }
.mv3-field label { display:block; font-size:13px; font-weight:700; color:var(--text-2); margin-bottom:6px; }

.mv3-input {
    width:100%;
    height:46px;
    background:var(--surface);
    border:1.5px solid var(--line-2);
    border-radius:var(--r-md);
    color:var(--text);
    font-family:var(--font-ui);
    font-size:15px;
    font-weight:500;
    padding:0 14px;
    transition:border-color .2s, box-shadow .2s;
}
.mv3-input:focus { outline:none; border-color:var(--teal); box-shadow:0 0 0 4px var(--teal-tint); }
.mv3-input::placeholder { color:var(--text-3); }
.mv3-input.is-error { border-color:var(--red); }

.mv3-errmsg {
    font-size:12px;
    color:var(--red-ink);
    margin-top:6px;
    display:flex;
    align-items:center;
    gap:5px;
    font-weight:600;
}

/* OTP input row */
.mv3-otp { display:flex; gap:10px; }
.mv3-otp input {
    width:48px;
    height:58px;
    text-align:center;
    font-family:var(--font-mono);
    font-size:22px;
    font-weight:500;
    background:var(--surface);
    border:1.5px solid var(--line-2);
    border-radius:var(--r-md);
    color:var(--text);
}
.mv3-otp input:focus { outline:none; border-color:var(--teal); box-shadow:0 0 0 4px var(--teal-tint); }
.mv3-otp input.is-filled { border-color:var(--teal); background:var(--teal-tint); }

/* Toggle switch */
.mv3-tog { display:inline-flex; align-items:center; gap:10px; cursor:pointer; position:relative; }
.mv3-tog input { position:absolute; opacity:0; pointer-events:none; }
.mv3-tog__track {
    width:44px; height:25px;
    border-radius:999px;
    background:var(--surface-2);
    border:1px solid var(--line-2);
    position:relative;
    transition:background .2s;
}
.mv3-tog__knob {
    position:absolute;
    top:2px;
    inset-inline-start:2px;
    width:19px; height:19px;
    border-radius:50%;
    background:var(--text-3);
    transition:.2s var(--ease);
}
.mv3-tog input:checked + .mv3-tog__track { background:var(--teal); border-color:var(--teal); }
.mv3-tog input:checked + .mv3-tog__track .mv3-tog__knob {
    inset-inline-start:21px;
    background:var(--on-teal);
}

/* ── cards / grid ── */
.mv3-card {
    background:var(--surface);
    border:1px solid var(--line);
    border-radius:var(--r-lg);
    padding:22px;
    box-shadow:var(--shadow-sm);
}

.mv3-grid { display:grid; gap:18px; }
.mv3-grid--g2 { grid-template-columns:repeat(2, 1fr); }
.mv3-grid--g3 { grid-template-columns:repeat(3, 1fr); }
.mv3-grid--g4 { grid-template-columns:repeat(4, 1fr); }

@media (max-width: 720px) {
    .mv3-grid--g2, .mv3-grid--g3, .mv3-grid--g4 { grid-template-columns:1fr; }
}

/* ── chips (risk semantics — icon + color + word) ── */
.mv3-chip {
    display:inline-flex;
    align-items:center;
    gap:7px;
    font-size:12px;
    font-weight:700;
    padding:5px 12px 5px 9px;
    border-radius:var(--r-pill);
    border:1.5px solid;
}
.mv3-chip__ico { width:15px; height:15px; flex:none; }

.mv3-chip--norm {
    background:var(--green-tint);
    color:var(--green-ink);
    border-color:color-mix(in srgb, var(--green) 42%, transparent);
}
.mv3-chip--warn {
    background:var(--amber-tint);
    color:var(--amber-ink);
    border-color:color-mix(in srgb, var(--amber) 50%, transparent);
}
.mv3-chip--crit {
    background:var(--red-tint);
    color:var(--red-ink);
    border-color:color-mix(in srgb, var(--red) 55%, transparent);
}

/* ── alerts / disclaimers ── */
.mv3-alert {
    display:flex;
    gap:14px;
    align-items:flex-start;
    background:var(--red-tint);
    border:1.5px solid color-mix(in srgb, var(--red) 45%, transparent);
    border-radius:var(--r-md);
    padding:16px 18px;
}
.mv3-alert__icon { flex:none; color:var(--red-ink); }
.mv3-alert b { color:var(--red-ink); }

.mv3-disc {
    display:flex;
    gap:9px;
    align-items:flex-start;
    font-size:13px;
    color:var(--text-3);
    background:var(--bg-2);
    border-radius:var(--r-md);
    padding:11px 14px;
    border:1.5px dashed var(--line-2);
    font-weight:500;
}

/* ── reference-range track (signature component) ── */
.mv3-track {
    position:relative;
    height:8px;
    background:var(--bg-2);
    border-radius:999px;
    min-width:120px;
    border:1px solid var(--line);
}
.mv3-track__safe {
    position:absolute;
    top:-1px;
    height:8px;
    border-radius:999px;
    background:var(--teal-tint);
    border:1px solid color-mix(in srgb, var(--teal) 50%, transparent);
}
.mv3-track__dot {
    position:absolute;
    top:50%;
    width:14px; height:14px;
    border-radius:50%;
    transform:translate(-50%, -50%);
    border:2px solid var(--surface);
}
:root[dir="rtl"] .mv3-track__dot { transform:translate(50%, -50%); }
.mv3-track__dot--ok { background:var(--green); }
.mv3-track__dot--warn { background:var(--amber); }
.mv3-track__dot--crit { background:var(--red); }

/* Big readout — hero версия signature component */
.mv3-bigread { padding:24px 22px 8px; }
.mv3-bigread__name {
    font-size:12px;
    color:var(--text-3);
    font-family:var(--font-mono);
    letter-spacing:.06em;
    text-transform:uppercase;
    font-weight:600;
}
.mv3-bigread__num {
    font-family:var(--font-mono);
    font-weight:600;
    font-size:clamp(3.2rem, 7vw, 4.6rem);
    line-height:1;
    letter-spacing:-.05em;
    display:flex;
    align-items:baseline;
    gap:10px;
    margin:10px 0 4px;
}
.mv3-bigread__num .u {
    font-size:1.1rem;
    color:var(--text-3);
    letter-spacing:0;
    font-weight:500;
}
.mv3-bigread__num .dir {
    font-size:1.7rem;
    color:var(--amber-ink);
}

.mv3-bigtrack {
    position:relative;
    height:14px;
    background:var(--bg-2);
    border-radius:999px;
    margin:16px 0 8px;
    border:1px solid var(--line);
}
.mv3-bigtrack__safe {
    position:absolute;
    top:-1px;
    height:14px;
    border-radius:999px;
    background:var(--teal-tint);
    border:1.5px solid color-mix(in srgb, var(--teal) 55%, transparent);
}
.mv3-bigtrack__lbl {
    position:absolute;
    top:18px;
    font-family:var(--font-mono);
    font-size:10px;
    color:var(--text-3);
}
.mv3-bigtrack__dot {
    position:absolute;
    top:50%;
    width:22px; height:22px;
    border-radius:50%;
    transform:translate(-50%, -50%);
    border:3px solid var(--surface);
    box-shadow:0 3px 8px rgba(0,0,0,.4);
}
:root[dir="rtl"] .mv3-bigtrack__dot { transform:translate(50%, -50%); }

/* ── pill nav (language switcher / status filters) ── */
.mv3-pill-nav {
    display:inline-flex;
    background:var(--surface-2);
    border-radius:999px;
    padding:3px;
    gap:2px;
    border:1px solid var(--line);
}
.mv3-pill-nav button {
    border:none;
    background:transparent;
    color:var(--text-2);
    font-family:var(--font-mono);
    font-size:13px;
    padding:6px 12px;
    border-radius:999px;
    cursor:pointer;
    font-weight:600;
}
.mv3-pill-nav button[aria-pressed="true"],
.mv3-pill-nav button.is-active {
    background:var(--teal);
    color:var(--on-teal);
}

/* ── icon button (circular) ── */
.mv3-iconbtn {
    width:38px; height:38px;
    border-radius:50%;
    border:1px solid var(--line);
    background:transparent;
    color:var(--text-2);
    cursor:pointer;
    display:grid;
    place-items:center;
    transition:.2s;
}
.mv3-iconbtn:hover { background:var(--surface-2); color:var(--text); }

/* ── header / sticky chrome ── */
.mv3-header {
    position:sticky;
    top:0;
    z-index:60;
    backdrop-filter:blur(14px);
    background:color-mix(in srgb, var(--bg) 82%, transparent);
    border-bottom:1px solid var(--line);
}
.mv3-header .mv3-wrap {
    display:flex;
    align-items:center;
    gap:18px;
    height:66px;
}
.mv3-brand { display:flex; align-items:center; gap:10px; }
.mv3-logo { height:26px; width:auto; display:block; flex:none; }

/* ── CTA band — single boldest moment per page ── */
.mv3-cta-band {
    background:var(--teal);
    color:var(--on-teal);
    border-radius:var(--r-xl);
    padding:54px 48px;
    display:flex;
    align-items:center;
    gap:36px;
    flex-wrap:wrap;
    position:relative;
    overflow:hidden;
}
.mv3-cta-band::after {
    content:"";
    position:absolute;
    width:380px; height:380px;
    border-radius:50%;
    background:rgba(255,255,255,.10);
    inset-inline-end:-120px;
    bottom:-160px;
}
.mv3-cta-band h2 {
    font-size:clamp(1.9rem, 3.4vw, 2.7rem);
    max-width:18ch;
    position:relative;
    letter-spacing:-.035em;
}
.mv3-cta-band__r {
    margin-inline-start:auto;
    display:flex;
    flex-direction:column;
    gap:12px;
    position:relative;
}
.mv3-cta-band__note {
    font-size:12.5px;
    font-weight:600;
    opacity:.8;
    text-align:center;
}

/* ── reveal animation ── */
.mv3-reveal {
    opacity:0;
    transform:translateY(26px);
    transition:opacity .7s var(--ease), transform .7s var(--ease);
}
.mv3-reveal.is-in,
.mv3-reveal.is-revealed,
.mv3-reveal[data-revealed="true"] { opacity:1; transform:none; }

/* ── skeletons ── */
.mv3-sk {
    background:linear-gradient(90deg, var(--surface-2) 25%, var(--line) 37%, var(--surface-2) 63%);
    background-size:400% 100%;
    animation:mv3-sh 1.4s ease infinite;
    border-radius:var(--r-sm);
}
.mv3-sk-line { height:13px; margin:9px 0; border-radius:6px; }
@keyframes mv3-sh {
    0%   { background-position:100% 0; }
    100% { background-position:-100% 0; }
}

/* ── empty state ── */
.mv3-empty { text-align:center; padding:42px 20px; }
.mv3-empty__icon {
    width:64px; height:64px;
    border-radius:18px;
    background:var(--teal);
    display:grid;
    place-items:center;
    margin:0 auto 16px;
    color:var(--on-teal);
}

/* ── motion reduction ── */
@media (prefers-reduced-motion: reduce) {
    .mv3 *,
    .mv3 *::before,
    .mv3 *::after {
        animation:none !important;
        transition:none !important;
    }
    .mv3-reveal { opacity:1; transform:none; }
}

/* ── responsive — collapse grids на mobile ── */
@media (max-width: 880px) {
    .mv3-cta-band {
        flex-direction:column;
        align-items:flex-start;
        padding:38px 28px;
    }
    .mv3-cta-band__r { margin:0; align-self:stretch; }
}
