    /* 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; }
    /* Bento-grid: 12 saraketta, perusyksikkö 40px korkea. Widget-koot ja sijainnit
       tallennetaan UserDashboardWidgetDto.PositionX/Y/Width/Height -kentissä (yksiköissä). */
    .mdi-dash-widget-grid {
        display: grid;
        grid-template-columns: repeat(12, 1fr);
        grid-auto-rows: 40px;
        gap: 8px;
    }
    /* Vahvempi raja moduuleille — käyttäjän pyyntö (selvempi). */
    .mdi-dash-widget {
        background: var(--color-surface, #fff);
        border: 1px solid var(--color-border);
        border-radius: 10px;
        padding: 12px 14px;
        min-height: 80px;
        box-shadow: 0 1px 3px rgba(0,0,0,0.04), 0 1px 2px rgba(0,0,0,0.02);
        transition: box-shadow 0.12s ease, transform 0.12s ease;
    }
    .mdi-dash-widget:hover {
        box-shadow: 0 4px 8px rgba(0,0,0,0.06), 0 2px 4px rgba(0,0,0,0.03);
    }
    /* Bento-widget: tarkka sijainti + koko style="grid-column:X/span W;grid-row:Y/span H" -inline.
       Näitä legacy-luokkia ei enää tarvita Bento-mallissa, säilytetty no-op:na backwards-compatible. */
    .mdi-dash-widget--small,
    .mdi-dash-widget--medium,
    .mdi-dash-widget--large { /* no-op — koko tulee inline-style:stä */ }
    .mdi-dash-widget--large .mdi-dash-w-body { max-height: none; }
    /* Widget itsellään overflow:hidden jotta sisältö ei valu yli (käytetään inline-styleissä koko). */
    .mdi-dash-widget { overflow: hidden; display: flex; flex-direction: column; }
    /* Toast-ilmoitus widget-paneelin yläosassa (esim. "ei tilaa" -varoitus) */
    .mdi-dash-toast {
        background: rgba(220, 38, 38, 0.1);
        color: var(--color-danger, #dc2626);
        border: 1px solid var(--color-danger, #dc2626);
        padding: 8px 12px;
        border-radius: 6px;
        font-size: 12px;
        margin-bottom: 12px;
        animation: mdi-dash-toast-in 0.2s ease-out;
    }
    @keyframes mdi-dash-toast-in {
        from { opacity: 0; transform: translateY(-8px); }
        to { opacity: 1; transform: translateY(0); }
    }

    /* Drag-and-drop drop-indikaattori: vahva sininen viiva (5px) jonka
       sumea hehku tekee selvemmäksi mihin pudotus tulee. */
    .mdi-dash-widget--drop-before {
        box-shadow: -5px 0 0 var(--color-primary, #2563eb), -7px 0 12px rgba(37,99,235,0.35);
    }
    .mdi-dash-widget--drop-after  {
        box-shadow:  5px 0 0 var(--color-primary, #2563eb),  7px 0 12px rgba(37,99,235,0.35);
    }
    .mdi-dash-widget--dragging {
        opacity: 0.3;
        transform: scale(0.97);
        outline: 2px dashed var(--color-primary, #2563eb);
        outline-offset: -2px;
    }
    .mdi-dash-widget--dragging * { pointer-events: none !important; }
    .mdi-dash-widget[draggable="true"] { cursor: grab; }
    .mdi-dash-widget[draggable="true"]:active { cursor: grabbing; }
    .mdi-dash-widget-grip {
        font-size: 14px; color: var(--color-text-muted); cursor: grab; user-select: none;
        padding-right: 4px;
    }
    .mdi-dash-widget-actions { display: inline-flex; gap: 2px; align-items: center; margin-left: auto; }
    .mdi-dash-size-btn {
        background: transparent;
        border: 1px solid var(--color-border);
        color: var(--color-text-muted);
        font-size: 9px; font-weight: 600;
        width: 20px; height: 20px;
        padding: 0;
        border-radius: 3px;
        cursor: pointer;
    }
    .mdi-dash-size-btn:hover { background: var(--color-bg); }
    .mdi-dash-size-btn.active {
        background: var(--color-primary, #2563eb); color: #fff; border-color: var(--color-primary, #2563eb);
    }
    .mdi-dash-widget-head { display: flex; align-items: center; gap: 6px; margin-bottom: 8px; padding-bottom: 6px; border-bottom: 1px solid var(--color-border-light, var(--color-border)); }
    .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);
        overflow-y: auto;
        flex: 1; min-height: 0;
    }
    /* Koko-presetin mukaisesti body:n max-height: säätää kuinka monta riviä mahtuu näkyviin
       ennen scroll-tarvetta. */
    .mdi-dash-widget--small  .mdi-dash-w-body { max-height: 140px; }
    .mdi-dash-widget--medium .mdi-dash-w-body { max-height: 280px; }
    .mdi-dash-widget--large  .mdi-dash-w-body { max-height: 600px; }
    .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); }

    /* User avatar — profiilikuva tai initiaalit värillisellä taustalla. */
    .user-avatar {
        display: inline-flex; align-items: center; justify-content: center;
        border-radius: 50%; overflow: hidden;
        color: #fff; font-weight: 600;
        flex-shrink: 0;
        line-height: 1;
    }
    .user-avatar img { width: 100%; height: 100%; object-fit: cover; }
    .user-avatar-initials { display: inline-block; }

    /* Aikajanan vasemman palstan HTML-sarakkeet (entinen SVG-versio jätetty käyttämättä). */
    .gantt-left {
        height: 100%;
        background: #fafafa;
        border-right: 1px solid var(--color-border);
        overflow: hidden;
        display: flex;
        flex-direction: column;
        position: relative;
    }
    .gantt-left-header {
        display: flex;
        align-items: center;
        background: #f1f5f9;
        border-bottom: 1px solid var(--color-border);
        flex-shrink: 0;
        position: relative;
        /* Käyttäjäpalaute 2026-05-19: rivit (transform-translateY) näkyivät
           otsikon LÄPI kun käyttäjä skrollasi alaspäin. z-index nostaa otsikon
           rows-elementin päälle, opaakki tausta peittää alla olevan sisällön. */
        z-index: 2;
    }
    .gantt-col-header {
        font-size: 10px;
        font-weight: 600;
        color: var(--color-text-muted);
        padding: 0 8px;
        flex-shrink: 0;
        border-right: 1px solid var(--color-border-light, var(--color-border));
        height: 100%;
        display: flex; align-items: center;
        position: relative;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
        min-width: 0;
    }
    /* Sarakeleveyden raahaus-kahva oikeassa reunassa */
    .gantt-col-resize {
        position: absolute;
        top: 0; right: -3px;
        width: 6px; height: 100%;
        cursor: col-resize;
        background: transparent;
        z-index: 5;
    }
    .gantt-col-resize:hover { background: rgba(59,130,246,0.3); }
    .gantt-col-resize:active { background: rgba(59,130,246,0.5); }
    .gantt-col-picker-btn {
        flex-shrink: 0;
        width: 28px; height: 100%;
        background: transparent;
        border: none;
        border-right: 1px solid var(--color-border-light, var(--color-border));
        cursor: pointer;
        font-size: 12px;
        padding: 0;
        color: var(--color-text-muted);
    }
    .gantt-col-picker-btn:hover { background: var(--color-bg); color: var(--color-primary); }
    .gantt-col-picker-backdrop {
        position: fixed;
        inset: 0;
        z-index: 99;
    }
    .gantt-col-picker {
        position: absolute;
        top: 30px; left: 4px;
        background: var(--color-surface);
        border: 1px solid var(--color-border);
        border-radius: 6px;
        box-shadow: 0 4px 12px rgba(0,0,0,0.12);
        padding: 6px;
        z-index: 100;
        min-width: 160px;
    }
    .gantt-col-picker-h {
        font-size: 10px;
        font-weight: 600;
        color: var(--color-text-muted);
        padding: 2px 4px 6px;
        border-bottom: 1px solid var(--color-border-light);
    }
    .gantt-col-picker-item {
        display: flex; align-items: center; gap: 6px;
        padding: 4px;
        font-size: 12px;
        cursor: pointer;
        border-radius: 4px;
    }
    .gantt-col-picker-item:hover { background: var(--color-bg); }
    .gantt-left-rows {
        flex: 1; overflow: hidden;
        box-sizing: border-box;
    }
    /* Sisempi wrapper jolle JS asettaa transform:translateY synkkasi varten.
       Blazor ei koskaan kirjoita tämän style-attribuuttia → transform säilyy
       renderien yli (toisin kuin .gantt-left-rows jolla on dynaaminen inline-style). */
    .gantt-left-rows-vscroll {
        will-change: transform;
        /* Vaakaviivat tausta-imageena — kulkee transform:n mukana joten rivien
           alareunat pysyvät kohdistuksessa viivoihin myös scroll-tilassa. */
        background-image: linear-gradient(to bottom, transparent 27px, var(--color-border-light, #f1f5f9) 27px, var(--color-border-light, #f1f5f9) 28px);
        background-size: 100% 28px;
        background-repeat: repeat-y;
    }
    .gantt-row {
        display: flex;
        align-items: center;
        border-bottom: 0.5px solid #e2e8f0;
        cursor: pointer;
        transition: background 0.1s ease;
    }
    .gantt-row:hover { background: #f1f5f9; }
    .gantt-row-selected { background: #dbeafe; }
    .gantt-row-selected:hover { background: #c7e0fc; }
    .gantt-cell {
        flex-shrink: 0;
        padding: 0 8px;
        font-size: 11px;
        border-right: 1px solid #f1f5f9;
        height: 100%;
        display: flex; align-items: center;
        overflow: hidden;
    }
    .gantt-cell-name {
        font-weight: 500;
        white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
        cursor: text;
        padding: 1px 3px;
        border-radius: 3px;
    }
    .gantt-cell-name:hover { background: rgba(37, 99, 235, 0.06); }
    /* Inline-edit input (käyttäjäpalaute 2026-05-15) — matches span:n tyyliä jotta layout ei hypää */
    .gantt-cell-name-input {
        flex: 1; min-width: 0;
        font-size: 11px; font-family: inherit; font-weight: 500;
        padding: 1px 4px;
        border: 1px solid var(--color-primary, #2563eb);
        border-radius: 3px;
        outline: none;
        background: var(--color-surface);
        color: var(--color-text);
    }
    .gantt-cell-name-input.is-parent { font-weight: 600; }
    .gantt-cell-date {
        width: 100%;
        background: transparent;
        border: 1px solid transparent;
        border-radius: 3px;
        padding: 2px 4px;
        font-size: 11px;
        font-family: inherit;
        outline: none;
    }
    .gantt-cell-date:hover { border-color: var(--color-border); background: var(--color-surface); }
    .gantt-cell-date:focus { border-color: var(--color-primary); background: var(--color-surface); }
    .gantt-cell-muted { color: var(--color-text-muted); font-size: 11px; }
    .gantt-cell-assignees { display: flex; align-items: center; gap: 2px; }
    .gantt-cell-assignees .user-avatar { margin-right: -4px; border: 1.5px solid var(--color-surface); }
    .gantt-cell-status, .gantt-cell-priority {
        font-size: 10px; padding: 1px 6px; border-radius: 10px;
    }
    .gantt-cell-priority { background: var(--color-border-light); color: var(--color-text); }

    /* Aikataulun alapaneeli: korkeus rajoitettu max 320px, scrollaa sisäisesti.
       Sisältö rajoitettu keskelle (max-width 720px) jotta laatikot eivät venty
       koko ikkunan leveyteen. */
    .aika-bottom-panel {
        flex-shrink: 0;
        height: 320px;
        max-height: 50vh;
        border-top: 1px solid var(--color-border);
        background: var(--color-surface);
        overflow: hidden;
    }
    .aika-bottom-panel .task-inline-panel {
        border-left: none;
        border-top: none;
        max-width: 720px;
        margin: 0 auto;
        width: 100%;
    }

    /* Tehtävän inline-muokkauspaneeli (To Do -tyylinen). Käytössä TehtavatWindow:n side-panel ja
       AikatauluWindow:n bottom-panel. Auto-tallennus onBlur:lla. */
    .task-inline-panel {
        display: flex; flex-direction: column;
        background: var(--color-surface, #fff);
        border-left: 1px solid var(--color-border);
        height: 100%; min-height: 0;
        overflow: hidden;
    }
    .task-inline-loading {
        padding: 24px; text-align: center; color: var(--color-text-muted); font-size: 12px;
    }
    .task-inline-head {
        display: flex; align-items: center; gap: 8px;
        padding: 10px 12px; border-bottom: 1px solid var(--color-border);
        flex-shrink: 0;
    }
    .task-inline-check {
        flex-shrink: 0; width: 22px; height: 22px;
        border: 1.8px solid var(--color-border, #d1d5db); border-radius: 50%;
        background: transparent; cursor: pointer; padding: 0;
        display: inline-flex; align-items: center; justify-content: center;
        color: transparent; transition: all 0.12s ease;
    }
    .task-inline-check:hover { border-color: var(--color-primary, #2563eb); }
    .task-inline-check.done {
        background: var(--color-primary, #2563eb);
        border-color: var(--color-primary, #2563eb);
        color: #fff;
    }
    .task-inline-title {
        flex: 1; min-width: 0;
        background: transparent; border: 1px solid transparent; outline: none;
        font-size: 15px; font-weight: 600; color: var(--color-text);
        padding: 4px 8px; border-radius: 4px;
        transition: all 0.12s ease;
    }
    .task-inline-title:hover { background: var(--color-background-secondary, rgba(0,0,0,0.03)); }
    .task-inline-title:focus { background: var(--color-background-secondary, rgba(0,0,0,0.03)); border-color: var(--color-primary); }
    .task-inline-title--done { text-decoration: line-through; color: var(--color-text-muted); }
    .task-inline-close {
        flex-shrink: 0;
        background: transparent; border: none; cursor: pointer;
        font-size: 20px; line-height: 1; color: var(--color-text-muted);
        padding: 4px 8px; border-radius: 4px;
    }
    .task-inline-close:hover { background: var(--color-background-secondary, rgba(0,0,0,0.05)); color: var(--color-text); }
    .task-inline-back {
        flex-shrink: 0;
        background: transparent; border: none; cursor: pointer;
        color: var(--color-text-muted);
        padding: 4px 6px; border-radius: 4px;
        display: inline-flex; align-items: center;
    }
    .task-inline-back:hover { background: var(--color-background-secondary, rgba(0,0,0,0.05)); color: var(--color-primary); }

    .task-inline-body {
        flex: 1; min-height: 0; overflow-y: auto;
        padding: 8px 12px;
        display: flex; flex-direction: column; gap: 8px;
        font-size: 12px;
    }
    /* Tiivis 2-saraketta-grid kentille jotta useampi vaihtoehto mahtuu samalle riville. */
    .task-inline-grid {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 6px 10px;
    }
    .task-inline-cell {
        display: flex; flex-direction: column; gap: 2px; min-width: 0;
    }
    .task-inline-cell--full { grid-column: 1 / -1; }
    .task-inline-row {
        display: flex; align-items: center; gap: 8px;
    }
    .task-inline-row--col {
        flex-direction: column; align-items: stretch;
    }
    .task-inline-label {
        font-size: 10px; color: var(--color-text-muted); font-weight: 500;
        text-transform: uppercase; letter-spacing: 0.3px;
    }
    .task-inline-row .task-inline-label { flex: 0 0 80px; }
    .task-inline-row--col .task-inline-label { flex: none; margin-bottom: 4px; }
    .task-inline-input {
        width: 100%; min-width: 0;
        padding: 4px 8px; font-size: 12px;
        border: 1px solid var(--color-border); border-radius: 4px;
        background: var(--color-surface);
        outline: none;
        box-sizing: border-box;
    }
    .task-inline-input:focus { border-color: var(--color-primary); }
    .task-inline-input--inline { flex: 1; }
    .task-inline-textarea { resize: vertical; min-height: 60px; font-family: inherit; }
    /* Pikavalintapainikkeet päivämääräkentän alle (Tänään / Huomenna / Ensi ma / Ensi pe) */
    .task-inline-date-quick {
        display: flex; flex-wrap: wrap; gap: 3px;
        margin-top: 4px;
    }
    .task-inline-date-pill {
        background: var(--color-background-secondary, rgba(0,0,0,0.04));
        border: 1px solid var(--color-border-tertiary, var(--color-border));
        color: var(--color-text-muted);
        padding: 2px 8px; font-size: 10px;
        border-radius: 10px;
        cursor: pointer;
    }
    .task-inline-date-pill:hover {
        background: var(--color-primary, #2563eb); color: #fff;
        border-color: var(--color-primary, #2563eb);
    }
    .task-inline-date-pill--clear {
        margin-left: auto;
        color: var(--color-danger, #dc2626);
        border-color: transparent;
    }
    .task-inline-date-pill--clear:hover {
        background: var(--color-danger, #dc2626);
        color: #fff;
        border-color: var(--color-danger, #dc2626);
    }
    .task-inline-checkbox { display: inline-flex; align-items: center; gap: 6px; cursor: pointer; font-size: 11px; }
    .task-inline-section { padding-top: 4px; }
    .task-inline-section-title { font-size: 11px; color: var(--color-text-muted); font-weight: 600; margin-bottom: 4px; }
    .task-inline-muted { font-size: 11px; color: var(--color-text-muted); font-style: italic; padding: 4px 0; }
    .task-inline-assignee {
        display: flex; align-items: center; gap: 6px; padding: 4px 0;
    }
    .task-inline-remove {
        background: transparent; border: none; color: var(--color-text-muted); cursor: pointer;
        padding: 2px 6px; border-radius: 4px; line-height: 1; font-size: 16px;
    }
    .task-inline-remove:hover { background: var(--color-background-secondary, rgba(0,0,0,0.05)); color: var(--color-danger, #dc2626); }
    .task-inline-add-assignee { display: flex; gap: 4px; padding-top: 4px; }
    .task-inline-add-btn {
        font-size: 11px; padding: 3px 8px;
        background: var(--color-background-secondary, rgba(0,0,0,0.04)); color: var(--color-text);
        border: 1px solid var(--color-border); border-radius: 4px; cursor: pointer;
    }
    .task-inline-add-btn:hover { background: var(--color-background-tertiary, rgba(0,0,0,0.08)); }
    .task-inline-actions {
        padding-top: 8px;
        border-top: 1px solid var(--color-border-tertiary, var(--color-border-light));
        margin-top: 4px;
        display: flex; gap: 6px; flex-wrap: wrap;
    }
    .task-inline-achieve {
        background: #16a34a; color: #fff; border: none;
        padding: 4px 10px; font-size: 11px; border-radius: 4px; cursor: pointer;
    }
    .task-inline-achieve:hover { background: #15803d; }
    .task-inline-reopen {
        background: transparent; color: var(--color-text); border: 1px solid var(--color-border);
        padding: 4px 10px; font-size: 11px; border-radius: 4px; cursor: pointer;
    }
    .task-inline-reopen:hover { background: var(--color-bg); }
    .task-inline-status-tag {
        display: inline-block; padding: 4px 8px; font-size: 11px;
        border-radius: 4px; color: #fff; font-weight: 500;
    }
    .ms-marker-dot {
        width: 14px; height: 14px; border-radius: 50%; flex-shrink: 0;
    }
    .task-inline-delete {
        background: transparent; color: var(--color-danger, #dc2626);
        border: 1px solid var(--color-danger, #dc2626);
        padding: 4px 10px; font-size: 11px; border-radius: 4px; cursor: pointer;
    }
    .task-inline-delete:hover { background: var(--color-danger, #dc2626); color: #fff; }
    .task-inline-error {
        padding: 6px 8px; font-size: 11px;
        background: color-mix(in srgb, var(--color-danger, #dc2626) 12%, transparent);
        color: var(--color-danger, #dc2626); border-radius: 4px;
    }

    /* Tämän päivän kalenteri (Outlook) -widget */
    /* .today-cal-widget pää-määrittely on .today-cal-grid-multi -lohkon jälkeen
       (käyttäjäpalaute 2026-05-15: lisätty height:100%+min-height:0 ettei tule
       kaksinkertaisia pystypalkkeja). Tämä deklaraatio on ylikirjoitettu siellä. */
    .today-cal-empty {
        text-align: center; padding: 12px 4px;
        font-size: 11px; color: var(--color-text-muted);
    }
    .today-cal-connect-btn {
        margin-top: 6px;
        background: transparent;
        border: 1px solid var(--color-border);
        color: var(--color-primary);
        padding: 4px 10px;
        font-size: 11px;
        border-radius: 4px;
        cursor: pointer;
    }
    .today-cal-connect-btn:hover { background: var(--color-bg); border-color: var(--color-primary); }
    /* Päivänavigaatio + Uusi merkintä -nappi */
    .today-cal-daynav { display: flex; gap: 4px; align-items: center; padding: 0 0 6px 0; flex-wrap: wrap; }
    .today-cal-range-sel { font-size: 10px; padding: 2px 4px; border: 1px solid var(--color-border); border-radius: 4px; background: var(--color-surface); color: var(--color-text-muted); cursor: pointer; }
    .today-cal-day-header { font-size: 11px; font-weight: 600; color: var(--color-text); text-transform: capitalize; padding: 8px 4px 4px; border-bottom: 1px solid var(--color-border-light, #f1f5f9); margin-top: 4px; }
    .today-cal-day-header:first-child { margin-top: 0; padding-top: 2px; }
    .today-cal-day-btn { background: transparent; border: 1px solid var(--color-border); padding: 3px 8px; border-radius: 4px; cursor: pointer; font-size: 11px; color: var(--color-text-muted); }
    .today-cal-day-btn:hover { background: var(--color-bg); color: var(--color-primary); border-color: var(--color-primary); }
    .today-cal-day-today { font-weight: 600; min-width: 80px; text-align: center; }
    .today-cal-day-today.active { background: var(--color-primary-light); color: var(--color-primary); border-color: var(--color-primary); }
    .today-cal-add-btn { margin-left: auto; background: var(--color-primary, #2563eb); color: #fff; border: none; padding: 3px 10px; border-radius: 4px; cursor: pointer; font-size: 11px; font-weight: 500; }
    .today-cal-add-btn:hover { background: var(--color-primary-hover, #1d4ed8); }
    /* Outlook-tyylinen väritys: minä järjestäjänä = sininen, kutsuttuna = vihreä.
       Käyttäjäpalaute 2026-05-14. Tekstit tummiksi jotta näkyvät vaaleassa bg:ssä. */
    .today-cal-grid-event.today-cal-grid-event--organizer {
        background: rgba(37, 99, 235, 0.14);
        border-left: 3px solid #2563eb;
        color: #1e3a8a;
    }
    .today-cal-grid-event.today-cal-grid-event--invited {
        background: rgba(22, 163, 74, 0.14);
        border-left: 3px solid #16a34a;
        color: #14532d;
    }
    .today-cal-grid-event--organizer .today-cal-grid-event-time,
    .today-cal-grid-event--organizer .today-cal-grid-event-loc,
    .today-cal-grid-event--invited .today-cal-grid-event-time,
    .today-cal-grid-event--invited .today-cal-grid-event-loc { opacity: 0.85; }
    .today-cal-item.today-cal-item--organizer { border-left: 3px solid #2563eb; padding-left: 6px; }
    .today-cal-item.today-cal-item--invited { border-left: 3px solid #16a34a; padding-left: 6px; }
    /* Multi-day tuntinäkymä (3 pv / työviikko jne.) — sarakkeet vierekkäin.
       Käyttäjäpalaute 2026-05-14. */
    .today-cal-grid-multi {
        position: relative;
        border: 1px solid var(--color-border);
        border-radius: 6px;
        background: var(--color-surface);
        /* Käyttäjäpalaute 2026-05-14: 24 h näkyvissä mut sisäinen scroll → lähtö klo 6:sta.
           Käyttäjäpalaute 2026-05-15: poistettu max-height + parent-scroll lukittu jotta
           vain YKSI pystypalkki näkyy (oli kaksi päällekäistä). */
        overflow-y: auto;
        flex: 1;
        min-height: 0;
    }
    /* Widget itse on flex-column joka täyttää parent:n korkeuden */
    .today-cal-widget { display: flex; flex-direction: column; gap: 4px; height: 100%; min-height: 0; }
    .today-cal-daynav { flex-shrink: 0; }
    /* Kalenteri-kortin body ei scrolla — widget täyttää sen ja vain sisäinen grid scrollaa */
    .quick-side-card-cal .quick-side-card-body { overflow: hidden; padding: 6px; min-height: 0; }
    .today-cal-grid-multi-header {
        display: flex;
        border-bottom: 1px solid var(--color-border);
        background: var(--color-bg);
    }
    .today-cal-grid-day-header {
        flex: 1;
        text-align: center;
        padding: 6px 4px;
        border-left: 1px solid var(--color-border-light, var(--color-border));
    }
    .today-cal-grid-day-header.today {
        background: color-mix(in srgb, var(--color-primary, #2563eb) 8%, transparent);
        color: var(--color-primary, #2563eb);
    }
    .today-cal-grid-multi-body {
        display: flex;
        position: relative;
    }
    .today-cal-grid-hours {
        flex: 0 0 44px;
        display: flex;
        flex-direction: column;
        border-right: 1px solid var(--color-border);
    }
    .today-cal-grid-hour-cell {
        height: 36px;
        padding: 2px 6px;
        font-size: 10px;
        color: var(--color-text-muted);
        border-bottom: 1px solid var(--color-border-light, #f1f5f9);
        box-sizing: border-box;
    }
    .today-cal-grid-day-col {
        flex: 1;
        position: relative;
        border-left: 1px solid var(--color-border-light, var(--color-border));
        min-width: 0;
    }
    .today-cal-grid-hour-slot {
        height: 36px;
        border-bottom: 1px solid var(--color-border-light, #f1f5f9);
        cursor: pointer;
        position: relative;
    }
    .today-cal-grid-hour-slot:hover { background: rgba(59,130,246,0.04); }
    .today-cal-grid-hour-slot .today-cal-grid-half {
        position: absolute; left: 0; right: 0; top: 50%;
        border-top: 1px dashed var(--color-border-light, #f1f5f9);
    }
    /* Outlook-tyyliset kentät: ikoni + täysleveä input + jakajat.
       Käyttäjäpalaute 2026-05-14. */
    .ne-row {
        position: relative;
        display: flex;
        align-items: center;
        gap: 10px;
        padding: 8px 4px;
        border-bottom: 1px solid var(--color-border-light, var(--color-border));
    }
    .ne-row:last-child { border-bottom: none; }
    .ne-row-icon {
        width: 22px; flex-shrink: 0;
        text-align: center;
        font-size: 14px; color: var(--color-text-muted);
        line-height: 1;
    }
    .ne-row-input {
        flex: 1; min-width: 0;
        border: none; outline: none;
        background: transparent;
        font: inherit; font-size: 13px;
        padding: 6px 4px;
        color: var(--color-text);
    }
    .ne-row-input:focus { background: rgba(37,99,235,0.04); border-radius: 4px; }
    .ne-row-input:disabled { color: var(--color-text-muted); cursor: not-allowed; background: transparent; }
    .ne-row-menu-btn {
        flex-shrink: 0;
        background: transparent; border: 1px solid transparent;
        cursor: pointer; padding: 4px 6px; border-radius: 4px;
        color: var(--color-text-muted);
        font-size: 13px;
    }
    .ne-row-menu-btn:hover { background: var(--color-bg); border-color: var(--color-border); color: var(--color-text); }
    .ne-row-popover {
        position: absolute; top: 100%; right: 0; z-index: 50;
        background: #fff;
        border: 1px solid var(--color-border);
        border-radius: 6px;
        box-shadow: 0 4px 12px rgba(0,0,0,0.12);
        padding: 8px 10px;
        min-width: 260px;
        display: flex; flex-direction: column; gap: 6px;
        font-size: 12px;
    }
    .ne-row-popover-row {
        display: flex; align-items: center; justify-content: space-between;
        cursor: pointer;
        padding: 4px 2px;
    }
    .ne-row-popover-row:hover { background: var(--color-bg); border-radius: 4px; }
    .ne-row-popover-divider { height: 1px; background: var(--color-border); margin: 4px 0; }
    .ne-row-popover-label { font-size: 10px; color: var(--color-text-muted); text-transform: uppercase; padding: 2px 2px 0; }
    .ne-row-pill {
        flex-shrink: 0;
        font-size: 10px; padding: 3px 7px;
        background: color-mix(in srgb, var(--color-primary) 12%, transparent);
        color: var(--color-primary);
        border-radius: 12px;
        white-space: nowrap;
    }
    .new-event-dialog { max-width: 480px; }
    /* Leveämpi 2-sarake-modaali isolla viewportilla. Vasen = lomake, oikea = seuranta + matka + kartta.
       Käyttäjäpalaute 2026-05-14 (Outlook-tyyli). 2026-05-14 leveys 1180 → 1320. */
    @media (min-width: 1024px) {
        .new-event-dialog { max-width: 1320px; }
        .new-event-dialog .modal-body.modal-body--split {
            display: grid;
            grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
            gap: 14px 28px;
            align-items: start;
        }
    }
    /* Modaalin headerin 2-rivinen ulkoasu: ylhäällä toimintonapit, alla otsikko + badge. */
    .new-event-dialog .modal-header {
        flex-direction: column;
        align-items: stretch;
        gap: 8px;
    }
    .new-event-dialog .modal-header-actions {
        display: flex;
        gap: 6px;
        align-items: center;
        flex-wrap: wrap;
        order: -1;
    }
    .new-event-dialog .modal-title { font-size: 16px; font-weight: 600; }
    .new-event-dialog .ne-col {
        display: flex;
        flex-direction: column;
        gap: 10px;
        min-width: 0;
    }
    /* Seuranta-paneeli (oikea sarake, kun muokataan olemassa olevaa kutsua) */
    .ne-tracking {
        background: var(--color-surface);
        border: 1px solid var(--color-border);
        border-radius: 6px;
        padding: 10px 12px;
    }
    .ne-tracking-title { font-size: 11px; font-weight: 700; color: var(--color-text-muted); text-transform: uppercase; margin-bottom: 6px; }
    .ne-tracking-organizer { font-size: 12px; margin-bottom: 8px; padding-bottom: 8px; border-bottom: 1px solid var(--color-border); }
    .ne-tracking-attendee { display: flex; align-items: center; gap: 8px; font-size: 11px; padding: 3px 0; }
    .ne-tracking-status { margin-left: auto; font-weight: 500; }
    /* Hyväksy / Hylkää / Alustava -napit modaalin yläpalkissa */
    .ne-invite-btn { padding: 4px 10px; border: 1px solid var(--color-border); border-radius: 4px; font-size: 11px; cursor: pointer; background: var(--color-surface); color: var(--color-text); display: inline-flex; align-items: center; gap: 4px; }
    .ne-invite-btn:hover { background: var(--color-bg); }
    .ne-invite-btn--accept { background: #dcfce7; border-color: #16a34a; color: #166534; }
    .ne-invite-btn--accept:hover { background: #bbf7d0; }
    .ne-invite-btn--decline { background: #fee2e2; border-color: #dc2626; color: #991b1b; }
    .ne-invite-btn--decline:hover { background: #fecaca; }
    .ne-invite-btn--tentative { background: #fef3c7; border-color: #d97706; color: #92400e; }
    .ne-invite-btn--tentative:hover { background: #fde68a; }

    .today-cal-list { display: flex; flex-direction: column; gap: 3px; }

    /* Tunti-grid (Outlook-tyyli) */
    .today-cal-grid { position: relative; border: 1px solid var(--color-border); border-radius: 6px; background: var(--color-surface); }
    .today-cal-grid-row { display: flex; height: 36px; border-bottom: 1px solid var(--color-border-light, #f1f5f9); cursor: pointer; }
    .today-cal-grid-row:hover { background: rgba(59,130,246,0.04); }
    .today-cal-grid-row:last-child { border-bottom: none; }
    .today-cal-grid-hour { flex: 0 0 44px; padding: 2px 6px; font-size: 10px; color: var(--color-text-muted); border-right: 1px solid var(--color-border-light, #f1f5f9); }
    .today-cal-grid-content { flex: 1; position: relative; }
    .today-cal-grid-half { position: absolute; top: 50%; left: 0; right: 0; border-top: 1px dashed rgba(0,0,0,0.06); }
    /* Yksipäivä-fallback (vanha today-cal-grid joka asetti left:48px tunti-labels:n takia).
       Multi-day-grid:ssä events ovat day-col:n sisällä, joten .today-cal-grid-day-col override
       palauttaa left:2px. */
    .today-cal-grid-event { position: absolute; left: 48px; right: 4px; background: var(--color-primary, #2563eb); color: #fff; border-radius: 4px; padding: 3px 6px; font-size: 10px; cursor: grab; overflow: hidden; box-shadow: 0 1px 2px rgba(0,0,0,0.15); z-index: 2; margin-top: 1px; margin-bottom: 1px; border: 1px solid var(--color-bg, #fff); user-select: none; }
    /* Multi-day grid: event-elementit ovat day-col:n sisällä → ei tunti-label-offsetia. */
    .today-cal-grid-day-col .today-cal-grid-event { left: 2px; right: 2px; }
    .today-cal-grid-event:hover { filter: brightness(1.1); }
    .today-cal-grid-event.dragging { cursor: grabbing; opacity: 0.75; box-shadow: 0 4px 12px rgba(0,0,0,0.35); z-index: 10; transition: none; }

    /* Nyky-aika-viiva (Outlook-tyyli): punainen vaakaviiva päivän sarakkeen läpi.
       Käyttäjäpalaute 2026-05-19. */
    .today-cal-now-line {
        position: absolute; left: 0; right: 0; height: 0;
        border-top: 2px solid #dc2626;
        z-index: 3;
        pointer-events: none;
    }
    .today-cal-now-line .today-cal-now-dot {
        position: absolute; left: -4px; top: -5px;
        width: 8px; height: 8px;
        border-radius: 50%;
        background: #dc2626;
        box-shadow: 0 0 0 2px rgba(255,255,255,0.9);
    }
    .today-cal-grid-event.current { background: #16a34a; }
    .today-cal-grid-event-time { font-size: 9px; opacity: 0.9; }
    .today-cal-grid-event-subject { font-size: 11px; font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    .today-cal-grid-event-loc { font-size: 9px; opacity: 0.8; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    /* Teams-liity-nappi tuntinäkymässä — käyttäjäpalaute 2026-05-11 */
    .today-cal-grid-teams-btn {
        display: inline-flex; align-items: center; gap: 3px;
        margin-top: 2px;
        font-size: 9px; font-weight: 600;
        background: rgba(255,255,255,0.96); color: #5b5fc7;
        border: 1px solid rgba(255,255,255,0.7);
        border-radius: 3px; padding: 1px 6px;
        cursor: pointer; white-space: nowrap;
        max-width: calc(100% - 4px); overflow: hidden; text-overflow: ellipsis;
    }
    .today-cal-grid-teams-btn:hover { background: #5b5fc7; color: #fff; border-color: #5b5fc7; }
    .today-cal-grid-allday { padding: 4px 6px; background: var(--color-bg); border-bottom: 1px solid var(--color-border-light); display: flex; flex-direction: column; gap: 3px; }
    .today-cal-allday-pill { padding: 3px 6px; background: #6264a7; color: #fff; border-radius: 3px; font-size: 10px; cursor: pointer; }
    .today-cal-allday-pill:hover { filter: brightness(1.1); }
    .today-cal-item {
        background: var(--color-bg, rgba(0,0,0,0.03));
        border-left: 3px solid var(--color-primary, #2563eb);
        border-radius: 4px;
        transition: background 0.1s ease;
    }
    .today-cal-item-head {
        display: flex; gap: 8px;
        padding: 6px 8px;
        cursor: pointer;
    }
    .today-cal-item-head:hover { background: var(--color-background-secondary, rgba(0,0,0,0.05)); }
    /* Hover-ikonit kortin oikeassa reunassa: piilossa kunnes hover */
    .today-cal-hover-actions { display: flex; gap: 4px; align-items: flex-start; opacity: 0; transition: opacity 0.12s ease; flex-shrink: 0; }
    .today-cal-item:hover .today-cal-hover-actions { opacity: 1; }
    .today-cal-iconbtn {
        background: var(--color-surface, #fff); border: 1px solid var(--color-border, #e2e8f0);
        width: 24px; height: 24px; display: inline-flex; align-items: center; justify-content: center;
        font-size: 12px; line-height: 1; cursor: pointer; border-radius: 4px;
        text-decoration: none; color: var(--color-text);
    }
    .today-cal-iconbtn:hover { border-color: var(--color-primary); color: var(--color-primary); }
    .today-cal-iconbtn-danger:hover { border-color: #dc2626; color: #dc2626; background: #fee2e2; }
    .today-cal-detail { padding: 4px 10px 8px 80px; border-top: 1px dashed var(--color-border-light, var(--color-border)); }
    .today-cal-actions { display: flex; gap: 6px; padding: 6px 0; flex-wrap: wrap; }
    .today-cal-teams-btn { background: #6264a7; color: #fff; padding: 4px 10px; border-radius: 4px; text-decoration: none; font-size: 10px; font-weight: 600; }
    .today-cal-teams-btn:hover { background: #4f5198; }
    .today-cal-link-btn { background: var(--color-surface); border: 1px solid var(--color-border); padding: 3px 10px; border-radius: 4px; text-decoration: none; font-size: 10px; color: var(--color-text); cursor: pointer; }
    .today-cal-link-btn:hover { border-color: var(--color-primary); color: var(--color-primary); }
    .today-cal-link-btn-danger:hover { border-color: var(--color-danger, #dc2626); color: var(--color-danger, #dc2626); }
    .today-cal-meta { font-size: 10px; color: var(--color-text-muted); padding: 3px 0; word-break: break-word; }
    .today-cal-meta strong { color: var(--color-text); }
    .today-cal-body { font-size: 10.5px; color: var(--color-text); padding: 4px 0; max-height: 200px; overflow-y: auto; }
    .today-cal-body img { max-width: 100%; height: auto; }
    .today-cal-body a { color: var(--color-primary); }
    .today-cal-teams-pill { font-size: 10px; margin-left: 4px; opacity: 0.8; }
    .today-cal-item.current {
        border-left-color: #16a34a;
        background: rgba(22, 163, 74, 0.08);
        font-weight: 500;
    }
    .today-cal-time {
        flex: 0 0 70px;
        font-size: 10px;
        color: var(--color-text-muted);
        display: flex; flex-direction: column; line-height: 1.2;
        font-variant-numeric: tabular-nums;
    }
    .today-cal-time-sep { font-size: 9px; opacity: 0.6; }
    .today-cal-main { flex: 1; min-width: 0; }
    .today-cal-subject {
        font-size: 12px;
        white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    }
    .today-cal-location {
        font-size: 10px; color: var(--color-text-muted);
        white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
        margin-top: 1px;
    }

    /* Tämä viikko -widget */
    .weekcal-widget { display: flex; flex-direction: column; gap: 6px; height: 100%; }
    .weekcal-head { display: flex; align-items: center; gap: 4px; }
    .weekcal-nav {
        background: transparent; border: 1px solid var(--color-border);
        border-radius: 4px; cursor: pointer;
        width: 22px; height: 22px; padding: 0;
        font-size: 14px; line-height: 1; color: var(--color-text-muted);
    }
    .weekcal-nav:hover { background: var(--color-bg); }
    .weekcal-range { flex: 1; text-align: center; font-size: 11px; font-weight: 600; }
    .weekcal-today-btn {
        background: transparent; border: 1px solid var(--color-border);
        border-radius: 4px; cursor: pointer;
        padding: 2px 8px; font-size: 10px; color: var(--color-text-muted);
    }
    .weekcal-today-btn:hover { background: var(--color-bg); }
    .weekcal-grid {
        display: grid; grid-template-columns: repeat(7, 1fr);
        gap: 2px;
        flex: 1; min-height: 0;
    }
    .weekcal-day {
        background: var(--color-bg, rgba(0,0,0,0.02));
        border: 1px solid transparent;
        border-radius: 4px;
        padding: 2px;
        display: flex; flex-direction: column; gap: 1px;
        min-width: 0;
        overflow: hidden;
    }
    .weekcal-day.today {
        background: rgba(37, 99, 235, 0.06);
        border-color: rgba(37, 99, 235, 0.3);
    }
    .weekcal-day.weekend { opacity: 0.85; }
    .weekcal-day-head { display: flex; flex-direction: column; align-items: center; gap: 0; line-height: 1.1; }
    .weekcal-dow { font-size: 8px; color: var(--color-text-muted); text-transform: uppercase; font-weight: 600; }
    .weekcal-num { font-size: 12px; font-weight: 600; color: var(--color-text); }
    .weekcal-day.today .weekcal-num { color: var(--color-primary); }
    .weekcal-events { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
    .weekcal-event {
        background: var(--color-primary);
        color: #fff; border: none; cursor: pointer;
        padding: 1px 3px; font-size: 9px; line-height: 1.2;
        border-radius: 2px;
        white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
        text-align: left;
    }
    .weekcal-event:hover { filter: brightness(0.9); }
    .weekcal-more { font-size: 9px; color: var(--color-text-muted); padding: 0 2px; }

    /* Päivän tehtävät -widget (To Do -tyylinen lista + pikalisäys).
       Käyttäjäpalaute 2026-05-15: vain yksi pystypalkki — sama kuin kalenterissa. */
    .today-tasks-widget { display: flex; flex-direction: column; gap: 6px; height: 100%; min-height: 0; }
    .today-tasks-empty { padding: 8px 4px; text-align: center; flex-shrink: 0; }
    .today-tasks-list { display: flex; flex-direction: column; gap: 2px; flex: 1; min-height: 0; overflow-y: auto; }
    /* Tehtäväkortin body ei scrolla — widget täyttää sen ja vain sisäinen lista scrollaa */
    .quick-side-card-tasks .quick-side-card-body { overflow: hidden; min-height: 0; }
    .today-task-row {
        display: flex; align-items: center; gap: 8px;
        padding: 4px 6px; border-radius: 6px;
        transition: background 0.1s ease;
    }
    .today-task-row:hover { background: var(--color-background-secondary, rgba(0,0,0,0.04)); }
    /* Kalenterimerkinnät päivän tehtävät -widgetin yläosassa */
    .today-tasks-cal-head { font-size: 10px; font-weight: 600; color: var(--color-primary, #2563eb); padding: 4px 8px 2px; text-transform: uppercase; letter-spacing: 0.4px; }
    .today-tasks-tasks-head { font-size: 10px; font-weight: 600; color: var(--color-text-muted); padding: 6px 8px 2px; text-transform: uppercase; letter-spacing: 0.4px; }
    .today-tasks-cal-list { display: flex; flex-direction: column; gap: 1px; padding-bottom: 2px; }
    .today-task-cal-row { background: rgba(37, 99, 235, 0.04); border-left: 3px solid var(--color-primary, #2563eb); padding-left: 6px; }
    .today-task-cal-time { font-size: 10px; color: var(--color-text-muted); min-width: 42px; flex-shrink: 0; padding: 4px 0; }
    .today-tasks-sep { height: 1px; background: var(--color-border-light, #f1f5f9); margin: 4px 0; }
    .today-task-check {
        flex-shrink: 0; width: 18px; height: 18px;
        border: 1.5px solid var(--color-border, #d1d5db); border-radius: 50%;
        background: transparent; cursor: pointer; padding: 0;
        display: inline-flex; align-items: center; justify-content: center;
        color: transparent; transition: all 0.12s ease;
    }
    .today-task-check:hover { border-color: var(--color-primary, #2563eb); }
    .today-task--done .today-task-check {
        background: var(--color-primary, #2563eb);
        border-color: var(--color-primary, #2563eb);
        color: #fff;
    }
    .today-task-name {
        flex: 1; min-width: 0;
        background: transparent; border: none; cursor: pointer;
        text-align: left; padding: 0; color: inherit;
        display: flex; align-items: baseline; gap: 8px;
        font-size: 12px;
    }
    .today-task-title {
        flex: 1; min-width: 0;
        overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
    }
    .today-task--done .today-task-title { text-decoration: line-through; color: var(--color-text-muted); }
    .today-task-due { font-size: 10px; color: var(--color-text-muted); flex-shrink: 0; }
    .today-task--overdue .today-task-due { color: var(--color-danger, #dc2626); font-weight: 600; }
    /* Emotehtävän konteksti vaihelle — käyttäjäpalaute 2026-05-15 */
    .today-task-parent { font-size: 9px; color: var(--color-primary, #2563eb); flex-shrink: 0; padding: 1px 4px; background: rgba(37, 99, 235, 0.08); border-radius: 3px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 140px; }
    /* Pikanapit (Tänään/Huom./Ensi ma) — POSITION:ABSOLUTE jotta eivät muokkaa rivin
       layoutia (käyttäjäpalaute 2026-05-11: 'läpinäkyvät napit tulee tehtävän päälle').
       Tehtävän nimi+due pysyvät paikoillaan, napit kelluvat oikeassa reunassa. */
    .today-task-row { position: relative; }
    .today-task-quick-dates {
        display: none; gap: 2px;
        position: absolute; right: 6px; top: 50%; transform: translateY(-50%);
        z-index: 5;
    }
    .today-task-row:hover .today-task-quick-dates { display: flex; }
    .today-task-quick-btn {
        font-size: 9px; padding: 2px 6px;
        background: rgba(255, 255, 255, 0.92);
        backdrop-filter: blur(2px);
        border: 1px solid var(--color-border);
        border-radius: 10px; cursor: pointer;
        color: var(--color-text); white-space: nowrap;
        transition: all .12s;
        box-shadow: 0 1px 3px rgba(0,0,0,0.08);
    }
    .today-task-quick-btn:hover { background: var(--color-primary, #2563eb); color: #fff; border-color: var(--color-primary, #2563eb); }
    .today-task-add { padding-top: 4px; border-top: 1px dashed var(--color-border-tertiary, var(--color-border)); }
    .today-task-add-input {
        width: 100%; padding: 6px 8px; font-size: 12px;
        border: 1px solid transparent; border-radius: 6px;
        background: var(--color-background-secondary, rgba(0,0,0,0.04));
        outline: none; transition: all 0.12s ease;
    }
    .today-task-add-input:focus {
        background: var(--color-surface, #fff);
        border-color: var(--color-primary, #2563eb);
    }
    .today-task-toggle { font-size: 10px; color: var(--color-text-muted); padding-top: 2px; }
    .today-task-toggle label { display: inline-flex; align-items: center; gap: 4px; cursor: pointer; }
    .today-task-toggle input[type="checkbox"] { margin: 0; transform: scale(0.8); }
    .today-task-footer { padding-top: 4px; }
    .today-task-open-window-btn {
        width: 100%; background: transparent;
        border: 1px solid var(--color-border);
        color: var(--color-primary);
        padding: 6px;
        border-radius: 6px;
        font-size: 11px;
        cursor: pointer;
        transition: all 0.12s ease;
    }
    .today-task-open-window-btn:hover {
        background: var(--color-bg);
        border-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.

      Z-index-hierarkia (2026-05-12):
        - Workspace backdrop: 9050 (himmentää ikkunat kun dash auki)
        - Dashboard panel: 9100 (tulee ikkunoiden + backdropin päälle)
        - Topbar (mdi-shell-hover-wrap): 9200 (Hapro/näkymä/profiili-painikkeet pysyvät klikattavissa)
    */
    .dashboard-panel.dashboard-panel--hapro {
        top: 0;
        /* z-index: 9100 peritään geneerisestä .dashboard-panel-säännöstä — älä alenna täällä. */
    }
    #mdi-topbar.mdi-topbar--shell {
        position: relative;
        z-index: 9200;
    }
    .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; max-width: 40%;
        /* EI 'overflow: hidden' tähän — leikkasi pudotusvalikon (mdi-topbar-proj-dd)
           näkymättömäksi. Ellipsis tehdään itse projekti-painikkeessa
           (.mdi-topbar-projbtn). Käyttäjäpalaute 2026-05-11: "ei avaa projekti listaa". */
        pointer-events: auto;
    }
    .mdi-topbar-projbtn { overflow: hidden; text-overflow: ellipsis; }
    .mdi-topbar-projbtn > span:first-child { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; min-width: 0; }
    .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); }

    /* Yhtenäinen yläpalkin ikoninappi — sama koko (+ ja näkymä) */
    .mdi-topbar-iconbtn {
        display: inline-flex; align-items: center; justify-content: center;
        width: 34px; height: 34px;
        padding: 0;
        border-radius: 8px;
        border: 1px solid var(--color-border);
        background: var(--color-bg);
        color: var(--color-text);
        cursor: pointer;
        box-shadow: 0 1px 2px rgba(0,0,0,.05);
        transition: background 0.12s, transform 0.08s, border-color 0.12s;
    }
    .mdi-topbar-iconbtn:hover { background: var(--color-border-light); }
    .mdi-topbar-iconbtn:active { transform: scale(0.96); }
    /* Täytetty + -muunnos */
    .mdi-topbar-iconbtn--filled { background: var(--color-primary, #2563eb); border-color: var(--color-primary, #2563eb); color: #fff; box-shadow: 0 1px 2px rgba(0,0,0,.08); }
    .mdi-topbar-iconbtn--filled:hover { background: var(--color-primary-hover, #1d4ed8); border-color: var(--color-primary-hover, #1d4ed8); }
    /* Pika-toimintojen pudotusvalikon ikonit (sama kuin Start-menun ja muiden ikonien tyyli) */
    .mdi-topbar-view-item .qa-icon { display:inline-flex; width:18px; height:18px; align-items:center; justify-content:center; color: var(--color-text-muted, #64748b); flex-shrink:0; }
    .mdi-topbar-view-item .qa-icon svg { width:18px; height:18px; }

    /* Projekti-picker-nappi keskellä yläpalkkia */
    .mdi-topbar-projbtn {
        display: inline-flex; align-items: center; gap: 6px;
        max-width: 100%; height: 32px;
        padding: 0 12px;
        border-radius: 8px;
        border: 1px solid transparent;
        background: transparent;
        cursor: pointer;
        font-size: 13px; font-weight: 600;
        color: inherit;
    }
    .mdi-topbar-projbtn:hover { background: rgba(0,0,0,0.04); border-color: var(--color-border); }
    .mdi-topbar-center.open .mdi-topbar-projbtn { background: rgba(0,0,0,0.04); border-color: var(--color-border); }

    /* Projekti-pickerin pudotusvalikko */
    .mdi-topbar-proj-dd {
        position: absolute; top: calc(100% + 6px); left: 50%; transform: translateX(-50%);
        min-width: 360px; max-width: 90vw; max-height: 70vh;
        display: flex; flex-direction: column;
        background: var(--color-bg); border: 1px solid var(--color-border);
        border-radius: 10px; box-shadow: 0 8px 24px rgba(0,0,0,.15);
        z-index: 9000;
    }
    .mdi-topbar-proj-search {
        padding: 8px 12px; border: 0; border-bottom: 1px solid var(--color-border-light);
        font-size: 13px; outline: 0; background: transparent;
        border-radius: 10px 10px 0 0;
    }
    .mdi-topbar-proj-search:focus { background: var(--color-surface); }
    .mdi-topbar-proj-list { flex: 1; min-height: 0; overflow-y: auto; padding: 4px 0; }
    .mdi-topbar-proj-item {
        display: block; width: 100%; text-align: left;
        padding: 6px 12px; border: 0; background: transparent; cursor: pointer;
        color: var(--color-text); border-radius: 0;
    }
    .mdi-topbar-proj-item:hover { background: var(--color-surface); }
    .mdi-topbar-proj-item.current { background: rgba(37,99,235,0.08); }
    .mdi-topbar-proj-item-name { font-size: 12px; font-weight: 500; }
    .mdi-topbar-proj-item-meta { font-size: 10px; color: var(--color-text-muted); display: flex; gap: 6px; margin-top: 2px; }
    .mdi-topbar-proj-empty { padding: 20px 16px; text-align: center; color: var(--color-text-muted); font-size: 12px; }
    .mdi-topbar-proj-foot { border-top: 1px solid var(--color-border-light); padding: 4px; }
    .mdi-topbar-proj-foot-btn { width: 100%; padding: 6px; border: 0; background: transparent; cursor: pointer; font-size: 11px; color: var(--color-text-muted); border-radius: 4px; }
    .mdi-topbar-proj-foot-btn:hover { background: var(--color-surface); color: var(--color-text); }

    /* HUOM: mdi-topbar-center on `position: absolute` (centered) — popover positioidaan
       siihen suhteen samalla absolute-ankkurilla. Ei tarvita position: relative -overridea. */
    .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;
        /* Käyttäjäpalaute 2026-06-06: mini-preview vie 64+10 px → nostettu leveyttä. */
        min-width: 320px;
        max-width: min(380px, 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;
        display: flex;
        flex-direction: column;
        gap: 1px;
    }
    /* Käyttäjäpalaute 2026-06-06: näkymän kuvaus alle pienenä tekstinä */
    .mdi-topbar-view-desc {
        font-size: 10px;
        color: var(--color-text-muted);
        font-weight: 400;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }
    /* Käyttäjäpalaute 2026-06-06: mini-preview kuten Windows Task View */
    .mdi-view-preview {
        position: relative;
        flex-shrink: 0;
        width: 64px;
        height: 40px;
        background: linear-gradient(135deg, #334155 0%, #1e293b 100%);
        border: 1px solid rgba(255,255,255,0.08);
        border-radius: 4px;
        margin-right: 10px;
        overflow: hidden;
        box-shadow: inset 0 1px 2px rgba(0,0,0,0.3);
    }
    .mdi-view-preview-rect {
        position: absolute;
        background: rgba(96,165,250,0.7);
        border: 1px solid rgba(191,219,254,0.95);
        border-radius: 1px;
        box-shadow: 0 0 2px rgba(0,0,0,0.5);
        min-width: 8px;
        min-height: 5px;
    }
    .mdi-topbar-view-item.current .mdi-view-preview {
        border-color: var(--color-primary);
        box-shadow: inset 0 1px 2px rgba(0,0,0,0.3), 0 0 0 2px color-mix(in srgb, var(--color-primary) 30%, transparent);
    }
    .mdi-view-preview-empty {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 100%;
        height: 100%;
        color: rgba(255,255,255,0.3);
        font-size: 16px;
        font-weight: 700;
    }
    .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 {
        /* Käyttäjäpalaute 2026-05-16: valikon leveys ei saa hyppiä hoverissä.
           Käytetään visibility:hidden:iä display:none:n sijaan jotta tila on aina
           varattu, mut napit näkyy vain rivin päällä hover:ssa. */
        display: flex;
        visibility: hidden;
        flex-shrink: 0;
        gap: 4px;
        align-items: stretch;
    }
    /* Muokkaa/poista näkyy vain hover:n yhteydessä. Käyttäjäpalaute 2026-05-11:
       'voisko olla et nuo napit näkyvät vain kun hiiri on valinnan päällä'. */
    .mdi-topbar-view-row:hover .mdi-topbar-view-actions,
    .mdi-topbar-view-row:focus-within .mdi-topbar-view-actions { visibility: visible; }
    .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 {
        /* Sama muoto + koko kuin muut yläpalkin painikkeet (mdi-topbar-iconbtn).
           Käyttäjäpalaute 2026-05-11: 'profiilikuva on ympyrän muotoinen, muut laatikko —
           pitäisi olla samanmuotoisia ja kokoisia'. */
        width: 34px; height: 34px; border-radius: 8px; 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 img { width: 100%; height: 100%; object-fit: cover; }
    .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: flex; align-items: center; gap: 10px; 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 > svg { width: 16px; height: 16px; flex-shrink: 0; }
    .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ä INCLUDING pikapaneeli (8995) ja MDI-ikkunat.
       Backdrop pitää olla z-index > pikapaneelin mutta < dashboardin (9100).
       Käyttäjäpalaute 2026-05-11: 'sivuosa ei tummu' — oli z-index 199 joka jäi alle. */
    .mdi-dash-workspace-backdrop {
        position: fixed;
        left: 0;
        right: 0;
        top: calc(var(--mdi-topbar-h, 44px) + env(safe-area-inset-top, 0px));
        bottom: 0;
        z-index: 9050;
        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;
        /* Käyttäjäpalaute 2026-06-06: 'saatko noiden ikkunoiden nurkkiin vähän isommat
           pyösritykset, pitäs olla samaa luokkaa kuin windowsissa'. Windows 11 client
           area -corner radius on 8 px (rounded). Nostettu 6 px → 10 px jotta erottuu
           selvemmin. */
        border: 1px solid rgba(0,0,0,.28); border-radius: 10px;
        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;
    }
    /* Käyttäjäpalaute 2026-06-03: 'windowsissa on tuossa ikkunan taustalla
       häilyvä taustakuva, ois tän tyyppinen mahdollista myös hapron ikkunoihin?'
       Windows 11 'Mica/Acrylic' -tyylinen sumennettu läpinäkyvä tausta.
       Päällä body[data-mdi-acrylic="1"]:llä → kaikki MDI-ikkunat saavat effektin.
       Drawing-canvas, video, kartta ja modaalit ovat poikkeuksia — niissä läpinäkyvyys
       sotkisi sisältöä. */
    body[data-mdi-acrylic="1"] .mdi-window:not(.mdi-window--no-acrylic) {
        background: color-mix(in srgb, var(--color-bg) 65%, transparent);
        backdrop-filter: blur(24px) saturate(180%);
        -webkit-backdrop-filter: blur(24px) saturate(180%);
        border-color: rgba(255,255,255,.18);
    }
    /* Sisäpaneelit: poista taustaväri jotta acrylic-efekti näkyy joka tasolla.
       Pidetään yhtenäinen 0.4 alfaa otsikkopalkille että tekstit lukukelpoisia. */
    body[data-mdi-acrylic="1"] .mdi-window:not(.mdi-window--no-acrylic) .mdi-win-head {
        background: color-mix(in srgb, var(--color-surface) 55%, transparent);
        backdrop-filter: blur(8px);
        -webkit-backdrop-filter: blur(8px);
    }
    .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;
        /* Käyttäjäpalaute 2026-06-04: narrow window → piilota ikkunan nimi ensin,
           sitten laskelma-keskialue jotta titlebar pysyy luettavana. */
        container-type: inline-size;
        container-name: mdi-titlebar;
    }
    /* < 520px → piilota ikkunan nimi (mutta ikoni jää) */
    @container mdi-titlebar (max-width: 520px) {
        .mdi-win-title { display: none; }
    }
    /* < 360px → piilota myös laskelma-keskialue */
    @container mdi-titlebar (max-width: 360px) {
        .mdi-win-head-center { display: none; }
    }
    .mdi-win-head:active { cursor: grabbing; }
    .mdi-win-head-main {
        display: flex; align-items: center; min-width: 0; gap: 0; flex-shrink: 0;
    }
    /* Otsikkopalkin keskialue (esim. EstimateHeader laskelma-ikkunoissa).
       Justify-center pitää sisällön keskellä riippumatta siitä kuinka leveä title on.
       :empty piilottaa div:n kokonaan ikkunatyypeillä joille ei ole sisältöä. */
    .mdi-win-head-center {
        display: flex; align-items: center; justify-content: center;
        flex: 1; min-width: 0; margin: 0 8px; cursor: default;
    }
    .mdi-win-head-center:empty { display: none; }
    /* EstimateHeader otsikkopalkin sisällä — poista oma chrome (border, bg, padding). */
    .mdi-win-head-center .estimate-hdr-compact {
        background: transparent !important;
        border: none !important;
        padding: 0 !important;
        font-size: 12px;
    }
    /* EstimateHeader: laskelma-nimi-nappi (vain itse nappi klikattava → muu yläpalkki vetokelpoinen). */
    .estimate-hdr-btn {
        background: transparent;
        border: 1px solid transparent;
        cursor: pointer;
        display: inline-flex;
        align-items: center;
        gap: 4px;
        padding: 2px 8px;
        border-radius: 4px;
        color: var(--color-text);
        transition: background 0.12s ease, border-color 0.12s ease;
    }
    .estimate-hdr-btn:hover {
        background: var(--color-background-secondary, rgba(0,0,0,0.04));
        border-color: var(--color-border-tertiary, var(--color-border));
    }
    /* Status-badge nappina: vakiotyyli säilyy (badge-luokat antavat värit), hover korostaa. */
    .estimate-hdr-status-btn {
        transition: filter 0.12s ease, transform 0.12s ease;
    }
    .estimate-hdr-status-btn:hover:not([disabled]):not([style*="not-allowed"]) {
        filter: brightness(0.95);
        transform: translateY(-0.5px);
    }
    .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); }
    /* Yleinen tab-painike (KayttajatWindow, AjopaivakirjaWindow:n modaali, ...) */
    .mdi-tab-btn {
        padding: 8px 14px; border: none; background: transparent;
        color: var(--color-text-muted); cursor: pointer; font-size: 12px;
        border-bottom: 2px solid transparent;
        display: inline-flex; align-items: center; gap: 4px;
        transition: background 0.12s ease, color 0.12s ease, border-color 0.12s ease;
    }
    .mdi-tab-btn:hover { color: var(--color-text); background: color-mix(in srgb, var(--color-border) 35%, transparent); }
    .mdi-tab-btn.mdi-tab-active {
        color: var(--color-primary);
        border-bottom-color: var(--color-primary);
        background: color-mix(in srgb, var(--color-primary) 8%, transparent);
        font-weight: 600;
    }
    /* Käyttäjäpalaute 2026-06-06: 'mitä tuolta yläpalkista painan niin mitään ei tapahdu'
       → varmista että napit ovat AINA klikattavissa: position:relative + z-index korkeampi
       kuin HeaderCenterContent (EstimateHeader voi joskus ylittyä), flex-shrink:0 jotta
       napit eivät kutistu pois näkyvistä ahtaassa ikkunassa, pointer-events:auto explicit. */
    .mdi-win-btns {
        display: flex; gap: 4px;
        position: relative; z-index: 5;
        flex-shrink: 0;
        pointer-events: auto;
    }
    .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;
        position: relative; z-index: 6;
        pointer-events: auto;
        flex-shrink: 0;
    }
    .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;
    }
    /* Käyttäjäpalaute 2026-06-04: puff-napit (tuplaa leveys/korkeus + palauta) */
    .mdi-win-btns button.mdi-puff-btn {
        font-size: 12px;
        line-height: 1;
        padding: 0 2px;
        color: var(--color-text-muted, #64748b);
    }
    .mdi-win-btns button.mdi-puff-btn:hover {
        color: var(--color-primary, #2563eb);
        background: rgba(37,99,235,0.10);
    }
    /* Palautusnappi näkyvä signaali että jokin puff on aktiivinen */
    .mdi-win-btns button.mdi-puff-btn--restore {
        color: var(--color-primary, #2563eb);
        background: rgba(37,99,235,0.10);
    }
    .mdi-win-body { flex: 1; min-height: 0; overflow: auto; padding: 8px; font-size: 12px; }
    .mdi-win-body.mdi-win-body-measlist,
    .mdi-win-body.mdi-win-body-flex {
        display: flex;
        flex-direction: column;
        min-height: 0;
        overflow: hidden;
        padding: 8px;
    }
    /* Tasks/Schedule -ikkunoissa eivät tarvitse paddingia — sisäiset palstat hoitavat sen */
    .mdi-win-body.mdi-win-body-flex { padding: 0; }
    .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; }

    /* ── Tiedostot-paneelin yläosa (siistempi versio, kaikki Lucide-ikoneilla) ── */
    .mdi-files-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));
        background: var(--color-bg);
        flex-shrink: 0;
    }
    .mdi-files-label {
        font-size: 11px;
        font-weight: 600;
        color: var(--color-text-muted, #64748b);
        letter-spacing: 0.02em;
    }
    .mdi-files-actions {
        display: flex;
        align-items: center;
        gap: 2px;
    }
    .mdi-files-iconbtn {
        width: 24px; height: 24px;
        border: none;
        border-radius: 6px;
        background: transparent;
        cursor: pointer;
        color: var(--color-text-muted, #64748b);
        display: inline-flex;
        align-items: center;
        justify-content: center;
        padding: 0;
        transition: background 0.12s, color 0.12s;
    }
    .mdi-files-iconbtn:hover {
        background: var(--color-surface, #f1f5f9);
        color: var(--color-text, #0f172a);
    }
    .mdi-files-iconbtn:active {
        background: color-mix(in srgb, var(--color-primary, #2563eb) 14%, transparent);
    }
    .mdi-files-iconbtn.active {
        background: color-mix(in srgb, var(--color-primary, #2563eb) 14%, transparent);
        color: var(--color-primary, #2563eb);
    }
    .mdi-files-iconbtn[disabled] { opacity: 0.45; cursor: default; }
    .mdi-files-iconbtn svg { width: 14px; height: 14px; 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; position: relative; }
    .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; }
    /* Silmäikoni "off"-tila: visuaalinen indikaattori että mittaus on piilotettu canvasilla */
    .ml-tb-btn--eye-off { opacity: 0.4; text-decoration: line-through; text-decoration-thickness: 1px; }
    .ml-tb-btn--eye-off:hover { opacity: 0.7; }
    .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;
    }
    /* Silmäikoni "off"-tila: visuaalinen indikaattori että mittaus on piilotettu canvasilla */
    .mdi-msettings-tb-btn--eye-off { opacity: 0.4; text-decoration: line-through; text-decoration-thickness: 1px; }
    .mdi-msettings-tb-btn--eye-off:hover:not(:disabled) { opacity: 0.7; }
    .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-toolbar-collapse-btn {
        flex-shrink: 0; align-self: center; width: 18px; height: 22px; padding: 0;
        border: 1px solid var(--color-border, #e2e8f0); border-radius: 4px;
        background: var(--color-bg, #fff); color: var(--color-text-muted, #64748b);
        cursor: pointer; font-size: 10px; line-height: 1; display: inline-flex;
        align-items: center; justify-content: center; margin-right: 2px;
    }
    .mdi-toolbar-collapse-btn:hover { border-color: var(--color-primary, #2563eb); color: var(--color-primary, #2563eb); }
    .mdi-file-search {
        position: sticky; top: 0; z-index: 3; flex-shrink: 0;
        display: flex; align-items: center; gap: 5px;
        padding: 5px 8px; background: var(--color-bg, #fff);
        border-bottom: 0.5px solid var(--color-border-tertiary, var(--color-border));
    }
    .mdi-file-search svg { color: var(--color-text-muted, #94a3b8); flex-shrink: 0; }
    .mdi-file-search input {
        flex: 1; min-width: 0; border: none; outline: none; background: transparent;
        font-size: 11px; color: var(--color-text, #0f172a); font-family: inherit; padding: 1px 0;
    }
    .mdi-file-search input::placeholder { color: var(--color-text-muted, #94a3b8); }
    .mdi-file-search-clear { border: none; background: none; cursor: pointer; color: var(--color-text-muted, #94a3b8); font-size: 11px; padding: 0 2px; flex-shrink: 0; }
    .mdi-file-search-clear:hover { color: var(--color-text, #0f172a); }
    .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;
        /* EI pointer-events:auto — aiemmin tämä blockasi kaikki ikkunoiden interaktiot
           (raahaus, resize, klikit) kunnes käyttäjä klikkasi tyhjää tilaa. Nyt käyttäjä
           voi heti raahata toista ikkunaa ilman että pitää ensin dismissata. Dismissaus
           tapahtuu Esc:llä, X-napilla, candidate-tilen klikkauksella tai uudella raahauksella
           (jokainen pointerdown ikkunassa triggeröi DismissSnapAssistOnInteract). */
        pointer-events: none;
    }
    .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;
        /* Käyttäjäpalaute 2026-05-18: splitter näkyi ärsyttävästi aina ikkunoiden päällä.
           Idle-tilassa täysin näkymätön — vain klikattava alue. Border + tausta + grip
           tulevat näkyviin hoverissa/focus:ssa, jolloin käyttäjä tietää mistä vetää. */
        border-left: 2px solid transparent;
        background: transparent;
        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; /* grip-merkki näkyy vasta hoverissa */
        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;
        /* Sama idle-näkymättömyys kuin --lr-variantissa */
        border-top: 2px solid transparent;
        background: transparent;
        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; /* grip näkyy vasta hoverissa */
        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;
    }
    /* Käyttäjäpalaute 2026-05-27: fixed-versio MDI-ikkunoiden overflow:hidden:in
       ohittamiseen. JS-positio asettaa top/left inline-tyyleinä trigger-napin alle. */
    .estimate-toolbar .validation-dropdown.validation-dropdown--fixed {
        position: fixed; top: 50px; left: 50px;
        display: block; z-index: 10000;
    }
    .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;
    }
    /* Käyttäjäpalaute 2026-05-27: tyhjennys-X hakukentässä */
    .search-widget .search-clear-btn {
        display: inline-flex; align-items: center; justify-content: center;
        flex-shrink: 0; width: 18px; height: 18px; margin-right: 4px; padding: 0;
        border: none; border-radius: 50%; background: var(--color-border-light, rgba(0,0,0,.07));
        color: var(--color-text-muted); cursor: pointer; transition: background .12s, color .12s;
    }
    .search-widget .search-clear-btn:hover {
        background: var(--color-danger, #dc2626); color: #fff;
    }
    .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);
    }
    /* Käyttäjäpalaute 2026-06-04: Littera/Suorite tabit korvattu yhdellä indikaattorilla
       jonka klikkaus avaa overflow-menun (Panos manuaalisesti, muut auto-detect:eilla). */
    .search-widget .search-mode-indicator {
        display: inline-flex;
        align-items: center;
        gap: 2px;
        padding: 3px 6px 3px 8px;
        margin-left: 4px;
        font-size: 10px;
        font-weight: 500;
        line-height: 1.35;
        cursor: pointer;
        background: var(--color-primary);
        color: #fff;
        border: 1px solid var(--color-primary);
        border-radius: 9999px;
        white-space: nowrap;
    }
    .search-widget .search-mode-indicator:hover {
        opacity: 0.92;
    }
    .search-widget .search-mode-indicator--manual {
        background: var(--color-warning, #f59e0b);
        border-color: var(--color-warning, #f59e0b);
    }
    .search-mode-menu {
        position: absolute;
        z-index: 9999;
        margin-top: 4px;
        background: var(--color-bg, #fff);
        border: 1px solid var(--color-border);
        border-radius: 6px;
        box-shadow: 0 4px 16px rgba(0,0,0,0.18);
        min-width: 180px;
        padding: 4px;
    }
    .search-mode-menu button {
        display: flex;
        align-items: center;
        justify-content: space-between;
        width: 100%;
        padding: 6px 10px;
        font-size: 12px;
        text-align: left;
        background: transparent;
        border: none;
        border-radius: 4px;
        cursor: pointer;
        color: var(--color-text);
    }
    .search-mode-menu button:hover { background: var(--color-border-light, rgba(0,0,0,0.06)); }
    .search-mode-menu button.active {
        background: rgba(37,99,235,0.12);
        color: var(--color-primary);
        font-weight: 600;
    }
    .search-mode-menu .hint {
        font-size: 9px;
        color: var(--color-text-muted);
        font-weight: normal;
        margin-left: 8px;
    }
    /* 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;} }
    /* Vasemman reunan pikapaneeli — koko sivun mittainen kahva + slide-out (Päivän tehtävät + kalenteri) */
    .quick-side-handle {
        position: fixed;
        left: 0;
        /* Koko sivun matkalle yläpalkin alta tehtäväpalkin yläpuolelle —
           helpompi osua hiirellä, ei voi missata */
        top: var(--mdi-topbar-h, 44px);
        bottom: var(--mdi-taskbar-h, 44px);
        width: 8px;
        background: rgba(0, 0, 0, 0.04);
        color: rgba(100, 116, 139, 0.5);
        border: none;
        border-radius: 0;
        cursor: pointer;
        font-size: 12px;
        z-index: 9000;
        box-shadow: none;
        transition: width 0.15s, background 0.15s, color 0.15s, opacity 0.15s;
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 0;
        opacity: 1;
    }
    .quick-side-handle:hover {
        width: 16px;
        background: var(--color-primary, #2563eb);
        color: #fff;
        box-shadow: 1px 0 8px rgba(0,0,0,0.18);
    }
    /* Kun paneeli on auki → kahvaa ei tarvita (sulje × tai klikkaa muualle) */
    .quick-side-handle.open { display: none; }
    .quick-side-backdrop {
        position: fixed;
        inset: 0;
        background: transparent;
        z-index: 8990;
    }
    .quick-side-panel {
        position: fixed;
        left: 0;
        top: var(--mdi-topbar-h, 44px); /* alkaa yläpalkin alta */
        bottom: 48px; /* taskbarin yläpuolelle (mdi-taskbar height = 48px) */
        width: 320px;
        background: var(--color-bg, #f8fafc);
        border-right: 1px solid var(--color-border, #e2e8f0);
        box-shadow: 2px 0 12px rgba(0,0,0,0.15);
        z-index: 8995;
        display: flex;
        flex-direction: column;
        gap: 6px;
        padding: 6px;
        padding-top: 28px; /* tilaa close-fab:ille (overlay-tilassa) */
        animation: quickSlideIn 0.2s ease-out;
    }
    /* HUOM: käytä margin-left:tia transform:n sijaan animaatiossa — transform luo
       stacking context:n joka rajaa lapsi-elementtien position:fixed -käyttäytymistä.
       Käyttäjäpalaute 2026-05-11: 'kun klikkaa modaalin alueella jossa on toinen
       ikkuna pohjalla, ohjelma valitsee pohjalla olevan ikkunan eikä modaalia'. */
    @@keyframes quickSlideIn { from { margin-left: -320px; } to { margin-left: 0; } }
    .quick-side-close-fab { position: absolute; top: 6px; right: 6px; background: transparent; border: none; cursor: pointer; font-size: 18px; line-height: 1; color: var(--color-text-muted, #64748b); padding: 2px 8px; border-radius: 4px; z-index: 10; }
    .quick-side-close-fab:hover { color: var(--color-danger, #dc2626); background: rgba(220,38,38,0.08); }

    /* Pikapaneelin yläpalkki (📌 lukitus + ×) */
    .quick-side-toolbar {
        display: flex; gap: 4px; justify-content: flex-end;
        padding: 2px 4px 4px;
    }
    .quick-side-iconbtn {
        background: transparent; border: 1px solid transparent;
        cursor: pointer; font-size: 14px; line-height: 1;
        padding: 4px 8px; border-radius: 4px;
        color: var(--color-text-muted, #64748b);
    }
    .quick-side-iconbtn:hover { background: var(--color-surface, #f8fafc); color: var(--color-text); border-color: var(--color-border); }
    .quick-side-iconbtn.active { background: var(--color-primary, #2563eb); color: #fff; border-color: var(--color-primary); }

    /* Splitter sivuosan oikealla reunalla — raahattava */
    .quick-side-resizer {
        position: absolute; top: 0; right: -2px; bottom: 0;
        width: 6px; cursor: col-resize; z-index: 20;
        background: transparent;
    }
    .quick-side-resizer:hover { background: rgba(37,99,235,0.20); }

    /* Lukittu paneeli — ei animaatiota, vähemmän varjostusta (osa layoutia).
       Käyttäjäpalaute 2026-05-31: kun lukittu, paneeli ulottuu yläreunasta (📌 logon
       tasolla) alareunaan asti — topbar + taskbar siirtyvät .mdi-page-padding:n
       takia paneelin oikealle puolelle, joten paneeli voi täyttää koko vasemman
       sarakkeen 0..100vh ilman päällekkäisyyttä. */
    .quick-side-panel.locked {
        animation: none;
        box-shadow: 1px 0 4px rgba(0,0,0,0.06);
        top: 0;
        bottom: 0;
        padding: 4px 6px 8px;
        gap: 4px;
    }
    /* Lukitussa tilassa toolbar on omat 44px (yläpalkin korkeus) jotta 📌 tulee
       täsmälleen Hapek-logon tasolle. Tehtävät-kortti alkaa heti tämän alta. */
    .quick-side-panel.locked .quick-side-toolbar {
        height: var(--mdi-topbar-h, 44px);
        align-items: center;
        padding: 0 4px;
        flex-shrink: 0;
    }

    /* Lukittu .mdi-page → työpöytä siirtyy paneelin oikealle puolelle.
       mdi-desktop-area ResizeObserver havaitsee koon muutoksen → snap-zonet recalc:taan. */
    .mdi-page.qp-locked { padding-left: var(--qp-w, 320px); }

    /* Vaakasplitter Päivän tehtävät- ja Kalenteri-korttien välissä — käyttäjä voi
       raahata muuttamaan korttien korkeussuhdetta. Tallennetaan localStorage:en. */
    .quick-side-vsplit {
        flex: 0 0 6px;
        cursor: row-resize;
        background: transparent;
        border-radius: 3px;
        position: relative;
        margin: 0 4px;
    }
    .quick-side-vsplit::before {
        content: "";
        position: absolute; left: 50%; top: 50%;
        transform: translate(-50%, -50%);
        width: 32px; height: 2px; border-radius: 2px;
        background: var(--color-border, #e2e8f0);
        opacity: 0.65; transition: opacity 0.15s, background 0.15s;
    }
    .quick-side-vsplit:hover { background: rgba(37,99,235,0.10); }
    .quick-side-vsplit:hover::before { background: var(--color-primary, #2563eb); opacity: 1; }

    /* Kortti-tyyli (yhtenäinen etusivun widgettien kanssa, hieman tiiviimpi) */
    .quick-side-card {
        background: var(--color-surface, #fff);
        border: 1px solid var(--color-border, #e2e8f0);
        border-radius: 8px;
        box-shadow: 0 1px 2px rgba(0,0,0,0.04);
        display: flex; flex-direction: column;
        overflow: hidden;
    }
    .quick-side-card-head {
        padding: 6px 10px;
        background: var(--color-bg, #f8fafc);
        border-bottom: 1px solid var(--color-border-light, #f1f5f9);
        font-size: 11px; font-weight: 600;
        color: var(--color-text-muted, #64748b);
        text-transform: uppercase; letter-spacing: 0.05em;
        display: flex; align-items: center; gap: 6px;
        flex-shrink: 0;
    }
    .quick-side-card-body {
        flex: 1; min-height: 0; overflow-y: auto;
        padding: 8px 10px;
    }
    /* Päivän tehtävät: kiinteä korkeus (splitter-säädettävä) — fallback 40% paneelin
       korkeudesta jos käyttäjä ei ole vielä raahannut. */
    .quick-side-card-tasks {
        flex: 0 0 auto;
        height: var(--qp-tasks-h, 40%);
        min-height: 80px;
    }
    /* Kalenteri: täyttää loput tilan */
    .quick-side-card-cal { flex: 1 1 auto; min-height: 80px; }
    .quick-side-icon { display: inline-flex; width: 14px; height: 14px; color: var(--color-primary, #2563eb); }
    .quick-side-icon svg { width: 14px; height: 14px; }

    /* 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); }
    /* Käyttäjäpalaute 2026-05-16: vaihdettu input → button jotta selain ei piirrä
       sisäistä kehystä input:in oletustyyleistä. */
    /* Käyttäjäpalaute 2026-06-01: 'tuo haku kenttä sais olla leveämpi'.
       Leveys 240px → 360px (1.5x), max 480px ja 50vw. Pieneillä näytöillä
       responsiivinen: min-width 160px. */
    .mdi-search-trigger {
        flex: 0 1 360px; min-width: 160px; max-width: min(480px, 50vw);
        padding: 0 10px 0 32px; cursor: pointer; font-family: inherit;
        text-align: left; color: var(--color-text-muted); font-size: 12px;
        display: inline-flex; align-items: center; gap: 8px;
        outline: none; -webkit-appearance: none; -moz-appearance: none; appearance: none;
    }
    .mdi-search-trigger:hover { background: var(--color-bg, transparent); }
    .mdi-search-placeholder { flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    .mdi-search-kbd { font-size: 10px; font-family: monospace; padding: 1px 5px; border: 1px solid var(--color-border); border-radius: 3px; color: var(--color-text-muted); background: var(--color-surface); flex-shrink: 0; }
    .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; }

    /* Päivän tehtävät -taskbar-painike (avaa dashboard-widget:n). */
    .mdi-tray-today-tasks {
        display: inline-flex; align-items: center; gap: 4px;
        background: transparent; border: none; padding: 4px 8px;
        border-radius: 6px; cursor: pointer;
        color: var(--color-text-muted); transition: all 0.12s ease;
    }
    .mdi-tray-today-tasks:hover {
        background: rgba(255,255,255,0.08);
        color: var(--color-text);
    }
    .mdi-tray-today-tasks-count {
        font-size: 10px; font-weight: 700;
        background: var(--color-primary, #2563eb); color: #fff;
        border-radius: 10px; padding: 1px 6px;
        min-width: 16px; text-align: center;
    }
    .mdi-tray-today-tasks--overdue .mdi-tray-today-tasks-count {
        background: var(--color-danger, #dc2626);
    }
    /* Alhaalta nouseva popover taskbar-painikkeesta. Käyttäjäpalaute 2026-05-11. */
    .mdi-tray-today-tasks-wrap { position: relative; display: inline-flex; }
    .mdi-tray-today-tasks--open { background: rgba(0,0,0,0.06); }
    .mdi-tray-today-tasks-backdrop {
        position: fixed; inset: 0; z-index: 9990; background: transparent;
    }
    .mdi-tray-today-tasks-popover {
        position: absolute;
        bottom: calc(100% + 8px);
        right: 0;
        width: 360px; max-width: 92vw;
        max-height: 70vh;
        background: var(--color-bg, #fff);
        border: 1px solid var(--color-border, #e2e8f0);
        border-radius: 10px;
        box-shadow: 0 -8px 24px rgba(0,0,0,0.18), 0 2px 8px rgba(0,0,0,0.08);
        z-index: 9995;
        display: flex; flex-direction: column;
        overflow: hidden;
        animation: mdi-tray-popover-up 0.18s ease-out;
    }
    @@keyframes mdi-tray-popover-up {
        from { opacity: 0; margin-bottom: -10px; }
        to { opacity: 1; margin-bottom: 0; }
    }
    .mdi-tray-today-tasks-header {
        display: flex; align-items: center; justify-content: space-between;
        padding: 8px 12px;
        font-size: 11px; font-weight: 600;
        border-bottom: 1px solid var(--color-border-light, #f1f5f9);
        background: var(--color-bg, #f8fafc);
        color: var(--color-text-muted, #64748b);
        text-transform: uppercase; letter-spacing: 0.05em;
    }
    /* Otsikko + ikoni — sama tyyli kuin vasemman reunan pikapaneelin .quick-side-card-head (käyttäjäpalaute 2026-05-14) */
    .mdi-tray-today-tasks-title { display: inline-flex; align-items: center; gap: 6px; }
    .mdi-tray-today-tasks-title-icon { display: inline-flex; width: 14px; height: 14px; color: var(--color-primary, #2563eb); }
    .mdi-tray-today-tasks-title-icon svg { width: 14px; height: 14px; }
    .mdi-tray-today-tasks-close {
        background: transparent; border: none; cursor: pointer;
        font-size: 18px; line-height: 1; color: var(--color-text-muted, #64748b);
        padding: 0 6px; border-radius: 4px;
    }
    .mdi-tray-today-tasks-close:hover { color: var(--color-danger, #dc2626); background: rgba(220,38,38,0.08); }
    .mdi-tray-today-tasks-body {
        flex: 1; min-height: 0; overflow-y: auto;
        padding: 8px 10px;
    }
    .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;
}


/* Käyttäjätaulukon hakurivi (mittauslistan tyylinen pilli + chips) */
.user-search-wrap {
    margin-bottom: 12px;
    display: flex; flex-direction: column; gap: 8px;
}
.user-search-row {
    display: flex; align-items: center; gap: 10px;
    flex-wrap: wrap;
}
.user-search-row .user-search-pill { flex: 1; min-width: 220px; max-width: 480px; }
.user-search-pill--company { flex: 0 0 auto; min-width: 200px; max-width: 280px; }
.user-search-pill {
    display: flex; align-items: center; gap: 6px;
    background: var(--color-surface, #fff);
    border: 1px solid var(--color-border);
    border-radius: 999px;
    padding: 4px 10px 4px 12px;
    max-width: 480px;
    transition: border-color 0.15s, box-shadow 0.15s;
}
.user-search-pill:focus-within {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary) 18%, transparent);
}
.user-search-icon {
    display: inline-flex; align-items: center; justify-content: center;
    color: var(--color-text-muted);
    flex-shrink: 0;
}
.user-search-input {
    flex: 1; min-width: 0;
    border: none; outline: none; background: transparent;
    font-size: 13px; padding: 6px 4px; color: var(--color-text);
}
/* Piilota selaimen oma X (type=search) ja datalist-nuoli — käytämme omaa X-nappia */
.user-search-input::-webkit-search-cancel-button,
.user-search-input::-webkit-search-decoration,
.user-search-input::-webkit-search-results-button,
.user-search-input::-webkit-search-results-decoration { -webkit-appearance: none; display: none; }
.user-search-input::-webkit-calendar-picker-indicator { display: none !important; opacity: 0; }
.user-search-clear {
    background: none; border: none; cursor: pointer;
    color: var(--color-text-muted); font-size: 18px; line-height: 1;
    padding: 0 6px;
}
.user-search-clear:hover { color: var(--color-text); }
.user-search-chips {
    display: flex; align-items: center; gap: 4px; flex-wrap: wrap;
}
.user-chips-label {
    font-size: 11px; color: var(--color-text-muted); margin: 0 4px 0 8px;
}
.user-chip-divider {
    width: 1px; height: 16px; background: var(--color-border);
    margin: 0 4px;
}
.user-chip {
    background: var(--color-bg, #f1f5f9);
    border: 1px solid var(--color-border);
    border-radius: 999px;
    padding: 3px 10px;
    font-size: 11px; font-weight: 500;
    color: var(--color-text-muted);
    cursor: pointer;
    transition: all 0.12s;
}
.user-chip:hover {
    border-color: var(--color-primary);
    color: var(--color-primary);
}
.user-chip--active {
    background: var(--color-primary, #2563eb);
    border-color: var(--color-primary, #2563eb);
    color: #fff;
}
.user-chip--active:hover {
    color: #fff;
}

/* Käyttäjätaulukon Tila-sarake: hover-popover info-näyttöä varten */
.user-status-cell {
    position: relative;
    display: inline-flex; align-items: center; gap: 4px;
    cursor: default;
}
.user-info-icon {
    display: inline-flex; align-items: center;
    color: var(--color-text-muted);
    font-size: 12px;
}
.user-info-popover {
    position: absolute; top: 100%; left: 0; margin-top: 4px;
    z-index: 9001;
    background: var(--color-surface, #fff);
    border: 1px solid var(--color-border);
    border-radius: 6px;
    box-shadow: 0 8px 24px rgba(0,0,0,0.18);
    padding: 10px 12px;
    font-size: 11px;
    color: var(--color-text);
    min-width: 240px;
    pointer-events: none;
    white-space: nowrap;
}
.user-info-popover > div { margin-bottom: 6px; }
.user-info-popover > div:last-child { margin-bottom: 0; }
.user-info-popover-extra {
    margin-top: 8px; padding-top: 8px;
    border-top: 1px solid var(--color-border-light, var(--color-border));
    color: #16a34a;
}

/* ─────────────────────────────────────────────────────────────────────
   Taukomuistutukset — moderni korttimainen UI per tauko-tyyppi
   ───────────────────────────────────────────────────────────────────── */
.break-card {
    background: var(--color-surface, #fff);
    border: 1px solid var(--color-border, #e2e8f0);
    border-radius: 12px;
    overflow: hidden;
    transition: border-color 0.15s, box-shadow 0.15s, opacity 0.15s;
    opacity: 0.78;
}
.break-card--on {
    opacity: 1;
    border-color: color-mix(in srgb, var(--color-primary, #2563eb) 35%, var(--color-border));
    box-shadow: 0 2px 8px color-mix(in srgb, var(--color-primary, #2563eb) 12%, transparent);
}
.break-card-head {
    display: flex; align-items: flex-start; gap: 12px;
    padding: 14px 16px;
    background: linear-gradient(180deg, color-mix(in srgb, var(--color-primary, #2563eb) 4%, transparent), transparent);
    border-bottom: 1px solid var(--color-border, #e2e8f0);
}
.break-card-emoji { font-size: 28px; line-height: 1; flex-shrink: 0; }
.break-card-title { flex: 1; min-width: 0; }
.break-card-title > strong { display: block; font-size: 14px; font-weight: 700; color: var(--color-text); margin-bottom: 2px; }
.break-card-title > span { display: block; font-size: 11px; color: var(--color-text-muted); }
.break-card-body { padding: 12px 16px 14px; }

.break-field-label {
    display: block;
    font-size: 11px; font-weight: 600;
    color: var(--color-text-muted);
    text-transform: uppercase; letter-spacing: 0.04em;
    margin-bottom: 6px;
}

.break-time-chips { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }
.break-time-chip {
    display: inline-flex; align-items: center;
    background: var(--color-bg, #f1f5f9);
    border: 1px solid var(--color-border);
    border-radius: 999px;
    padding: 2px 4px 2px 10px;
}
.break-time-input {
    border: none; background: transparent; outline: none;
    font-size: 13px; padding: 4px 0; width: 90px; color: var(--color-text);
    font-variant-numeric: tabular-nums;
}
.break-time-input--solo {
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: 6px 10px;
    background: var(--color-bg, #f8fafc);
    width: 130px;
}
.break-time-remove {
    background: none; border: none; cursor: pointer;
    width: 22px; height: 22px; border-radius: 50%;
    color: var(--color-text-muted);
    font-size: 14px; line-height: 1;
    transition: background 0.12s, color 0.12s;
}
.break-time-remove:hover { background: #fee2e2; color: #dc2626; }
.break-time-add {
    background: transparent;
    border: 1px dashed var(--color-border);
    border-radius: 999px;
    padding: 4px 12px;
    font-size: 12px; color: var(--color-text-muted);
    cursor: pointer;
    transition: border-color 0.12s, color 0.12s, background 0.12s;
}
.break-time-add:hover {
    border-color: var(--color-primary);
    color: var(--color-primary);
    background: color-mix(in srgb, var(--color-primary, #2563eb) 6%, transparent);
}

.break-msg-input {
    width: 100%; box-sizing: border-box;
    padding: 8px 10px;
    border: 1px solid var(--color-border);
    border-radius: 8px;
    font-size: 13px;
    background: var(--color-bg, #f8fafc);
    color: var(--color-text);
    outline: none;
    transition: border-color 0.12s, box-shadow 0.12s;
}
.break-msg-input:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary, #2563eb) 18%, transparent);
}

.pomodoro-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
}
.break-num-input {
    width: 100%; box-sizing: border-box;
    padding: 6px 10px;
    border: 1px solid var(--color-border);
    border-radius: 8px;
    font-size: 13px;
    background: var(--color-bg, #f8fafc);
    color: var(--color-text);
    font-variant-numeric: tabular-nums;
    outline: none;
    margin-top: 4px;
}

.break-extras {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 12px;
}
.break-extra-row {
    display: flex; align-items: flex-start; gap: 10px;
    padding: 12px 14px;
    border: 1px solid var(--color-border);
    border-radius: 10px;
    background: var(--color-bg, #f8fafc);
    cursor: pointer;
    transition: border-color 0.12s, background 0.12s;
}
.break-extra-row:hover { border-color: var(--color-primary); }
.break-extra-row > input[type=checkbox] { margin-top: 2px; flex-shrink: 0; }
.break-extra-emoji { font-size: 20px; flex-shrink: 0; }
.break-extra-row > div { flex: 1; min-width: 0; }
.break-extra-row > div > strong { display: block; font-size: 13px; font-weight: 600; color: var(--color-text); margin-bottom: 2px; }
.break-extra-row > div > span { display: block; font-size: 11px; color: var(--color-text-muted); }

/* Toggle-switch (kortin oikeassa yläreunassa) */
.toggle-switch {
    position: relative;
    display: inline-block;
    width: 36px; height: 20px;
    flex-shrink: 0;
    cursor: pointer;
}
.toggle-switch input { opacity: 0; width: 0; height: 0; }
.toggle-switch .toggle-slider {
    position: absolute; inset: 0;
    background-color: #cbd5e1;
    border-radius: 999px;
    transition: background-color 0.18s;
}
.toggle-switch .toggle-slider::before {
    content: "";
    position: absolute;
    height: 16px; width: 16px;
    left: 2px; bottom: 2px;
    background-color: #fff;
    border-radius: 50%;
    transition: transform 0.18s;
    box-shadow: 0 1px 3px rgba(0,0,0,0.15);
}
.toggle-switch input:checked + .toggle-slider { background-color: var(--color-primary, #2563eb); }

/* ── Tekoälyavustaja — liukupaneeli oikealta ───────────────────────────── */
/* Juuri ei kaappaa klikkejä → sovellus jää käytettäväksi paneelin takana (paneeli "pysyy auki"). */
.ai-asst-root { position: fixed; inset: 0; z-index: 100000; pointer-events: none; }
.ai-asst-panel {
    position: absolute; top: 0; right: 0; bottom: 48px; width: 400px; max-width: 92vw;
    pointer-events: auto;
    background: var(--color-bg, #fff); border-left: 1px solid var(--color-border, #e2e8f0);
    box-shadow: -8px 0 28px rgba(0,0,0,0.18);
    display: flex; flex-direction: column; min-height: 0;
    transform: translateX(110%); transition: transform 0.22s ease;
}
.ai-asst-root.open .ai-asst-panel { transform: translateX(0); }

/* Lukittu AI-paneeli — käyttäjäpalaute 2026-05-31: 📌 lukitsee paneelin, työpöytä
   pienenee (mdi-page-padding:n takia topbar + taskbar siirtyvät vasemmalle).
   Paneeli ulottuu yläreunasta alareunaan asti, kevyempi varjo. */
.ai-asst-root.ai-locked .ai-asst-panel {
    bottom: 0;
    box-shadow: -1px 0 4px rgba(0,0,0,0.06);
    border-left: 1px solid var(--color-border, #e2e8f0);
}
/* Lukittu .mdi-page → työpöytä siirtyy AI-paneelin vasemmalle puolelle. */
.mdi-page.ai-locked { padding-right: var(--ai-w, 400px); }

/* Scroll-to-bottom -nappi viestialueen sisällä, oikea alanurkka. Näkyy kun
   käyttäjä on rullannut ylös. Käyttäjäpalaute 2026-05-31. */
.ai-asst-scroll-down {
    position: absolute;
    right: 16px;
    /* Sijoitettu juuri input-alueen yläpuolelle (input ~60px korkea) */
    bottom: 76px;
    width: 34px;
    height: 34px;
    border-radius: 50%;
    border: 1px solid var(--color-border, #e2e8f0);
    background: var(--color-bg, #fff);
    color: var(--color-text, #0f172a);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 12px rgba(0,0,0,0.12), 0 2px 4px rgba(0,0,0,0.06);
    z-index: 5;
    opacity: 0;
    pointer-events: none;
    transform: translateY(8px);
    transition: opacity 0.18s, transform 0.18s;
}
.ai-asst-scroll-down.visible {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
}
.ai-asst-scroll-down:hover {
    background: var(--color-surface, #f8fafc);
    border-color: var(--color-primary, #2563eb);
    color: var(--color-primary, #2563eb);
}

/* Bottom-right -indikaattori joka näkyy kun paneeli on KIINNI ja AI vastasi.
   Klikkaus avaa paneelin. Käyttäjäpalaute 2026-05-31. */
.ai-asst-notify {
    position: fixed; right: 18px; bottom: 60px;
    z-index: 99999;
    pointer-events: auto;
    background: linear-gradient(135deg, #7c3aed, #2563eb);
    color: #fff;
    padding: 10px 14px;
    border-radius: 999px;
    box-shadow: 0 8px 24px rgba(124,58,237,0.35), 0 2px 6px rgba(0,0,0,0.18);
    cursor: pointer;
    display: inline-flex; align-items: center; gap: 8px;
    font-size: 13px; font-weight: 600;
    border: none;
    animation: aiAsstNotifyPop 0.32s ease-out;
}
.ai-asst-notify:hover { transform: translateY(-1px); box-shadow: 0 10px 28px rgba(124,58,237,0.45); }
.ai-asst-notify-dot {
    width: 8px; height: 8px; border-radius: 50%;
    background: #fff; box-shadow: 0 0 0 0 rgba(255,255,255,0.6);
    animation: aiAsstNotifyPulse 1.6s infinite;
}
@keyframes aiAsstNotifyPop { from { transform: scale(0.7) translateY(20px); opacity: 0; } to { transform: scale(1) translateY(0); opacity: 1; } }
@keyframes aiAsstNotifyPulse { 0% { box-shadow: 0 0 0 0 rgba(255,255,255,0.7); } 70% { box-shadow: 0 0 0 10px rgba(255,255,255,0); } 100% { box-shadow: 0 0 0 0 rgba(255,255,255,0); } }

/* Vetolatch AI-paneelin vasempaan reunaan — käyttäjä voi raahata muuttamaan
   leveyttä (lukitussa tilassa työpöytä mukautuu, overlay-tilassa vain paneeli). */
.ai-asst-resizer {
    position: absolute; top: 0; left: -3px; bottom: 0;
    width: 6px; cursor: col-resize; z-index: 20;
    background: transparent;
}
.ai-asst-resizer:hover { background: rgba(124,58,237,0.20); }
.ai-asst-panel.ai-asst-dropping { outline: 3px dashed var(--color-primary, #2563eb); outline-offset: -8px; background: rgba(37,99,235,0.05); }
.ai-asst-panel.ai-asst-dropping::after { content: "📎 Pudota tiedosto liittääksesi"; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); background: var(--color-primary,#2563eb); color: #fff; padding: 12px 22px; border-radius: 10px; font-weight: 600; font-size: 14px; pointer-events: none; z-index: 10; }
.ai-asst-head {
    display: flex; align-items: center; gap: 6px; padding: 10px 12px;
    border-bottom: 1px solid var(--color-border, #e2e8f0);
    background: linear-gradient(90deg, rgba(124,58,237,0.10), transparent);
}
.ai-asst-title { display: inline-flex; align-items: center; gap: 6px; font-weight: 700; font-size: 14px; color: var(--color-text, #0f172a); }
.ai-asst-title svg { color: #7c3aed; }
.ai-asst-prov { font-size: 11px; padding: 3px 6px; border: 1px solid var(--color-border, #e2e8f0); border-radius: 6px; background: var(--color-surface, #f8fafc); color: var(--color-text, #0f172a); }
.ai-asst-close { border: none; background: none; font-size: 16px; cursor: pointer; color: var(--color-text-muted, #64748b); padding: 2px 6px; border-radius: 6px; }
.ai-asst-close:hover { background: var(--color-surface, #f1f5f9); }
.ai-asst-mode { display: flex; align-items: center; gap: 8px; padding: 6px 12px; border-bottom: 1px solid var(--color-border-light, #f1f5f9); }
.ai-asst-switch { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; cursor: pointer; color: var(--color-text, #0f172a); }
.ai-asst-switch input { cursor: pointer; }
.ai-asst-clear { margin-left: auto; border: none; background: none; font-size: 11px; color: var(--color-text-muted, #64748b); cursor: pointer; text-decoration: underline; }
.ai-asst-msgs { flex: 1 1 auto; min-height: 0; overflow-y: auto; padding: 12px; display: flex; flex-direction: column; gap: 10px; }
.ai-asst-input { flex-shrink: 0; }
.ai-asst-empty { color: var(--color-text, #0f172a); font-size: 13px; margin: auto 0; text-align: left; }
.ai-asst-suggests { display: flex; flex-direction: column; gap: 6px; }
.ai-asst-suggests button { text-align: left; font-size: 12px; padding: 7px 10px; border: 1px solid var(--color-border, #e2e8f0); border-radius: 8px; background: var(--color-surface, #f8fafc); cursor: pointer; color: var(--color-text, #0f172a); }
.ai-asst-suggests button:hover { border-color: #7c3aed; }
.ai-asst-msg { display: flex; flex-direction: column; max-width: 100%; }
.ai-asst-msg.user { align-items: flex-end; }
.ai-asst-msg.asst { align-items: flex-start; }
.ai-asst-bubble { white-space: pre-wrap; word-break: break-word; font-size: 13px; line-height: 1.45; padding: 8px 11px; border-radius: 12px; max-width: 88%; }
.ai-asst-msg.user .ai-asst-bubble { background: var(--color-primary, #2563eb); color: #fff; border-bottom-right-radius: 4px; }
.ai-asst-msg.asst .ai-asst-bubble { background: var(--color-surface, #f1f5f9); color: var(--color-text, #0f172a); border-bottom-left-radius: 4px; }
.ai-asst-msg.err .ai-asst-bubble { background: #fee2e2; color: #991b1b; }
/* Renderöity markdown avustajan vastauksessa */
.ai-asst-bubble table { border-collapse: collapse; margin: 6px 0; width: 100%; font-size: 12px; }
.ai-asst-bubble th, .ai-asst-bubble td { border: 1px solid var(--color-border, #e2e8f0); padding: 3px 6px; text-align: left; vertical-align: top; }
.ai-asst-bubble th { background: color-mix(in srgb, var(--color-primary, #2563eb) 8%, transparent); font-weight: 600; }
.ai-asst-bubble code { background: rgba(0,0,0,0.07); padding: 0 4px; border-radius: 3px; font-size: 11px; font-family: ui-monospace, monospace; }
.ai-asst-bubble ul, .ai-asst-bubble ol { margin: 4px 0; padding-left: 20px; }
.ai-asst-bubble li { margin: 1px 0; }
.ai-asst-bubble h4, .ai-asst-bubble h5, .ai-asst-bubble h6 { margin: 6px 0 2px; font-size: 13px; font-weight: 700; }
.ai-asst-bubble > div:empty { display: none; }
.ai-asst-tools { display: flex; flex-wrap: wrap; gap: 4px; margin-bottom: 4px; }
.ai-asst-tool { font-size: 10px; padding: 2px 6px; border-radius: 999px; background: #ede9fe; color: #6d28d9; border: 1px solid #ddd6fe; }
.ai-asst-tool.fail { background: #fee2e2; color: #991b1b; border-color: #fecaca; }
.ai-asst-thinking { display: inline-flex; gap: 3px; align-items: center; }
.ai-asst-thinking span { width: 6px; height: 6px; border-radius: 50%; background: var(--color-text-muted, #94a3b8); animation: aiAsstBlink 1.2s infinite both; }
.ai-asst-thinking span:nth-child(2) { animation-delay: 0.2s; }
.ai-asst-thinking span:nth-child(3) { animation-delay: 0.4s; }
@keyframes aiAsstBlink { 0%, 80%, 100% { opacity: 0.25; } 40% { opacity: 1; } }
.ai-asst-input { display: flex; gap: 6px; padding: 10px 12px; border-top: 1px solid var(--color-border, #e2e8f0); align-items: flex-end; }
.ai-asst-input textarea { flex: 1; resize: none; font-family: inherit; font-size: 13px; padding: 8px 10px; border: 1px solid var(--color-border, #e2e8f0); border-radius: 10px; background: var(--color-bg, #fff); color: var(--color-text, #0f172a); max-height: 120px; }
.ai-asst-input textarea:focus { outline: none; border-color: #7c3aed; }
.ai-asst-send { flex-shrink: 0; width: 38px; height: 38px; border: none; border-radius: 10px; background: var(--color-primary, #2563eb); color: #fff; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; }
.ai-asst-send:disabled { opacity: 0.45; cursor: default; }
.ai-asst-foot { padding: 4px 12px 8px; font-size: 10px; color: var(--color-text-muted, #94a3b8); }
.ai-asst-settings { padding: 8px 12px; border-bottom: 1px solid var(--color-border-light, #f1f5f9); background: var(--color-surface, #f8fafc); }
.ai-asst-settings label { display: block; font-size: 11px; font-weight: 600; color: var(--color-text-muted, #64748b); margin-bottom: 4px; }
.ai-asst-settings textarea { width: 100%; box-sizing: border-box; resize: vertical; font-family: inherit; font-size: 12px; padding: 6px 8px; border: 1px solid var(--color-border, #e2e8f0); border-radius: 6px; background: var(--color-bg, #fff); color: var(--color-text, #0f172a); }
.ai-asst-settings textarea:focus { outline: none; border-color: #7c3aed; }
.ai-asst-settings-hint { font-size: 10px; color: var(--color-text-muted, #94a3b8); margin-top: 3px; }
.ai-asst-opendraw { display: flex; flex-wrap: wrap; gap: 5px; margin-top: 6px; }
.ai-asst-openbtn { font-size: 11px; padding: 4px 10px; border: 1px solid #7c3aed; border-radius: 999px; background: #ede9fe; color: #6d28d9; cursor: pointer; }
.ai-asst-openbtn:hover { background: #7c3aed; color: #fff; }

/* ── AI-poiminta-lappu (rakenneosat leikkauksesta) ─────────────────────── */
.ai-poiminta-back { position: fixed; inset: 0; background: rgba(15,23,42,0.35); z-index: 16000050; display: flex; align-items: center; justify-content: center; }
.ai-poiminta-dialog { width: 580px; max-width: 94vw; max-height: 86vh; background: var(--color-bg,#fff); border-radius: 10px; box-shadow: 0 12px 40px rgba(0,0,0,0.3); display: flex; flex-direction: column; overflow: hidden; }
.ai-poiminta-head { display: flex; align-items: center; justify-content: space-between; padding: 10px 14px; font-weight: 700; font-size: 14px; border-bottom: 1px solid var(--color-border,#e2e8f0); background: linear-gradient(90deg, rgba(124,58,237,0.10), transparent); }
.ai-poiminta-x { border: none; background: none; cursor: pointer; font-size: 15px; color: var(--color-text-muted,#64748b); }
.ai-poiminta-loading { padding: 40px; text-align: center; color: var(--color-text-muted,#64748b); font-size: 13px; display: flex; flex-direction: column; align-items: center; }
.ai-poiminta-error { padding: 14px; color: #991b1b; background: #fee2e2; margin: 12px; border-radius: 6px; font-size: 13px; }
.ai-poiminta-opts { padding: 10px 14px; display: flex; flex-wrap: wrap; gap: 8px 16px; align-items: center; font-size: 12px; border-bottom: 1px solid var(--color-border-light,#f1f5f9); }
.ai-poiminta-radio { display: inline-flex; align-items: center; gap: 5px; cursor: pointer; }
.ai-poiminta-rows { overflow-y: auto; padding: 8px 14px; flex: 1 1 auto; min-height: 0; }
.ai-poiminta-row { display: grid; grid-template-columns: 24px 1fr 72px 26px; gap: 6px; align-items: center; margin-bottom: 4px; }
.ai-poiminta-rowhead { font-size: 10px; color: var(--color-text-muted,#64748b); font-weight: 600; text-transform: uppercase; }
.ai-poiminta-name, .ai-poiminta-unit { font-size: 12px; padding: 4px 6px; border: 1px solid var(--color-border,#e2e8f0); border-radius: 4px; background: var(--color-bg,#fff); color: var(--color-text,#0f172a); }
.ai-poiminta-del { border: none; background: none; cursor: pointer; color: #dc2626; font-size: 12px; }
.ai-poiminta-add { margin-top: 6px; border: 1px dashed var(--color-border,#e2e8f0); background: none; border-radius: 6px; padding: 4px 10px; font-size: 12px; cursor: pointer; color: var(--color-text-muted,#64748b); }
.ai-poiminta-foot { display: flex; align-items: center; gap: 8px; padding: 10px 14px; border-top: 1px solid var(--color-border,#e2e8f0); }
.ai-poiminta-info { font-size: 10px; color: var(--color-text-muted,#94a3b8); }
.ai-poiminta-create { background: #16a34a; color: #fff; border-color: #16a34a; }
.ai-poiminta-create:disabled { opacity: .5; cursor: default; }
.ai-poiminta-page-row { display: flex; align-items: center; gap: 8px; padding: 6px 4px; border-bottom: 1px solid var(--color-border-light,#f1f5f9); cursor: pointer; font-size: 12px; }
.ai-poiminta-page-row:hover { background: var(--color-surface,#f8fafc); }
.ai-poiminta-page-n { color: var(--color-text-muted,#64748b); min-width: 54px; }
.ai-poiminta-page-tunnus { font-weight: 700; color: #7c3aed; background: #ede9fe; padding: 1px 6px; border-radius: 4px; }
.ai-poiminta-page-label { color: var(--color-text,#0f172a); }
.ai-poiminta-namewrap { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.ai-poiminta-src { font-size: 9px; color: #7c3aed; }
.toggle-switch input:checked + .toggle-slider::before { transform: translateX(16px); }