    /* Juurikääre: vahvistusmodaali .mdi-pagen ulkopuolella (pinonta / overflow). */
    .hapro-desktop-root {
        display: flex;
        flex-direction: column;
        flex: 1 1 auto;
        min-height: 0;
        width: 100%;
        position: relative;
        box-sizing: border-box;
    }
    /* Täyttää app-contentin (flex: app-content:has(.mdi-page) on app.css). */
    .mdi-page {
        display: flex; flex-direction: column;
        flex: 1 1 auto;
        min-height: 0;
        width: 100%;
        position: relative; overflow: hidden;
        margin: 0; max-width: none; box-sizing: border-box;
        background: var(--color-bg);
    }
    .hapro-top-stack {
        position: relative;
        z-index: 200;
        flex-shrink: 0;
        --mdi-topbar-h: 44px;
    }
    .mdi-topbar {
        height: 40px; flex-shrink: 0; display: flex; align-items: center; justify-content: space-between;
        padding: 0 12px; border-bottom: 1px solid var(--color-border); background: var(--color-surface);
        font-size: 13px;
    }
    .mdi-topbar--shell {
        height: 44px;
        padding: 0 14px;
        gap: 10px;
        /* Kevyt päävärisävy — erottuu harmaasta työalueesta; käyttäjän palkkiväri yliajaa inline-tyylillä */
        background: linear-gradient(
            180deg,
            color-mix(in srgb, var(--color-primary) 12%, var(--color-surface)) 0%,
            color-mix(in srgb, var(--color-primary) 5%, var(--color-surface)) 100%
        );
        border-bottom: 1px solid color-mix(in srgb, var(--color-primary) 20%, var(--color-border));
        box-shadow: 0 1px 0 color-mix(in srgb, var(--color-primary) 10%, transparent);
    }
    .mdi-topbar-dash-zone {
        flex: 1;
        min-width: 48px;
        align-self: stretch;
        background: transparent;
        border: none;
        box-shadow: none;
        cursor: default;
    }
    .mdi-topbar-dash-zone:hover {
        background: transparent;
        border: none;
    }
    .mdi-dash-header {
        display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px;
    }
    .mdi-dash-header-title { font-size: 13px; font-weight: 700; color: var(--color-text); }
    .mdi-dash-edit-btn {
        border: none; background: transparent; cursor: pointer; font-size: 14px;
        color: var(--color-text-muted); padding: 4px 8px; border-radius: 6px;
    }
    .mdi-dash-edit-btn:hover { background: var(--color-background-secondary, rgba(0,0,0,0.08)); color: var(--color-text); }
    .mdi-dash-empty { font-size: 12px; color: var(--color-text-muted); margin: 16px 0; }
    .mdi-dash-widget-grid {
        display: grid; grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
        gap: 12px;
    }
    .mdi-dash-widget {
        background: var(--color-background-primary, var(--color-bg));
        border: 0.5px solid var(--color-border-tertiary, var(--color-border));
        border-radius: 10px; padding: 12px 16px; min-height: 80px;
    }
    .mdi-dash-widget-head { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 6px; }
    .mdi-dash-widget-remove {
        border: none; background: transparent; cursor: pointer; font-size: 13px;
        color: var(--color-text-muted); padding: 0 4px; border-radius: 4px; line-height: 1;
    }
    .mdi-dash-widget-remove:hover { background: rgba(239,68,68,0.12); color: #ef4444; }
    .mdi-dash-w-h {
        font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em;
        color: var(--color-text-muted); margin: 0;
    }
    .mdi-dash-w-body { font-size: 12px; color: var(--color-text); }
    .mdi-dash-add-section { margin-top: 12px; padding-top: 12px; border-top: 0.5px solid var(--color-border-tertiary, var(--color-border)); }
    .mdi-dash-add-title { font-size: 10px; font-weight: 700; color: var(--color-text-muted); text-transform: uppercase; margin-bottom: 8px; }
    .mdi-dash-add-grid { display: flex; flex-wrap: wrap; gap: 6px; }
    .mdi-dash-add-btn {
        border: 1px dashed var(--color-border); border-radius: 6px; background: transparent;
        padding: 6px 10px; font-size: 11px; color: var(--color-text-muted); cursor: pointer;
    }
    .mdi-dash-add-btn:hover { border-color: var(--color-primary); color: var(--color-primary); background: color-mix(in srgb, var(--color-primary) 6%, transparent); }
    .mdi-dw-row {
        display: flex;
        align-items: center;
        gap: 8px;
        padding: 6px 0;
        border-bottom: 1px solid var(--color-border-light);
        text-decoration: none;
        color: inherit;
    }
    .mdi-dw-row:last-child { border-bottom: none; }
    a.mdi-dw-row:hover { color: var(--color-primary); }
    .mdi-dw-row-name { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-weight: 500; }
    .mdi-dw-row-meta { font-size: 10px; color: var(--color-text-muted); flex-shrink: 0; }
    .mdi-dash-w-ph { font-size: 11px; color: var(--color-text-muted); margin: 0; }
    .mdi-dash-to-dash { font-size: 11px; font-weight: 600; margin-top: 8px; display: inline-block; color: var(--color-primary); }

    /*
      Hapro widget-paneeli (Tilat/etusivu): ankkuri näytön yläreunaan (top: 0), ei yläpalkin alle.
      Yläpalkki korkeammalla z-indexillä jotta Hapro/näkymä/profiili pysyy klikattavina.
      Avattuna: max-height laskettu ilman palkin vähennystä; sisällölle padding-top ettei mene palkin alle.
    */
    .dashboard-panel.dashboard-panel--hapro {
        top: 0;
        z-index: 1;
    }
    #mdi-topbar.mdi-topbar--shell {
        position: relative;
        z-index: 2;
    }
    .dashboard-panel.dashboard-panel--hapro.peek {
        border-top: 0.5px solid var(--color-border-tertiary, var(--color-border));
        border-radius: 0 0 12px 12px;
    }
    .dashboard-panel.dashboard-panel--hapro.open {
        max-height: min(80vh, calc(100vh - 48px));
    }
    .dashboard-panel.dashboard-panel--hapro.open .dashboard-panel-inner {
        padding-top: calc(var(--mdi-topbar-h, 44px) + 10px);
    }
    .mdi-shell-brand-link {
        font-weight: 800; font-size: 15px; color: var(--color-primary); text-decoration: none;
        letter-spacing: -0.02em;
    }
    .mdi-shell-brand-link:hover { opacity: 0.92; }
    .mdi-topbar-center {
        position: absolute; left: 50%; transform: translateX(-50%);
        font-size: 13px; font-weight: 500; color: var(--color-text-primary, var(--color-text));
        white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 40%; pointer-events: none;
    }
    .mdi-topbar-end {
        display: flex;
        align-items: center;
        gap: 8px;
        flex-shrink: 0;
    }
    .mdi-topbar-view { position: relative; flex-shrink: 1; min-width: 0; max-width: 200px; }
    .mdi-topbar-view-btn {
        display: inline-flex;
        align-items: center;
        gap: 4px;
        max-width: 100%;
        height: 34px;
        padding: 0 10px 0 12px;
        border-radius: 8px;
        border: 1px solid var(--color-border);
        background: var(--color-bg);
        cursor: pointer;
        font-size: 12px;
        font-weight: 600;
        color: var(--color-text);
        box-shadow: 0 1px 2px rgba(0,0,0,.05);
    }
    .mdi-topbar-view-btn:hover { background: var(--color-border-light); }
    .mdi-topbar-view-txt { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; min-width: 0; }
    .mdi-topbar-view-chev { flex-shrink: 0; font-size: 10px; opacity: 0.65; line-height: 1; }
    .mdi-topbar-view-dd {
        position: absolute;
        top: calc(100% + 6px);
        right: 0;
        min-width: 220px;
        max-width: min(280px, 92vw);
        background: var(--color-background-secondary, var(--color-bg));
        border: 0.5px solid var(--color-border-tertiary, var(--color-border));
        border-radius: 10px;
        box-shadow: var(--shadow);
        padding: 8px 0;
        z-index: 9000;
        font-size: 13px;
        color: var(--color-text-primary, var(--color-text));
        max-height: min(420px, 78vh);
        overflow-y: auto;
    }
    .mdi-topbar-view-h {
        padding: 4px 14px 8px;
        font-size: 10px;
        font-weight: 700;
        text-transform: uppercase;
        letter-spacing: 0.06em;
        color: var(--color-text-muted);
    }
    .mdi-topbar-view-item {
        display: flex;
        align-items: center;
        gap: 8px;
        width: 100%;
        padding: 8px 14px;
        border: none;
        background: none;
        text-align: left;
        font: inherit;
        color: var(--color-text);
        cursor: pointer;
    }
    .mdi-topbar-view-item:hover { background: var(--color-border-light); }
    .mdi-topbar-view-item.current { background: color-mix(in srgb, var(--color-primary) 14%, transparent); font-weight: 600; }
    .mdi-topbar-view-check { flex-shrink: 0; width: 1em; color: var(--color-primary); font-weight: 800; }
    .mdi-topbar-view-name { min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
    .mdi-topbar-view-empty { padding: 8px 14px; font-size: 12px; color: var(--color-text-muted); }
    .mdi-topbar-view-sep { height: 1px; background: var(--color-border); margin: 6px 0; }
    .mdi-topbar-view-item--action { font-weight: 600; color: var(--color-primary); }
    .mdi-topbar-view-item--action:disabled { opacity: 0.45; cursor: not-allowed; color: var(--color-text-muted); }
    .mdi-topbar-view-item--danger {
        color: #b91c1c !important;
        font-weight: 600;
        font-size: 12px;
    }
    .mdi-topbar-view-item--danger:hover {
        background: color-mix(in srgb, #b91c1c 10%, var(--color-border-light, #e5e5e5)) !important;
    }
    .mdi-topbar-view-row {
        display: flex;
        align-items: stretch;
        gap: 4px;
        width: 100%;
    }
    .mdi-topbar-view-row .mdi-topbar-view-item { flex: 1 1 auto; min-width: 0; }
    .mdi-topbar-view-rename {
        flex-shrink: 0;
        width: 32px;
        min-height: 36px;
        border: 1px solid var(--color-border);
        border-radius: 8px;
        background: var(--color-bg);
        cursor: pointer;
        font-size: 14px;
        line-height: 1;
        color: var(--color-text-muted);
    }
    .mdi-topbar-view-rename:hover { background: var(--color-border-light); color: var(--color-text); }
    .mdi-topbar-view-actions {
        display: flex;
        flex-shrink: 0;
        gap: 4px;
        align-items: stretch;
        transition: opacity 0.12s ease, visibility 0.12s ease;
    }
    /* Muokkaa/poista vain rivin kohdalla (hiiri tai näppäimistöfokus); kosketuslaitteilla aina näkyvissä */
    @media (hover: hover) and (pointer: fine) {
        .mdi-topbar-view-row:not(:hover):not(:focus-within) .mdi-topbar-view-actions {
            opacity: 0;
            visibility: hidden;
            pointer-events: none;
        }
    }
    .mdi-topbar-view-delete {
        flex-shrink: 0;
        width: 32px;
        min-height: 36px;
        border: 1px solid var(--color-border);
        border-radius: 8px;
        background: var(--color-bg);
        cursor: pointer;
        font-size: 14px;
        line-height: 1;
        color: var(--color-text-muted);
    }
    .mdi-topbar-view-delete:hover { background: color-mix(in srgb, #b91c1c 12%, var(--color-bg)); color: #b91c1c; border-color: color-mix(in srgb, #b91c1c 35%, var(--color-border)); }
    .mdi-start-desktop-row {
        display: flex;
        align-items: stretch;
        gap: 4px;
        width: 100%;
    }
    .mdi-start-desktop-row .mdi-start-desktop-btn { flex: 1 1 auto; min-width: 0; }
    .mdi-start-desktop-rename {
        flex-shrink: 0;
        width: 28px;
        border: 1px solid color-mix(in srgb, var(--color-border) 70%, transparent);
        border-radius: 6px;
        background: var(--color-background-primary, var(--color-bg));
        cursor: pointer;
        font-size: 13px;
        color: var(--color-text-muted);
    }
    .mdi-start-desktop-rename:hover { background: var(--color-background-secondary, rgba(0,0,0,0.06)); color: var(--color-text); }
    .mdi-start-desktop-actions {
        display: flex;
        flex-shrink: 0;
        gap: 4px;
        align-items: stretch;
        transition: opacity 0.12s ease, visibility 0.12s ease;
    }
    @media (hover: hover) and (pointer: fine) {
        .mdi-start-desktop-row:not(:hover):not(:focus-within) .mdi-start-desktop-actions {
            opacity: 0;
            visibility: hidden;
            pointer-events: none;
        }
    }
    .mdi-start-desktop-delete {
        flex-shrink: 0;
        width: 28px;
        border: 1px solid color-mix(in srgb, var(--color-border) 70%, transparent);
        border-radius: 6px;
        background: var(--color-background-primary, var(--color-bg));
        cursor: pointer;
        font-size: 13px;
        color: var(--color-text-muted);
    }
    .mdi-start-desktop-delete:hover { background: color-mix(in srgb, #b91c1c 12%, var(--color-background-primary, var(--color-bg))); color: #b91c1c; }
    .mdi-start-desktop-btn--preset { font-size: 11px; text-align: left; }
    .mdi-snap-editor-layout-row {
        display: flex;
        flex-direction: column;
        gap: 4px;
        margin-bottom: 10px;
    }
    .mdi-snap-editor-layout-row label { font-size: 11px; font-weight: 600; color: var(--color-text-muted); }
    .mdi-snap-editor-layout-select {
        font-size: 12px;
        padding: 6px 10px;
        border-radius: 8px;
        border: 1px solid var(--color-border);
        background: var(--color-bg);
        color: var(--color-text);
        max-width: 100%;
    }
    .mdi-topbar-user { position: relative; flex-shrink: 0; }
    .mdi-topbar-user-btn {
        width: 34px; height: 34px; border-radius: 50%; border: 1px solid var(--color-border);
        background: var(--color-bg); cursor: pointer; font-size: 11px; font-weight: 800;
        color: var(--color-text); display: inline-flex; align-items: center; justify-content: center;
        box-shadow: 0 1px 2px rgba(0,0,0,.05); padding: 0; overflow: hidden;
    }
    .mdi-topbar-user-btn:hover { background: var(--color-border-light); }
    .mdi-topbar-user-dd {
        position: absolute; top: calc(100% + 6px); right: 0; min-width: 220px;
        background: var(--color-background-secondary, var(--color-bg)); border: 0.5px solid var(--color-border-tertiary, var(--color-border)); border-radius: 10px;
        box-shadow: var(--shadow); padding: 8px 0; z-index: 9000; font-size: 13px;
        color: var(--color-text-primary, var(--color-text));
    }
    .mdi-topbar-user-h { padding: 8px 14px 4px; font-weight: 700; color: var(--color-text); }
    .mdi-topbar-user-sub { padding: 0 14px 10px; font-size: 11px; color: var(--color-text-muted); border-bottom: 1px solid var(--color-border); margin-bottom: 4px; }
    .mdi-topbar-user-item {
        display: block; padding: 8px 14px; color: var(--color-text); text-decoration: none; cursor: pointer;
        border: none; width: 100%; text-align: left; background: none; font: inherit;
    }
    .mdi-topbar-user-item:hover { background: var(--color-border-light); }
    .mdi-topbar-user-item.logout { color: #b91c1c; }
    .mdi-topbar-left { display: flex; align-items: center; gap: 10px; }
    .mdi-fs-btn {
        flex-shrink: 0; width: 32px; height: 30px; padding: 0; border: 1px solid var(--color-border); border-radius: 6px;
        background: var(--color-bg); cursor: pointer; font-size: 16px; line-height: 1; color: var(--color-text);
        display: inline-flex; align-items: center; justify-content: center;
    }
    .mdi-fs-btn:hover { background: var(--color-border-light); border-color: var(--color-text-muted); }
    .mdi-fs-btn.on { border-color: var(--color-primary); background: color-mix(in srgb, var(--color-primary) 12%, transparent); }
    .mdi-back { background: none; border: none; color: var(--color-primary); cursor: pointer; font-size: 12px; }
    .mdi-back:hover { text-decoration: underline; }
    .mdi-tools { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
    .mdi-tool-btn { padding: 3px 8px; font-size: 11px; border: 1px solid var(--color-border); border-radius: 4px; background: var(--color-bg); cursor: pointer; transition: background .12s, color .12s, border-color .12s; }
    .mdi-tool-btn:hover { background: var(--color-primary, #2563eb); color: #fff; border-color: var(--color-primary, #2563eb); }
    .mdi-tool-btn.active { background: var(--color-primary); color: #fff; border-color: var(--color-primary); }

    /* Mittauksen asetukset — täytekuvio (ikonit kuten klassinen ml-pattern-btn) */
    .mdi-meas-fill-pattern-row {
        display: flex; flex-wrap: wrap; gap: 3px; margin-bottom: 4px; align-items: center;
    }
    .mdi-meas-fill-pattern-btn {
        padding: 3px 6px; font-size: 11px; border: 1px solid var(--color-border); border-radius: 3px;
        background: var(--color-bg, transparent); cursor: pointer; color: var(--color-text);
        min-width: 28px; text-align: center; line-height: 1.1;
        font-family: Consolas, "Cascadia Mono", "Segoe UI", monospace;
    }
    .mdi-meas-fill-pattern-btn:hover { background: var(--color-surface); }
    .mdi-meas-fill-pattern-btn.active {
        background: var(--color-primary); color: #fff; border-color: var(--color-primary);
    }

    /* Mittauksen asetukset — katto / kalteva: vaiheet (klassinen roof-phase-indicator) */
    .mdi-roof-phase-hint {
        font-size: 10px;
        font-weight: 600;
        color: var(--color-text-muted);
        margin: 8px 0 4px;
    }
    .mdi-roof-phase-indicator {
        display: flex;
        align-items: center;
        gap: 6px;
        flex-wrap: wrap;
        margin-bottom: 8px;
        padding: 8px 10px;
        border-radius: 8px;
        background: color-mix(in srgb, var(--color-primary, #8b5cf6) 10%, transparent);
        border: 1px solid color-mix(in srgb, var(--color-primary, #8b5cf6) 28%, var(--color-border));
    }
    .mdi-roof-phase-step {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        min-width: 22px;
        height: 22px;
        border-radius: 6px;
        font-size: 11px;
        font-weight: 700;
        flex-shrink: 0;
    }
    .mdi-roof-phase-step.active {
        background: var(--color-primary, #8b5cf6);
        color: #fff;
    }
    .mdi-roof-phase-step.done {
        background: #22c55e;
        color: #fff;
    }
    .mdi-roof-phase-step.pending {
        background: color-mix(in srgb, var(--color-primary) 18%, transparent);
        color: var(--color-text-muted);
    }
    .mdi-roof-phase-text {
        flex: 1;
        font-size: 11px;
        font-weight: 600;
        color: var(--color-text);
        min-width: 100px;
        line-height: 1.3;
    }
    .mdi-roof-skip-btn {
        font-size: 10px;
        padding: 4px 8px;
        border: 1px solid color-mix(in srgb, var(--color-primary) 45%, var(--color-border));
        border-radius: 6px;
        background: var(--color-bg);
        cursor: pointer;
        margin-right: 6px;
        margin-top: 2px;
        color: var(--color-text);
    }
    .mdi-roof-skip-btn:hover {
        background: var(--color-surface);
    }
    .mdi-roof-stop-btn {
        font-size: 10px;
        padding: 4px 8px;
        border: 1px solid #ef4444;
        border-radius: 6px;
        background: color-mix(in srgb, #ef4444 12%, transparent);
        color: #b91c1c;
        cursor: pointer;
        margin-top: 2px;
    }
    .mdi-roof-stop-btn:hover {
        background: color-mix(in srgb, #ef4444 22%, transparent);
    }

    /* Mittatiedot ?-popover: vaihdettu CSS-hoverista click-toggleen Razor-puolella (_mittatiedotHelpOpen). */

    .mdi-desktop {
        flex: 1; min-height: 0; position: relative;
        background: linear-gradient(135deg, color-mix(in srgb, var(--color-text) 5%, var(--color-background-primary) 95%) 0%, color-mix(in srgb, var(--color-text) 8%, var(--color-background-primary) 92%) 100%);
        overflow: hidden;
    }
    .mdi-fullpage-bg {
        position: fixed; inset: 0; z-index: 0; overflow: hidden; pointer-events: none;
    }
    .mdi-wallpaper-stack {
        position: absolute; inset: 0; z-index: 0; overflow: hidden; pointer-events: none;
    }
    .mdi-wallpaper-fill { position: absolute; inset: 0; }
    .mdi-wallpaper-yt {
        position: absolute; top: 0; left: 0; width: 100%; height: 100%; border: 0;
        pointer-events: none;
    }
    /* Widgetit auki: himmennä koko työpöytä (ikkunat mukaan). z-index < .hapro-top-stack (200); taskbar/start fixed korkeammalla. */
    .mdi-dash-workspace-backdrop {
        position: absolute;
        left: 0;
        right: 0;
        top: calc(var(--mdi-topbar-h, 44px) + env(safe-area-inset-top, 0px));
        bottom: 0;
        z-index: 199;
        pointer-events: auto;
        background: rgba(15, 23, 42, 0.55);
    }
    .mdi-windows-host { position: absolute; inset: 0; z-index: 1; pointer-events: none; }
    .mdi-window {
        position: absolute; display: flex; flex-direction: column; pointer-events: auto;
        border: 1px solid rgba(0,0,0,.28); border-radius: 6px;
        background: var(--color-bg);
        box-shadow: 0 12px 36px rgba(0,0,0,.32), 0 4px 10px rgba(0,0,0,.18), 0 1px 3px rgba(0,0,0,.14);
        min-width: 200px; min-height: 150px;
        overflow: hidden;
        user-select: none;
        -webkit-user-select: none;
    }
    .mdi-window[data-mdi-maximized="true"] {
        border: none; border-radius: 0; box-shadow: none;
    }
    /* Määrälaskenta: sivupalkin oikea hiiri (fixed-kontekstivalikko) ei saa jäädä overflow:hidden -leikkauksen taakse */
    .mdi-window--shell-overlay {
        overflow: visible;
    }
    .mdi-window--shell-overlay > .mdi-win-body.mdi-win-body-drawing {
        overflow: hidden;
        border-radius: 0 0 5px 5px;
    }
    .mdi-window--pinned {
        /* Pinned-tila selkeästi näkyväksi: punainen vasen reuna + otsikkopalkki
           punaiseksi vihjeiseksi. Näin käyttäjä huomaa jos ikkuna ei nouse eteen
           koska se on pinnattu (z-index 10M+ voittaa muut nostot). */
        box-shadow: -3px 0 0 0 #dc2626, 0 4px 14px rgba(0,0,0,.12) !important;
    }
    .mdi-window--pinned .mdi-win-head {
        background: linear-gradient(to right, rgba(220,38,38,0.12), rgba(220,38,38,0.04) 30%, transparent 70%);
    }
    .mdi-window--pinned .mdi-win-title::after {
        content: " • Päällimmäisenä";
        color: #dc2626;
        font-size: 0.85em;
        font-weight: 500;
    }
    .mdi-window:focus, .mdi-window:focus-visible, .mdi-window:focus-within {
        outline: none !important;
    }
    /* Aktiivinen MDI-ikkuna: 2 px aksenttiviiva yläreunassa + primary-tinttinen reunavarjo.
       Erottaa ikkunan työpöydän yläpalkista; inaktiiviset säilyttävät pelkän reunuksen. */
    .mdi-window:focus-within:not([data-mdi-maximized="true"]) {
        box-shadow:
            0 0 0 1px var(--color-primary, #2563eb),
            0 4px 16px rgba(37, 99, 235, 0.18),
            0 12px 36px rgba(0,0,0,.20) !important;
    }
    .mdi-window:not([data-mdi-maximized="true"])::before {
        content: '';
        position: absolute;
        top: 0; left: 0; right: 0;
        height: 0;
        background: var(--color-primary, #2563eb);
        z-index: 10;
        border-radius: 5px 5px 0 0;
        pointer-events: none;
        transition: height 0.12s ease;
    }
    .mdi-window:focus-within:not([data-mdi-maximized="true"])::before {
        height: 2px;
    }
    /* Pinned-ikkuna pitää oman punaisen aksenttinsa myös aktiivisena. */
    .mdi-window--pinned:focus-within:not([data-mdi-maximized="true"])::before {
        background: #dc2626;
    }
    .mdi-win-body :is(input, textarea, select) {
        user-select: text;
        -webkit-user-select: text;
    }
    .mdi-window-chrome {
        flex-shrink: 0;
        display: flex;
        flex-direction: column;
    }
    .mdi-win-head {
        height: 36px; flex-shrink: 0; display: flex; align-items: center; justify-content: space-between;
        padding: 0 8px 0 12px;
        background: var(--color-background-secondary, var(--color-surface));
        border-bottom: 0.5px solid var(--color-border-tertiary, var(--color-border));
        color: var(--color-text-primary, var(--color-text));
        cursor: grab; user-select: none; font-size: 13px; font-weight: 600;
    }
    .mdi-win-head:active { cursor: grabbing; }
    .mdi-win-head-main {
        display: flex; align-items: center; min-width: 0; flex: 1; gap: 0;
    }
    .mdi-win-type-ic {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        flex-shrink: 0;
        margin: 0 8px 0 2px;
        color: var(--color-text-muted);
    }
    .mdi-win-type-ic svg {
        display: block;
        width: 20px;
        height: 20px;
    }
    .mdi-desk-ic-svg svg {
        display: block;
        width: 18px;
        height: 18px;
        color: var(--color-text-muted);
    }
    .mdi-win-title {
        overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
        font-size: 13px; font-weight: 600; color: var(--color-text); min-width: 0;
    }
    .mdi-win-tabs-row {
        flex-shrink: 0;
        padding: 4px 8px 6px;
        background: var(--color-background-secondary, var(--color-surface));
        border-bottom: 0.5px solid var(--color-border-tertiary, var(--color-border));
    }
    .mdi-draw-tabstrip-body {
        display: flex; align-items: stretch; gap: 0; min-width: 0;
        flex-shrink: 0; padding: 2px 2px 0; margin: 0;
        background: var(--color-bg, #fff);
        border-bottom: none;
        z-index: 1;
    }
    .mdi-draw-tabstrip-body .mdi-tab-pill {
        border-radius: 6px 6px 0 0;
        border: 0.5px solid var(--color-border-tertiary, var(--color-border));
        border-bottom: none;
        margin: 0; padding: 4px 10px;
        background: var(--color-bg, #fff);
        color: var(--color-text-muted);
    }
    .mdi-draw-tabstrip-body .mdi-tab-pill:hover {
        color: var(--color-text);
    }
    .mdi-draw-tabstrip-body .mdi-tab-pill.active {
        border-color: transparent;
        border-bottom: none;
        background: #e5e7eb;
        color: var(--color-text);
        margin-bottom: -2px;
        z-index: 1;
    }
    /* Spinner-nuolet pois number-inputeista */
    .mdi-dshell input[type=number]::-webkit-inner-spin-button,
    .mdi-dshell input[type=number]::-webkit-outer-spin-button { -webkit-appearance: none; margin: 0; }
    .mdi-dshell input[type=number] { -moz-appearance: textfield; }
    .mdi-draw-tabs-wrap { display: flex; align-items: center; gap: 4px; min-width: 0; flex: 1; }
    .mdi-tab-menu { position: relative; flex-shrink: 0; }
    .mdi-tab-burger {
        width: 28px; height: 24px; border: none; border-radius: 4px; cursor: pointer;
        background: transparent; color: var(--color-text-muted); font-size: 14px; line-height: 1;
        display: inline-flex; align-items: center; justify-content: center;
    }
    .mdi-tab-burger:hover { background: var(--color-border-light); color: var(--color-text); }
    .mdi-tab-flyout {
        position: absolute; top: 100%; left: 0; margin-top: 4px; min-width: 220px; max-width: min(320px, 90vw);
        max-height: min(320px, 50vh); overflow-y: auto; z-index: 7100;
        background: var(--color-bg); border: 1px solid var(--color-border); border-radius: 8px;
        box-shadow: 0 10px 28px rgba(0,0,0,.18); padding: 6px 0; font-size: 12px;
    }
    .mdi-tab-fly-h {
        padding: 6px 12px 4px; font-size: 10px; font-weight: 700; color: var(--color-text-muted);
        text-transform: uppercase; letter-spacing: .04em;
    }
    .mdi-tab-fly-item {
        display: block; width: 100%; text-align: left; padding: 8px 12px; border: none; background: none;
        cursor: pointer; color: var(--color-text); overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
    }
    .mdi-tab-fly-item:hover { background: var(--color-border-light); }
    .mdi-tab-fly-item.active { background: color-mix(in srgb, var(--color-primary) 12%, transparent); font-weight: 600; }
    .mdi-tab-fly-muted { padding: 8px 12px; color: var(--color-text-muted); font-size: 11px; }
    .mdi-tab-strip-scroll {
        display: flex; align-items: stretch; gap: 3px; min-width: 0; flex: 1; overflow-x: auto;
        scrollbar-width: thin; padding: 2px 0;
    }
    .mdi-tab-pill {
        flex: 0 0 auto; display: inline-flex; align-items: center; gap: 2px; max-width: 160px;
        padding: 3px 4px 3px 10px; border-radius: 6px 6px 0 0; border: 1px solid transparent;
        border-bottom: none; cursor: pointer; font-size: 11px; font-weight: 500; color: var(--color-text-muted);
        background: color-mix(in srgb, var(--color-border-light) 50%, transparent);
        user-select: none; -webkit-user-select: none;
    }
    .mdi-tab-pill:hover { color: var(--color-text); background: color-mix(in srgb, var(--color-border) 35%, transparent); }
    .mdi-tab-pill.active {
        color: var(--color-text); background: var(--color-bg);
        border-color: var(--color-border); border-bottom-color: var(--color-bg); margin-bottom: -1px; z-index: 1;
    }
    .mdi-tab-title { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
    .mdi-tab-close {
        width: 20px; height: 20px; border: none; border-radius: 4px; cursor: pointer; flex-shrink: 0;
        background: transparent; color: var(--color-text-muted); font-size: 14px; line-height: 1;
        display: inline-flex; align-items: center; justify-content: center; padding: 0;
    }
    .mdi-tab-close:hover { background: var(--color-border); color: var(--color-text); }
    .mdi-tab-plus {
        flex: 0 0 auto; width: 28px; min-height: 24px; border: 1px dashed var(--color-border); border-radius: 6px;
        background: transparent; cursor: pointer; color: var(--color-text-muted); font-size: 16px; line-height: 1;
    }
    .mdi-tab-plus:hover { border-color: var(--color-primary); color: var(--color-primary); }
    .mdi-win-btns { display: flex; gap: 4px; }
    .mdi-win-btns button {
        width: 32px; height: 28px; border: none; border-radius: 4px; cursor: pointer; font-size: 14px;
        background: transparent; color: var(--color-text-muted);
        display: inline-flex; align-items: center; justify-content: center;
    }
    .mdi-win-btns button:hover { background: var(--color-border-light); color: var(--color-text); }
    .mdi-win-btns button.mdi-win-close:hover { background: #e81123; color: #fff; }
    .mdi-win-btns button.mdi-pin-top { font-size: 12px; line-height: 1; padding: 0 1px; }
    .mdi-win-btns button.mdi-pin-top.on {
        color: #dc2626;
        background: rgba(220,38,38,0.18);
        box-shadow: 0 0 0 1px #dc2626;
    }
    .mdi-win-body { flex: 1; min-height: 0; overflow: auto; padding: 8px; font-size: 12px; }
    .mdi-win-body.mdi-win-body-measlist {
        display: flex;
        flex-direction: column;
        min-height: 0;
        overflow: hidden;
        padding: 8px;
    }
    .mdi-window-content {
        overflow: auto;
        min-height: 0;
        flex: 1;
    }
    .mdi-win-body.mdi-win-body-measlist.mdi-window-content {
        overflow: hidden;
    }
    /* Suunnitelmat: täytä MDI-ruutu (klassinen määrälaskenta -tyyli); flex-ketju + ei ylimääräistä scrollia */
    .mdi-win-body.mdi-win-body-drawing {
        display: flex;
        flex-direction: column;
        flex: 1;
        min-height: 0;
        min-width: 0;
        overflow: hidden;
        padding: 0;
    }
    /* MaaralaskentaWindow juuri: koko ketju ikkunan body → shell → viewport */
    .mdi-drawing-root {
        flex: 1;
        min-height: 0;
        min-width: 0;
        display: flex;
        flex-direction: column;
        overflow: hidden;
    }
    .mdi-drawing-stack {
        flex: 1;
        min-height: 0;
        min-width: 0;
        display: flex;
        flex-direction: column;
        overflow: hidden;
        /* Yhteinen sävy: aktiivinen välilehti + PDF-alue ilman vaaleaa saumaa */
        --mdi-draw-tab-canvas-bg: #e5e7eb;
    }
    .mdi-drawing-canvas-column {
        position: relative;
    }
    .calibration-input-card {
        position: absolute;
        right: 16px;
        bottom: 48px;
        z-index: 1000;
        background: var(--color-background-primary, var(--color-bg, #fff));
        border: 0.5px solid var(--color-border-tertiary, var(--color-border));
        border-radius: var(--border-radius-lg, 10px);
        padding: 12px 16px;
        width: 220px;
        box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
    }
    .cal-card-title {
        font-size: 13px;
        font-weight: 500;
        margin-bottom: 10px;
        color: var(--color-text-primary, var(--color-text));
    }
    .cal-card-label {
        font-size: 12px;
        display: block;
        margin-bottom: 4px;
        color: var(--color-text);
    }
    .cal-input-row {
        display: flex;
        align-items: center;
        gap: 6px;
        margin: 8px 0;
    }
    .cal-input-row input {
        width: 120px;
        font-size: 16px;
        font-weight: 500;
        padding: 4px 8px;
        border: 1px solid var(--color-border);
        border-radius: 6px;
        background: var(--color-bg);
        color: var(--color-text);
    }
    .cal-card-hint {
        font-size: 11px;
        color: var(--color-text-tertiary, var(--color-text-muted));
        line-height: 1.4;
        margin-bottom: 10px;
    }
    .cal-card-footer {
        display: flex;
        justify-content: flex-end;
        gap: 6px;
        flex-wrap: wrap;
    }
    .cal-btn-primary {
        background: var(--color-primary, #2563eb) !important;
        color: #fff !important;
        border-color: var(--color-primary, #2563eb) !important;
    }
    /* Suunnitelmaikkuna: välitön vanhempi plans-viewportille (jos käytössä) */
    .mdi-drawing-viewport {
        position: relative;
        overflow: hidden;
        flex: 1;
        min-height: 0;
        min-width: 0;
        width: 100%;
        height: 100%;
        background: var(--mdi-draw-tab-canvas-bg, #e5e7eb);
    }
    /* mdiPlansViewer.js luo .mdi-plans-viewport (oikea host DOMissa) */
    .mdi-plans-viewport {
        background: var(--mdi-draw-tab-canvas-bg, #e5e7eb);
    }
    /* Mahdollinen tuleva käyttö: kehys ilman yläreunaa */
    .mdi-plans-host-stack {
        flex-direction: column;
        position: absolute;
        inset: 0;
        overflow: hidden;
        background: var(--mdi-draw-tab-canvas-bg, #e5e7eb);
        border-left: 1px solid var(--color-border);
        border-right: 1px solid var(--color-border);
        border-bottom: 1px solid var(--color-border);
        border-top: none;
        border-radius: 0 0 4px 4px;
        touch-action: none;
    }
    .mdi-plans-canvas-overlay {
        flex: 1;
        width: 100%;
        height: 100%;
        min-height: 0;
        display: block;
        background: var(--color-border-light, var(--color-border));
        touch-action: none;
    }
    /* Bluebeam-tyylinen paneeliarkkitehtuuri — positioning-konteksti sivupaneelille (top:0 = töökalurivin jälkeen, ei MDI-otsikon suhteessa). */
    .mdi-dshell { position: relative; display: flex; flex: 1; min-height: 0; min-width: 0; overflow: hidden; }
    .mdi-dshell-iconbar {
        width: 30px; flex-shrink: 0; display: flex; flex-direction: column; gap: 2px; padding: 4px 2px;
        background: var(--color-surface, #f1f5f9);
        border-right: 0.5px solid var(--color-border-tertiary, var(--color-border));
    }
    .mdi-dshell-iconbar--right {
        border-right: none;
        border-left: 0.5px solid var(--color-border-tertiary, var(--color-border));
    }
    .mdi-dshell-icon-btn {
        width: 26px; height: 26px; border: none; border-radius: 4px; background: transparent;
        display: flex; align-items: center; justify-content: center; cursor: pointer;
        color: var(--color-text-muted); padding: 0;
    }
    .mdi-dshell-icon-btn:hover { background: var(--color-background-secondary, rgba(0,0,0,0.06)); color: var(--color-text); }
    .mdi-dshell-icon-btn.active {
        background: color-mix(in srgb, var(--color-primary) 14%, transparent);
        color: var(--color-primary);
    }
    .mdi-dshell-icon-btn svg { width: 16px; height: 16px; display: block; }
    .mdi-dshell-sidepanel {
        position: absolute; top: 0; bottom: 0; z-index: 5000;
        display: flex; flex-direction: column;
        min-width: 100px;
        max-width: 500px;
        box-sizing: border-box;
        background: var(--color-bg); overflow: hidden;
        box-shadow: 0 2px 12px rgba(0,0,0,0.15);
    }
    .mdi-dshell-sidepanel:has(.mdi-add-files-backdrop) { z-index: 50000 !important; }
    .mdi-dshell-sidepanel--left { left: 30px; border-right: 0.5px solid var(--color-border-tertiary, var(--color-border)); }
    .mdi-dshell-sidepanel--right { right: 30px; border-left: 0.5px solid var(--color-border-tertiary, var(--color-border)); }
    .mdi-dshell-sidepanel-body { flex: 1; overflow-y: auto; font-size: 11px; }
    .mdi-dshell-splitter {
        position: absolute; top: 0; bottom: 0; width: 5px; z-index: 61; cursor: col-resize;
        background: transparent; touch-action: none;
    }
    /* dshell-splitter: left/right vain inline (Razor / drag-JS) */
    .mdi-dshell-splitter::before {
        content: ''; position: absolute; inset: 0 -3px; z-index: 1;
    }
    .mdi-dshell-splitter:hover, .mdi-dshell-splitter:active, .mdi-dshell-splitter.dragging {
        background: color-mix(in srgb, var(--color-primary) 20%, transparent);
    }
    .mdi-dshell-center { flex: 1; min-width: 0; display: flex; flex-direction: column; min-height: 0; position: relative; }

    /* Bluebeam-tyyli: tabi-rivi ja alapalkki siirtyvät — padding asetetaan inline-stylellä Razor:ssa */

    /* Kelluva mittausasetuslappu */
    .mdi-measure-float {
        /* right: var — Sivupaneeli (z 60) peittää keskialueen oikean reunan; offset = paneelin leveys + sama pieni väli kuin ShellPanelPadRight (+5). */
        position: absolute; top: 8px; right: var(--mdi-measure-float-right, 8px); z-index: 50;
        width: 240px; max-height: 50vh; overflow-y: auto;
        background: var(--color-surface, #fff); border: 1px solid var(--color-border);
        border-radius: 8px; box-shadow: 0 4px 16px rgba(0,0,0,.15);
    }
    .mdi-measure-float-open {
        position: absolute; top: 4px; right: 4px;
        border: none; background: none; cursor: pointer; font-size: 10px;
        color: var(--color-text-muted); padding: 2px 4px; border-radius: 3px;
    }
    .mdi-measure-float-open:hover { background: var(--color-hover); }

    /* Mittauksen asetukset — kelluva sticky note canvaksen päällä */
    .mdi-measure-lappu {
        position: absolute;
        bottom: 16px;
        right: 16px;
        width: min(820px, calc(100% - 32px));
        max-height: 60vh;
        background: var(--color-bg, #fff);
        border: 1.5px solid color-mix(in srgb, var(--color-border) 80%, #000 20%);
        border-radius: 8px;
        /* Vahvempi varjo — näkyy selvemmin canvaksen päällä, erottuu taustasta */
        box-shadow: 0 2px 6px rgba(0,0,0,0.10), 0 16px 40px rgba(0,0,0,0.28);
        display: flex;
        flex-direction: column;
        z-index: 5001;
        overflow: hidden;
        transition: width 0.15s ease-out;
        /* Piilotettu kunnes JS palauttaa sijainnin localStoragesta ja asettaa visible:ksi.
           Estää välähdyksen oletussijainnissa (oikea-ala) ennen tallennettuun siirtoa. */
        visibility: hidden;
    }
    /* Kapea-tila: vain kohdistus + syötettävät arvot (ei Mittatiedot-saraketta) */
    .mdi-measure-lappu.mdi-measure-lappu--narrow {
        width: min(560px, calc(100% - 32px));
    }
    .mdi-measure-lappu-header {
        display: flex; align-items: center; justify-content: space-between;
        padding: 6px 12px;
        background: var(--color-surface);
        border-bottom: 1px solid var(--color-border);
        cursor: move;
        user-select: none;
        flex-shrink: 0;
    }
    .mdi-measure-lappu-title {
        font-size: 11px; font-weight: 600; color: var(--color-text-muted);
        letter-spacing: 0.02em;
    }
    .mdi-measure-lappu-close {
        border: none; background: none; cursor: pointer;
        font-size: 18px; line-height: 1; color: var(--color-text-muted);
        padding: 2px 8px; border-radius: 4px;
        font-family: inherit; font-weight: 300;
    }
    .mdi-measure-lappu-close:hover { background: rgba(220,38,38,0.1); color: #dc2626; }

    /* Uusi: mittauksen asetukset -lapun yläpalkki (toolbar ikoneilla, korvaa otsikkopalkin) */
    .ml-lappu-toolbar {
        display: flex; align-items: center; gap: 2px; flex-wrap: wrap;
        padding: 4px 6px;
        background: var(--color-surface);
        border-bottom: 1px solid var(--color-border);
        cursor: move;
        user-select: none;
        flex-shrink: 0;
    }
    .ml-lappu-toolbar-grip {
        width: 14px; height: 22px; display: inline-flex; align-items: center; justify-content: center;
        color: var(--color-text-muted); cursor: move; opacity: 0.5; flex-shrink: 0;
    }
    .ml-tb-btn {
        display: inline-flex; align-items: center; justify-content: center;
        width: 26px; height: 26px;
        border: 1px solid transparent; border-radius: 4px;
        background: transparent; cursor: pointer; color: var(--color-text);
        position: relative; flex-shrink: 0;
    }
    .ml-tb-btn:hover:not(:disabled) { background: color-mix(in srgb, var(--color-primary) 10%, transparent); color: var(--color-primary); }
    .ml-tb-btn:disabled { opacity: 0.4; cursor: not-allowed; }
    .ml-tb-btn--danger:hover { background: rgba(220,38,38,0.12) !important; color: #dc2626 !important; }
    .ml-tb-btn--close { margin-left: auto; }
    .ml-tb-btn .ml-tb-chev {
        position: absolute; right: 1px; bottom: 0;
        font-size: 7px; line-height: 1; opacity: 0.7;
    }
    .ml-tb-split { display: inline-flex; position: relative; }
    .ml-tb-split-chev-btn {
        display: inline-flex; align-items: center; justify-content: center;
        width: 14px; height: 26px; border: 1px solid transparent; border-radius: 4px;
        background: transparent; cursor: pointer; color: var(--color-text-muted);
        font-size: 8px; flex-shrink: 0;
    }
    .ml-tb-split-chev-btn:hover { background: color-mix(in srgb, var(--color-primary) 10%, transparent); color: var(--color-primary); }
    .ml-tb-divider { width: 1px; height: 18px; background: var(--color-border); margin: 0 3px; flex-shrink: 0; }
    /* Tyyli-chip: swatch näyttää valitun värin + fill-patternin */
    .ml-tb-swatch {
        display: inline-block; width: 16px; height: 16px;
        border-radius: 3px; border: 1px solid rgba(0,0,0,0.25);
        position: relative; overflow: hidden;
    }

    /* Dropdown/overflow-valikko yläpalkista */
    .ml-tb-dropdown-backdrop { position: fixed; inset: 0; z-index: 10100; }
    .ml-tb-dropdown {
        position: fixed; z-index: 10101; min-width: 180px;
        background: var(--color-bg, #fff);
        border: 1px solid var(--color-border);
        border-radius: 6px;
        box-shadow: 0 6px 20px rgba(0,0,0,.15);
        padding: 3px 0;
        font-size: 11px;
    }
    .ml-tb-dropdown-item {
        display: flex; align-items: center; gap: 8px;
        width: 100%; padding: 5px 10px; border: none; background: transparent;
        cursor: pointer; text-align: left; font-size: 11px; color: var(--color-text);
    }
    .ml-tb-dropdown-item:hover { background: color-mix(in srgb, var(--color-primary) 10%, transparent); }
    .ml-tb-dropdown-item--selected { background: color-mix(in srgb, var(--color-primary) 16%, transparent); font-weight: 600; }
    .ml-tb-dropdown-ico { width: 22px; height: 22px; display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; }

    /* Tyyli-popover */
    .ml-style-pop-backdrop { position: fixed; inset: 0; z-index: 10100; }
    .ml-style-pop {
        position: fixed; z-index: 10101; width: 300px;
        background: var(--color-bg, #fff);
        border: 1px solid var(--color-border);
        border-radius: 8px;
        box-shadow: 0 8px 24px rgba(0,0,0,0.12);
        padding: 12px;
        font-size: 11px; color: var(--color-text);
    }
    .ml-style-color {
        aspect-ratio: 1; border-radius: 4px; cursor: pointer; box-sizing: border-box;
        border: 1px solid rgba(0,0,0,0.15);
    }
    .ml-style-color--selected { border-width: 2px; border-color: color-mix(in srgb, var(--color-primary) 80%, #000 20%); }
    .ml-style-lw-btn {
        width: 32px; height: 26px; border: 1px solid var(--color-border); border-radius: 4px;
        background: var(--color-bg, #fff); cursor: pointer;
        display: inline-flex; align-items: center; justify-content: center; padding: 0;
    }
    .ml-style-lw-btn--selected { border: 2px solid var(--color-primary); background: color-mix(in srgb, var(--color-primary) 8%, transparent); }
    .ml-style-toggle {
        display: flex; align-items: center; justify-content: center; gap: 5px;
        padding: 4px 8px; border-radius: 4px;
        border: 1px solid var(--color-border); background: var(--color-bg, #fff);
        color: var(--color-text-muted); cursor: pointer;
        font-size: 10px; font-weight: 500;
    }
    .ml-style-toggle--active { border-color: var(--color-primary); background: color-mix(in srgb, var(--color-primary) 12%, transparent); color: color-mix(in srgb, var(--color-primary) 80%, #000 20%); font-weight: 600; }
    .ml-style-fill-btn {
        height: 28px; border: 1px solid var(--color-border); border-radius: 4px;
        cursor: pointer; padding: 0;
    }
    .ml-style-fill-btn--selected { border: 2px solid var(--color-primary); }
    .mdi-measure-lappu-cols {
        display: flex; flex: 1; min-height: 0; overflow: hidden;
    }
    .mdi-measure-lappu-col {
        flex: 1; min-width: 0; overflow-y: auto; padding: 6px 10px; font-size: 11px;
    }
    .mdi-measure-lappu-splitter {
        width: 1px; flex-shrink: 0; background: var(--color-border);
    }

    /* Values-osio: syötettävät arvot YLÖS, mittatiedot ALAS — käyttäjäpalaute */
    .mdi-msettings--values { display: flex; flex-direction: column; }
    .mdi-msettings--values [data-mvalues="inputs"] { order: 1; }
    .mdi-msettings--values [data-mvalues="info"] { order: 2; margin-top: 8px; }

    /* Sivupaneelin yläreunan ikonirivi (sama idea kuin lappu-toolbarissa,
       mutta ilman sulje-X:ää ja monirivisenä kun leveys loppuu). */
    .mdi-msettings-toolbar {
        display: flex; flex-wrap: wrap; gap: 3px;
        margin-bottom: 8px; padding-bottom: 8px;
        border-bottom: 1px solid var(--color-border-light, rgba(0,0,0,.08));
    }
    .mdi-msettings-tb-btn {
        width: 26px; height: 24px;
        display: inline-flex; align-items: center; justify-content: center;
        border: 1px solid transparent; border-radius: 4px;
        background: transparent; color: var(--color-text); cursor: pointer;
        padding: 0;
    }
    .mdi-msettings-tb-btn:hover:not(:disabled) {
        background: var(--color-surface-hover, rgba(0,0,0,.04));
        border-color: var(--color-border, #e5e7eb);
    }
    .mdi-msettings-tb-btn:disabled { opacity: 0.35; cursor: default; }
    .mdi-msettings-tb-btn--danger:hover:not(:disabled) {
        background: rgba(220,38,38,.08); border-color: #dc2626; color: #dc2626;
    }
    .mdi-msettings-tb-btn svg { width: 14px; height: 14px; }
    .mdi-msettings-tb-split {
        display: inline-flex; align-items: center; gap: 0;
    }
    .mdi-msettings-tb-split .mdi-msettings-tb-btn { border-right: none; border-top-right-radius: 0; border-bottom-right-radius: 0; }
    .mdi-msettings-tb-chev {
        width: 12px; height: 24px; display: inline-flex; align-items: center; justify-content: center;
        border: 1px solid transparent; border-top-left-radius: 0; border-bottom-left-radius: 0;
        border-top-right-radius: 4px; border-bottom-right-radius: 4px;
        background: transparent; color: var(--color-text-muted); cursor: pointer; padding: 0;
        font-size: 9px; line-height: 1;
    }
    .mdi-msettings-tb-chev:hover:not(:disabled) {
        background: var(--color-surface-hover, rgba(0,0,0,.04));
        border-color: var(--color-border, #e5e7eb);
    }
    .mdi-msettings-tb-chev:disabled { opacity: 0.35; cursor: default; }
    .mdi-msettings-tb-dropdown {
        position: fixed; z-index: 100; background: var(--color-bg, #fff);
        border: 1px solid var(--color-border, #e5e7eb); border-radius: 6px;
        box-shadow: 0 4px 12px rgba(0,0,0,.12); min-width: 180px; padding: 2px 0;
    }
    .mdi-msettings-tb-dropdown-item {
        display: flex; align-items: center; gap: 8px; width: 100%;
        padding: 6px 10px; font-size: 11px; border: none; background: none;
        cursor: pointer; color: var(--color-text); text-align: left;
    }
    .mdi-msettings-tb-dropdown-item:hover { background: var(--color-surface-hover, rgba(0,0,0,.04)); }
    .mdi-msettings-tb-dropdown-ico { width: 16px; display: inline-flex; align-items: center; justify-content: center; color: var(--color-text-muted); }
    .mdi-msettings-tb-dropdown-ico svg { width: 14px; height: 14px; }

    /* Side panel (Section=null) järjestys:
       header/toolbar (order 0 default) → Nimi → Kansio → Syötettävät → Suoritteet/Rak → Tyyli → Mittatiedot.
       Juuren flex-column jotta order vaikuttaa. Data-mpart asetetaan razor:ssa. */
    .mdi-msettings-root-all { display: flex; flex-direction: column; }
    .mdi-msettings-root-all [data-mpart="nimi"] { order: 10; }
    .mdi-msettings-root-all [data-mpart="kansio"] { order: 20; }
    .mdi-msettings-root-all [data-mpart="inputs"] { order: 30; }
    .mdi-msettings-root-all [data-mpart="binds"] { order: 40; }
    .mdi-msettings-root-all [data-mpart="style"] { order: 50; }
    .mdi-msettings-root-all [data-mpart="mittatiedot"] { order: 60; margin-top: 8px; }

    /* Mittauslistan drag/drop — mittauksen siirto kansiosta toiseen */
    .mdi-meas-item-draggable { transition: opacity 0.15s; }
    .mdi-meas-item-draggable.mdi-meas-dragging { opacity: 0.4; }
    .mdi-meas-group-droptarget { transition: background 0.1s; }
    .mdi-meas-group-droptarget--over {
        background: rgba(37,99,235,0.12) !important;
        outline: 2px dashed var(--color-primary);
        outline-offset: -2px;
    }

    /* Mittatiedot-listan kollapsi-nappi */
    .mdi-msettings-collapse-btn {
        border: none; background: none; cursor: pointer;
        font-size: 12px; line-height: 1; color: var(--color-text-muted);
        padding: 2px 6px; border-radius: 3px;
    }
    .mdi-msettings-collapse-btn:hover { background: rgba(0,0,0,0.05); color: var(--color-text); }

    /* Section-rajaukset: piilota väärät osiot per sarake */
    .mdi-msettings--style [data-msection="bindings"],
    .mdi-msettings--style [data-msection="values"] { display: none !important; }
    .mdi-msettings--bindings [data-msection="style"],
    .mdi-msettings--bindings [data-msection="values"] { display: none !important; }
    .mdi-msettings--values [data-msection="style"],
    .mdi-msettings--values [data-msection="bindings"] { display: none !important; }
    /* values jaettuna kahteen alasarakkeeseen — values_inputs piilottaa info, values_info piilottaa inputs */
    .mdi-msettings--values-inputs [data-mvalues="info"] { display: none !important; }
    .mdi-msettings--values-info [data-mvalues="inputs"] { display: none !important; }

    .mdi-dtoolbar-group {
        display: flex; gap: 4px; align-items: center;
        padding: 0 4px 0 0; border-right: 1px solid var(--color-border-light, #e2e8f0); margin-right: 4px;
    }
    .mdi-dtoolbar-group--stacked {
        flex-direction: column; align-items: stretch; gap: 2px;
        padding-top: 2px; padding-bottom: 2px;
    }
    .mdi-dtoolbar-group-head {
        display: flex; align-items: center; justify-content: space-between; gap: 4px;
        min-height: 14px;
    }
    .mdi-dtoolbar-group-label {
        font-size: 9px; font-weight: 600; color: var(--color-text-muted); text-transform: uppercase; letter-spacing: 0.02em;
        white-space: nowrap;
    }
    .mdi-dtoolbar-group-btns {
        display: flex; flex-wrap: wrap; gap: 4px; align-items: center;
    }
    .mdi-dtoolbar-empty-hint {
        font-size: 11px; color: var(--color-text-muted); opacity: 0.65; padding: 2px 4px;
    }
    .mdi-dtoolbar-gear-btn {
        width: 20px; height: 18px; border: none; border-radius: 3px; background: transparent;
        cursor: pointer; font-size: 11px; color: var(--color-text-muted); display: flex; align-items: center; justify-content: center;
        flex-shrink: 0;
    }
    .mdi-dtoolbar-gear-btn:hover { background: var(--color-background-secondary, rgba(0,0,0,0.06)); color: var(--color-text); }
    .mdi-dtoolbar-meas-backdrop {
        position: fixed; inset: 0; z-index: 9998; background: transparent;
    }
    .mdi-dtoolbar-meas-panel {
        position: fixed; z-index: 9999; top: 52px; right: 12px;
        min-width: 220px; padding: 10px 12px;
        background: var(--color-surface, #fff); border: 1px solid var(--color-border);
        border-radius: 8px; box-shadow: 0 8px 24px rgba(0,0,0,.12);
        font-size: 11px;
    }
    .mdi-meas-color-dot {
        width: 20px; height: 20px; border-radius: 4px; border: 2px solid var(--color-border); cursor: pointer;
        padding: 0;
    }
    .mdi-meas-color-dot.active { outline: 2px solid var(--color-primary); outline-offset: 1px; }
    .mdi-meas-width-btn {
        min-width: 28px; padding: 3px 8px; font-size: 10px; border-radius: 4px;
        border: 1px solid var(--color-border); background: var(--color-bg); cursor: pointer; color: var(--color-text);
    }
    .mdi-meas-width-btn.active { border-color: var(--color-primary); background: color-mix(in srgb, var(--color-primary) 12%, transparent); font-weight: 600; }
    .mdi-meas-fill-select {
        width: 100%; font-size: 10px; padding: 4px 6px; border-radius: 4px; border: 1px solid var(--color-border);
        background: var(--color-bg); color: var(--color-text);
    }
    .mdi-dtoolbar-group:last-of-type { border-right: none; margin-right: 0; }

    /* Piirustyökalupalkki: ryhmäotsikko + ikonit, yhtenäinen nappikoko */
    .mdi-draw-toolbar-host .mdi-dtoolbar-group--stacked {
        padding-top: 0; padding-bottom: 0; gap: 1px;
    }
    .mdi-draw-toolbar-host .mdi-dtoolbar-group {
        padding-right: 2px; margin-right: 2px;
    }
    .mdi-draw-toolbar-host .mdi-tool-btn {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        padding: 4px 6px;
        min-width: 28px;
    }
    .mdi-draw-toolbar-host .mdi-tool-btn svg {
        width: 16px;
        height: 16px;
    }
    .mdi-dtoolbar-edit-btn, .mdi-dtoolbar-config-btn {
        width: 20px; height: 20px; border: none; border-radius: 3px; background: transparent;
        cursor: pointer; font-size: 11px; color: var(--color-text-muted); display: flex; align-items: center; justify-content: center;
    }
    .mdi-dtoolbar-edit-btn:hover, .mdi-dtoolbar-config-btn:hover { background: var(--color-background-secondary, rgba(0,0,0,0.06)); }
    .mdi-dtoolbar-editor {
        position: absolute; top: 100%; left: 0; z-index: 100; padding: 10px;
        background: var(--color-bg); border: 1px solid var(--color-border); border-radius: 8px;
        box-shadow: 0 4px 16px rgba(0,0,0,.12); min-width: 180px;
    }
    .mdi-panel-tool-btn {
        display: flex; align-items: center; gap: 6px; width: 100%; padding: 5px 8px;
        border: none; border-radius: 4px; background: transparent; cursor: pointer;
        font-size: 11px; color: var(--color-text); text-align: left;
    }
    .mdi-panel-tool-btn:hover { background: var(--color-background-secondary, rgba(0,0,0,0.06)); }
    .mdi-panel-tool-btn.active { background: color-mix(in srgb, var(--color-primary) 14%, transparent); color: var(--color-primary); font-weight: 600; }
    .mdi-page-card {
        border: 1px solid var(--color-border-tertiary, var(--color-border));
        border-radius: 4px; overflow: hidden; cursor: pointer; margin-bottom: 4px;
        background: var(--color-bg, #fff);
    }
    .mdi-page-card.active { border-color: var(--color-primary); border-width: 2px; }
    .mdi-page-card:hover { border-color: var(--color-primary); }
    .mdi-page-card-img { width: 100%; height: auto; display: block; background: white; }
    .mdi-page-card-placeholder {
        height: 60px; display: flex; align-items: center; justify-content: center;
        font-size: 16px; color: var(--color-text-muted); background: var(--color-surface, #f8fafc);
    }
    .mdi-file-thumb-card {
        border: 1px solid var(--color-border-tertiary, var(--color-border));
        border-radius: 4px; overflow: hidden; cursor: pointer; background: var(--color-bg, #fff);
    }
    .mdi-file-thumb-card.selected { border-color: var(--color-primary); border-width: 2px; }
    .mdi-file-thumb-card:hover { border-color: var(--color-primary); }
    .mdi-page-card-footer {
        display: flex; align-items: center; justify-content: space-between;
        padding: 2px 6px; font-size: 10px; background: var(--color-surface, #f8fafc);
    }
    .mdi-folder-panel {
        width: 180px; flex-shrink: 0; display: flex; flex-direction: column;
        border-right: 0.5px solid var(--color-border-tertiary, var(--color-border));
        background: var(--color-surface, #f8fafc); font-size: 11px; overflow: hidden;
    }
    .mdi-folder-panel.collapsed { width: 24px; }
    .mdi-folder-header {
        display: flex; align-items: center; justify-content: space-between;
        padding: 6px 8px; border-bottom: 0.5px solid var(--color-border-tertiary, var(--color-border));
    }
    .mdi-folder-title { font-size: 10px; font-weight: 700; text-transform: uppercase; color: var(--color-text-muted); letter-spacing: .04em; }
    .mdi-folder-toggle, .mdi-folder-expand {
        border: none; background: transparent; cursor: pointer; color: var(--color-text-muted);
        font-size: 11px; padding: 2px 4px; border-radius: 4px;
    }
    .mdi-folder-toggle:hover, .mdi-folder-expand:hover { background: var(--color-background-secondary, rgba(0,0,0,0.06)); }
    .mdi-folder-expand { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; }
    .mdi-add-files-backdrop {
        position: fixed; inset: 0; z-index: 20000000; background: rgba(0,0,0,0.2);
    }
    .mdi-add-files-dialog {
        position: fixed; left: 50%; top: 50%; transform: translate(-50%, -50%); z-index: 20000001;
        background: var(--color-bg, #fff); border: 1px solid var(--color-border);
        border-radius: 10px; box-shadow: 0 12px 40px rgba(0,0,0,0.18);
        padding: 20px; width: 440px; max-width: 90vw;
    }
    .mdi-folder-chips { display: flex; gap: 4px; flex-wrap: wrap; }
    .mdi-folder-chip {
        padding: 3px 10px; border-radius: 14px; border: 1px solid var(--color-border);
        font-size: 11px; cursor: pointer; background: var(--color-bg); color: var(--color-text);
    }
    .mdi-folder-chip:hover { background: var(--color-background-secondary, rgba(0,0,0,0.06)); }
    .mdi-folder-chip.active { background: color-mix(in srgb, var(--color-primary) 12%, transparent); color: var(--color-primary); border-color: var(--color-primary); font-weight: 600; }
    .mdi-dropzone {
        border: 1.5px dashed var(--color-border); border-radius: 8px; padding: 20px;
        text-align: center; cursor: pointer; min-height: 120px;
        display: flex; align-items: center; justify-content: center; margin: 10px 0;
        transition: background 0.15s, border-color 0.15s;
    }
    .mdi-dropzone.dragover { background: color-mix(in srgb, var(--color-primary) 6%, transparent); border-color: var(--color-primary); }
    .mdi-dropzone-file {
        display: flex; align-items: center; gap: 6px; padding: 4px 6px; border-radius: 4px; font-size: 12px;
    }
    .mdi-dropzone-file:hover { background: var(--color-background-secondary, rgba(0,0,0,0.04)); }
    .mdi-folder-tree { flex: 1; overflow-y: auto; padding: 4px 0; }
    .mdi-folder-row {
        display: flex; align-items: center; gap: 6px; width: 100%; padding: 7px 8px;
        border: none; background: transparent; cursor: pointer; font-size: 11px; color: var(--color-text); text-align: left;
        min-height: 30px;
    }
    .mdi-folder-row:hover { background: var(--color-background-secondary, rgba(0,0,0,0.06)); }
    .mdi-folder-arrow { width: 12px; flex-shrink: 0; font-size: 9px; color: var(--color-text-muted); }
    .mdi-folder-glyph {
        width: 16px;
        height: 16px;
        flex-shrink: 0;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        color: color-mix(in srgb, var(--color-text-muted) 92%, var(--color-text));
    }
    .mdi-folder-glyph svg { display: block; }
    .mdi-folder-icon { flex-shrink: 0; }
    .mdi-folder-name { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-weight: 600; }
    .mdi-folder-count { font-size: 10px; color: var(--color-text-muted); }
    .mdi-file-row {
        display: flex; align-items: center; gap: 6px; width: 100%; padding: 6px 8px 6px 28px;
        border: none; background: transparent; cursor: pointer; font-size: 11px; color: var(--color-text); text-align: left;
        min-height: 28px;
    }
    .mdi-file-row:hover { background: var(--color-background-secondary, rgba(0,0,0,0.06)); }
    .mdi-file-row.selected { background: color-mix(in srgb, var(--color-primary) 12%, transparent); color: var(--color-primary); font-weight: 600; }
    .mdi-file-icon { flex-shrink: 0; }
    .mdi-file-name { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
    .mdi-folder-empty { padding: 12px 8px; color: var(--color-text-muted); text-align: center; }
    .mdi-folder-footer { padding: 6px 8px; border-top: 0.5px solid var(--color-border-tertiary, var(--color-border)); }
    .mdi-folder-upload-input { display: none; }
    .mdi-folder-upload-btn {
        display: block; width: 100%; text-align: center; padding: 5px 8px; border-radius: 6px;
        border: 1px dashed var(--color-border); font-size: 11px; color: var(--color-text-muted); cursor: pointer;
    }
    .mdi-folder-upload-btn:hover { border-color: var(--color-primary); color: var(--color-primary); }
    .mdi-folder-addmenu {
        position: absolute; right: 0; top: 100%; z-index: 100; min-width: 180px;
        background: var(--color-bg); border: 1px solid var(--color-border); border-radius: 8px;
        box-shadow: 0 4px 16px rgba(0,0,0,.12); padding: 4px 0; font-size: 11px;
    }
    .mdi-folder-addmenu-h {
        padding: 6px 12px 2px; font-size: 9px; font-weight: 700; color: var(--color-primary);
        text-transform: uppercase; letter-spacing: .04em;
    }
    .mdi-folder-addmenu-item {
        display: flex; align-items: center; justify-content: space-between; gap: 8px;
        width: 100%; padding: 5px 12px; border: none; background: transparent;
        cursor: pointer; font-size: 11px; color: var(--color-text); text-align: left;
    }
    .mdi-folder-addmenu-item:hover { background: var(--color-background-secondary, rgba(0,0,0,0.06)); }
    .mdi-file-version {
        font-size: 9px; font-weight: 700; color: var(--color-text-muted);
        background: var(--color-border-light, #e2e8f0); border-radius: 3px; padding: 0 3px; flex-shrink: 0;
    }
    /* Määrälaskenta: alapalkki + toast; z-index > sivupaneeli (60) jotta toast ei jää moduulien alle */
    .mdi-drawing-footer-host {
        position: relative;
        flex-shrink: 0;
        z-index: 200;
    }
    .mdi-kohdistus-toast {
        /* Fixed sijoitus: toastin pitää näkyä sivuosioiden päällä, ei jäädä niiden alle.
           bottom: 80px — yläpuolella drawing-statusbarin (28px) + marginaali jotta ei osu
           tehtäväpalkkiin eikä statusbariin. */
        position: fixed;
        left: 50%;
        transform: translateX(-50%);
        bottom: 80px;
        max-width: 92vw;
        padding: 4px 4px 4px 4px;
        font-size: 11px;
        color: #16a34a;
        background: color-mix(in srgb, #22c55e 12%, var(--color-bg, #fff));
        border: 0.5px solid #bbf7d0;
        border-radius: 6px;
        pointer-events: none;
        box-shadow: 0 2px 10px rgba(0, 0, 0, 0.10), 0 -4px 12px rgba(0, 0, 0, 0.06);
        z-index: 9500;
        display: inline-flex;
        align-items: center;
        gap: 8px;
    }
    .mdi-kohdistus-toast > span:last-child { padding-right: 10px; }
    .mdi-kohdistus-toast-icon {
        display: inline-flex; align-items: center; justify-content: center;
        width: 20px; height: 20px; border-radius: 4px;
        background: #16a34a; color: #fff;
        font-size: 12px; line-height: 1; font-weight: bold;
        flex-shrink: 0;
    }
    .mdi-kohdistus-toast--warn {
        color: #b45309;
        background: color-mix(in srgb, #f59e0b 12%, var(--color-bg, #fff));
        border-color: #fde68a;
    }
    .mdi-kohdistus-toast--warn .mdi-kohdistus-toast-icon { background: #b45309; }
    /* Estä kahden toastin päällekkäisyys: kun "Tallennus kesken" -toast on näkyvissä,
       piilota kohdistus-toast. Save-in-progress on etusijalla koska se estää tarkemman toimintaketjun. */
    body.ml-save-in-progress .mdi-kohdistus-toast { display: none !important; }
    .mdi-drawing-statusbar {
        position: relative;
        height: 28px; flex-shrink: 0; display: flex; align-items: center; gap: 4px; padding: 0 8px;
        border-top: 0.5px solid var(--color-border-tertiary, var(--color-border));
        font-size: 11px; color: var(--color-text-muted);
    }
    /* Statusbarin alin 8px päästää reunaa-venytä-klikit läpi — napit/inputit pysyvät klikattavina */
    .mdi-drawing-statusbar > :is(button, input, select, .mdi-statusbar-zoom, label) {
        position: relative; z-index: 1;
    }
    .mdi-statusbar-btn {
        width: 22px; height: 22px; border: none; border-radius: 4px; background: transparent;
        cursor: pointer; display: inline-flex; align-items: center; justify-content: center;
        color: var(--color-text-muted); font-size: 13px; padding: 0;
    }
    /* Määrälaskenta: kiertopainikkeet tiiviimpänä */
    .mdi-statusbar-btn.mdi-statusbar-btn--rotate {
        width: 18px;
        height: 18px;
        min-width: 18px;
        border-radius: 3px;
    }
    .mdi-statusbar-btn.mdi-statusbar-btn--rotate svg {
        width: 10px;
        height: 10px;
        flex-shrink: 0;
    }
    .mdi-statusbar-btn:hover { background: var(--color-primary, #2563eb); color: #fff; }
    .mdi-statusbar-zoom { font-variant-numeric: tabular-nums; min-width: 36px; text-align: center; }
    .mdi-statusbar-input {
        width: 36px; padding: 1px 3px; font-size: 10px; font-variant-numeric: tabular-nums;
        border: 1px solid var(--color-border-tertiary, var(--color-border)); border-radius: 3px;
        background: var(--color-bg, #fff); color: var(--color-text); text-align: center;
        outline: none; -moz-appearance: textfield;
    }
    .mdi-statusbar-input::-webkit-inner-spin-button,
    .mdi-statusbar-input::-webkit-outer-spin-button,
    .mdi-no-spin::-webkit-inner-spin-button,
    .mdi-no-spin::-webkit-outer-spin-button { -webkit-appearance: none; margin: 0; }
    .mdi-no-spin { -moz-appearance: textfield; appearance: textfield; }
    .mdi-statusbar-input:focus { border-color: var(--color-primary); }
    .mdi-statusbar-scale { font-weight: 600; }
    .mdi-scale-btn {
        font-size: 10px; padding: 1px 6px; border-radius: 4px; cursor: pointer;
        border: 1px solid var(--color-border); background: transparent; white-space: nowrap;
    }
    .mdi-scale-ok { color: #16a34a; border-color: #bbf7d0; }
    .mdi-scale-unset { color: #dc2626; border-color: #fca5a5; }
    .mdi-scale-dropdown {
        position: absolute; bottom: 100%; right: 0; margin-bottom: 4px;
        background: var(--color-bg, #fff); border: 1px solid var(--color-border);
        border-radius: 8px; box-shadow: 0 -4px 16px rgba(0,0,0,0.12);
        min-width: 160px; padding: 4px 0; z-index: 100;
    }
    .mdi-scale-item {
        display: block; width: 100%; text-align: left; border: none; background: none;
        padding: 4px 12px; font-size: 11px; cursor: pointer; color: var(--color-text);
    }
    .mdi-scale-item:hover { background: var(--color-background-secondary, rgba(0,0,0,0.06)); }
    .mdi-scale-item.active { font-weight: 700; color: var(--color-primary); }
    /* Vanha ctx-menu poistettu — yhtenäinen tyyli alla (rivi ~1660) */
    .mdi-shortcuts-panel {
        position: absolute; right: 0; top: 100%; z-index: 10001; width: 280px;
        background: var(--color-bg, #fff); border: 1px solid var(--color-border);
        border-radius: 8px; box-shadow: 0 4px 20px rgba(0,0,0,.25), 0 1px 4px rgba(0,0,0,.1);
        padding: 12px; max-height: 70vh; overflow-y: auto; font-size: 11px;
    }
    .mdi-sc-section {
        font-size: 10px; font-weight: 700; color: var(--color-text-muted);
        text-transform: uppercase; letter-spacing: 0.04em; margin: 8px 0 4px; padding-top: 4px;
        border-top: 0.5px solid var(--color-border-tertiary, var(--color-border));
    }
    .mdi-sc-section:first-of-type { border-top: none; margin-top: 0; }
    .mdi-sc-row {
        display: flex; justify-content: space-between; padding: 2px 0;
    }
    .mdi-sc-row > span:first-child {
        font-weight: 600; font-family: monospace; font-size: 10px;
        background: var(--color-surface, #f1f5f9); padding: 1px 4px; border-radius: 3px;
        border: 0.5px solid var(--color-border-tertiary);
    }
    .mdi-statusbar-sep { color: var(--color-border); margin: 0 2px; }
    .mdi-statusbar-hint { font-size: 10px; color: var(--color-text-muted); margin-left: auto; }
    body.mdi-desktop-interacting {
        user-select: none !important;
        -webkit-user-select: none !important;
    }
    .mdi-desktop.is-dragging .mdi-window:not(.dragging) {
        pointer-events: none;
        will-change: auto;
    }
    /* Win11-tyylinen snap-apu (desktopInterop.js dynaaminen paneeli) */
    .mdi-snap-assist--floating {
        transform: translateX(-50%) translateY(-100%);
        opacity: 0;
        pointer-events: none;
        transition: transform 0.2s ease, opacity 0.15s ease;
    }
    .mdi-snap-assist--floating.peek {
        transform: translateX(-50%) translateY(-30%);
        opacity: 0.92;
        pointer-events: none;
    }
    .mdi-snap-assist--floating.open {
        transform: translateX(-50%) translateY(8px);
        opacity: 1;
        pointer-events: auto;
    }
    .mdi-snap-assist-inner { user-select: none; -webkit-user-select: none; }
    .mdi-snap-assist-card {
        background: color-mix(in srgb, var(--color-background-secondary, var(--color-surface)) 96%, var(--color-text) 4%);
        border: 0.5px solid var(--color-border-tertiary, var(--color-border));
        box-shadow: inset 0 1px 0 color-mix(in srgb, var(--color-text) 6%, transparent);
        transition: border-color 0.15s ease, box-shadow 0.15s ease;
    }
    .mdi-snap-assist-card:hover {
        border-color: var(--color-border, var(--color-border-tertiary));
        box-shadow: inset 0 1px 0 color-mix(in srgb, var(--color-text) 8%, transparent), 0 0 0 1px color-mix(in srgb, var(--color-primary) 18%, transparent);
    }
    .mdi-snap-assist-cell {
        border: 0.5px solid var(--color-border-tertiary, var(--color-border)) !important;
        background: color-mix(in srgb, var(--color-border-light) 55%, var(--color-background-secondary, var(--color-surface)) 45%) !important;
        transition: background 0.12s ease, border-color 0.12s ease, box-shadow 0.12s ease, opacity 0.12s ease;
    }
    .mdi-snap-assist-card:has(.mdi-snap-assist-cell--hover) .mdi-snap-assist-cell:not(.mdi-snap-assist-cell--hover),
    .mdi-snap-assist-card:has(.mdi-snap-assist-cell:hover) .mdi-snap-assist-cell:not(:hover) {
        opacity: 0.4;
    }
    .mdi-snap-assist-cell--hover,
    .mdi-snap-assist-cell:hover {
        opacity: 1 !important;
        background: color-mix(in srgb, var(--color-primary) 22%, var(--color-background-secondary, var(--color-surface)) 78%) !important;
        border-color: color-mix(in srgb, var(--color-primary) 45%, var(--color-border) 55%) !important;
        box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--color-primary) 12%, transparent), 0 0 12px color-mix(in srgb, var(--color-primary) 22%, transparent) !important;
    }
    /* Snap Assist (jakamisen jälkeen): valitse ikkuna viereiseen puoliskoon — Win11-tyyli */
    .mdi-snap-assist-backdrop {
        position: absolute;
        inset: 0;
        z-index: 10050;
        border-radius: 0;
        background: transparent;
        pointer-events: auto;
    }
    .mdi-snap-assist-outline {
        position: absolute;
        z-index: 10051;
        box-sizing: border-box;
        border: 2px solid color-mix(in srgb, var(--color-primary) 50%, var(--color-border) 50%);
        border-radius: 10px;
        pointer-events: none;
        box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--color-background-secondary, var(--color-surface)) 35%, transparent), 0 8px 28px color-mix(in srgb, var(--color-primary) 18%, transparent);
        background: rgba(59,130,246,0.06);
    }
    .mdi-snap-assist-strip-outer {
        position: absolute;
        z-index: 10052;
        pointer-events: none;
        display: flex;
        flex-direction: column;
        align-items: stretch;
        gap: 8px;
        transform: translate(-50%, -50%);
        box-sizing: border-box;
    }
    .mdi-snap-assist-strip {
        pointer-events: auto;
        padding: 6px;
        border-radius: 10px;
        background: transparent;
        border: none;
        color: var(--color-text-primary, var(--color-text));
        box-shadow: none;
        outline: none;
    }
    .mdi-snap-assist-strip:focus-visible {
        box-shadow: none;
    }
    .mdi-snap-assist-strip-h {
        font-size: 11px;
        font-weight: 600;
        color: var(--color-text-primary, var(--color-text));
        margin-bottom: 8px;
        letter-spacing: 0.02em;
    }
    .mdi-snap-assist-tiles {
        display: flex;
        flex-wrap: wrap;
        gap: 8px;
        max-height: 200px;
        overflow-y: auto;
    }
    .mdi-snap-assist-tiles { max-height: none; overflow: visible; }
    .mdi-snap-assist-tile {
        display: flex; flex-direction: column; align-items: center; gap: 4px;
        width: 120px; padding: 4px; border-radius: 8px;
        border: 1px solid var(--color-border-tertiary, var(--color-border));
        background: var(--color-bg); color: var(--color-text);
        cursor: pointer; font-size: 10px; transition: border-color 0.12s ease;
    }
    .mdi-snap-assist-tile:hover { border-color: #0078d4; }
    .mdi-snap-assist-tile-preview {
        width: 112px; height: 70px; border-radius: 4px; overflow: hidden;
        background: var(--color-surface); position: relative;
    }
    .mdi-snap-assist-tile-title {
        max-width: 100%; overflow: hidden; text-overflow: ellipsis;
        white-space: nowrap; text-align: center;
        word-break: break-word;
    }
    .mdi-snap-splitter {
        position: absolute;
        pointer-events: auto;
        box-sizing: border-box;
        touch-action: none;
    }
    .mdi-snap-splitter--lr {
        cursor: col-resize;
        width: 8px;
        margin-left: -4px;
        border-left: 2px solid rgba(148,163,184,0.28);
        background: rgba(148,163,184,0.06);
        transition: border-color 0.15s ease, background 0.15s ease;
    }
    .mdi-snap-splitter--lr:hover,
    .mdi-snap-splitter--lr:focus-visible {
        border-left-color: rgba(100,116,139,0.65);
        background: rgba(59,130,246,0.12);
    }
    .mdi-snap-splitter--lr::after {
        content: '';
        position: absolute;
        left: 50%;
        top: 50%;
        transform: translate(-50%, -50%);
        width: 4px;
        height: 52px;
        border-radius: 4px;
        background: rgba(51,65,85,0.55);
        box-shadow: 0 1px 3px rgba(0,0,0,0.2);
        pointer-events: none;
        opacity: 0.55;
        transition: opacity 0.15s ease, background 0.15s ease;
    }
    .mdi-snap-splitter--lr:hover::after,
    .mdi-snap-splitter--lr:focus-visible::after {
        opacity: 1;
        background: rgba(71,85,105,0.85);
    }
    .mdi-snap-splitter--tb {
        cursor: row-resize;
        height: 8px;
        margin-top: -4px;
        border-top: 2px solid rgba(148,163,184,0.28);
        background: rgba(148,163,184,0.06);
        transition: border-color 0.15s ease, background 0.15s ease;
    }
    .mdi-snap-splitter--tb:hover,
    .mdi-snap-splitter--tb:focus-visible {
        border-top-color: rgba(100,116,139,0.65);
        background: rgba(59,130,246,0.12);
    }
    .mdi-snap-splitter--tb::after {
        content: '';
        position: absolute;
        left: 50%;
        top: 50%;
        transform: translate(-50%, -50%);
        width: 52px;
        height: 4px;
        border-radius: 4px;
        background: rgba(51,65,85,0.55);
        box-shadow: 0 1px 3px rgba(0,0,0,0.2);
        pointer-events: none;
        opacity: 0.55;
        transition: opacity 0.15s ease, background 0.15s ease;
    }
    .mdi-snap-splitter--tb:hover::after,
    .mdi-snap-splitter--tb:focus-visible::after {
        opacity: 1;
        background: rgba(71,85,105,0.85);
    }
    /* Modaali (fixed) ikkunan sisällä jää MDI-snap- tai dshell-splittern alle pinossa; piilota ja poista osumat. */
    body.mdi-snap-splitters-blocked .mdi-snap-splitter,
    body.mdi-snap-splitters-blocked .mdi-dshell-splitter {
        visibility: hidden !important;
        pointer-events: none !important;
    }
    .mdi-resize-handle {
        position: absolute;
        z-index: 10000002;
        box-sizing: border-box;
        touch-action: none;
        pointer-events: auto;
    }
    .mdi-resize-handle.corner { width: 20px; height: 20px; }
    .mdi-resize-n { left: 18px; right: 18px; top: -4px; height: 10px; cursor: ns-resize; }
    .mdi-resize-s { left: 18px; right: 18px; bottom: -4px; height: 14px; cursor: ns-resize; }
    .mdi-resize-e { top: 18px; bottom: 18px; right: -4px; width: 10px; cursor: ew-resize; }
    .mdi-resize-w { top: 18px; bottom: 18px; left: -4px; width: 10px; cursor: ew-resize; }
    .mdi-resize-ne { right: -4px; top: -4px; cursor: nesw-resize; }
    .mdi-resize-nw { left: -4px; top: -4px; cursor: nwse-resize; }
    .mdi-resize-se { right: -4px; bottom: -4px; cursor: nwse-resize; }
    .mdi-resize-sw { left: -4px; bottom: -4px; cursor: nesw-resize; }
    .mdi-resize-se.mdi-resize-se-grip {
        width: 20px; height: 20px;
        /* Vinoviivat poistettu — käyttäjän pyynnöstä. Resize-toiminta säilyy. */
    }
    .mdi-dd-wrap { position: relative; display: inline-block; }
    .mdi-dd-menu {
        position: absolute; top: 100%; right: 0; margin-top: 4px; z-index: 2000;
        min-width: 200px; background: var(--color-bg); border: 1px solid var(--color-border); border-radius: 6px;
        box-shadow: 0 8px 24px rgba(0,0,0,.15); padding: 4px 0;
    }
    .mdi-dd-item { display: block; width: 100%; text-align: left; padding: 6px 12px; border: none; background: none; cursor: pointer; font-size: 12px; }
    .mdi-dd-item:hover { background: var(--color-border-light); }
    .mdi-suorite-window-host {
        display: flex;
        flex-direction: column;
        flex: 1;
        min-height: 0;
        min-width: 0;
    }
    .mdi-suorite-layout {
        display: flex;
        flex-direction: column;
        flex: 1;
        min-height: 0;
        height: 100%;
        /* overflow: visible → validointivalikko toolbarissa; vieritys grid-alueella */
        overflow-x: hidden;
        overflow-y: visible;
        container-type: inline-size;
    }
    /* Kapea näkymä: Muistio- ja Suodattimet-napit ikoniksi */
    @container (max-width: 520px) {
        .mdi-suorite-layout .suorite-toolbar-compact .btn-txt { display: none; }
        .mdi-suorite-layout .suorite-toolbar-compact { min-width: 28px; padding: 2px 6px; }
    }
    /*
     * Suoritetaulukko / rakennusosat: .suorite-shell tulee toolbarin jälkeen DOMissa,
     * joten grid maalataan työkalurivin abs-valikoiden päälle ilman erillistä z-indexiä.
     */
    .mdi-suorite-layout > .estimate-toolbar.estimate-toolbar-host {
        position: relative;
        z-index: 100;
    }
    /* EstimateToolbar MDI: EstimatePage-rivitys on scoped — tarvitaan flex täällä */
    .estimate-toolbar.estimate-toolbar-host .toolbar-row {
        display: flex;
        flex-direction: row;
        align-items: center;
        gap: 8px;
        flex-wrap: wrap;
    }
    /* Suoritetaulukko: kompakti työkalurivi; rivittyy usealle riville ilman vaakavieritystä */
    .estimate-toolbar.estimate-toolbar-host.estimate-toolbar--single-row .toolbar-row {
        flex-wrap: wrap;
        align-items: center;
        gap: 6px;
        padding: 3px 8px;
        min-width: 0;
        overflow-x: visible;
        overflow-y: visible;
        border-bottom: 1px solid var(--color-border);
        background: var(--color-surface);
        font-size: 10px;
    }
    .estimate-toolbar.estimate-toolbar-host.estimate-toolbar--single-row .estimate-toolbar-leading {
        display: inline-flex;
        flex-wrap: wrap;
        align-items: center;
        gap: 6px;
        flex: 0 1 auto;
        min-width: 0;
        max-width: 100%;
    }
    .estimate-toolbar.estimate-toolbar-host.estimate-toolbar--single-row .search-widget {
        flex: 0 1 320px;
        min-width: 180px;
        max-width: 320px;
        height: 28px;
    }
    .estimate-toolbar.estimate-toolbar-host.estimate-toolbar--single-row .undo-redo-group {
        flex-shrink: 0;
    }
    .mdi-suorite-toolbar-more {
        margin-left: auto;
        flex-shrink: 0;
    }
    /* Suoritetaulukko: suodatinflyout; ankkuri left (ei right) jotta ei jää mdi-suorite-layout overflow-x:n taakse */
    .mdi-suorite-filter-flyout {
        min-width: 220px;
        max-width: min(340px, calc(100vw - 16px));
    }
    /* Suoritetaulukko: Lista / Nimikkeistö + Avaa/Sulje yhtenäisenä ryhmänä */
    .mdi-suorite-toolbar-group {
        display: inline-flex;
        align-items: center;
        gap: 6px;
        flex-shrink: 0;
        padding: 2px 8px 2px 8px;
        border: 1px solid var(--color-border);
        border-radius: 6px;
        background: color-mix(in srgb, var(--color-surface, #f8fafc) 88%, var(--color-bg));
        box-shadow: 0 1px 1px rgba(0, 0, 0, .04);
    }
    .mdi-suorite-toolbar-group__label {
        font-size: 9px;
        font-weight: 700;
        text-transform: uppercase;
        letter-spacing: 0.05em;
        color: var(--color-text-muted);
        white-space: nowrap;
        padding-right: 6px;
        margin-right: 2px;
        border-right: 1px solid var(--color-border-tertiary, var(--color-border));
    }
    .mdi-suorite-toolbar-group__controls {
        display: inline-flex;
        align-items: center;
        gap: 4px;
        flex-wrap: wrap;
        min-width: 0;
    }
    .estimate-toolbar.estimate-toolbar-host.estimate-toolbar--single-row .mdi-suorite-viewmode-toggle {
        margin-right: 0;
    }
    .estimate-toolbar.estimate-toolbar-host.estimate-toolbar--single-row .mdi-suorite-viewmode-toggle button {
        padding: 2px 8px;
        font-size: 10px;
    }
    .mdi-suorite-nim-actions {
        color: var(--color-border);
        font-size: 10px;
        user-select: none;
        padding: 0 2px;
    }
    .mdi-suorite-nim-actions-btns {
        display: inline-flex;
        align-items: center;
        gap: 2px;
    }
    .mdi-suorite-nim-action {
        font-size: 9px;
        font-weight: 500;
        border: none;
        background: none;
        color: var(--color-primary);
        cursor: pointer;
        padding: 2px 5px;
        border-radius: 3px;
    }
    .mdi-suorite-nim-action:hover {
        background: color-mix(in srgb, var(--color-primary) 14%, transparent);
    }
    /* Yksi pystyvieritys: vain EstimateSuoriteGridin .estimate-grid-pane.
       Kaksoisscroll (täällä + pane) aiheutti scrollIntoView-fokuksen pomppimisen osaikkunassa. */
    .mdi-suorite-grid-area {
        flex: 1;
        min-height: 0;
        min-width: 0;
        overflow: hidden;
        display: flex;
        flex-direction: column;
    }

    .mdi-suorite-grid-area > .estimate-suorite-grid-root {
        flex: 1;
        min-height: 0;
        min-width: 0;
        display: flex;
        flex-direction: column;
    }
    .mdi-suorite-split-divider {
        height: 4px;
        flex-shrink: 0;
        background: var(--color-border-tertiary, var(--color-border));
        cursor: row-resize;
    }
    .mdi-suorite-split-divider:hover,
    .mdi-suorite-split-divider:active {
        background: color-mix(in srgb, var(--color-primary) 25%, transparent);
    }
    /* Estimate toolbar view-toggle */
    .view-toggle { display: inline-flex; border: 1px solid var(--color-border); border-radius: 5px; overflow: hidden; margin-right: 4px; }
    .view-toggle button { padding: 4px 12px; font-size: 11px; font-weight: 500; cursor: pointer; background: transparent; border: none; color: var(--color-text-muted); border-right: 1px solid var(--color-border); transition: background .1s; }
    .view-toggle button:last-child { border-right: none; }
    .view-toggle button:hover { background: var(--color-surface); }
    .view-toggle button.active { background: var(--color-primary); color: white; }
    .toggle-btn { display: inline-flex; align-items: center; gap: 4px; padding: 4px 8px; font-size: 11px; border: 1px solid var(--color-border); border-radius: 4px; background: transparent; cursor: pointer; color: var(--color-text); }
    .toggle-btn:hover { background: var(--color-primary, #2563eb); color: #fff; }
    .toggle-btn.active { background: color-mix(in srgb, var(--color-primary) 12%, transparent); color: var(--color-primary); border-color: var(--color-primary); }
    /* Validointi (EstimateToolbar MDI / perintäsivu) */
    .estimate-toolbar .validation-dropdown-wrap { position: relative; z-index: 50; }
    .estimate-toolbar .vb-errors { color: #dc2626; font-weight: 600; }
    .estimate-toolbar .vb-warnings { color: #d97706; font-weight: 600; }
    .estimate-toolbar .validation-dropdown {
        display: none; position: absolute; top: calc(100% + 6px); left: 0;
        min-width: 320px; max-width: 400px; z-index: 8000;
        background: var(--color-surface); border: 1px solid var(--color-border);
        border-radius: 8px; box-shadow: 0 4px 16px rgba(0,0,0,0.12);
        max-height: 320px; overflow-y: auto; padding: 0;
    }
    .estimate-toolbar .validation-dropdown-wrap.open .validation-dropdown { display: block; }
    .estimate-toolbar .validation-dd-header {
        padding: 8px 12px 6px; font-size: 11px; font-weight: 600; color: var(--color-text-muted);
        text-transform: uppercase; letter-spacing: .04em; border-bottom: 1px solid var(--color-border-light, var(--color-border));
    }
    .estimate-toolbar .validation-item {
        display: flex; align-items: center; gap: 8px; padding: 7px 12px;
        border-bottom: 1px solid var(--color-border-light, var(--color-border)); cursor: pointer;
        font-size: 12px; border: none; background: none; width: 100%; text-align: left;
        transition: background .1s;
    }
    .estimate-toolbar .validation-item:last-child { border-bottom: none; }
    .estimate-toolbar .validation-item:hover { background: var(--color-surface-hover, rgba(0,0,0,.04)); }
    .estimate-toolbar .validation-item .vi-icon { flex-shrink: 0; font-size: 13px; }
    .estimate-toolbar .validation-item .vi-desc { flex: 1; color: var(--color-text); }
    .estimate-toolbar .validation-item .vi-loc { color: var(--color-text-muted); font-size: 11px; white-space: nowrap; }
    .estimate-toolbar .validation-filter-btn {
        font-size: 11px; padding: 2px 8px; border-radius: 4px; cursor: pointer;
        border: 1px solid var(--color-border); background: var(--color-surface);
        color: var(--color-text-muted); margin: 6px 12px;
    }
    .estimate-toolbar .validation-filter-btn:hover { background: var(--color-border-light, rgba(0,0,0,.04)); }
    .estimate-toolbar .validation-filter-btn.active { background: var(--color-primary); color: #fff; border-color: var(--color-primary); }
    /* Hakupalkki (sama hengenveto kuin EstimatePage / määrälaskenta) */
    .search-widget {
        display: flex;
        align-items: center;
        flex: 1;
        min-width: 0;
        max-width: 380px;
        height: 30px;
        border: 1px solid var(--color-border);
        border-radius: 9999px;
        background: var(--color-bg);
        overflow: hidden;
        transition: border-color 0.15s ease, box-shadow 0.15s ease;
    }
    .search-widget:focus-within {
        border-color: var(--color-primary);
        box-shadow: 0 0 0 2px color-mix(in srgb, var(--color-primary) 22%, transparent);
    }
    .search-widget .search-icon {
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 0 6px 0 10px;
        color: var(--color-text-muted);
        flex-shrink: 0;
    }
    .search-widget .search-main {
        border: none !important;
        outline: none !important;
        background: transparent !important;
        flex: 1;
        min-width: 0;
        height: 100%;
        font-size: 12px;
        padding: 0 6px 0 0;
        color: var(--color-text);
    }
    .search-widget .search-main::placeholder {
        color: var(--color-text-muted);
        opacity: 0.85;
    }
    .search-widget { container-type: inline-size; container-name: search-widget; }
    .search-widget .search-tabs {
        display: flex;
        align-items: center;
        gap: 3px;
        padding: 0 6px 0 2px;
        flex-shrink: 0;
    }
    .search-widget .search-tab {
        padding: 3px 8px;
        font-size: 10px;
        font-weight: 500;
        line-height: 1.35;
        cursor: pointer;
        background: transparent;
        color: var(--color-text-muted);
        border: 1px solid var(--color-border-light, var(--color-border));
        border-radius: 9999px;
        transition: background 0.1s ease, color 0.1s ease, border-color 0.1s ease;
        white-space: nowrap;
    }
    /* Porrastetut hakutyyppi-labelit: täysi → lyhyt → yksi kirjain (kaikki tabit klikattavissa) */
    .search-widget .search-tab__mid,
    .search-widget .search-tab__abbr { display: none; }
    .search-widget .search-tab__full { display: inline; }
    @container search-widget (max-width: 300px) {
        .search-widget .search-tab__full { display: none; }
        .search-widget .search-tab__mid { display: inline; }
    }
    @container search-widget (max-width: 205px) {
        .search-widget .search-tab__mid { display: none; }
        .search-widget .search-tab__abbr { display: inline; }
        .search-widget .search-tab { padding: 3px 6px; font-size: 9px; }
        .search-widget .search-tabs { gap: 2px; padding-right: 4px; }
        .search-widget .search-main { min-width: 52px; }
    }
    .search-widget .search-tab:hover:not(.active) {
        background: var(--color-border-light, rgba(0, 0, 0, 0.04));
        color: var(--color-text);
    }
    .search-widget .search-tab.active {
        background: var(--color-primary);
        color: #fff;
        border-color: var(--color-primary);
    }
    /* Split-panel tyylit (EstimateBottomPanel) */
    .split-panel-header { display: flex; align-items: center; justify-content: space-between; padding: 8px 14px; background: var(--color-surface); border-bottom: 1px solid var(--color-border); flex-shrink: 0; }
    .split-panel-title { font-size: 13px; font-weight: 600; }
    .split-panel-tabs { display: flex; border-bottom: 1px solid var(--color-border); background: var(--color-surface); flex-shrink: 0; }
    .split-panel-tab { padding: 7px 16px; font-size: 12.5px; border: none; background: none; cursor: pointer; color: var(--color-text-muted); border-bottom: 2px solid transparent; margin-bottom: -1px; }
    .split-panel-tab.active { color: var(--color-primary); border-bottom-color: var(--color-primary); }
    .split-panel-tab:focus-visible { outline: 2px solid var(--color-primary); outline-offset: -2px; }
    .split-panel-content { padding: 16px; }
    .split-memo-ta:focus { border-color: var(--color-primary) !important; }
    .mdi-suorite-bottom-area {
        flex-shrink: 0;
        height: 260px;
        overflow-y: auto;
        display: flex;
        flex-direction: column;
        border-top: 0.5px solid var(--color-border-tertiary, var(--color-border));
    }
    .mdi-item-table { width: 100%; border-collapse: collapse; font-size: 11px; }
    .mdi-item-table th, .mdi-item-table td { border-bottom: 1px solid var(--color-border); padding: 4px 6px; text-align: left; vertical-align: top; }
    .mdi-item-table th { background: var(--color-surface); font-weight: 600; position: sticky; top: 0; }
    .mdi-item-table .num { text-align: right; font-variant-numeric: tabular-nums; white-space: nowrap; }
    .mdi-item-table tr.hdr td { background: var(--color-border-light); font-weight: 600; padding-top: 8px; }
    .mdi-item-table tr.flash-green { animation: mdi-flash 1s ease-out; }
    @@keyframes mdi-flash { 0%{background:rgba(34,197,94,0.35);} 100%{background:transparent;} }
    /* Pinonta yli MDI-ikkunoiden (w.ZIndex kasvaa; aiemmin flyout z-index 6500 jäi ikkunoiden taakse). */
    #mdi-taskbar.mdi-taskbar {
        --mdi-taskbar-h: auto;
        height: 48px;
        flex-shrink: 0;
        border-top: 1px solid color-mix(in srgb, var(--color-primary) 22%, var(--color-border));
        background: linear-gradient(
            180deg,
            color-mix(in srgb, var(--color-primary) 14%, var(--color-surface)) 0%,
            color-mix(in srgb, var(--color-primary) 7%, color-mix(in srgb, var(--color-surface) 88%, #0f172a 8%)) 100%
        );
        box-shadow: 0 -4px 20px color-mix(in srgb, var(--color-primary) 12%, rgba(15, 23, 42, 0.08));
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 4px;
        font-size: 11px;
        color: var(--color-text-muted);
        padding: 0 4px;
        padding-right: 220px;
        position: relative;
        z-index: 15000000;
        isolation: isolate;
    }
    #mdi-taskbar, #mdi-taskbar *:not(input) {
        cursor: default !important; user-select: none !important; -webkit-user-select: none !important;
    }
    #mdi-taskbar button, #mdi-taskbar .mdi-task-ic-btn,
    #mdi-taskbar .mdi-pin-btn, #mdi-taskbar .mdi-task-stack-btn,
    #mdi-taskbar .mdi-task-item, #mdi-taskbar .mdi-project-chevron {
        cursor: pointer !important;
    }
    #mdi-taskbar input {
        cursor: pointer !important; user-select: none !important; -webkit-user-select: none !important;
    }
    #mdi-taskbar input:focus {
        cursor: text !important; user-select: text !important; -webkit-user-select: text !important;
    }
    #mdi-taskbar *:focus, #mdi-taskbar *:focus-visible, #mdi-taskbar *:focus-within,
    #mdi-taskbar button:focus, #mdi-taskbar button:focus-visible,
    #mdi-taskbar a, #mdi-taskbar a:hover, #mdi-taskbar a:focus {
        outline: none !important; box-shadow: none !important;
        text-decoration: none !important; border-bottom: none !important;
        -webkit-tap-highlight-color: transparent;
    }
    #mdi-taskbar button::after, #mdi-taskbar button::before,
    #mdi-taskbar a::after, #mdi-taskbar a::before {
        display: none !important; content: none !important;
    }
    .mdi-taskbar--win11 {
        border-top: 1px solid color-mix(in srgb, var(--color-primary) 26%, var(--color-border));
        background: linear-gradient(
            180deg,
            color-mix(in srgb, var(--color-primary) 13%, var(--color-surface)) 0%,
            color-mix(in srgb, var(--color-primary) 5%, color-mix(in srgb, var(--color-surface) 86%, #0f172a 11%)) 100%
        );
    }
    #mdi-taskbar-right.mdi-taskbar-right {
        position: absolute;
        right: 8px;
        top: 50%;
        transform: translateY(-50%);
        display: flex;
        align-items: center;
        gap: 8px;
    }
    .mdi-taskbar-proj-cluster {
        display: flex;
        align-items: center;
        gap: 2px;
        flex-shrink: 0;
    }
    .mdi-taskbar-proj-wrap { position: relative; }
    .mdi-project-search-wrap {
        display: inline-flex; align-items: center; position: relative; height: 34px;
        border: 1px solid var(--color-border-tertiary, var(--color-border)); border-radius: 6px;
        background: var(--color-background-primary, var(--color-bg)); overflow: hidden;
    }
    .mdi-project-search-input {
        border: none; outline: none; background: transparent; padding: 0 8px; height: 100%;
        font-size: 11px; color: var(--color-text-primary, var(--color-text)); width: 140px; max-width: 180px;
    }
    .mdi-project-search-input::placeholder { color: var(--color-text-muted); font-weight: 500; }
    .mdi-project-chevron {
        display: inline-flex; align-items: center; justify-content: center; width: 24px; height: 100%;
        color: var(--color-text-muted); font-size: 12px; flex-shrink: 0;
    }
    .mdi-project-chevron:hover { background: var(--color-background-secondary, rgba(0,0,0,0.06)); }
    .mdi-taskbar-proj-dd {
        position: fixed;
        bottom: 52px;
        left: var(--mdi-proj-dd-left, 50%);
        padding-bottom: 4px;
        z-index: 9999;
    }
    .mdi-taskbar-proj-dd > .mdi-taskbar-proj-panel {
        min-width: 220px;
        max-width: min(92vw, 360px);
        max-height: min(48vh, 400px);
        overflow-y: auto;
        background: var(--color-background-primary, var(--color-bg));
        border: 0.5px solid var(--color-border-tertiary, var(--color-border));
        border-radius: 10px;
        box-shadow: 0 -4px 16px rgba(0,0,0,.12);
        padding: 6px 0;
    }
    .mdi-taskbar-proj-dd-h {
        padding: 6px 14px 4px;
        font-size: 10px;
        font-weight: 700;
        color: var(--color-text-muted);
        text-transform: uppercase;
        letter-spacing: 0.05em;
    }
    .mdi-taskbar-proj-dd-item {
        display: block;
        width: 100%;
        text-align: left;
        padding: 8px 14px;
        border: none;
        background: none;
        font-size: 12px;
        color: var(--color-text);
        cursor: pointer;
    }
    .mdi-taskbar-proj-dd-item:hover { background: rgba(0,0,0,0.06); }
    .mdi-taskbar-proj-dd-item.current { color: var(--color-primary); font-weight: 700; }
    .mdi-task-ic-btn {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 40px !important; height: 40px !important; min-width: 40px !important; max-width: 40px !important;
        padding: 0; margin: 0;
        border: 1px solid transparent;
        box-sizing: border-box;
        background: transparent; box-shadow: none; border-radius: 4px;
        cursor: pointer; color: var(--color-text); flex-shrink: 0 !important;
    }
    .mdi-task-ic-btn:hover {
        border-color: color-mix(in srgb, var(--color-text) 12%, var(--color-border) 88%);
        background: color-mix(in srgb, var(--color-text) 5%, transparent);
    }
    .mdi-task-ic-btn:focus-visible {
        outline: 2px solid color-mix(in srgb, var(--color-primary) 60%, transparent);
        outline-offset: 2px;
    }
    .mdi-task-ic-btn svg { width: 24px !important; height: 24px !important; display: block; flex-shrink: 0 !important; }
    .mdi-taskview--bar .mdi-taskview-btn img { width: 22px; height: 22px; object-fit: contain; display: block; }
    .mdi-tray-pomo {
        display: inline-flex;
        align-items: center;
        gap: 5px;
        padding: 4px 10px;
        border-radius: 999px;
        border: 1px solid var(--color-border);
        background: var(--color-bg);
        cursor: pointer;
        font-size: 11px;
        font-weight: 600;
        color: var(--color-text);
        box-shadow: 0 1px 2px rgba(0,0,0,.06);
    }
    .mdi-tray-pomo:hover { background: var(--color-border-light); }
    #mdi-taskbar-main.mdi-taskbar-main {
        display: flex;
        align-items: center;
        justify-content: center;
        flex: 0 1 auto;
        max-width: 100%;
        min-width: 0;
        overflow: visible;
        gap: 0;
    }
    .mdi-taskbar-main-inner {
        display: flex;
        flex-wrap: nowrap;
        align-items: center;
        justify-content: center;
        gap: 4px;
        min-width: min-content;
        max-width: 100%;
        padding: 0 2px;
        overflow: visible;
    }
    .mdi-taskbar-before-open {
        display: flex;
        align-items: center;
        gap: 4px;
        flex-shrink: 0;
    }
    .mdi-taskbar-before-open .mdi-desk-ic {
        width: 28px;
        height: 28px;
        border-radius: 0;
        border: none;
        background: transparent;
        box-shadow: none;
    }
    .mdi-taskbar-before-open .mdi-desk-ic svg { width: 24px; height: 24px; display: block; }
    .mdi-task-sep-slot { color: var(--color-border); margin: 0 2px; flex-shrink: 0; font-weight: 300; }
    #mdi-start-btn.mdi-task-start {
        width: 44px !important;
        height: 44px !important;
        border-radius: 8px !important;
        font-size: 26px;
        font-weight: 800;
        line-height: 1;
        letter-spacing: 0;
    }
    #mdi-start-btn.mdi-task-start:hover {
        border-color: color-mix(in srgb, var(--color-text) 12%, var(--color-border) 88%);
        background: color-mix(in srgb, var(--color-text) 5%, transparent);
        transform: scale(1.05);
        transition: transform 0.1s ease, border-color 0.12s ease, background 0.12s ease;
    }
    #mdi-start-btn.mdi-task-start:active { transform: scale(0.96); }
    /* Hakukenttä + Tehtävätila-ikoni (virtuaalityöpöydät) */
    .mdi-search-cluster {
        display: inline-flex;
        align-items: center;
        gap: 2px;
        flex-shrink: 0;
        position: relative;
    }
    .mdi-taskview-wrap {
        position: relative;
        flex-shrink: 0;
        display: flex;
        align-items: center;
    }
    .mdi-taskview-ic {
        display: flex;
        align-items: center;
        justify-content: center;
        line-height: 0;
        color: var(--color-text);
    }
    .mdi-taskview-ic svg {
        display: block;
    }
    .mdi-taskview-ic--large svg {
        width: 32px !important;
        height: 32px !important;
    }
    .mdi-task-ic-btn.mdi-taskview-btn--open {
        border-color: color-mix(in srgb, var(--color-text) 18%, var(--color-border) 82%);
        background: color-mix(in srgb, var(--color-text) 10%, transparent);
    }
    .mdi-desktop-switcher-popover {
        position: absolute;
        bottom: calc(100% + 10px);
        left: 0;
        z-index: 10001;
        min-width: 260px;
        max-width: min(320px, 92vw);
        background: var(--color-background-primary, var(--color-bg));
        border: 0.5px solid var(--color-border-tertiary, var(--color-border));
        border-radius: 12px;
        box-shadow: 0 -4px 24px rgba(0, 0, 0, 0.15);
        padding: 10px 10px 8px;
        color: var(--color-text);
    }
    .mdi-desktop-switcher-popover--cards {
        min-width: min(520px, 94vw);
        max-width: min(640px, 96vw);
        padding: 10px 12px 10px;
    }
    .mdi-desktop-switcher-popover-h {
        font-size: 11px;
        font-weight: 700;
        text-transform: uppercase;
        letter-spacing: 0.06em;
        color: var(--color-text-muted);
        margin: 0 4px 6px;
    }
    .mdi-desktop-switcher-hint {
        margin: 0 4px 10px;
        font-size: 10px;
        color: var(--color-text-muted);
        line-height: 1.35;
    }
    .mdi-desktop-switcher-strip {
        display: flex;
        flex-direction: row;
        flex-wrap: nowrap;
        gap: 10px;
        overflow-x: auto;
        overflow-y: hidden;
        padding: 4px 2px 8px;
        scrollbar-width: thin;
        max-width: 100%;
    }
    .mdi-desktop-switcher-card {
        position: relative;
        flex: 0 0 auto;
        width: 132px;
        border-radius: 10px;
        border: 2px solid transparent;
        background: var(--color-background-secondary, rgba(0, 0, 0, 0.04));
    }
    .mdi-desktop-switcher-card:hover {
        border-color: color-mix(in srgb, var(--color-text) 12%, transparent);
    }
    .mdi-desktop-switcher-card.active {
        border-color: color-mix(in srgb, var(--color-primary) 55%, transparent);
        box-shadow: 0 0 0 1px color-mix(in srgb, var(--color-primary) 25%, transparent);
    }
    .mdi-desktop-switcher-card-main {
        display: flex;
        flex-direction: column;
        align-items: stretch;
        width: 100%;
        padding: 0;
        margin: 0;
        border: none;
        border-radius: 8px;
        background: transparent;
        cursor: pointer;
        text-align: left;
        color: var(--color-text);
        box-shadow: none;
    }
    .mdi-desktop-switcher-thumb {
        width: 100%;
        aspect-ratio: 16 / 10;
        border-radius: 8px 8px 0 0;
        background-size: cover;
        background-position: center;
        border: 0.5px solid var(--color-border-tertiary, var(--color-border));
        border-bottom: none;
    }
    .mdi-desktop-switcher-card-num {
        position: absolute;
        left: 6px;
        top: 6px;
        min-width: 22px;
        height: 22px;
        padding: 0 5px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        border-radius: 5px;
        font-size: 11px;
        font-weight: 800;
        background: rgba(255, 255, 255, 0.92);
        color: #0f172a;
        border: 0.5px solid rgba(0, 0, 0, 0.12);
        box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12);
        pointer-events: none;
    }
    .mdi-desktop-switcher-card.active .mdi-desktop-switcher-card-num {
        background: color-mix(in srgb, var(--color-primary) 18%, #fff);
        color: var(--color-primary);
        border-color: color-mix(in srgb, var(--color-primary) 35%, transparent);
    }
    .mdi-desktop-switcher-card-label {
        padding: 8px 8px 2px;
        font-size: 11px;
        font-weight: 600;
        line-height: 1.25;
        max-height: 3.1em;
        overflow: hidden;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
    }
    .mdi-desktop-switcher-card-view {
        padding: 0 8px 8px;
        font-size: 9px;
        font-weight: 500;
        line-height: 1.2;
        color: var(--color-text-muted);
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
        max-width: 100%;
    }
    .mdi-desktop-switcher-card-del {
        position: absolute;
        right: 4px;
        top: 4px;
        width: 26px;
        height: 26px;
        padding: 0;
        border: none;
        border-radius: 6px;
        background: rgba(255, 255, 255, 0.92);
        color: var(--color-text-muted);
        font-size: 13px;
        line-height: 1;
        cursor: pointer;
        box-shadow: 0 1px 4px rgba(0, 0, 0, 0.12);
    }
    .mdi-desktop-switcher-card-del:hover {
        background: color-mix(in srgb, #fecaca 40%, #fff);
        color: #b91c1c;
    }
    .mdi-desktop-switcher-new {
        margin-top: 8px;
        width: 100%;
        padding: 8px 10px;
        border: 2px dashed var(--color-border-tertiary, var(--color-border));
        border-radius: 8px;
        background: transparent;
        cursor: pointer;
        font-size: 12px;
        font-weight: 600;
        color: var(--color-text-muted);
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: 6px;
    }
    .mdi-desktop-switcher-new:hover {
        border-color: color-mix(in srgb, var(--color-primary) 40%, var(--color-border) 60%);
        color: var(--color-text);
        background: color-mix(in srgb, var(--color-primary) 6%, transparent);
    }
    .mdi-search-wrap {
        position: relative; flex: 0 1 240px; min-width: 112px; max-width: min(280px, 36vw);
        display: inline-flex; align-items: center; height: 28px;
        border: 1px solid var(--color-border-tertiary, var(--color-border)); border-radius: 999px;
        background: var(--color-background-primary, var(--color-bg)); overflow: hidden;
    }
    .mdi-search-ic {
        position: absolute; left: 10px; top: 50%; transform: translateY(-50%); opacity: .5;
        pointer-events: none; line-height: 0; color: var(--color-text-muted);
    }
    .mdi-search-ic svg { display: block; }
    .mdi-search-input {
        width: 100%; box-sizing: border-box; border: none; outline: none; background: transparent;
        padding: 0 12px 0 32px; font-size: 12px; color: var(--color-text); height: 100%;
        box-shadow: none; -webkit-appearance: none; -moz-appearance: none; appearance: none;
    }
    .mdi-search-input::placeholder { color: var(--color-text-muted); }
    .mdi-search-panel {
        position: fixed; z-index: 9999; bottom: 52px; left: 50%; transform: translateX(-50%);
        width: min(600px, 90vw);
        background: var(--color-background-primary, var(--color-bg));
        border: 0.5px solid var(--color-border-tertiary, var(--color-border));
        border-radius: 12px; box-shadow: 0 -4px 24px rgba(0,0,0,0.15);
        overflow: hidden;
    }
    .mdi-search-filters {
        display: flex; gap: 6px; padding: 10px 12px; flex-wrap: wrap;
        border-bottom: 0.5px solid var(--color-border-tertiary, var(--color-border));
    }
    .mdi-search-filter-pill {
        padding: 4px 10px; border-radius: 20px; font-size: 12px;
        border: 0.5px solid var(--color-border, var(--color-border-tertiary));
        color: var(--color-text-muted); cursor: pointer !important; background: transparent;
        box-shadow: none;
    }
    .mdi-search-filter-pill:hover { border-color: var(--color-primary); color: var(--color-text); }
    .mdi-search-filter-pill.active {
        background: color-mix(in srgb, var(--color-primary) 12%, transparent);
        color: var(--color-primary); border-color: color-mix(in srgb, var(--color-primary) 40%, transparent);
    }
    .mdi-search-results { max-height: min(400px, 60vh); overflow-y: auto; padding: 6px 0; }
    .mdi-search-group-h {
        padding: 8px 14px 4px; font-size: 10px; font-weight: 700; color: var(--color-text-muted);
        text-transform: uppercase; letter-spacing: 0.04em;
    }
    .mdi-search-result-row {
        display: flex; align-items: center; gap: 8px; width: 100%; text-align: left;
        padding: 7px 14px; border: none; background: transparent; cursor: pointer;
        font-size: 12px; color: var(--color-text); box-shadow: none;
    }
    .mdi-search-result-row:hover { background: var(--color-background-secondary, rgba(0,0,0,0.06)); }
    .mdi-search-result-ic { font-size: 14px; flex-shrink: 0; opacity: 0.7; }
    .mdi-search-result-title { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
    .mdi-search-result-sub { font-size: 10px; color: var(--color-text-muted); flex-shrink: 0; }
    .mdi-search-empty { padding: 16px 14px; font-size: 12px; color: var(--color-text-muted); text-align: center; }
    .mdi-taskview { position: relative; flex-shrink: 0; }
    .mdi-taskview-btn {
        width: 40px !important; height: 40px !important;
        border: 1px solid transparent;
        box-sizing: border-box;
        background: transparent; box-shadow: none; border-radius: 4px; cursor: pointer;
        display: inline-flex; align-items: center; justify-content: center; padding: 0;
    }
    .mdi-taskview-btn:hover {
        border-color: color-mix(in srgb, var(--color-text) 12%, var(--color-border) 88%);
        background: color-mix(in srgb, var(--color-text) 5%, transparent);
    }
    .mdi-taskview-btn img { width: 18px; height: 18px; object-fit: contain; display: block; }
    .mdi-taskview-anchor {
        display: none; position: absolute; bottom: 100%; left: 50%; transform: translateX(-50%);
        padding-bottom: 12px; z-index: 50;
    }
    .mdi-taskview:hover .mdi-taskview-anchor,
    .mdi-taskview:focus-within .mdi-taskview-anchor { display: block; }
    .mdi-taskview-panel {
        background: var(--color-background-secondary, var(--color-surface));
        border: 0.5px solid var(--color-border-tertiary, var(--color-border)); border-radius: 12px;
        box-shadow: var(--shadow); padding: 14px 16px; min-width: min(280px, 92vw); max-width: min(920px, 96vw);
        color: var(--color-text-primary, var(--color-text));
    }
    .mdi-taskview-h {
        color: var(--color-text-primary, var(--color-text)); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em;
        margin: 0 0 10px 2px;
    }
    .mdi-taskview-strip { display: flex; flex-wrap: nowrap; gap: 14px; align-items: stretch; padding-bottom: 4px; scrollbar-width: thin; }
    .mdi-taskview-strip--profiles { align-items: stretch; min-width: 0; }
    .mdi-taskview-cards-scroll {
        display: flex; flex-wrap: nowrap; gap: 14px; overflow-x: auto; flex: 1 1 auto; min-width: 0; padding-bottom: 2px;
    }
    .mdi-taskview-card {
        flex: 0 0 auto; width: 168px; border: none; background: transparent; cursor: pointer; padding: 0;
        border-radius: 10px; text-align: left;
    }
    .mdi-taskview-card:hover .mdi-taskview-thumb-wrap { outline: 2px solid color-mix(in srgb, var(--color-primary) 55%, transparent); outline-offset: 2px; }
    .mdi-taskview-card.current .mdi-taskview-thumb-wrap {
        outline: 2px solid var(--color-primary); outline-offset: 2px; box-shadow: 0 0 0 1px color-mix(in srgb, var(--color-primary) 35%, transparent);
    }
    .mdi-taskview-thumb-wrap {
        border-radius: 8px; overflow: hidden;
        background: color-mix(in srgb, var(--color-border-light) 55%, var(--color-background-secondary, var(--color-surface)) 45%);
        border: 0.5px solid var(--color-border-tertiary, var(--color-border));
        aspect-ratio: 16 / 10; position: relative;
    }
    .mdi-taskview-thumb-placeholder {
        position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center;
        gap: 6px; padding: 10px 8px; text-align: center;
    }
    .mdi-taskview-thumb-ic { font-size: 28px; line-height: 1; opacity: 0.88; }
    .mdi-taskview-thumb-name {
        font-size: 11px; font-weight: 700; color: var(--color-text-primary, var(--color-text));
        line-height: 1.25; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
        word-break: break-word; max-width: 100%;
    }
    .mdi-taskview-cap {
        margin-top: 8px; font-size: 12px; font-weight: 600; color: var(--color-text-primary, var(--color-text));
        overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 168px;
    }
    .mdi-taskview-card.current .mdi-taskview-cap { color: var(--color-primary); }
    .mdi-taskview-h2 {
        color: var(--color-text-muted); font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: .05em;
        margin: 14px 0 8px 2px;
    }
    .mdi-taskview-h2:first-of-type { margin-top: 0; }
    .mdi-taskview-new {
        flex: 0 0 auto; width: 112px; min-height: 0; align-self: stretch; border-radius: 10px; cursor: pointer; padding: 8px 10px; text-align: center;
        border: 2px dashed var(--color-border-tertiary, var(--color-border));
        background: color-mix(in srgb, var(--color-border-light) 75%, var(--color-background-primary, var(--color-bg)) 25%);
        color: var(--color-text-muted);
        font-size: 12px; font-weight: 600; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 6px;
    }
    .mdi-taskview-new:hover:not(:disabled) {
        border-color: color-mix(in srgb, var(--color-primary) 40%, var(--color-border) 60%);
        color: var(--color-text-primary, var(--color-text));
        background: color-mix(in srgb, var(--color-primary) 8%, var(--color-background-secondary, var(--color-surface)) 92%);
    }
    .mdi-taskview-new:disabled { opacity: 0.45; cursor: not-allowed; }
    .mdi-task-pinned { display: flex; align-items: center; gap: 4px; flex: 0 0 auto; }
    .mdi-pin-btn {
        flex-shrink: 0 !important; width: 40px !important; height: 40px !important; min-width: 40px !important; max-width: 40px !important;
        padding: 0; border-radius: 4px;
        border: 1px solid transparent;
        box-sizing: border-box;
        background: transparent; cursor: pointer; font-size: 11px;
        display: inline-flex; align-items: center; justify-content: center; color: var(--color-text);
        box-shadow: none; position: relative;
    }
    .mdi-pin-btn:hover {
        border-color: color-mix(in srgb, var(--color-text) 12%, var(--color-border) 88%);
        background: color-mix(in srgb, var(--color-text) 5%, transparent);
    }
    .mdi-task-open { display: flex; align-items: center; flex-wrap: nowrap; gap: 4px; flex: 0 0 auto; min-width: 0; overflow: visible; }
    .mdi-task-item {
        flex-shrink: 0 !important; width: 40px !important; height: 40px !important; min-width: 40px !important; max-width: 40px !important;
        padding: 0; border-radius: 4px; background: transparent;
        cursor: pointer; font-size: 11px; color: var(--color-text);
        border: 1px solid transparent;
        box-sizing: border-box;
        position: relative;
        display: inline-flex; align-items: center; justify-content: center;
        box-shadow: none;
    }
    .mdi-task-item:hover {
        border-color: color-mix(in srgb, var(--color-text) 12%, var(--color-border) 88%);
        background: color-mix(in srgb, var(--color-text) 5%, transparent);
    }
    .mdi-task-indicator {
        position: absolute; bottom: 2px; left: 50%; transform: translateX(-50%);
        height: 3px; border-radius: 2px; transition: width 0.15s ease, background 0.15s ease;
    }
    .mdi-task-indicator.has-windows { width: 12px; background: var(--color-text-primary, var(--color-text)); }
    .mdi-task-indicator.active { width: 20px; background: #0078d4; }
    .mdi-task-group { position: relative; flex-shrink: 0; }
    .mdi-task-stack-btn {
        display: inline-flex; align-items: center; justify-content: center; gap: 0;
        width: 40px !important; height: 40px !important; min-width: 40px !important; max-width: 40px !important;
        padding: 0; border-radius: 4px;
        border: 1px solid transparent;
        box-sizing: border-box;
        background: transparent; cursor: pointer; font-size: 11px; color: var(--color-text);
        box-shadow: none; position: relative; flex-shrink: 0 !important;
    }
    .mdi-task-stack-lbl { display: none; }
    .mdi-task-stack-badge { display: none; }
    .mdi-task-stack-btn:hover {
        border-color: color-mix(in srgb, var(--color-text) 12%, var(--color-border) 88%);
        background: color-mix(in srgb, var(--color-text) 5%, transparent);
    }
    .mdi-task-stack-ic { line-height: 0; }
    .mdi-task-stack-ic svg { width: 24px !important; height: 24px !important; display: block; flex-shrink: 0 !important; }
    .mdi-task-stack-badge {
        font-size: 10px; font-weight: 700; background: var(--color-primary); color: #fff; border-radius: 9px;
        padding: 1px 6px; min-width: 18px; text-align: center; font-variant-numeric: tabular-nums;
    }
    .mdi-task-group-anchor {
        display: none; position: absolute; bottom: 100%; left: 50%; transform: translateX(-50%); padding-bottom: 10px; z-index: 50; min-width: 100%;
    }
    .mdi-task-group:hover .mdi-task-group-anchor { display: block; }
    .mdi-task-group.mdi-task-group--suppress-taskbar-preview .mdi-task-group-anchor {
        display: none !important;
    }
    .mdi-taskbar-preview {
        display: flex; gap: 8px; padding: 8px;
        background: var(--color-background-primary, var(--color-bg));
        border: 0.5px solid var(--color-border-tertiary, var(--color-border));
        border-radius: 8px;
        box-shadow: 0 -4px 16px rgba(0,0,0,0.12);
        transform-origin: bottom center;
        animation: mdi-preview-in 0.15s ease forwards;
        max-width: calc(100vw - 40px);
        overflow-x: auto;
    }
    @@keyframes mdi-preview-in {
        from { transform: translateY(8px) scale(0.95); opacity: 0; }
        to { transform: translateY(0) scale(1); opacity: 1; }
    }
    /* Oletuskoko ennen JS:ää; populatePreview asettaa leveyden/korkeuden ikkunan kuvasuhteen mukaan (max 200×130). */
    .mdi-preview-thumb {
        width: 200px; height: 130px; max-width: 200px; max-height: 130px;
        border-radius: 6px;
        border: 1px solid var(--color-border-tertiary, var(--color-border));
        overflow: hidden; position: relative; cursor: pointer;
        background: var(--color-background-secondary, var(--color-surface));
        flex-shrink: 0; display: flex; flex-direction: column;
    }
    .mdi-preview-thumb:hover { background: var(--color-surface); }
    .mdi-preview-titlebar {
        height: 20px; flex-shrink: 0;
        background: var(--color-background-secondary, var(--color-surface));
        border-bottom: 0.5px solid var(--color-border-tertiary, var(--color-border));
        font-size: 10px; padding: 0 6px;
        display: flex; align-items: center;
        color: var(--color-text-muted);
        white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    }
    .mdi-preview-content {
        flex: 1; overflow: hidden; position: relative;
        background: var(--color-bg, #fff);
    }
    .mdi-preview-close {
        position: absolute; top: 2px; right: 2px; width: 16px; height: 16px; border-radius: 50%;
        background: rgba(0,0,0,0.3); color: #fff; font-size: 8px; border: none;
        display: none; align-items: center; justify-content: center; cursor: pointer !important; line-height: 1;
    }
    .mdi-preview-thumb:hover .mdi-preview-close { display: flex; }
    .mdi-task-stack-badge--single { display: none; }
    .mdi-tray-build { font-size: 9px; color: var(--color-text-muted); padding: 0 6px; max-width: 200px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; cursor: default; }
    .mdi-task-clock { flex-shrink: 0; padding: 0 4px; display: flex; align-items: center; font-variant-numeric: tabular-nums; color: var(--color-text); font-size: 12px; font-weight: 600; }
    .mdi-hapro-tray-break {
        display: inline-flex;
        align-items: center;
        gap: 4px;
        padding: 2px 8px;
        border-radius: 6px;
        border: none;
        background: color-mix(in srgb, #22c55e 14%, transparent);
        color: #166534;
        font-size: 10px;
        font-weight: 700;
        cursor: pointer;
    }
    .mdi-hapro-tray-break--warn { background: color-mix(in srgb, #eab308 20%, transparent); color: #854d0e; }
    .mdi-hapro-tray-break--crit { background: color-mix(in srgb, #ef4444 18%, transparent); color: #991b1b; animation: mdi-hapro-pulse 1.2s ease-in-out infinite; }
    @@keyframes mdi-hapro-pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.72; } }
    .mdi-show-desktop-btn {
        flex-shrink: 0; align-self: stretch; width: 8px;
        background: transparent; border: none; padding: 0; margin: 0;
        border-left: 1px solid color-mix(in srgb, var(--color-border) 30%, transparent);
        cursor: default !important; -webkit-appearance: none; appearance: none;
    }
    .mdi-show-desktop-btn:hover {
        background: var(--color-background-secondary, rgba(0,0,0,0.06));
    }
    .mdi-show-desktop-btn:focus { outline: none; }
    .mdi-weather-widget {
        position: fixed; bottom: 52px; left: 8px; z-index: 250;
        display: inline-flex; align-items: center; gap: 5px;
        padding: 4px 10px; border-radius: 8px;
        background: color-mix(in srgb, var(--color-surface) 85%, transparent);
        border: 0.5px solid color-mix(in srgb, var(--color-border) 40%, transparent);
        font-size: 11px; color: var(--color-text); opacity: 0.8;
        pointer-events: auto; backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);
    }
    .mdi-weather-widget:hover { opacity: 1; }
    .mdi-weather-icon { font-size: 14px; line-height: 1; }
    .mdi-weather-temp { font-weight: 700; font-variant-numeric: tabular-nums; }
    .mdi-weather-place { color: var(--color-text-muted); max-width: 100px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
    .mdi-start-backdrop { position: fixed; inset: 0; z-index: 5000; background: transparent; }
    .mdi-start-menu {
        position: fixed; z-index: 5001; bottom: 52px; left: 50%; transform: translateX(-50%);
        width: min(700px, 95vw); max-height: min(78vh, 560px);
        display: flex; flex-direction: column;
        background: var(--color-background-primary, var(--color-bg));
        border: 0.5px solid var(--color-border-tertiary, var(--color-border));
        border-radius: 12px;
        box-shadow: 0 -4px 24px rgba(0,0,0,0.15); font-size: 12px; overflow: hidden;
    }
    .mdi-start-menu, .mdi-start-menu * { cursor: default !important; user-select: none !important; -webkit-user-select: none !important; }
    .mdi-start-menu button { cursor: pointer !important; }
    .mdi-start-top {
        display: grid; grid-template-columns: 1fr 2fr 1fr; gap: 0; flex: 1; min-height: 0; overflow-y: auto;
        border-bottom: 0.5px solid var(--color-border-tertiary, var(--color-border));
    }
    .mdi-start-col {
        padding: 14px 12px;
        border-right: 0.5px solid var(--color-border-tertiary, var(--color-border));
        overflow-y: auto;
    }
    .mdi-start-col:last-child { border-right: none; }
    .mdi-start-col-h {
        font-size: 10px; font-weight: 700; color: var(--color-text-muted);
        text-transform: uppercase; letter-spacing: 0.04em; margin-bottom: 8px;
    }
    .mdi-start-quickbtn {
        display: flex; align-items: center; justify-content: center; gap: 4px; padding: 6px 10px; border-radius: 6px;
        font-size: 12px; width: 100%; border: 0.5px solid var(--color-border, var(--color-border-tertiary));
        background: transparent; color: var(--color-text); box-shadow: none; margin-bottom: 6px;
    }
    .mdi-start-quickbtn--compact {
        padding: 4px 8px;
        font-size: 11px;
        margin-bottom: 0;
        min-height: 0;
    }
    .mdi-start-quick-row {
        display: flex;
        flex-wrap: wrap;
        gap: 6px;
        margin-bottom: 6px;
    }
    .mdi-start-quick-row .mdi-start-quickbtn {
        flex: 1 1 calc(50% - 3px);
        min-width: min(120px, 100%);
        width: auto;
    }
    .mdi-start-quick-plus { font-size: 12px; line-height: 1; font-weight: 600; }
    .mdi-start-quickbtn--compact .mdi-start-quick-plus { font-size: 11px; }
    .mdi-start-col > .mdi-start-quickbtn:first-child { margin-bottom: 6px; }
    .mdi-start-quickbtn:hover { background: var(--color-background-secondary, rgba(0,0,0,0.08)); }
    .mdi-start-icon-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 4px; }
    .mdi-start-icon-grid--wide { grid-template-columns: repeat(3, 1fr); }
    .mdi-start-app-btn {
        display: flex; flex-direction: column; align-items: center; gap: 3px;
        padding: 6px 2px; border-radius: 6px; border: none; background: transparent;
        color: var(--color-text); text-align: center; min-width: 0; box-shadow: none;
    }
    .mdi-start-app-btn:hover { background: var(--color-background-secondary, rgba(0,0,0,0.08)); }
    .mdi-start-app-ic { display: inline-flex; align-items: center; justify-content: center; }
    .mdi-start-app-ic svg { width: 24px; height: 24px; display: block; }
    .mdi-start-app-label {
        font-size: 9px; font-weight: 600; line-height: 1.15; color: var(--color-text-primary, var(--color-text));
        max-width: 100%; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
    }
    .mdi-start-project-btn {
        display: block; width: 100%; text-align: left; padding: 5px 8px; border-radius: 6px;
        border: none; background: transparent; font-size: 11px; box-shadow: none;
        color: var(--color-text-primary, var(--color-text)); white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    }
    .mdi-start-project-btn:hover { background: var(--color-background-secondary, rgba(0,0,0,0.08)); }
    .mdi-start-project-btn.current { color: var(--color-primary); font-weight: 600; }
    .mdi-start-project-search {
        width: 100%; box-sizing: border-box; margin-bottom: 8px;
        padding: 5px 8px; font-size: 11px; border-radius: 6px;
        border: 0.5px solid var(--color-border, var(--color-border-tertiary));
        background: var(--color-surface, var(--color-background-primary));
        color: var(--color-text);
        user-select: text !important; -webkit-user-select: text !important; cursor: text !important;
    }
    .mdi-start-project-search:focus { outline: 2px solid color-mix(in srgb, var(--color-primary) 35%, transparent); outline-offset: 1px; }
    .mdi-start-project-list {
        max-height: min(220px, 38vh); overflow-y: auto;
        margin: 0 -4px; padding: 0 4px;
    }
    .mdi-start-project-dialog-backdrop {
        position: fixed; inset: 0; z-index: 12000;
        background: rgba(15, 23, 42, 0.45);
        display: flex; align-items: center; justify-content: center; padding: 16px;
    }
    .mdi-start-project-dialog {
        max-width: 380px; width: 100%;
        background: var(--color-surface, var(--color-background-primary));
        border-radius: 12px;
        border: 0.5px solid var(--color-border);
        padding: 18px 20px;
        box-shadow: 0 20px 50px rgba(0, 0, 0, 0.25);
    }
    .mdi-start-project-dialog-title { font-weight: 700; font-size: 15px; margin-bottom: 8px; color: var(--color-text); }
    .mdi-start-project-dialog-text { margin: 0 0 16px 0; font-size: 12px; line-height: 1.45; color: var(--color-text-muted); }
    .mdi-start-project-dialog-text--tight { margin-bottom: 12px; }
    .mdi-start-project-dialog-hint {
        font-size: 12px; line-height: 1.4; color: var(--color-text-muted);
        margin: 10px 0 0 0; padding: 10px 12px; border-radius: 8px;
        background: color-mix(in srgb, var(--color-warning, #ca8a04) 12%, var(--color-surface));
        border: 1px solid color-mix(in srgb, var(--color-warning, #ca8a04) 28%, transparent);
    }
    .mdi-start-project-dialog-options {
        display: flex; flex-direction: column; gap: 10px; margin: 0 0 4px 0;
    }
    .mdi-start-project-dialog-option {
        display: flex; align-items: flex-start; gap: 12px; width: 100%;
        text-align: left; padding: 12px 14px; border-radius: 10px;
        border: 1.5px solid var(--color-border);
        background: var(--color-surface, var(--color-background-primary));
        color: var(--color-text); font: inherit; cursor: pointer;
        transition: border-color 0.15s ease, background 0.15s ease, box-shadow 0.15s ease;
    }
    .mdi-start-project-dialog-option:hover:not(:disabled) {
        border-color: color-mix(in srgb, var(--color-primary) 40%, var(--color-border));
        background: color-mix(in srgb, var(--color-primary) 5%, var(--color-surface, var(--color-background-primary)));
    }
    .mdi-start-project-dialog-option:focus-visible {
        outline: 2px solid color-mix(in srgb, var(--color-primary) 45%, transparent);
        outline-offset: 2px;
    }
    .mdi-start-project-dialog-option--selected {
        border-color: var(--color-primary);
        background: color-mix(in srgb, var(--color-primary) 10%, var(--color-surface, var(--color-background-primary)));
        box-shadow: 0 0 0 1px color-mix(in srgb, var(--color-primary) 20%, transparent);
    }
    .mdi-start-project-dialog-option:disabled {
        opacity: 0.48; cursor: not-allowed;
    }
    .mdi-start-project-dialog-option__radio {
        flex-shrink: 0; width: 18px; height: 18px; margin-top: 2px; border-radius: 50%;
        border: 2px solid var(--color-border); position: relative; box-sizing: border-box;
        background: var(--color-surface, var(--color-background-primary));
    }
    .mdi-start-project-dialog-option--selected .mdi-start-project-dialog-option__radio {
        border-color: var(--color-primary);
    }
    .mdi-start-project-dialog-option--selected .mdi-start-project-dialog-option__radio::after {
        content: ""; position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);
        width: 8px; height: 8px; border-radius: 50%; background: var(--color-primary);
    }
    .mdi-start-project-dialog-option__text { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
    .mdi-start-project-dialog-option__label { font-weight: 600; font-size: 13px; line-height: 1.25; }
    .mdi-start-project-dialog-option__desc { font-size: 11px; line-height: 1.35; color: var(--color-text-muted); font-weight: 400; }
    .mdi-start-project-dialog-actions { display: flex; gap: 10px; flex-wrap: wrap; justify-content: flex-end; margin-top: 16px; }
    .mdi-start-project-dialog-btn { font-size: 12px; padding: 6px 12px; }
    .mdi-start-user-bar {
        grid-column: 1 / -1; display: flex; align-items: center; justify-content: space-between;
        padding: 10px 16px; border-top: 0.5px solid var(--color-border-tertiary, var(--color-border)); margin-top: 0;
    }
    .mdi-start-user-info { display: flex; align-items: center; gap: 10px; }
    .mdi-start-user-avatar { width: 32px; height: 32px; border-radius: 50%; object-fit: cover; }
    .mdi-start-user-initials {
        width: 32px; height: 32px; border-radius: 50%;
        background: color-mix(in srgb, var(--color-primary) 15%, var(--color-bg));
        color: var(--color-primary); display: flex; align-items: center; justify-content: center;
        font-size: 13px; font-weight: 600;
    }
    .mdi-start-user-name { font-size: 13px; font-weight: 500; color: var(--color-text-primary, var(--color-text)); }
    .mdi-start-user-actions { display: flex; gap: 4px; }
    .mdi-start-user-btn {
        width: 32px; height: 32px; border-radius: 6px; border: none; background: transparent;
        display: flex; align-items: center; justify-content: center;
        color: var(--color-text-muted); box-shadow: none;
    }
    .mdi-start-user-btn:hover { background: var(--color-background-secondary, rgba(0,0,0,0.08)); color: var(--color-text-primary, var(--color-text)); }
    .mdi-start-desktop-list { display: flex; flex-direction: column; gap: 6px; margin-bottom: 2px; }
    .mdi-start-view-select {
        width: 100%; box-sizing: border-box; font-size: 12px; padding: 6px 8px;
        border: 1px solid var(--color-border-tertiary, var(--color-border)); border-radius: 8px;
        background: var(--color-bg, #fff); color: var(--color-text); cursor: pointer;
    }
    .mdi-start-view-select:focus { outline: 2px solid color-mix(in srgb, var(--color-primary) 35%, transparent); outline-offset: 1px; }
    .mdi-start-view-actions { display: flex; align-items: center; gap: 6px; }
    .mdi-start-view-actions .mdi-start-desktop-rename,
    .mdi-start-view-actions .mdi-start-desktop-delete {
        flex: 1 1 0; width: auto; min-width: 0; font-size: 11px; padding: 5px 6px;
    }
    .mdi-start-desktop-btn {
        display: flex; align-items: center; gap: 8px; width: 100%; text-align: left;
        padding: 5px 8px; border-radius: 6px; border: none; background: transparent;
        font-size: 11px; color: var(--color-text-primary, var(--color-text)); box-shadow: none; position: relative;
    }
    .mdi-start-desktop-btn:hover { background: var(--color-background-secondary, rgba(0,0,0,0.08)); }
    .mdi-start-desktop-btn.current { font-weight: 600; }
    .mdi-start-desktop-btn--new { color: var(--color-primary); }
    .mdi-start-desktop-btn--new:disabled { opacity: 0.4; cursor: not-allowed; }
    .mdi-start-desktop-dot {
        width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0;
        border: 1.5px solid var(--color-text-muted); background: transparent;
    }
    .mdi-start-desktop-dot.active {
        background: var(--color-primary); border-color: var(--color-primary);
    }
    .mdi-desktop-preview {
        background: var(--color-surface, var(--color-background-primary));
        border: 0.5px solid var(--color-border-tertiary, var(--color-border));
        border-radius: 10px;
        box-shadow: 0 4px 16px rgba(0,0,0,0.12);
        padding: 10px 12px;
        min-width: 160px; max-width: 220px;
        pointer-events: auto;
    }
    .mdi-start-h { padding: 0 0 10px; font-size: 10px; font-weight: 700; color: var(--color-text-muted); text-transform: uppercase; letter-spacing: .05em; }
    .mdi-desk-ic { flex-shrink: 0; width: 26px; height: 26px; display: inline-flex; align-items: center; justify-content: center; border-radius: 6px; background: color-mix(in srgb, var(--color-border-light) 90%, transparent); }
    .mdi-desk-ic-emoji { font-size: 17px; line-height: 1; }
    .mdi-desk-ic-img { display: block; width: 20px; height: 20px; object-fit: contain; border-radius: 4px; }
    .mdi-pin-btn-inner { display: inline-flex; align-items: center; justify-content: center; width: 100%; height: 100%; }
    .mdi-task-item-inner {
        display: inline-flex; align-items: center; justify-content: flex-start; gap: 6px;
        width: 100%; height: 100%; min-width: 0;
    }
    .mdi-task-item-lbl {
        font-size: 10px;
        font-weight: 600;
        line-height: 1.1;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
        min-width: 0;
        flex: 1 1 auto;
        text-align: left;
    }
    .mdi-start-sep { height: 0.5px; background: color-mix(in srgb, var(--color-border) 50%, transparent); margin: 4px 12px; }
    /* ── Yhtenäinen kontekstivalikko (kompakti, natiivi-tyylinen) ── */
    .mdi-ctx-menu {
        position: fixed; z-index: 10001; min-width: 140px; max-width: 220px;
        background: var(--color-background-primary, var(--color-bg, #fff));
        border: 0.5px solid color-mix(in srgb, var(--color-border) 60%, transparent);
        border-radius: 6px;
        /* Tummempi varjo kontekstivalikolle — erottuu selvemmin canvaksen ja sivupaneelien päällä */
        box-shadow: 0 10px 28px rgba(0,0,0,.35), 0 2px 6px rgba(0,0,0,.18);
        padding: 3px 0; font-size: 12px;
        backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
    }
    .mdi-ctx-menu--autopos { max-height: calc(100vh - 20px); max-height: calc(100dvh - 20px); overflow-y: auto; }
    /* Piirtokonteksti: overflow ei ole päällä → flyoutit toimivat position:absolute:lla hover-CSS:llä kuten muissa menuissa. */
    .mdi-ctx-menu--drawing .mdi-ctx-sub > .mdi-ctx-flyout {
        position: absolute;
        left: 100%; top: -3px;
        margin: 0;
    }
    .mdi-ctx-menu--drawing .mdi-ctx-sub:hover > .mdi-ctx-flyout { display: block; }
    .mdi-ctx-item {
        display: flex; align-items: center; gap: 6px; width: 100%; text-align: left;
        padding: 3px 12px; border: none; border-radius: 0;
        background: none; cursor: pointer; color: var(--color-text);
        font-size: 12px; line-height: 1.4;
    }
    .mdi-ctx-item:hover { background: var(--color-primary, #2563eb); color: #fff; }
    .mdi-ctx-item:active { background: var(--color-primary, #2563eb); color: #fff; opacity: .9; }
    .mdi-ctx-item .ctx-icon { display: inline-flex; align-items: center; justify-content: center; width: 14px; flex-shrink: 0; }
    .mdi-ctx-item .ctx-icon svg { display: block; }
    .mdi-ctx-item .ctx-shortcut { margin-left: auto; font-size: 11px; color: #999; padding-left: 12px; }
    .mdi-ctx-item:hover .ctx-shortcut { color: rgba(255,255,255,.7); }
    /* Separaattori: tummempi viiva jotta osiot erottuvat selkeämmin */
    .mdi-ctx-sep { height: 1px; background: color-mix(in srgb, var(--color-border) 140%, #000 20%); margin: 3px 0; opacity: 0.6; }
    /* Ikoni-rivi mittauksen kontekstivalikon yläosassa: Kopioi/Leikkaa/Liitä/Poista. */
    .mdi-ctx-iconbar { display: flex; align-items: center; gap: 2px; padding: 2px 4px; }
    .mdi-ctx-iconbtn {
        flex: 1; display: inline-flex; align-items: center; justify-content: center;
        width: 28px; height: 26px; padding: 4px;
        border: 1px solid transparent; border-radius: 4px;
        background: transparent; cursor: pointer; color: var(--color-text);
    }
    .mdi-ctx-iconbtn:hover { background: var(--color-primary, #2563eb); color: #fff; border-color: var(--color-primary); }
    .mdi-ctx-iconbtn--danger { color: var(--color-danger, #dc2626); }
    .mdi-ctx-iconbtn--danger:hover { background: var(--color-danger, #dc2626); color: #fff; border-color: var(--color-danger); }
    .mdi-ctx-iconbtn svg { width: 14px; height: 14px; display: block; }
    .mdi-ctx-sub { position: relative; }
    .mdi-ctx-sub > .mdi-ctx-flyout {
        display: none; position: absolute; left: 100%; top: -3px;
        background: var(--color-background-primary, var(--color-bg, #fff));
        border: 0.5px solid color-mix(in srgb, var(--color-border) 60%, transparent);
        border-radius: 6px; box-shadow: 0 4px 20px rgba(0,0,0,.25), 0 1px 4px rgba(0,0,0,.1);
        min-width: 120px; max-width: 220px; padding: 3px 0; z-index: 10002;
        backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
    }
    .mdi-ctx-sub > .mdi-ctx-flyout.mdi-ctx-flyout--layouts {
        max-width: 260px;
        min-width: 140px;
        max-height: min(360px, 72vh);
        overflow-y: auto;
    }
    .mdi-ctx-menu:not(.mdi-ctx-menu--drawing) .mdi-ctx-sub:hover > .mdi-ctx-flyout { display: block; }
    /* Flip: flyout ei mahdu oikealle → aukeaa vasemmalle sub-menu:n sijainnin suhteen */
    .mdi-ctx-sub > .mdi-ctx-flyout.mdi-ctx-flyout--flip { left: auto; right: 100%; }
    .mdi-ctx-sub-h {
        display: flex;
        align-items: center;
        gap: 6px;
        width: 100%;
        box-sizing: border-box;
        padding: 3px 12px;
        font-size: 12px;
        line-height: 1.4;
        color: var(--color-text);
        cursor: default;
    }
    .mdi-ctx-sub-h::after { content: '\25B6'; font-size: 10px; margin-left: auto; opacity: .5; }
    .mdi-ctx-item-muted {
        padding: 6px 12px;
        font-size: 11px;
        line-height: 1.35;
        color: var(--color-text-muted);
        cursor: default;
    }
    .mdi-ctx-item--current { font-weight: 600; }
    .mdi-ctx-item--danger {
        color: #b91c1c;
        font-weight: 600;
    }
    .mdi-ctx-item--danger:hover {
        background: color-mix(in srgb, #b91c1c 88%, #000) !important;
        color: #fff !important;
    }
    .mdi-ctx-sub > .mdi-ctx-item::after { content: '\25B6'; font-size: 10px; margin-left: auto; opacity: .5; }
    .mdi-jump-backdrop { position: fixed; inset: 0; z-index: 7090; background: transparent; }
    .mdi-jump-menu {
        position: fixed; z-index: 7100; min-width: 180px; max-width: 220px;
        background: var(--color-background-primary, var(--color-bg, #fff));
        border: 0.5px solid color-mix(in srgb, var(--color-border) 60%, transparent);
        border-radius: 6px;
        box-shadow: 0 4px 20px rgba(0,0,0,.25), 0 1px 4px rgba(0,0,0,.1);
        padding: 3px 0; font-size: 12px;
        backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
    }
    .mdi-jump-h {
        display: flex; align-items: center; gap: 6px; padding: 4px 12px 3px; font-weight: 600; color: var(--color-text);
        border-bottom: 1px solid var(--color-border); margin-bottom: 2px; font-size: 12px;
    }
    .mdi-jump-h .mdi-desk-ic { width: 18px; height: 18px; }
    .mdi-jump-sep { height: 1px; background: var(--color-border); margin: 2px 0; }
    .mdi-jump-item {
        display: flex; align-items: center; gap: 6px; width: 100%; text-align: left;
        padding: 3px 12px; border: none; border-radius: 0; background: none; cursor: pointer;
        color: var(--color-text); font-size: 12px;
    }
    .mdi-jump-item:hover { background: var(--color-primary, #2563eb); color: #fff; }
    .mdi-jump-item:disabled { opacity: .45; cursor: not-allowed; }
    .mdi-jump-item-muted { font-size: 10px; color: var(--color-text-muted); padding: 2px 12px 6px; }
    .mdi-modal-back { position: fixed; inset: 0; z-index: var(--app-modal-z, 20000000); background: color-mix(in srgb, var(--color-text) 38%, transparent); display: flex; align-items: center; justify-content: center; padding: 16px; }
    .mdi-modal { background: var(--color-bg); border-radius: 10px; border: 1px solid var(--color-border); max-width: 560px; width: 100%; max-height: 90vh; overflow: auto; padding: 16px; box-shadow: 0 20px 50px rgba(0,0,0,.25); }
    .mdi-snap-canvas { position: relative; width: 100%; height: 220px; background: var(--color-surface); border: 1px dashed var(--color-border); border-radius: 8px; margin: 10px 0; }
    .mdi-snap-canvas-edit { pointer-events: auto; cursor: default; overflow: visible; touch-action: none; user-select: none; -webkit-user-select: none; }
    .mdi-snap-zone-edit { position: absolute; box-sizing: border-box; border: 2px solid rgba(37,99,235,0.85); background: rgba(37,99,235,0.12); min-width: 8%; min-height: 12%; z-index: 1; border-radius: 8px; overflow: visible; }
    .mdi-snap-zone-edit--selected { z-index: 3 !important; border-width: 3px; border-color: #d97706; box-shadow: 0 0 0 2px rgba(217, 119, 6, 0.4), inset 0 0 0 1px rgba(255,255,255,0.25); background: rgba(245, 158, 11, 0.2); }
    .mdi-snap-zone-edit--selected .mdi-snap-zone-label { color: #9a3412; font-weight: 800; }
    .mdi-snap-zone-label { position: absolute; left: 4px; top: 2px; font-size: 9px; font-weight: 700; color: #1e40af; pointer-events: none; max-width: calc(100% - 8px); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
    .mdi-snap-h {
        position: absolute; width: 22px; height: 22px; z-index: 4; box-sizing: border-box; pointer-events: auto;
        border-radius: 4px; background: rgba(37, 99, 235, 0.22); border: 1px solid rgba(37, 99, 235, 0.45);
        opacity: 0.35; transition: opacity 0.12s ease, background 0.12s ease;
    }
    .mdi-snap-zone-edit:hover .mdi-snap-h { opacity: 0.65; }
    .mdi-snap-zone-edit--selected .mdi-snap-h { opacity: 0.55; background: rgba(217, 119, 6, 0.2); border-color: rgba(180, 83, 9, 0.55); }
    .mdi-snap-h-nw { left: -9px; top: -9px; cursor: nwse-resize; }
    .mdi-snap-h-n { left: 50%; top: -9px; transform: translateX(-50%); cursor: ns-resize; }
    .mdi-snap-h-ne { right: -9px; top: -9px; cursor: nesw-resize; }
    .mdi-snap-h-w { left: -9px; top: 50%; transform: translateY(-50%); cursor: ew-resize; }
    .mdi-snap-h-e { right: -9px; top: 50%; transform: translateY(-50%); cursor: ew-resize; }
    .mdi-snap-h-sw { left: -9px; bottom: -9px; cursor: nesw-resize; }
    .mdi-snap-h-s { left: 50%; bottom: -9px; transform: translateX(-50%); cursor: ns-resize; }
    .mdi-snap-h-se { right: -9px; bottom: -9px; cursor: nwse-resize; }
    .mdi-snap-settings { border: 1px solid var(--color-border); border-radius: 8px; padding: 10px 12px; margin-bottom: 12px; background: var(--color-surface); }
    .mdi-snap-settings h4 { margin: 0 0 10px 0; font-size: 12px; font-weight: 700; color: var(--color-text-muted); text-transform: uppercase; letter-spacing: .04em; }
    .mdi-snap-setting-row { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; flex-wrap: wrap; }
    .mdi-snap-setting-row:last-child { margin-bottom: 0; }
    .mdi-snap-setting-row label { flex: 1; min-width: 140px; font-size: 12px; color: var(--color-text); }
    .mdi-snap-setting-row input[type="range"] { flex: 1; min-width: 120px; max-width: 220px; accent-color: var(--color-primary); }
    .mdi-snap-setting-val { min-width: 52px; font-size: 12px; font-variant-numeric: tabular-nums; color: var(--color-text-muted); }
    .mdi-snap-selection-footer { margin-top: 10px; min-height: 92px; padding: 10px 12px; border: 1px solid var(--color-border); border-radius: 8px; background: var(--color-surface); display: flex; flex-direction: column; gap: 10px; font-size: 12px; box-sizing: border-box; }
    .mdi-snap-selection-footer-muted { color: var(--color-text-muted); font-size: 12px; }
    .mdi-meas-tree { font-size: 11px; line-height: 1.35; }
    .mdi-meas-row { display: flex; align-items: flex-start; gap: 6px; margin: 2px 0; }
    .mdi-meas-toggle { cursor: pointer; user-select: none; color: var(--color-primary); width: 14px; flex-shrink: 0; }
    .tool-ic { font-size: 12px; flex-shrink: 0; display: inline-flex; align-items: center; }
    .tool-ic svg { display: block; width: 14px; height: 14px; }
    .mdi-meas-col-tool { flex: 0 0 auto; width: 18px; display: inline-flex; align-items: center; justify-content: center; color: var(--color-text-muted); opacity: 0.85; }
    .mdi-meas-col-tool svg { width: 14px; height: 14px; }
    .mdi-meas-rakosa-badge {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        font-size: 8px;
        font-weight: 700;
        line-height: 1;
        min-width: 12px;
        padding: 1px 3px;
        margin-right: 4px;
        border-radius: 3px;
        background: rgba(37, 99, 235, 0.14);
        color: var(--color-primary, #2563eb);
        flex-shrink: 0;
        vertical-align: middle;
    }
    .mdi-active-group { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; color: var(--color-text); margin-left: 8px; }
    .mdi-active-dot { width: 8px; height: 8px; border-radius: 50%; background: #22c55e; flex-shrink: 0; }
    /* Yhdenmukainen tyyli mdi-kohdistus-toast:n kanssa — sama pieni pille-esitys
       samassa sijainnissa (bottom 80px, keskitetty). Yläpuolella drawing-statusbarin,
       ei nakkaudu tehtäväpalkin kanssa päällekkäin. */
    .mdi-toast {
        position: fixed; bottom: 80px; left: 50%; transform: translateX(-50%);
        z-index: 9500; padding: 4px 14px; font-size: 11px;
        color: var(--color-text-primary, var(--color-text));
        background: var(--color-background-secondary, var(--color-surface));
        border: 0.5px solid var(--color-border-tertiary, var(--color-border));
        border-radius: 6px; box-shadow: 0 2px 10px rgba(0, 0, 0, 0.10), 0 -4px 12px rgba(0, 0, 0, 0.06);
        max-width: 92vw; pointer-events: none;
    }
    .pomodoro-widget { position: absolute; top: 8px; right: 8px; z-index: 60; background: var(--color-surface, #f1f5f9); border: 1px solid var(--color-border, #e2e8f0); border-radius: 8px; padding: 4px 8px; font-size: 12px; cursor: pointer; display: flex; align-items: center; gap: 4px; }
    .pomodoro-panel { position: fixed; bottom: 72px; right: 16px; top: auto; z-index: 61; background: var(--color-bg, #fff); border: 1px solid var(--color-border); border-radius: 10px; padding: 12px; min-width: 160px; box-shadow: 0 8px 24px rgba(0,0,0,.15); }
    .pomodoro-time { font-size: 20px; font-weight: 700; font-variant-numeric: tabular-nums; }
    .pomodoro-phase { font-size: 11px; color: var(--color-text-muted); margin: 4px 0 8px; }
    .pomodoro-controls { display: flex; gap: 6px; }
    .pomodoro-controls button { border: 1px solid var(--color-border); background: var(--color-surface); border-radius: 6px; cursor: pointer; padding: 4px 8px; }
    .pomodoro-dots { display: inline-flex; gap: 3px; align-items: center; }
    .pomodoro-dots .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--color-border, #cbd5e1); }
    .pomodoro-dots .dot-active { background: #eab308; }
    .friday-text { position: absolute; top: 40px; right: 8px; z-index: 59; font-size: 11px; color: var(--color-text-muted); max-width: 200px; text-align: right; }
    .break-notification { position: fixed; bottom: 58px; right: 16px; z-index: 8500; max-width: 280px; background: var(--color-bg); border: 1px solid var(--color-border); border-radius: 12px; padding: 12px; box-shadow: 0 12px 32px rgba(0,0,0,.2); }
    .break-notification .break-icon { font-size: 28px; margin-bottom: 6px; }
    .break-notification .break-message { font-size: 13px; font-weight: 600; margin-bottom: 10px; }
    .break-actions { display: flex; gap: 8px; flex-wrap: wrap; }
    .break-actions button { font-size: 11px; padding: 6px 10px; border-radius: 6px; border: 1px solid var(--color-border); background: var(--color-surface); cursor: pointer; }
    .yt-curated { display: flex; flex-direction: column; gap: 10px; margin-bottom: 10px; }
    .yt-curated-h { font-size: 10px; font-weight: 700; color: var(--color-text-muted); text-transform: uppercase; }
    .yt-curated-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; }
    .yt-pick { border: 1px solid var(--color-border); border-radius: 8px; padding: 8px 6px; cursor: pointer; font-size: 10px; text-align: center; line-height: 1.25; background: var(--color-surface); }
    .yt-pick:hover { border-color: var(--color-primary); }
    .yt-pick.sel { border-color: var(--color-primary); background: rgba(37,99,235,.1); }

    /* ── Paneeli hsplitter ──────────────────────────────── */
    .mdi-dshell-hsplitter { height: 4px; min-height: 4px; background: var(--color-border-tertiary, var(--color-border)); cursor: ns-resize; flex-shrink: 0; }
    .mdi-dshell-hsplitter:hover { background: var(--color-primary); }
    .panel-icon-btn.dragging { opacity: .4; cursor: grabbing !important; }
    .panel-icon-placeholder { width: 100%; background: rgba(37,99,235,.12); border-radius: 4px; border: 1px dashed var(--color-primary); margin: 2px 0; min-height: 32px; }

    /* ── Tilat-paneeli (MdiZonesPanel) ─────────────────────── */
    .zones-panel {
        display: flex;
        flex-direction: column;
        height: 100%;
        min-height: 0;
        background: var(--color-bg, #fff);
        color: var(--color-text);
        font-size: 11px;
    }
    .zones-panel-toolbar {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        gap: 6px;
        padding: 8px 10px;
        border-bottom: 0.5px solid var(--color-border-tertiary, var(--color-border));
        flex-shrink: 0;
        background: var(--color-surface, #f8fafc);
        position: relative;
        z-index: 1;
    }
    .zones-four-actions {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 6px;
        padding: 8px 10px 4px;
        flex-shrink: 0;
        border-bottom: 0.5px solid var(--color-border-tertiary, var(--color-border));
        background: var(--color-surface, #f8fafc);
    }
    .zones-four-btn {
        padding: 8px 6px;
        font-size: 11px;
        font-weight: 600;
        border-radius: 6px;
        border: 0.5px solid var(--color-border-tertiary, var(--color-border));
        background: var(--color-bg);
        cursor: pointer;
        color: var(--color-text);
    }
    .zones-four-btn:hover { background: var(--color-surface-hover, rgba(0,0,0,.04)); }
    .zones-four-btn--primary {
        border-color: var(--color-primary);
        background: color-mix(in srgb, var(--color-primary) 12%, transparent);
        color: var(--color-primary);
    }
    .zones-toolbar-secondary {
        padding: 4px 10px 8px;
        flex-shrink: 0;
        border-bottom: 0.5px solid var(--color-border-tertiary, var(--color-border));
        background: var(--color-surface, #f8fafc);
    }
    .zones-linkish-btn {
        background: none;
        border: none;
        padding: 0;
        font-size: 10px;
        color: var(--color-primary);
        cursor: pointer;
        text-decoration: underline;
    }
    .zones-panel-title {
        font-size: 12px;
        font-weight: 600;
        color: var(--color-text);
        margin-right: auto;
        letter-spacing: 0.01em;
    }
    /* Tilat-paneeli: pelkkä silmä-kuvake (ei laatikkonappia) */
    .zones-toolbar-icon-btn {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        border: none;
        border-radius: 4px;
        background: transparent;
        cursor: pointer;
        font-size: 16px;
        line-height: 1;
        padding: 4px 6px;
        margin: 0;
        width: auto;
        height: auto;
        min-width: 28px;
        min-height: 28px;
        color: var(--color-text-muted);
        -webkit-tap-highlight-color: transparent;
    }
    .zones-toolbar-icon-btn:hover {
        background: var(--color-surface-hover, rgba(0,0,0,.06));
        color: var(--color-text);
    }
    .zones-toolbar-icon-btn:focus-visible {
        outline: 2px solid var(--color-primary);
        outline-offset: 1px;
    }
    .zones-toolbar-icon-btn.active {
        background: transparent;
        color: var(--color-primary);
    }
    .zones-toolbar-btn {
        padding: 4px 10px;
        font-size: 11px;
        border-radius: 6px;
        border: 0.5px solid var(--color-border-tertiary, var(--color-border));
        background: var(--color-bg);
        color: var(--color-text);
        cursor: pointer;
        white-space: nowrap;
    }
    .zones-toolbar-btn:hover { background: var(--color-surface-hover, rgba(0,0,0,.04)); }
    .zones-toolbar-btn.active {
        border-color: color-mix(in srgb, var(--color-primary) 45%, transparent);
        background: color-mix(in srgb, var(--color-primary) 16%, transparent);
        color: var(--color-primary);
        font-weight: 600;
    }
    .zones-toolbar-btn--accent {
        border-color: var(--color-primary);
        background: var(--color-primary);
        color: #fff;
    }
    /* Ei vaihdeta taustaa hoverissa: geneerinen .zones-toolbar-btn:hover muuten peittää sinisen. */
    .zones-toolbar-btn--accent:hover {
        background: var(--color-primary);
        color: #fff;
        border-color: var(--color-primary);
        filter: none;
    }
    .zones-toolbar-btn--compact { padding: 4px 9px; min-width: 30px; font-weight: 600; }
    .zones-toolbar-add-wrap {
        position: relative;
        display: inline-flex;
        align-items: center;
    }
    .zones-add-backdrop {
        position: fixed;
        inset: 0;
        z-index: 99;
        background: transparent;
    }
    .zones-add-flyout {
        position: absolute;
        right: 0;
        top: calc(100% + 4px);
        z-index: 100;
        min-width: 228px;
        padding: 4px 0;
        background: var(--color-bg, #fff);
        border: 0.5px solid var(--color-border-tertiary, var(--color-border));
        border-radius: 8px;
        box-shadow: 0 8px 24px rgba(0,0,0,.12);
    }
    /* Koko työkalurivin leveys: kapeassa sivupaneelissa ei tipu vasemmalle piiloon (228px > nappi). */
    .zones-add-flyout--toolbar {
        left: 10px;
        right: 10px;
        width: auto;
        min-width: 0;
        top: 100%;
        margin-top: 4px;
    }
    .zones-add-item {
        display: block;
        width: 100%;
        text-align: left;
        padding: 6px 12px;
        font-size: 11px;
        border: none;
        background: none;
        cursor: pointer;
        color: var(--color-text);
    }
    .zones-add-item:hover { background: color-mix(in srgb, var(--color-primary) 10%, transparent); }
    .zones-add-item--muted { color: var(--color-text-muted); font-size: 10px; }
    .zones-add-sep { height: 1px; margin: 4px 8px; background: var(--color-border-tertiary, var(--color-border)); }
    .zones-section-label {
        font-size: 10px;
        font-weight: 600;
        color: var(--color-text-muted);
        text-transform: uppercase;
        letter-spacing: 0.04em;
        margin: 10px 4px 4px 8px;
    }
    .zones-section-label--indented { margin-left: 22px; }
    .zones-section-label--floor { margin-left: 34px; margin-top: 8px; }
    .zones-hint {
        font-size: 10px;
        line-height: 1.45;
        color: var(--color-text-secondary);
        margin: 6px 8px 8px 22px;
        padding: 8px 10px;
        background: color-mix(in srgb, var(--color-primary) 6%, transparent);
        border-radius: 6px;
        border: 0.5px solid color-mix(in srgb, var(--color-primary) 18%, transparent);
    }
    .zones-action-btn {
        display: block;
        width: calc(100% - 16px);
        margin: 4px 8px;
        padding: 6px 10px;
        font-size: 10px;
        text-align: left;
        border-radius: 6px;
        border: 0.5px solid var(--color-border-tertiary, var(--color-border));
        background: var(--color-bg);
        color: var(--color-primary);
        cursor: pointer;
        font-weight: 500;
    }
    .zones-action-btn:hover {
        background: color-mix(in srgb, var(--color-primary) 10%, transparent);
        border-color: color-mix(in srgb, var(--color-primary) 35%, transparent);
    }
    .zones-action-btn--floor { margin-left: 34px; width: calc(100% - 42px); }
    .zones-action-btn--block { margin-left: 46px; width: calc(100% - 54px); }
    .zones-action-btn--building { margin-left: 22px; width: calc(100% - 30px); font-weight: 600; }
    .zones-action-btn--global { margin-top: 8px; }
    .zones-action-btn--primary {
        border-color: var(--color-primary);
        background: color-mix(in srgb, var(--color-primary) 12%, transparent);
        font-weight: 600;
    }
    .zones-action-btn--secondary {
        font-weight: 500;
        color: var(--color-text-secondary);
        border-style: dashed;
    }
    .zones-action-btn--secondary:hover {
        color: var(--color-primary);
    }
    .zone-name-col {
        flex: 1;
        min-width: 0;
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        gap: 2px;
    }
    .zone-name-col .zone-name {
        max-width: 100%;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }
    .zones-geo-badge {
        font-size: 9px;
        font-weight: 600;
        color: var(--color-text-muted);
        background: var(--color-surface-hover, rgba(0,0,0,.06));
        padding: 1px 5px;
        border-radius: 4px;
        line-height: 1.2;
    }
    .zones-list { flex: 1; min-height: 0; overflow-y: auto; padding: 8px 6px; }
    .zones-empty-card {
        padding: 12px;
        font-size: 11px;
        color: var(--color-text-secondary);
        line-height: 1.5;
        border: 0.5px dashed var(--color-border-tertiary, var(--color-border));
        border-radius: 8px;
        margin-bottom: 8px;
        background: var(--color-surface, #f8fafc);
    }
    .zones-empty-title { font-weight: 600; color: var(--color-text); margin: 0 0 8px 0; font-size: 12px; }
    .zones-empty-actions { display: flex; flex-direction: column; gap: 6px; margin-top: 10px; }
    .zone-row {
        display: flex;
        align-items: center;
        gap: 4px;
        padding: 5px 6px;
        border-radius: 6px;
        cursor: pointer;
        font-size: 11px;
        min-height: 28px;
    }
    .zone-row:hover { background: var(--color-surface-hover, rgba(0,0,0,.04)); }
    .zone-row.building-row { font-weight: 600; }
    .zone-row.space-row.selected {
        background: color-mix(in srgb, var(--color-primary) 10%, transparent);
        outline: 1px solid color-mix(in srgb, var(--color-primary) 40%, transparent);
        outline-offset: -1px;
    }
    .zone-toggle { width: 14px; flex-shrink: 0; color: var(--color-text-muted); font-size: 9px; text-align: center; }
    .zone-indent { width: 12px; flex-shrink: 0; }
    .zone-indent2 { width: 22px; flex-shrink: 0; }
    .zone-color-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
    .zone-row .zone-name { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
    .zone-row .zone-area, .zone-row .zone-area-missing { font-size: 10px; color: var(--color-text-muted); flex-shrink: 0; }
    .zone-area-missing { opacity: .65; }
    .zone-add-space, .zone-add-floor, .zone-add-building {
        font-size: 10px;
        color: var(--color-primary);
        padding: 5px 6px 5px 8px;
        margin: 2px 0;
        border-radius: 4px;
        cursor: pointer;
    }
    .zone-add-space:hover, .zone-add-floor:hover, .zone-add-building:hover {
        background: color-mix(in srgb, var(--color-primary) 8%, transparent);
    }
    .zone-add-building--emph { font-weight: 600; }
    .zone-detail {
        flex-shrink: 0;
        border-top: 0.5px solid var(--color-border-tertiary, var(--color-border));
        padding: 10px;
        background: var(--color-surface, #f8fafc);
    }
    .zone-detail-name { font-weight: 600; font-size: 12px; margin-bottom: 8px; color: var(--color-text); }
    .zone-detail-hint {
        font-size: 10px;
        line-height: 1.45;
        color: var(--color-text-secondary);
        margin-bottom: 10px;
        padding: 8px;
        background: var(--color-surface-hover, rgba(0,0,0,.04));
        border-radius: 6px;
    }
    .zone-detail-row {
        display: flex;
        justify-content: space-between;
        gap: 8px;
        font-size: 11px;
        margin-bottom: 6px;
        color: var(--color-text-secondary);
    }
    .zone-detail-row span:last-child { color: var(--color-text); font-weight: 500; }
    .zone-copy-btn {
        margin-top: 10px;
        width: 100%;
        padding: 6px 10px;
        font-size: 11px;
    }
    /* Tilat-paneelin kontekstivalikko: ClientX/Y vaatii position:fixed (.mdi-context-menu ei ollut määritelty) */
    .zones-ctx-backdrop {
        position: fixed;
        inset: 0;
        z-index: 10000;
        background: transparent;
    }
    .mdi-ctx-menu.zones-ctx .ctx-item {
        display: block;
        padding: 3px 12px;
        font-size: 12px;
        line-height: 1.4;
        cursor: pointer;
        color: var(--color-text);
        user-select: none;
    }
    .mdi-ctx-menu.zones-ctx .ctx-item:hover {
        background: var(--color-primary, #2563eb);
        color: #fff;
    }
    .mdi-ctx-menu.zones-ctx .ctx-item.danger {
        color: #b91c1c;
        font-weight: 600;
    }
    .mdi-ctx-menu.zones-ctx .ctx-item.danger:hover {
        background: color-mix(in srgb, #b91c1c 88%, #000);
        color: #fff;
    }
    .mdi-ctx-menu.zones-ctx .ctx-divider {
        height: 1px;
        margin: 2px 0;
        background: var(--color-border-tertiary, var(--color-border));
    }
    .mdi-ctx-menu.zones-ctx .ctx-item.ctx-item--static {
        cursor: default;
        font-size: 10px;
        font-weight: 600;
        color: var(--color-text-muted);
        text-transform: uppercase;
        letter-spacing: 0.03em;
        pointer-events: none;
    }
    .mdi-ctx-menu.zones-ctx .ctx-item.ctx-item--static:hover {
        background: transparent;
        color: var(--color-text-muted);
    }
    .zones-ctx-color-row {
        display: flex;
        flex-wrap: wrap;
        gap: 6px;
        padding: 2px 12px 8px;
    }
    .zones-ctx-swatch {
        width: 18px;
        height: 18px;
        border-radius: 50%;
        border: 2px solid rgba(0,0,0,0.12);
        cursor: pointer;
        padding: 0;
        flex-shrink: 0;
    }
    .zones-ctx-swatch:hover { filter: brightness(1.08); }
    .zones-ctx-swatch.active {
        box-shadow: 0 0 0 2px var(--color-primary, #2563eb);
    }
    .zones-modal-card {
        position: fixed;
        z-index: 10002;
        min-width: 260px;
        max-width: min(360px, calc(100vw - 32px));
        background: var(--color-bg);
        border: 0.5px solid var(--color-border-tertiary, var(--color-border));
        border-radius: 10px;
        box-shadow: 0 12px 40px rgba(0,0,0,.16);
    }
    .zones-modal-card--center {
        left: 50%;
        top: 28%;
        transform: translateX(-50%);
    }
    .zones-modal-card--wide { min-width: 280px; max-width: min(400px, calc(100vw - 32px)); }
    .zones-modal-card-header { padding: 12px 12px 4px; font-weight: 600; font-size: 12px; color: var(--color-text); }
    .zones-modal-card-hint {
        padding: 0 12px 10px;
        font-size: 11px;
        color: var(--color-text-secondary);
        line-height: 1.45;
    }
    .zones-modal-field-label {
        padding: 6px 12px 4px;
        font-size: 10px;
        font-weight: 600;
        color: var(--color-text-muted);
        text-transform: uppercase;
        letter-spacing: 0.03em;
    }
    .zones-modal-input, .zones-modal-select {
        margin: 0 12px 10px;
        display: block;
        width: calc(100% - 24px);
        box-sizing: border-box;
        padding: 6px 8px;
        font-size: 11px;
        border: 0.5px solid var(--color-border-tertiary, var(--color-border));
        border-radius: 6px;
        background: var(--color-bg);
        color: var(--color-text);
    }
    .zones-modal-select { cursor: pointer; }
    .zones-modal-input:focus, .zones-modal-select:focus {
        outline: none;
        border-color: var(--color-primary);
        box-shadow: 0 0 0 2px color-mix(in srgb, var(--color-primary) 22%, transparent);
    }
    .zones-type-toggle { display: flex; gap: 6px; padding: 0 12px 8px; }
    .zones-type-toggle .mdi-tool-btn { flex: 1; }
    .zones-modal-actions {
        display: flex;
        justify-content: flex-end;
        gap: 8px;
        padding: 10px 12px 12px;
        border-top: 0.5px solid var(--color-border-tertiary, var(--color-border));
    }

    /* ── Tilat/Zones (lista nimellä) ─────────────────────── */
    .zone-select-all { display: flex; align-items: center; gap: 8px; padding: 6px 8px; border-bottom: 0.5px solid var(--color-border-tertiary, var(--color-border)); font-size: 12px; flex-shrink: 0; }
    .selected-count { color: var(--color-primary); font-size: 11px; }
    .create-measurements-btn { margin-left: auto; font-size: 11px; color: #fff; background: var(--color-primary); border: none; border-radius: 4px; padding: 3px 10px; cursor: pointer; white-space: nowrap; }
    .create-measurements-btn:hover { opacity: .85; }
    .zone-item { display: flex; align-items: center; gap: 6px; padding: 3px 8px; font-size: 11px; cursor: pointer; border-radius: 3px; }
    .zone-item:hover { background: var(--color-surface-hover, rgba(0,0,0,.04)); }
    .zone-item.selected { background: rgba(37,99,235,.08); }
    .zone-item.zone-active { outline: 1.5px solid var(--color-primary); outline-offset: -1px; }
    .zone-name { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
    .zone-area { color: var(--color-text-muted); font-size: 10px; white-space: nowrap; }

    /* ── Tila-tietopaneeli ────────────────────────────── */
    .zone-detail-panel { width: 220px; flex-shrink: 0; border-left: 0.5px solid var(--color-border-tertiary, var(--color-border)); padding: 8px; overflow-y: auto; font-size: 11px; }
    .zone-detail-title { font-size: 13px; font-weight: 500; margin-bottom: 10px; padding-bottom: 6px; border-bottom: 0.5px solid var(--color-border-tertiary, var(--color-border)); }
    .zone-field { margin-bottom: 10px; }
    .zone-field label { display: block; font-size: 10px; font-weight: 500; color: var(--color-text-muted); text-transform: uppercase; letter-spacing: .4px; margin-bottom: 3px; }
    .zone-field input, .zone-field select, .zone-field textarea { width: 100%; padding: 3px 6px; border: 1px solid var(--color-border); border-radius: 3px; font-size: 11px; box-sizing: border-box; }
    .zone-field textarea { resize: vertical; }
    .zone-field-row { display: flex; align-items: center; gap: 4px; }
    .zone-field-hint { display: block; font-size: 9px; color: var(--color-text-muted); margin-top: 2px; }
    .zone-calculated { font-size: 13px; font-weight: 500; }
    .zone-from-drawing { font-size: 13px; cursor: help; }
    .zone-source { margin-top: 12px; padding-top: 6px; border-top: 0.5px solid var(--color-border-tertiary, var(--color-border)); }
    .source-badge { font-size: 10px; padding: 2px 6px; border-radius: 12px; }
    .source-drawing { background: rgba(37,99,235,.1); color: var(--color-primary); }
    .source-manual { background: var(--color-surface-hover, rgba(0,0,0,.04)); color: var(--color-text-muted); }

    /* ── Vahvistusdialogi ──────────────────────────── */
    .mdi-confirm-dialog { background: var(--color-bg, #fff); border-radius: 12px; box-shadow: 0 8px 32px rgba(0,0,0,.15); padding: 20px 24px; max-width: 360px; width: 90%; margin: auto; }
    .mdi-confirm-title { font-size: 15px; font-weight: 600; margin-bottom: 8px; }
    .mdi-confirm-msg { font-size: 13px; color: var(--color-text-muted); margin: 0 0 16px 0; }
    .mdi-confirm-actions { display: flex; justify-content: flex-end; gap: 8px; }
    .mdi-confirm-danger { background: #dc2626 !important; color: #fff !important; border-color: #dc2626 !important; }
    .mdi-confirm-danger:hover { background: #b91c1c !important; }
    .mdi-modal-back { position: fixed; inset: 0; z-index: var(--app-modal-z, 20000000); background: rgba(0,0,0,.3); display: flex; align-items: center; justify-content: center; }
    /* Vahvistus: korkein taso + varmistusdialogi klikattavana (taskbar/always-on-top -ikkunat). */
    .mdi-modal-back--confirm {
        z-index: 2147483000;
    }
    .mdi-modal-back--confirm .mdi-confirm-dialog {
        position: relative;
        z-index: 1;
    }
    /* Snap-editori: ei pystysuuntaista keskitystä → modaali ei hyppää kun valintapaneeli kasvaa */
    .mdi-modal-back--snap {
        align-items: flex-start;
        justify-content: center;
        padding-top: max(20px, min(10vh, 72px));
        padding-bottom: 24px;
        padding-left: 16px;
        padding-right: 16px;
    }
    .mdi-snap-editor-modal {
        user-select: none;
        -webkit-user-select: none;
        touch-action: manipulation;
    }

    /* ── Työpöytävaihdin: Tehtävätila-ikoni + popover (mdi-search-cluster) ── */

    /* ── Kelluva piirustusvalitsin ──────────────────── */
    .mdi-drawing-switcher { position: absolute; top: 4px; left: 50%; transform: translateX(-50%); z-index: 100; pointer-events: all; }
    .mdi-drawing-switcher-btn { display: flex; align-items: center; gap: 4px; background: var(--color-primary, #2563eb); border: none; border-radius: 6px; padding: 4px 12px; font-size: 11px; cursor: pointer; color: #fff; max-width: 320px; white-space: nowrap; box-shadow: 0 2px 6px rgba(0,0,0,.12); }
    .mdi-drawing-switcher-btn:hover { background: color-mix(in srgb, var(--color-primary, #2563eb) 85%, #000); }
    .mdi-drawing-switcher-label { overflow: hidden; text-overflow: ellipsis; }
    .mdi-drawing-switcher-dropdown { position: absolute; top: 100%; left: 0; margin-top: 2px; min-width: 240px; max-width: 340px; max-height: min(400px, 60vh); overflow-y: auto; background: var(--color-bg, #fff); border: 0.5px solid var(--color-border-tertiary, var(--color-border)); border-radius: 6px; box-shadow: 0 4px 20px rgba(0,0,0,.25), 0 1px 4px rgba(0,0,0,.1); padding: 3px 0; z-index: 101; }
    .mdi-drawing-switcher-item { display: flex; align-items: center; gap: 6px; width: 100%; padding: 4px 10px; border: none; background: none; cursor: pointer; font-size: 11px; color: var(--color-text); text-align: left; }
    .mdi-drawing-switcher-item:hover { background: var(--color-primary, #2563eb); color: #fff; }
    .mdi-drawing-switcher-item.active { font-weight: 600; }

    /* ── Kelluva sivunumero ─────────────────────────── */
    .mdi-page-nav-float { position: absolute; bottom: 8px; left: 50%; transform: translateX(-50%); display: flex; align-items: center; gap: 6px; background: rgba(255,255,255,.92); backdrop-filter: blur(4px); border: 0.5px solid var(--color-border-tertiary, var(--color-border)); border-radius: 16px; padding: 3px 10px; font-size: 12px; z-index: 100; pointer-events: all; box-shadow: 0 2px 8px rgba(0,0,0,.08); }
    .mdi-page-nav-float button { border: none; background: none; cursor: pointer; font-size: 11px; padding: 2px 4px; color: var(--color-text-muted); border-radius: 4px; }
    .mdi-page-nav-float button:hover:not(:disabled) { background: var(--color-surface-hover, rgba(0,0,0,.05)); color: var(--color-text); }
    .mdi-page-nav-float button:disabled { opacity: .3; cursor: default; }
    .page-num-input { width: 32px; text-align: center; font-size: 12px; border: 0.5px solid var(--color-border-tertiary, var(--color-border)); border-radius: 4px; padding: 1px 2px; -moz-appearance: textfield; font-variant-numeric: tabular-nums; }
    .page-num-input::-webkit-inner-spin-button, .page-num-input::-webkit-outer-spin-button { -webkit-appearance: none; margin: 0; }
    .page-num-input:focus { border-color: var(--color-primary); outline: none; }

    /* ── ProjektitWindow ──────────────────────────────── */
    .mdi-projects-window { display: flex; flex-direction: column; height: 100%; overflow: hidden; }
    .mdi-projects-toolbar { display: flex; align-items: center; gap: 8px; padding: 6px 10px; border-bottom: 0.5px solid var(--color-border-tertiary, var(--color-border)); flex-shrink: 0; }
    .mdi-projects-excel-wrap { position: relative; margin-left: auto; flex-shrink: 0; }
    .mdi-projects-excel-kebab { min-width: 28px; padding-left: 8px; padding-right: 8px; font-size: 16px; line-height: 1; letter-spacing: -2px; }
    .mdi-projects-excel-backdrop { position: fixed; inset: 0; z-index: 1999; }
    .mdi-projects-excel-dropdown { position: absolute; right: 0; top: 100%; margin-top: 2px; min-width: 200px; z-index: 2000; background: var(--color-bg, #fff); border: 0.5px solid var(--color-border); border-radius: 8px; box-shadow: 0 8px 24px rgba(0,0,0,.12); padding: 4px 0; font-size: 11px; }
    .mdi-projects-excel-item { display: block; width: 100%; text-align: left; padding: 8px 12px; border: none; background: none; cursor: pointer; color: inherit; font: inherit; }
    .mdi-projects-excel-item:hover { background: var(--color-surface-hover, rgba(0,0,0,.04)); }
    .mdi-hidden-file-input { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0; opacity: 0; }
    .mdi-projects-table-wrap { flex: 1; overflow-y: auto; min-height: 0; }
    .mdi-projects-table { width: 100%; border-collapse: collapse; font-size: 12px; }
    .mdi-projects-table th { position: sticky; top: 0; background: var(--color-bg, #fff); border-bottom: 0.5px solid var(--color-border); padding: 6px 10px; text-align: left; font-weight: 500; font-size: 11px; color: var(--color-text-muted); cursor: pointer; user-select: none; white-space: nowrap; }
    .mdi-projects-table th:hover { background: var(--color-surface-hover, rgba(0,0,0,.03)); }
    .project-row { cursor: pointer; border-bottom: 0.5px solid var(--color-border-tertiary, var(--color-border)); }
    .project-row:hover { background: var(--color-surface-hover, rgba(0,0,0,.03)); }
    .mdi-projects-table td { padding: 6px 10px; font-size: 12px; }
    .project-name { font-weight: 500; }
    .status-badge { font-size: 10px; padding: 2px 6px; border-radius: 12px; }
    .status-badge.status-active { background: rgba(22,163,74,.1); color: #16a34a; }
    .status-badge.status-offer { background: rgba(245,158,11,.1); color: #d97706; }
    .status-badge.status-completed { background: var(--color-surface-hover, rgba(0,0,0,.04)); color: var(--color-text-muted); }
    .status-badge.status-archived { background: var(--color-surface-hover, rgba(0,0,0,.04)); color: var(--color-text-muted); }
    .mdi-projects-footer { display: flex; align-items: center; justify-content: space-between; padding: 4px 10px; border-top: 0.5px solid var(--color-border-tertiary, var(--color-border)); font-size: 11px; color: var(--color-text-muted); flex-shrink: 0; }
    .mdi-project-detail-nav { display: flex; align-items: center; gap: 10px; padding: 6px 10px; border-bottom: 0.5px solid var(--color-border-tertiary, var(--color-border)); flex-shrink: 0; }
    .mdi-back-btn { font-size: 12px; color: var(--color-primary); border: none; background: none; cursor: pointer; padding: 3px 6px; border-radius: 4px; }
    .mdi-back-btn:hover { background: var(--color-surface-hover, rgba(0,0,0,.04)); }

    /* Piirustusversiointi: historia + overlay-säädin */
    .version-history-dropdown {
        position: fixed;
        z-index: 10001;
        background: var(--color-background-primary, var(--color-bg, #fff));
        border: 0.5px solid var(--color-border-tertiary, var(--color-border));
        border-radius: var(--border-radius-lg, 12px);
        padding: 8px;
        min-width: 280px;
        max-height: min(420px, 70vh);
        overflow-y: auto;
        box-shadow: 0 4px 16px rgba(0,0,0,0.12);
    }
    .version-history-title {
        font-size: 11px;
        font-weight: 500;
        color: var(--color-text-secondary, var(--color-text-muted));
        text-transform: uppercase;
        letter-spacing: 0.5px;
        padding: 4px 8px 8px;
        border-bottom: 0.5px solid var(--color-border-tertiary, var(--color-border));
        margin-bottom: 4px;
    }
    .version-history-item {
        padding: 8px;
        border-radius: var(--border-radius-md, 8px);
        margin-bottom: 4px;
    }
    .version-history-item.latest {
        background: var(--color-background-info, rgba(59, 130, 246, 0.08));
    }
    .version-info {
        display: flex;
        align-items: center;
        gap: 8px;
        margin-bottom: 4px;
    }
    .version-num {
        font-weight: 600;
        font-size: 13px;
    }
    .version-badge {
        font-size: 10px;
        background: #0078d4;
        color: white;
        padding: 1px 6px;
        border-radius: 10px;
    }
    .version-date {
        font-size: 11px;
        color: var(--color-text-tertiary, var(--color-text-muted));
        margin-left: auto;
    }
    .version-comment {
        font-size: 11px;
        color: var(--color-text-secondary, var(--color-text-muted));
        margin-bottom: 4px;
        font-style: italic;
    }
    .version-actions {
        display: flex;
        flex-wrap: wrap;
        gap: 6px;
    }
    .version-actions button {
        font-size: 11px;
        padding: 2px 8px;
        border-radius: var(--border-radius-md, 6px);
        border: 0.5px solid var(--color-border-tertiary, var(--color-border));
        cursor: pointer;
        background: none;
    }
    .mdi-overlay-opacity {
        display: flex;
        align-items: center;
        gap: 4px;
        font-size: 10px;
        color: var(--color-text-muted);
    }
    .mdi-overlay-opacity input[type="range"] { width: 80px; }


    /* Kohdistuslistan hover-x */
    .mdi-cohdistus-remove { border:none;background:none;color:var(--color-text-muted);cursor:pointer;font-size:9px;padding:0 2px;opacity:0;flex-shrink:0;transition:opacity .1s; }
    .mdi-cohdistus-row:hover .mdi-cohdistus-remove { opacity:1; }
    .mdi-cohdistus-remove:hover { color:#ef4444; }

    /* Rakennusosan työkalu-nappi */
    .ro-measure-btn {
        display:inline-flex;align-items:center;justify-content:center;
        min-width:32px;min-height:28px;padding:2px 6px;
        border:1px solid var(--color-primary);border-radius:5px;
        background:color-mix(in srgb, var(--color-primary) 8%, transparent);
        cursor:pointer;color:var(--color-primary);
        transition:background .1s,border-color .1s;
    }
    .ro-measure-btn:hover {
        background:color-mix(in srgb, var(--color-primary) 18%, transparent);
    }
    .ro-measure-btn:active {
        background:color-mix(in srgb, var(--color-primary) 28%, transparent);
    }
    .ro-measure-btn--active {
        background:#f97316 !important;border-color:#f97316 !important;color:#fff !important;
    }
    .ro-measure-btn--active:hover {
        background:#ea580c !important;border-color:#ea580c !important;
    }
    /* Litteran edessä oleva mittausnappi — pienempi, lähempänä määrälaskenta-canvasia */
    .ro-measure-btn--lead {
        min-width:24px;min-height:22px;padding:1px 4px;
        border-radius:4px;flex-shrink:0;
    }

    /* Piirustusikkunan ikonipaneelin drag-visuaalit */
    .dshell-drag-ghost { opacity:0.4; }
    .dshell-drag-chosen { outline:2px solid var(--color-primary);outline-offset:-2px;border-radius:4px; }

    /* Alue-muoto-presetit: hover-tooltip ohjekuvalla — JS asettaa position:fixed
       jotta tooltip pakenee paneelin overflow-clipin (scroll). 0.7s viive. */
    .ml-shape-tooltip {
        visibility:hidden;
        opacity:0;
        position:fixed;
        z-index:10000;
        background:#fff;
        border:1px solid var(--color-border);
        border-radius:6px;
        box-shadow:0 6px 20px rgba(0,0,0,0.18);
        padding:8px;
        pointer-events:none;
        white-space:nowrap;
        transition:opacity 0.12s;
    }
    .ml-shape-tooltip--show { visibility:visible; opacity:1; }


/* Mittauksen asetukset: nimi-solu välähtää oranssina kun "Muokkaa nimeä" -toiminto laukaisee
   focus-tilan (ks. HaproDesktop.razor.cs OnEditMeasurementLabel). 3 pulssia 1.5s, sitten
   animaation jälkeen serveri-puoli tyhjentää MeasureSettingsFocusField:n joten luokka katoaa. */
@keyframes mdi-meas-name-flash {
    0%, 60%, 100% { outline:2px solid #f97316; outline-offset:2px; }
    20%, 80%      { outline:2px solid transparent; outline-offset:2px; }
    40%           { outline:2px solid #f97316; outline-offset:2px; }
}
.ml-meas-name-flash {
    animation: mdi-meas-name-flash 1.4s ease-in-out;
    animation-iteration-count: 1;
}

