[hidden] { display: none !important; }

/* ——— Layout ————————————————————————————————————————————————————————————— */

.ts-wrap {
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

/* ——— Controls ———————————————————————————————————————————————————————————— */

.ts-controls {
    display: flex;
    align-items: center;
    padding: 0 clamp(1.5rem, 5vw, 3rem);
    height: 56px;
    border-bottom: 1px solid var(--border);
    flex-shrink: 0;
    gap: 1.5rem;
}

.ts-controls__left  { flex-shrink: 0; }

.ts-controls__center {
    display: flex;
    align-items: center;
    gap: 1rem;
    flex: 1;
    justify-content: center;
    overflow: hidden;
}

.ts-controls__right { flex-shrink: 0; }

.ts-title {
    font-family: 'Bebas Neue', sans-serif;
    font-size: 1.4rem;
    letter-spacing: 0.05em;
    color: var(--text);
}

/* Options */
.ts-opt {
    display: flex;
    align-items: center;
    gap: 0.45rem;
    font-size: 0.78rem;
    color: var(--muted);
    white-space: nowrap;
    cursor: default;
}

.ts-opt--grow {
    flex: 1;
    min-width: 0;
}

.ts-unit {
    font-size: 0.72rem;
    color: var(--muted);
}

/* Number input */
.ts-number {
    width: 44px;
    height: 28px;
    padding: 0 0.35rem;
    border-radius: 6px;
    border: 1px solid var(--border);
    background: var(--bg);
    color: var(--text);
    font-size: 0.78rem;
    font-family: inherit;
    text-align: center;
}
.ts-number::-webkit-outer-spin-button,
.ts-number::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.ts-number { -moz-appearance: textfield; }
.ts-number:focus { outline: none; border-color: var(--accent); }

/* Select */
.ts-select {
    height: 28px;
    padding: 0 0.5rem;
    border-radius: 6px;
    border: 1px solid var(--border);
    background: var(--bg);
    color: var(--text);
    font-size: 0.78rem;
    font-family: inherit;
    cursor: pointer;
}

.ts-select--sm { width: 70px; }

/* Sample text input */
.ts-sample-input {
    height: 28px;
    padding: 0 0.5rem;
    border-radius: 6px;
    border: 1px solid var(--border);
    background: var(--bg);
    color: var(--text);
    font-size: 0.78rem;
    font-family: inherit;
    flex: 1;
    min-width: 100px;
    max-width: 240px;
}
.ts-sample-input:focus { outline: none; border-color: var(--accent); }

/* Button */
.ts-btn {
    height: 34px;
    padding: 0 1.1rem;
    border-radius: 7px;
    font-size: 0.82rem;
    font-weight: 500;
    cursor: pointer;
    border: 1px solid transparent;
    font-family: inherit;
    transition: background 0.2s, border-color 0.2s, color 0.2s;
    white-space: nowrap;
}
.ts-btn--ghost {
    background: transparent;
    color: var(--text);
    border-color: var(--border);
}
.ts-btn--ghost:hover { border-color: var(--accent); color: var(--accent); }

/* ——— Info bar ———————————————————————————————————————————————————————————— */

.ts-infobar {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0 clamp(1.5rem, 5vw, 3rem);
    height: 36px;
    border-bottom: 1px solid var(--border);
    flex-shrink: 0;
    font-size: 0.75rem;
    color: var(--muted);
}

#ts-scale-name { color: var(--accent); font-weight: 600; }
#ts-base-val   { color: var(--text); }
.ts-infobar__sep { opacity: 0.3; }

/* ——— Preview ————————————————————————————————————————————————————————————— */

.ts-preview {
    flex: 1;
    overflow-y: auto;
    overflow-x: hidden;
}

.ts-preview::-webkit-scrollbar { width: 5px; }
.ts-preview::-webkit-scrollbar-track { background: transparent; }
.ts-preview::-webkit-scrollbar-thumb { background: var(--border); border-radius: 3px; }

/* ——— Rows ———————————————————————————————————————————————————————————————— */

.ts-row {
    display: flex;
    align-items: stretch;
    border-bottom: 1px solid var(--border);
    overflow: hidden;
    transition: background 0.12s;
}

.ts-row:nth-child(odd) { background: rgba(255, 255, 255, 0.012); }
.ts-row:hover          { background: rgba(59, 130, 246, 0.05); }

/* ——— Row meta column ————————————————————————————————————————————————————— */

.ts-row__meta {
    flex-shrink: 0;
    width: 92px;
    padding: 1rem 1.25rem;
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
    justify-content: center;
    border-right: 1px solid var(--border);
}

.ts-row__tag {
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--text);
    line-height: 1;
}

.ts-row__px,
.ts-row__rem {
    font-size: 0.6rem;
    color: var(--muted);
    font-family: 'Courier New', 'Cascadia Code', monospace;
    letter-spacing: 0.02em;
    line-height: 1.4;
}

/* ——— Row text column ————————————————————————————————————————————————————— */

.ts-row__text {
    flex: 1;
    min-width: 0;
    padding: 0.9rem 2rem 0.9rem clamp(1.25rem, 3vw, 2rem);
    color: var(--text);
    display: flex;
    align-items: center;
}

/* Headings: single line, clip overflow */
.ts-row--heading .ts-row__text {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Very large sizes (Display, H1, H2): cap row height */
.ts-row--huge {
    max-height: 130px;
}

/* Body & small: allow wrap */
.ts-row--body .ts-row__text {
    align-items: flex-start;
    padding-top: 1rem;
    padding-bottom: 1rem;
    line-height: inherit;
}

/* ——— Responsive ————————————————————————————————————————————————————————— */

@media (max-width: 860px) {
    .ts-controls__center { gap: 0.6rem; }
    .ts-select { font-size: 0.73rem; }
    .ts-sample-input { max-width: 130px; }
}

@media (max-width: 680px) {
    .ts-controls__center { display: none; }
    .ts-controls__left { flex: 1; }
    .ts-row__meta { width: 72px; padding: 0.75rem 0.75rem; }
}
