@layer components {

    .asset-chart__container {
        block-size: 320px;
        inline-size: 100%;
        margin-block-start: var(--block-space);
    }
    /* Point chart (single measurement point page) */
    .point-chart__container {
        block-size: 280px;
        inline-size: 100%;
    }

    .point-chart__filters {
        align-items: center;
        display: flex;
        flex-wrap: wrap;
        gap: 0.5em;
        margin-block: 0.5rem;
    }

    .point-chart__filter-label {
        font-size: var(--text-small);
        color: var(--color-ink-dark);
    }

    .point-chart__filter-input {
        --input-padding: 0.3em 0.5em;

        font-size: var(--text-small);
        max-inline-size: 10em;
    }

    /* Vibration chart (measurement detail page) */
    .vibration-chart__container {
        block-size: 320px;
        inline-size: 100%;
    }

    /* Measurement metrics grid */
    .measurement-metric {
        display: flex;
        flex-direction: column;
        min-inline-size: 8ch;
    }

    /* ==========================================
       MACHINE BODY DIAGRAM
       ========================================== */

    .machine-body {
        /* Drawing + caption strip stack. Drawing height stays what it was
           (the SVG uses the original 0..80 viewBox); the caption row sits
           underneath as an HTML element so CSS font-size is honest. */
        --machine-body-height: 2.5em;
        --sensor-circle-size: calc(var(--machine-body-height) * 0.7);
        --dot-size: 0.35em;
        --dot-offset: calc(var(--sensor-circle-size) / 2 + var(--dot-size) * 0.2);

        display: inline-block;
        position: relative;
        vertical-align: middle;
    }

    .machine-body__drawing {
        block-size: var(--machine-body-height);
        display: block;
        position: relative;
    }

    .machine-body__shape {
        block-size: 100%;
        display: block;
        inline-size: auto;
    }

    /* Caption row — HTML, positioned below the drawing. Each segment label
       sits at its own percentage offset so captions track the rects above
       regardless of viewBox width. Matches datasheet eyebrow typography. */
    .machine-body__captions {
        block-size: 1.2em;
        inline-size: 100%;
        margin-block-start: 0.35em;
        position: relative;
    }

    .machine-body__segment-label {
        color: var(--ink-faint);
        font-family: var(--font-data);
        font-size: 0.625rem;
        font-weight: 700;
        letter-spacing: 0.14em;
        line-height: 1.1;
        position: absolute;
        text-transform: uppercase;
        top: 0;
        transform: translateX(-50%);
    }

    .machine-body__sensor-circle {
        aspect-ratio: 1;
        block-size: var(--sensor-circle-size);
        position: absolute;
        top: 50%;
        transform: translate(-50%, -50%);
    }

    .machine-body__ring {
        block-size: 100%;
        border: 1px solid var(--ink-faint);
        border-radius: 50%;
        inline-size: 100%;
    }

    .machine-body__dot {
        background-color: var(--sensor-color, var(--color-ink-medium));
        block-size: var(--dot-size);
        border-radius: 50%;
        inline-size: var(--dot-size);
        left: calc(50% - var(--dot-size) / 2);
        position: absolute;
        top: calc(50% - var(--dot-size) / 2);
        transform: rotate(var(--dot-angle, 0deg)) translateY(calc(-1 * var(--dot-offset)));
        transform-origin: calc(var(--dot-size) / 2) calc(var(--dot-size) / 2);
    }

    .machine-body__dot--axial {
        transform: none;
    }

    /* 10 sensor identity colors */
    .machine-body__dot--c0 { --sensor-color: oklch(var(--lch-blue-medium)); }
    .machine-body__dot--c1 { --sensor-color: oklch(var(--lch-purple-medium)); }
    .machine-body__dot--c2 { --sensor-color: oklch(var(--lch-aqua-medium)); }
    .machine-body__dot--c3 { --sensor-color: oklch(var(--lch-pink-medium)); }
    .machine-body__dot--c4 { --sensor-color: oklch(var(--lch-violet-medium)); }
    .machine-body__dot--c5 { --sensor-color: oklch(var(--lch-lime-medium)); }
    .machine-body__dot--c6 { --sensor-color: oklch(var(--lch-uncolor-medium)); }
    .machine-body__dot--c7 { --sensor-color: oklch(var(--lch-blue-dark)); }
    .machine-body__dot--c8 { --sensor-color: oklch(var(--lch-pink-dark)); }
    .machine-body__dot--c9 { --sensor-color: oklch(var(--lch-aqua-dark)); }
    /* ==========================================
       BODY LAYOUT EDITOR (asset edit)
       ========================================== */

    .body-layout-editor {
        margin-block-start: 1em;
    }

    .body-layout-editor__label {
        color: var(--color-ink-dark);
        font-size: var(--text-x-small);
        font-weight: 600;
        letter-spacing: 0.03em;
        margin-block-end: 0.5em;
        text-transform: uppercase;
    }

    .body-layout-editor__segments {
        align-items: center;
        display: flex;
        flex-wrap: wrap;
        gap: 0.35em;
        min-block-size: 2.5em;
    }

    .body-layout-editor__pill {
        align-items: center;
        background-color: var(--color-ink-lightest);
        border: 1px solid var(--color-ink-lighter);
        border-radius: 0.3em;
        cursor: grab;
        display: inline-flex;
        font-size: var(--text-small);
        font-weight: 600;
        gap: 0.3em;
        padding: 0.3em 0.6em;
        user-select: none;
    }

    .body-layout-editor__pill:active {
        cursor: grabbing;
    }

    .body-layout-editor__pill--dragging {
        opacity: 0.4;
    }

    .body-layout-editor__pill--de {
        border-color: var(--color-ink-light);
    }

    .body-layout-editor__pill--nde {
        border-color: var(--color-ink-lighter);
    }

    .body-layout-editor__pill--custom {
        border-color: var(--color-ink-light);
        border-style: dashed;
    }

    .body-layout-editor__custom {
        position: relative;
    }

    .body-layout-editor__custom-input {
        inline-size: 12ch;
        padding-inline-end: 2.2em;
    }

    .body-layout-editor__custom-add {
        --icon-size: 0.85em;

        appearance: none;
        background: none;
        border: none;
        color: var(--color-ink-medium);
        cursor: pointer;
        inset-block: 0;
        inset-inline-end: 0;
        padding-inline: 0.45em;
        position: absolute;
    }

    .body-layout-editor__custom-add:hover {
        color: var(--color-ink-dark);
    }

    .body-layout-editor__pill-remove {
        --icon-size: 0.7em;

        appearance: none;
        background: none;
        border: none;
        color: var(--color-ink-medium);
        cursor: pointer;
        padding: 0;
    }

    .body-layout-editor__pill-remove:hover {
        color: var(--color-negative);
    }

    .body-layout-editor__actions {
        display: flex;
        gap: 0.35em;
        margin-block-start: 0.5em;
    }
}
