/* Shared form controls and helpers. */

.password-policy-title {
    margin-bottom: 0.65rem;
    color: var(--app-text);
    font-size: 0.75rem;
    line-height: 1.2;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.password-policy-list {
    padding-left: 0;
    list-style: none;
}

.password-policy-item {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    color: var(--app-muted);
    font-size: 0.82rem;
    line-height: 1.2;
}

.password-policy-item + .password-policy-item {
    margin-top: 0.3rem;
}

.password-policy-indicator {
    flex: 0 0 auto;
    width: 0.8rem;
    height: 0.8rem;
    border: 2px solid currentColor;
    border-radius: 999px;
    opacity: 0.65;
}

.password-policy-item.is-met {
    color: #1f7a49;
}

.password-policy-item.is-met .password-policy-indicator {
    background: currentColor;
    border-color: currentColor;
    opacity: 1;
}

.password-policy-item.is-unmet {
    color: var(--app-muted);
}

.password-field {
    position: relative;
}

.password-field .form-control {
    padding-right: 3rem;
}

.form-control::placeholder,
.form-select::placeholder,
textarea.form-control::placeholder {
    color: #8f9baa;
    opacity: 1;
}

body[data-app-theme="dark"] .form-control::placeholder,
body[data-app-theme="dark"] .form-select::placeholder,
body[data-app-theme="dark"] textarea.form-control::placeholder {
    color: #8396b5;
}

textarea {
    resize: none;
}

.password-toggle-btn {
    position: absolute;
    top: 50%;
    right: 0.8rem;
    z-index: 3;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.5rem;
    height: 1.5rem;
    padding: 0;
    background: transparent;
    border: 0;
    color: var(--app-muted);
    transform: translateY(-50%);
    cursor: pointer;
}

.password-toggle-btn:hover,
.password-toggle-btn:focus {
    background: transparent;
    border: 0;
    color: var(--app-primary);
    box-shadow: none;
}

.password-toggle-btn:focus-visible {
    outline: 0;
    color: var(--app-primary);
}

.password-toggle-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.15rem;
    height: 1.15rem;
}

.password-toggle-icon svg {
    width: 100%;
    height: 100%;
    fill: currentColor;
}

.password-toggle-icon i {
    font-size: 1rem;
    line-height: 1;
}

.iti {
    display: block;
    width: 100%;
}

.iti__tel-input {
    width: 100%;
}

.iti .form-control {
    width: 100%;
}

.daterangepicker {
    font-size: 0.82rem;
}

body[data-app-theme="dark"] .daterangepicker {
    background: var(--app-surface);
    border-color: var(--app-border);
    color: var(--app-text);
    box-shadow: var(--app-shadow);
}

body[data-app-theme="dark"] .daterangepicker.openscenter::before,
body[data-app-theme="dark"] .daterangepicker.openscenter::after {
    display: none;
}

body[data-app-theme="dark"] .daterangepicker::before {
    border-bottom-color: var(--app-border);
}

body[data-app-theme="dark"] .daterangepicker::after {
    border-bottom-color: var(--app-surface);
}

body[data-app-theme="dark"] .daterangepicker.drop-up::before {
    border-top-color: var(--app-border);
}

body[data-app-theme="dark"] .daterangepicker.drop-up::after {
    border-top-color: var(--app-surface);
}

body[data-app-theme="dark"] .daterangepicker .drp-calendar,
body[data-app-theme="dark"] .daterangepicker .calendar-table,
body[data-app-theme="dark"] .daterangepicker .calendar-table table,
body[data-app-theme="dark"] .daterangepicker .ranges,
body[data-app-theme="dark"] .daterangepicker .drp-buttons {
    background: var(--app-surface);
    color: var(--app-text);
    border-color: var(--app-border);
}

body[data-app-theme="dark"] .daterangepicker .calendar-table th,
body[data-app-theme="dark"] .daterangepicker .calendar-table td,
body[data-app-theme="dark"] .daterangepicker .drp-selected,
body[data-app-theme="dark"] .daterangepicker .ranges li {
    color: var(--app-text);
}

body[data-app-theme="dark"] .daterangepicker td.off,
body[data-app-theme="dark"] .daterangepicker td.disabled,
body[data-app-theme="dark"] .daterangepicker option.disabled,
body[data-app-theme="dark"] .daterangepicker .drp-selected {
    background: var(--app-surface);
    border-color: transparent;
    color: var(--app-muted);
}

body[data-app-theme="dark"] .daterangepicker td.available:hover,
body[data-app-theme="dark"] .daterangepicker th.available:hover,
body[data-app-theme="dark"] .daterangepicker .ranges li:hover {
    background: var(--app-surface-alt);
    color: var(--app-text);
}

body[data-app-theme="dark"] .daterangepicker td.active,
body[data-app-theme="dark"] .daterangepicker td.active:hover,
body[data-app-theme="dark"] .daterangepicker .ranges li.active {
    background: var(--app-primary);
    border-color: transparent;
    color: #0f1724;
    box-shadow: none;
}

body[data-app-theme="dark"] .daterangepicker select.monthselect,
body[data-app-theme="dark"] .daterangepicker select.yearselect {
    background: var(--app-surface-alt);
    color: var(--app-text);
    border: 1px solid var(--app-border);
}

