/* ══════════════════════════════════════════════════════════════
   JsonComponent — Three-Mode Design Language
   Styles for FullGUI (expanded chips), Detailed (labelled inline
   fields) and Compact (single command-line) rendering. Every
   InputComponentBase<T> renders exactly one .json-token carrying
   its own mode-* class, so these rules apply regardless of where
   the component is mounted in the DOM.
   ══════════════════════════════════════════════════════════════ */

@import url('json-component-colors.css');

/* ── Token base ───────────────────────────────────────────────── */

.json-token {
    position: relative;
    transition: all 0.3s ease;
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
}

.token-label {
    display: block;
    font-weight: 600;
    letter-spacing: 0.04em;
    user-select: none;
    transition: all 0.25s ease;
}

/* Label-row wrapper: the label + optional accessory (type dropdown, toggle,
   etc.) sit side by side at the top of the chip. */
.token-label-row {
    display: flex;
    align-items: baseline;
    gap: 0.35rem;
}

.token-label-accessory {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    flex-shrink: 0;
    margin-left: auto;
}

/* Repr summary sits inline after the label — inherits chip colour,
   one step smaller than the label. */
.token-repr-summary {
    color: var(--token-color);
    font-family: 'SF Mono', 'Cascadia Code', 'Fira Code', 'Consolas', monospace;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    min-width: 0;
}

.token-repr-summary::before {
    content: ":\00a0";
    opacity: 0.5;
}

/* Scale the repr summary relative to the label in each mode */
.json-token.mode-full > .token-label-row > .token-repr-summary {
    font-size: 0.55rem;
    opacity: 0.85;
}

.json-token.mode-detailed > .token-label-row > .token-repr-summary {
    font-size: 0.55rem;
    opacity: 0.8;
}

.json-token.mode-compact > .token-label-row > .token-repr-summary {
    font-size: 0.5rem;
    opacity: 0.7;
}

/* Compact never shows the accessory — it only has room for the input. */
.json-token.mode-compact .token-label-accessory {
    display: none;
}

/* Small uppercase dropdown look for type-select accessories. */
.token-label-accessory select {
    padding: 0.1rem 0.35rem;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid var(--token-border);
    border-radius: 3px;
    color: var(--token-color);
    font-size: 0.65rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    cursor: pointer;
}

.token-label-accessory select:focus {
    outline: none;
    border-color: var(--token-color);
}

/* Pill-shaped on/off toggle used for optional chip content. */
.token-toggle {
    appearance: none;
    -webkit-appearance: none;
    width: 1.8rem;
    height: 0.9rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.12);
    border: 1px solid var(--token-border);
    position: relative;
    cursor: pointer;
    margin: 0;
    transition: background 0.2s ease, border-color 0.2s ease;
}

.token-toggle::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 0.1rem;
    width: 0.55rem;
    height: 0.55rem;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.6);
    transform: translateY(-50%);
    transition: left 0.2s ease, background 0.2s ease;
}

.token-toggle:checked {
    background: var(--token-color);
    border-color: var(--token-color);
}

.token-toggle:checked::after {
    left: 1.05rem;
    background: var(--cpd-dark, #061221);
}

/* Disabled-body pattern for optional chips — label/accessory stay live,
   everything else is greyed and non-interactive. */
.json-token.disabled > :not(.token-label-row) {
    opacity: 0.35;
    pointer-events: none;
    user-select: none;
}

/* ── Generic row container for composing top-level JsonComponents */

.json-component-row {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    align-items: stretch;
}

/* Top-level JsonComponents inside a row all share the same full width, so
   Trade / SwapConvention / OisConvention line up regardless of content. */
.json-component-row > .json-token {
    flex: 1 1 100%;
    width: 100%;
    min-width: 0;
}

/* ── Role → colour variable binding ───────────────────────────── */

.json-token[data-role="position"]     { --token-color: var(--token-position);     --token-bg: var(--token-position-bg);     --token-border: var(--token-position-border);     }
.json-token[data-role="notional"]     { --token-color: var(--token-notional);     --token-bg: var(--token-notional-bg);     --token-border: var(--token-notional-border);     }
.json-token[data-role="instrument"]   { --token-color: var(--token-instrument);   --token-bg: var(--token-instrument-bg);   --token-border: var(--token-instrument-border);   }
.json-token[data-role="rate"]         { --token-color: var(--token-rate);         --token-bg: var(--token-rate-bg);         --token-border: var(--token-rate-border);         }
.json-token[data-role="date"]         { --token-color: var(--token-date);         --token-bg: var(--token-date-bg);         --token-border: var(--token-date-border);         }
.json-token[data-role="type"]         { --token-color: var(--token-type);         --token-bg: var(--token-type-bg);         --token-border: var(--token-type-border);         }
.json-token[data-role="end-of-month"] { --token-color: var(--token-end-of-month); --token-bg: var(--token-end-of-month-bg); --token-border: var(--token-end-of-month-border); }
.json-token[data-role="convention"]   { --token-color: var(--token-instrument);   --token-bg: var(--token-instrument-bg);   --token-border: var(--token-instrument-border);   }
.json-token[data-role="accrual"]      { --token-color: var(--token-rate);         --token-bg: var(--token-rate-bg);         --token-border: var(--token-rate-border);         }
.json-token[data-role="tenor"]        { --token-color: var(--token-rate);         --token-bg: var(--token-rate-bg);         --token-border: var(--token-rate-border);         }
.json-token[data-role="rate-index"]   { --token-color: var(--token-rate);         --token-bg: var(--token-rate-bg);         --token-border: var(--token-rate-border);         }
.json-token[data-role="calendar"]     { --token-color: var(--token-date);         --token-bg: var(--token-date-bg);         --token-border: var(--token-date-border);         }
.json-token[data-role="trade"]        { --token-color: var(--cpd-gold);           --token-bg: rgba(246, 212, 107, 0.04);    --token-border: rgba(246, 212, 107, 0.25);        }


/* ══════════════════════════════════════════════════════════════
   FULL GUI MODE — Expanded chips
   ══════════════════════════════════════════════════════════════ */

.json-token.mode-full {
    background: var(--token-bg);
    border: 1.5px solid var(--token-border);
    border-radius: 8px;
    padding: 0.5rem 0.75rem 0.65rem;
    min-width: 7rem;
    gap: 0.35rem;
}

/* Label pinned at top; remaining body content centred in the leftover
   vertical space so short chips (e.g. Notional) line up with tall ones
   (e.g. IRS) in the same flex row. */
.json-token.mode-full > .token-label-row + * {
    margin-top: auto;
}
.json-token.mode-full > *:last-child {
    margin-bottom: auto;
}

.json-token.mode-full:hover {
    border-color: var(--token-color);
    box-shadow: 0 0 8px rgba(0, 0, 0, 0.15);
}

.json-token.mode-full > .token-label-row {
    padding-bottom: 0.15rem;
    border-bottom: 1px solid var(--token-border);
    margin-bottom: 0.1rem;
}

.json-token.mode-full > .token-label-row > .token-label {
    font-size: 0.65rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--token-color);
    opacity: 0.85;
}

/* Chip form controls */
.json-token.mode-full .form-input,
.json-token.mode-full .detail-spin,
.json-token.mode-full .detail-select {
    background: rgba(255, 255, 255, 0.06);
    border-color: var(--token-border);
    font-size: 0.85rem;
}

.json-token.mode-full .form-input:focus,
.json-token.mode-full .detail-spin:focus,
.json-token.mode-full .detail-select:focus {
    border-color: var(--token-color);
    box-shadow: 0 0 0 2px var(--token-bg);
}

.json-token.mode-full[data-role="type"] .token-control select {
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid var(--token-border);
    border-radius: 4px;
    padding: 0.35rem 0.6rem;
    color: var(--cpd-light);
    font-size: 0.85rem;
}

/* Nested .child-flow inside a FullGUI chip is a compact
   horizontal flow of mini-tokens, not a wide wrap. */
.json-token.mode-full > .child-flow {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 0.4rem;
    padding-top: 0.25rem;
}

.json-token.mode-full > .child-flow > .json-token {
    background: transparent;
    border: 1px solid var(--token-border);
    border-radius: 4px;
    padding: 0.2rem 0.45rem 0.3rem;
    min-width: 0;
    flex: 0 1 auto;
}

.json-token.mode-full > .child-flow > .json-token > .token-label-row {
    border-bottom: none;
    padding-bottom: 0;
    margin-bottom: 0;
}

.json-token.mode-full > .child-flow > .json-token > .token-label-row > .token-label {
    font-size: 0.6rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--token-color);
    opacity: 0.7;
}

/* ── Separator (@ symbol inside a FullGUI row) ───────────────── */

.json-separator {
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--token-separator);
    font-family: 'SF Mono', 'Cascadia Code', 'Fira Code', 'Consolas', monospace;
    font-size: 1.1rem;
    font-weight: 600;
    padding: 0 0.15rem;
    align-self: center;
    opacity: 0.7;
}


/* ══════════════════════════════════════════════════════════════
   DETAILED MODE — Labelled inline fields
   A .mode-detailed token acts as a transparent container whose
   child-flow is a row of cascaded .mode-compact children.
   ══════════════════════════════════════════════════════════════ */

.json-token.mode-detailed {
    background: var(--token-bg);
    border: 1.5px solid var(--token-border);
    border-radius: 8px;
    padding: 0.5rem 0.75rem 0.65rem;
    gap: 0.35rem;
}

.json-token.mode-detailed > .token-label-row + * {
    margin-top: auto;
}
.json-token.mode-detailed > *:last-child {
    margin-bottom: auto;
}

.json-token.mode-detailed:hover {
    border-color: var(--token-color);
    box-shadow: 0 0 8px rgba(0, 0, 0, 0.15);
}

.json-token.mode-detailed > .token-label-row > .token-label {
    font-size: 0.65rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--token-color);
    opacity: 0.75;
}

.json-token.mode-detailed > .child-flow {
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: flex-end;
    gap: 0.5rem;
    padding-top: 0.25rem;
    overflow-x: auto;
}

/* Detailed-mode child tokens must hug their content, not stretch to row width. */
.json-token.mode-detailed > .child-flow > .json-token {
    flex: 0 0 auto;
    width: auto;
    min-width: 0;
}

/* Bare underlined field look for cascaded-Compact children. */
.json-token.mode-compact {
    gap: 0.1rem;
    border-bottom: 2px solid var(--token-border);
    padding-bottom: 0.1rem;
    min-width: 3rem;
    flex: 0 1 auto;
}

.json-token.mode-compact:focus-within {
    border-bottom-color: var(--token-color);
}

.json-token.mode-compact > .token-label-row > .token-label {
    font-size: 0.6rem;
    text-transform: lowercase;
    letter-spacing: 0.04em;
    color: var(--token-color);
    opacity: 0.7;
}

.json-token.mode-compact:focus-within > .token-label-row > .token-label {
    opacity: 1;
}

.json-token.mode-compact .form-input,
.json-token.mode-compact .repr-overlay-wrapper > .form-input {
    border: none;
    background: transparent;
    padding: 0.1rem 0.2rem;
    font-size: 0.85rem;
    font-family: 'SF Mono', 'Cascadia Code', 'Fira Code', 'Consolas', monospace;
    color: var(--token-color);
    min-width: 4rem;
}

.json-token.mode-compact .form-input:focus,
.json-token.mode-compact .repr-overlay-wrapper > .form-input:focus {
    outline: none;
    box-shadow: none;
    background: rgba(255, 255, 255, 0.03);
}

.json-token.mode-compact .form-input::placeholder {
    color: var(--token-color);
    opacity: 0.3;
}

.json-token.mode-compact[data-role="type"] .token-control select {
    border: none;
    background: transparent;
    color: var(--token-color);
    font-family: 'SF Mono', 'Cascadia Code', 'Fira Code', 'Consolas', monospace;
    font-size: 0.85rem;
    padding: 0.1rem 0.2rem;
}

.json-token.mode-detailed .json-separator {
    padding: 0 0.1rem;
    align-self: flex-end;
    padding-bottom: 0.2rem;
    font-size: 0.9rem;
}


/* ══════════════════════════════════════════════════════════════
   COMPACT MODE — Full-width command line
   Any top-level Compact token (direct child of .json-component-row)
   renders as a boxed full-width command-line input, regardless of
   role. Nested Compact tokens (inside a Detailed parent) keep the
   bare underlined look defined above.
   ══════════════════════════════════════════════════════════════ */

.json-component-row > .json-token.mode-compact {
    gap: 0.25rem;
    border-bottom: none;
    padding-bottom: 0;
}

.json-component-row > .json-token.mode-compact .form-input,
.json-component-row > .json-token.mode-compact .repr-overlay-wrapper > .form-input {
    flex: 1;
    width: 100%;
    font-size: 1.05rem;
    letter-spacing: 0.01em;
    padding: 0.65rem 0.9rem;
    background: var(--cpd-dark, #061221);
    border: 1px solid var(--token-border);
    border-radius: 6px;
    color: var(--cpd-light);
    font-family: 'SF Mono', 'Cascadia Code', 'Fira Code', 'Consolas', monospace;
    min-width: 0;
}

.json-component-row > .json-token.mode-compact .form-input:focus,
.json-component-row > .json-token.mode-compact .repr-overlay-wrapper > .form-input:focus {
    border-color: var(--token-color);
    box-shadow: 0 0 0 2px rgba(246, 212, 107, 0.1);
    background: var(--cpd-dark, #061221);
}
