/**
 * Talentrush public styles (simple + theme-friendly).
 * Only global UI controls live here: labels, inputs, selects, buttons, choice lists.
 * Component-specific layout belongs in component css files.
 */

:root {
    --tr-primary: #0ea5e9;
    --tr-secondary: #0f172a;
    --tr-surface: #f8f9f8;
    --tr-hero-text: #0f172a;
    --tr-on-primary: #ffffff;

    --tr-border: rgba(15, 23, 42, 0.18);
    --tr-text: rgba(15, 23, 42, 0.92);
    --tr-muted: rgba(15, 23, 42, 0.60);

    --tr-radius: 10px;
    --tr-gap: 12px;

    --tr-control-height: 44px;
    --tr-control-padding-x: 12px;
    --tr-control-padding-y: 10px;

    --tr-label-font-size: 14px;
    --tr-label-line-height: 1.2;
    --tr-label-margin-bottom: 6px;
    --tr-label-block: 22px;

    --tr-shadow-focus: 0 0 0 1px color-mix(in srgb, var(--tr-primary) 22%, transparent);
}

/* Keep viewport width stable when content height changes between pages/states. */
html {
    scrollbar-gutter: stable;
}

/* -------------------------------------------------------------------------
 * Labels
 * ---------------------------------------------------------------------- */

.tr-ui .tr-label {
    display: block;
    font-size: var(--tr-label-font-size);
    line-height: var(--tr-label-line-height);
    font-weight: 600;
    color: var(--tr-secondary);
    opacity: 0.98;
    margin: 0 0 var(--tr-label-margin-bottom);
}

.tr-ui .tr-label--sr {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* -------------------------------------------------------------------------
 * Inputs / selects
 * ---------------------------------------------------------------------- */

.tr-ui .tr-input,
.tr-ui .tr-select {
    width: 100%;
    box-sizing: border-box;

    height: var(--tr-control-height);
    border: 1px solid var(--tr-border);
    border-radius: var(--tr-radius);

    padding: var(--tr-control-padding-y) var(--tr-control-padding-x);
    background: #fff;
    color: var(--tr-text);

    font: inherit;
    line-height: 1.2;

    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.tr-ui .tr-input::placeholder {
    color: color-mix(in srgb, var(--tr-secondary) 45%, transparent);
    opacity: 1;
}

.tr-ui .tr-input:focus,
.tr-ui .tr-select:focus,
.tr-ui .tr-input:focus-visible,
.tr-ui .tr-select:focus-visible {
    outline: none;
    border-color: var(--tr-border);
    box-shadow: var(--tr-shadow-focus);
}

/* Search input cleanup */
.tr-ui .tr-input[type="search"]::-webkit-search-decoration,
.tr-ui .tr-input[type="search"]::-webkit-search-cancel-button,
.tr-ui .tr-input[type="search"]::-webkit-search-results-button,
.tr-ui .tr-input[type="search"]::-webkit-search-results-decoration {
    -webkit-appearance: none;
}

/* Select */
.tr-ui .tr-select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    padding-right: 46px;
    background-color: #fff;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1.25 6 6.25 11 1.25' stroke='%230f172a' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 16px center;
    background-size: 12px 8px;
}

.tr-ui .tr-select option {
    color: var(--tr-text);
    background: #fff;
}

/* -------------------------------------------------------------------------
 * Buttons
 * ---------------------------------------------------------------------- */

.tr-ui .tr-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    -webkit-appearance: none;
    appearance: none;
    -webkit-tap-highlight-color: transparent;

    height: var(--tr-control-height);
    border: 1px solid var(--tr-primary);
    border-radius: var(--tr-radius);
    padding: 0 16px;

    cursor: pointer !important;

    font: inherit;
    font-weight: 600;
    line-height: 1;
    text-decoration: none;
    white-space: nowrap;

    background: var(--tr-primary);
    color: var(--tr-on-primary);

    background-image: none;
    box-shadow: none;

    transition: filter 0.15s ease, box-shadow 0.15s ease, transform 0.05s ease, opacity 0.15s ease;

    gap: 4px;
}

.tr-ui a.tr-button:link,
.tr-ui a.tr-button:visited {
    color: var(--tr-on-primary) !important;
    text-decoration: none !important;
}

.tr-ui button.tr-button:hover,
.tr-ui a.tr-button:hover {
    background: var(--tr-primary) !important;
    border-color: var(--tr-primary) !important;
    color: var(--tr-on-primary) !important;
    background-image: none !important;
    filter: brightness(0.92);
}

.tr-ui .tr-button:focus,
.tr-ui .tr-button:focus-visible {
    outline: none !important;
    box-shadow: var(--tr-shadow-focus);
}

.tr-ui button.tr-button:active,
.tr-ui a.tr-button:active,
.tr-ui button.tr-button:hover:active,
.tr-ui a.tr-button:hover:active {
    background: var(--tr-primary) !important;
    border-color: var(--tr-primary) !important;
    color: var(--tr-on-primary) !important;
    background-image: none !important;
    filter: brightness(0.88);
    transform: translateY(1px);
}

.tr-ui button.tr-button,
.tr-ui button.tr-button:hover,
.tr-ui button.tr-button:focus,
.tr-ui button.tr-button:focus-visible,
.tr-ui button.tr-button:active {
    background-image: none !important;
}

.tr-ui .tr-button:disabled,
.tr-ui .tr-button[aria-disabled="true"] {
    opacity: 0.55;
    cursor: not-allowed !important;
    filter: none;
    transform: none;
}

.tr-ui a.tr-button[aria-disabled="true"] {
    pointer-events: none;
}

/* Secondary button */
.tr-ui .tr-button--secondary {
    background: transparent;
    border-color: var(--tr-border);
    color: var(--tr-secondary);
    background-image: none;
}

.tr-ui a.tr-button--secondary:link,
.tr-ui a.tr-button--secondary:visited {
    color: var(--tr-secondary) !important;
    text-decoration: none !important;
}

.tr-ui button.tr-button--secondary:hover,
.tr-ui a.tr-button--secondary:hover {
    background: color-mix(in srgb, var(--tr-secondary) 6%, transparent) !important;
    border-color: var(--tr-border) !important;
    color: var(--tr-secondary) !important;
    background-image: none !important;
    filter: none;
}

.tr-ui button.tr-button--secondary:active,
.tr-ui a.tr-button--secondary:active,
.tr-ui button.tr-button--secondary:hover:active,
.tr-ui a.tr-button--secondary:hover:active {
    background: color-mix(in srgb, var(--tr-secondary) 10%, transparent) !important;
    border-color: var(--tr-border) !important;
    color: var(--tr-secondary) !important;
    filter: none;
    transform: translateY(1px);
}

/* -------------------------------------------------------------------------
 * Choice lists (checkbox/radio)
 * ---------------------------------------------------------------------- */

.tr-ui .tr-choices {
    display: grid;
    gap: 8px;
}

.tr-ui .tr-choice {
    display: flex;
    align-items: center;
    gap: 10px;

    padding: 10px 12px;
    border: 1px solid var(--tr-border);
    border-radius: var(--tr-radius);
    background: #fff;

    color: var(--tr-text);
}

.tr-ui .tr-choice input {
    width: 18px;
    height: 18px;
    margin: 0;
}

.tr-ui .tr-choice:hover {
    background: color-mix(in srgb, var(--tr-secondary) 4%, transparent);
}

.tr-ui .tr-choice input:focus,
.tr-ui .tr-choice input:focus-visible {
    outline: none;
    box-shadow: var(--tr-shadow-focus);
}

/* -------------------------------------------------------------------------
 * Control wrapper (generic, reusable in any component)
 * ---------------------------------------------------------------------- */

.tr-ui .tr-control {
    display: block;
}

.tr-ui .tr-control--choices {
    border: 0;
    padding: 0;
    margin: 0;
}

.tr-ui .tr-control--range .tr-control__range {
    /* layout is component-specific; but keep safe fallback */
    display: grid;
    gap: var(--tr-gap);
}

/* -------------------------------------------------------------------------
 * Notices
 * ---------------------------------------------------------------------- */

.tr-ui .talentrush-notice {
    border-radius: 12px;
    border: 1px solid color-mix(in srgb, var(--tr-secondary) 14%, transparent);
    background: color-mix(in srgb, var(--tr-secondary) 3%, #ffffff);
    color: color-mix(in srgb, var(--tr-secondary) 88%, transparent);
    padding: 12px 14px;
    margin: 0 0 14px;
    font-size: 14px;
    line-height: 1.5;
}

.tr-ui .talentrush-notice__list {
    margin: 0;
    padding-left: 18px;
}

.tr-ui .talentrush-notice__single {
    margin: 0;
}

.tr-ui .talentrush-notice--error {
    border-color: color-mix(in srgb, #dc2626 36%, transparent);
    background: color-mix(in srgb, #dc2626 8%, #ffffff);
    color: color-mix(in srgb, #7f1d1d 84%, #000000);
}

.tr-ui .talentrush-notice--success {
    border-color: color-mix(in srgb, var(--tr-primary) 42%, transparent);
    background: color-mix(in srgb, var(--tr-primary) 10%, #ffffff);
    color: color-mix(in srgb, var(--tr-secondary) 92%, #000000);
}

/* Shared summary labels on vacancy/apply pages (kept identical by design). */
.tr-ui .tr-vacancy-page__summary-label,
.tr-ui .tr-apply-page__summary-label {
    margin: 0 0 3px;
    font-size: 14px;
    line-height: 1.2;
    font-weight: 700;
    color: var(--tr-secondary);
}

.tr-ui .tr-separator-dot {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 0.82em;
    margin-inline: 0.28em;
    line-height: 1;
    vertical-align: middle;
    flex: 0 0 auto;
}

.tr-ui .tr-separator-dot::before {
    content: "";
    width: 0.34em;
    height: 0.34em;
    border-radius: 999px;
    background: color-mix(in srgb, currentColor 86%, transparent);
}

/* -------------------------------------------------------------------------
 * Legacy form compatibility (application shortcodes)
 * ---------------------------------------------------------------------- */

.tr-ui .tr-input--textarea,
.tr-ui .talentrush-textarea {
    min-height: 120px;
    height: auto;
    resize: vertical;
    padding-block: 10px;
}

.tr-ui .talentrush-actions {
    margin-top: 12px;
}
