/* =============================================================
   np-forms — Shared Form Input Component Styles (Desktop)
   Used on: Kundali, Panchang, Match-Making, and all form pages
   ============================================================= */

/* ── Field wrapper ──────────────────────────────────────────── */
.np-field {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

/* ── Label ──────────────────────────────────────────────────── */
.np-label {
    font-size: 14px;
    font-weight: 600;
    color: var(--np-text-dark, #3E2723);
    letter-spacing: 0.01em;
}

.np-label .np-required {
    color: var(--np-saffron, #F37420);
    margin-left: 2px;
}

/* ── Text selection — override browser blue ──────────────────── */
.np-field *::selection,
.np-input::selection,
.np-input-group *::selection,
.np-ts .ts-control *::selection {
    background: rgba(243, 116, 32, 0.20);
    color: var(--np-text-dark, #3E2723);
}

/* ── Base input ─────────────────────────────────────────────── */
.np-input {
    width: 100%;
    height: 46px;
    padding: 0 14px;
    font-size: 15px;
    font-family: var(--np-font, 'Noto Sans', sans-serif);
    color: var(--np-text-dark, #3E2723);
    background: #fff;
    border: 1.5px solid #E0D5CC;
    border-radius: 10px;
    outline: none;
    -webkit-appearance: none;
    appearance: none;
    accent-color: var(--np-saffron, #F37420);
    caret-color: var(--np-saffron, #F37420);
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.np-input::placeholder {
    color: #B0A098;
    font-size: 14px;
}

.np-input:hover {
    border-color: #C8B8AE;
}

.np-input:focus {
    border-color: var(--np-saffron, #F37420);
    box-shadow: 0 0 0 3px rgba(243, 116, 32, 0.12);
}

/* ── Textarea ───────────────────────────────────────────────── */
textarea.np-input,
.np-textarea {
    height: auto;
    min-height: 100px;
    padding: 12px 14px;
    resize: vertical;
    line-height: 1.6;
}

/* ── States ─────────────────────────────────────────────────── */
.np-input.is-error,
.np-input.is-error:focus {
    border-color: #E53935;
    box-shadow: 0 0 0 3px rgba(229, 57, 53, 0.10);
}

.np-input.is-success,
.np-input.is-success:focus {
    border-color: #43A047;
    box-shadow: 0 0 0 3px rgba(67, 160, 71, 0.10);
}

.np-input:disabled {
    background: #F5F0EC;
    border-color: #E0D5CC;
    color: #B0A098;
    cursor: not-allowed;
}

/* ── Helper / error / success text ─────────────────────────── */
.np-helper {
    font-size: 12px;
    color: var(--np-text-mid, #6B5B4F);
    margin-top: 2px;
    line-height: 1.4;
}

.np-error-text {
    font-size: 12px;
    color: #E53935;
    margin-top: 2px;
}

.np-success-text {
    font-size: 12px;
    color: #43A047;
    margin-top: 2px;
}

/* ── Input group (input + button side by side) ────────────── */
.np-input-group {
    display: flex;
    align-items: stretch;
    gap: 0;
    border: 1.5px solid #E0D5CC;
    border-radius: 10px;
    /* No overflow:hidden — it clips the country-code picker dropdown */
    position: relative;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    background: #fff;
}

.np-input-group:hover {
    border-color: #C8B8AE;
}

.np-input-group:focus-within {
    border-color: var(--np-saffron, #F37420);
    box-shadow: 0 0 0 3px rgba(243, 116, 32, 0.12);
}

.np-input-group.is-error {
    border-color: #E53935;
    box-shadow: 0 0 0 3px rgba(229, 57, 53, 0.10);
}

/* The picker must escape overflow — ensure visibility */
.np-input-group .np-cc-picker {
    overflow: visible;
}

.np-input-group .np-cc-picker__trigger {
    border-radius: 8px 0 0 8px !important;
}

.np-input-group__btn:last-child {
    border-radius: 0 8px 8px 0;
}

/* Clip button corners to match container radius */
.np-input-group>*:first-child {
    border-radius: 8px 0 0 8px;
}

.np-input-group>*:last-child {
    border-radius: 0 8px 8px 0;
}

/* But picker dropdown must escape — reset its own radius */
.np-input-group .np-cc-picker {
    overflow: visible;
    border-radius: 8px 0 0 8px;
}

.np-input-group .np-cc-picker__dropdown {
    border-radius: 12px;
}

.np-input-group .np-input {
    flex: 1;
    border: none;
    border-radius: 0;
    box-shadow: none;
    height: 46px;
    background: transparent;
    font-size: 15px;
}

.np-input-group .np-input:focus {
    border: none;
    box-shadow: none;
}

/* Filled (solid) group button */
.np-input-group__btn {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 0 18px;
    font-size: 14px;
    font-weight: 600;
    border: none;
    border-left: 1.5px solid #E0D5CC;
    cursor: pointer;
    white-space: nowrap;
    transition: background 0.2s ease, opacity 0.2s ease;
    background: var(--np-saffron, #F37420);
    color: #fff;
}

.np-input-group__btn:hover {
    background: var(--np-saffron-dark, #e05515);
}

.np-input-group__btn:active {
    opacity: 0.85;
}

/* Outlined group button */
.np-input-group__btn--outline {
    background: transparent;
    color: var(--np-saffron, #F37420);
    border-left: 1.5px solid #E0D5CC;
}

.np-input-group__btn--outline:hover {
    background: rgba(243, 116, 32, 0.06);
}

/* Ghost/text-only group button */
.np-input-group__btn--ghost {
    background: transparent;
    color: var(--np-text-mid, #6B5B4F);
    font-weight: 500;
    border-left: 1.5px solid #E0D5CC;
}

.np-input-group__btn--ghost:hover {
    background: #F5F0EC;
}

/* btn_color modifiers — override the default saffron fill */
.np-input-group__btn--green {
    background: var(--np-green, #059669) !important;
    color: #fff !important;
}

.np-input-group__btn--green:hover {
    background: #047857 !important;
}

.np-input-group__btn--green:active {
    background: #065f46 !important;
}

.np-input-group__btn--dark {
    background: var(--np-text-dark, #3E2723) !important;
    color: #fff !important;
}

.np-input-group__btn--white {
    background: #fff !important;
    color: var(--np-saffron, #F37420) !important;
}

/* ── Custom select (.np-cs) ──────────────────────────────────── */
.np-cs {
    position: relative;
    width: 100%;
    height: 46px;
    background: #fff;
    border: 1.5px solid #E0D5CC;
    border-radius: 10px;
    cursor: pointer;
    user-select: none;
    outline: none;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    color: var(--np-text-dark, #3E2723);
    font-family: var(--np-font, 'Noto Sans', sans-serif);
}

.np-cs:hover {
    border-color: #C8B8AE;
}

.np-cs:focus,
.np-cs.is-open {
    border-color: var(--np-saffron, #F37420);
    box-shadow: 0 0 0 3px rgba(243, 116, 32, 0.12);
}

.np-cs__trigger {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 14px;
    height: 100%;
    gap: 8px;
}

.np-cs__text {
    font-size: 15px;
    color: var(--np-text-dark, #3E2723);
    flex: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.np-cs__text.is-placeholder {
    color: #B0A098;
    font-size: 14px;
}

.np-cs__arrow {
    flex-shrink: 0;
    color: #B0A098;
    transition: transform 0.2s ease, color 0.2s ease;
}

.np-cs.is-open .np-cs__arrow {
    transform: rotate(180deg);
    color: var(--np-saffron, #F37420);
}

.np-cs__list {
    display: none;
    position: absolute;
    top: calc(100% + 4px);
    left: -1.5px;
    right: -1.5px;
    z-index: 1050;
    background: #fff;
    border: 1.5px solid var(--np-saffron, #F37420);
    border-radius: 10px;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.10);
    list-style: none;
    padding: 4px 0;
    margin: 0;
    max-height: 240px;
    overflow-y: auto;
}

.np-cs.is-open .np-cs__list {
    display: block;
}

.np-cs__option {
    padding: 10px 14px;
    font-size: 14px;
    color: var(--np-text-dark, #3E2723);
    cursor: pointer;
    transition: background 0.15s, color 0.15s;
}

.np-cs__option:hover,
.np-cs__option.is-focused {
    background: var(--np-bg-cream, #FFF8F0);
    color: var(--np-saffron, #F37420);
}

.np-cs__option.is-selected {
    background: rgba(243, 116, 32, 0.08);
    color: var(--np-text-dark, #3E2723);
    font-weight: 600;
}

.np-cs__option.is-selected.is-focused {
    background: rgba(243, 116, 32, 0.14);
    color: var(--np-saffron, #F37420);
}

/* ── Native select (kept for fallback pages) ─────────────────── */
.np-select-native {
    width: 100%;
    height: 46px;
    padding: 0 38px 0 14px;
    font-size: 15px;
    font-family: var(--np-font, 'Noto Sans', sans-serif);
    color: var(--np-text-dark, #3E2723);
    background: #fff 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 1l5 5 5-5' stroke='%23B0A098' stroke-width='1.8' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat right 14px center;
    border: 1.5px solid #E0D5CC;
    border-radius: 10px;
    outline: none;
    cursor: pointer;
    -webkit-appearance: none;
    appearance: none;
    accent-color: var(--np-saffron, #F37420);
    color-scheme: light;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.np-select-native:hover {
    border-color: #C8B8AE;
}

.np-select-native:focus {
    border-color: var(--np-saffron, #F37420);
    box-shadow: 0 0 0 3px rgba(243, 116, 32, 0.12);
}

/* ── Phone group (country code + input) ─────────────────────── */
.np-phone-group {
    display: flex;
    align-items: stretch;
    border: 1.5px solid #E0D5CC;
    border-radius: 12px;
    /* No overflow:hidden — clips the picker dropdown */
    background: #fff;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    position: relative;
}

.np-phone-group:focus-within {
    border-color: var(--np-saffron, #F37420);
    box-shadow: 0 0 0 3px rgba(243, 116, 32, 0.12);
}

/* Allow picker dropdown to escape container */
.np-phone-group .np-cc-picker {
    overflow: visible;
}

.np-phone-group .np-cc-picker__trigger {
    border-radius: 10px 0 0 10px;
}

.np-input--phone {
    border: none !important;
    border-radius: 0 10px 10px 0 !important;
    box-shadow: none !important;
    flex: 1;
    min-width: 0;
}

/* ── Custom country-code picker (.np-cc-picker) ──────────── */
/* Trigger button */
.np-cc-picker {
    position: relative;
    flex-shrink: 0;
}

.np-cc-picker__trigger {
    display: flex;
    align-items: center;
    gap: 4px;
    height: 46px;
    padding: 0 10px 0 12px;
    background: var(--np-bg-cream, #FFF8F0);
    border: none;
    border-right: 1.5px solid #E0D5CC;
    cursor: pointer;
    font-size: 14px;
    font-family: var(--np-font, 'Noto Sans', sans-serif);
    font-weight: 500;
    color: var(--np-text-dark, #3E2723);
    white-space: nowrap;
    transition: background 0.15s ease;
    -webkit-tap-highlight-color: transparent;
}

.np-cc-picker__trigger:hover {
    background: #F0E8E0;
}

.np-cc-picker__trigger svg {
    opacity: 0.55;
    transition: transform 0.2s ease;
}

.np-cc-picker.is-open .np-cc-picker__trigger svg {
    transform: rotate(180deg);
    opacity: 0.9;
}

/* Dropdown panel */
.np-cc-picker__dropdown {
    display: none;
    position: absolute;
    top: calc(100% + 6px);
    left: -1px;
    z-index: 1200;
    background: #fff;
    border: 1.5px solid var(--np-saffron, #F37420);
    border-radius: 12px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.13);
    min-width: 200px;
    overflow: hidden;
}

.np-cc-picker.is-open .np-cc-picker__dropdown {
    display: block;
}

/* Search box */
.np-cc-picker__search-wrap {
    padding: 8px 10px;
    border-bottom: 1px solid #F0E8E0;
}

.np-cc-picker__search {
    width: 100%;
    height: 34px;
    padding: 0 10px;
    font-size: 13px;
    font-family: var(--np-font, 'Noto Sans', sans-serif);
    border: 1.5px solid #E0D5CC;
    border-radius: 8px;
    outline: none;
    background: #FFFBF5;
    color: var(--np-text-dark, #3E2723);
    caret-color: var(--np-saffron, #F37420);
    box-sizing: border-box;
}

.np-cc-picker__search:focus {
    border-color: var(--np-saffron, #F37420);
}

/* Options list */
.np-cc-picker__list {
    list-style: none;
    margin: 0;
    padding: 4px 0;
    max-height: 220px;
    overflow-y: auto;
}

.np-cc-picker__option {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 9px 14px;
    font-size: 14px;
    color: var(--np-text-dark, #3E2723);
    cursor: pointer;
    transition: background 0.12s;
}

.np-cc-picker__option:hover {
    background: var(--np-bg-cream, #FFF8F0);
}

.np-cc-picker__option.is-selected {
    background: rgba(243, 116, 32, 0.08);
    font-weight: 600;
    color: var(--np-saffron, #F37420);
}

.np-cc-picker__option-flag {
    font-size: 18px;
    line-height: 1;
}

.np-cc-picker__option-name {
    flex: 1;
    font-size: 13px;
    color: var(--np-text-mid, #6B5B4F);
}

.np-cc-picker__option-code {
    font-weight: 600;
    color: var(--np-saffron, #F37420);
    font-size: 13px;
}

/* Hidden native input (value carrier) */
.np-cc-picker input[type="hidden"] {
    display: none;
}

/* When picker is inside .np-phone-group or .np-input-group */
.np-phone-group .np-cc-picker__trigger,
.np-input-group .np-cc-picker__trigger {
    border-radius: 0;
}


/* ── Time input (Flatpickr) ─────────────────────────────────── */
/* Use both selectors — .flatpickr-input.np-input would otherwise win */
.np-time-input,
.flatpickr-input.np-time-input {
    cursor: pointer;
    background: #fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none'%3E%3Ccircle cx='12' cy='12' r='9' stroke='%23B0A098' stroke-width='1.8'/%3E%3Cpath d='M12 7v5l3 3' stroke='%23B0A098' stroke-width='1.8' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat right 14px center !important;
    padding-right: 38px !important;
}

/* Flatpickr time-only widget overrides */
.flatpickr-calendar.hasTime.noCalendar {
    border: 1.5px solid var(--np-saffron, #F37420) !important;
    border-radius: 12px !important;
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.12) !important;
    padding: 16px !important;
    width: auto !important;
    min-width: 200px;
}

.flatpickr-time {
    border: none !important;
    height: auto !important;
    overflow: visible !important;
    max-height: none !important;
}

.flatpickr-time input,
.flatpickr-time .flatpickr-am-pm {
    font-family: var(--np-font, 'Noto Sans', sans-serif) !important;
    font-size: 22px !important;
    font-weight: 600 !important;
    color: var(--np-text-dark, #3E2723) !important;
    background: var(--np-bg-cream, #FFF8F0) !important;
    border-radius: 8px !important;
    border: 1.5px solid #E0D5CC !important;
    height: 48px !important;
}

.flatpickr-time .flatpickr-am-pm {
    min-width: 52px !important;
    text-align: center !important;
    font-size: 16px !important;
}

.flatpickr-time input:focus,
.flatpickr-time .flatpickr-am-pm:focus,
.flatpickr-time input:hover,
.flatpickr-time .flatpickr-am-pm:hover {
    background: rgba(243, 116, 32, 0.06) !important;
    border-color: var(--np-saffron, #F37420) !important;
    color: var(--np-saffron, #F37420) !important;
}

.flatpickr-time .numInputWrapper span.arrowUp:after {
    border-bottom-color: var(--np-saffron, #F37420) !important;
}

.flatpickr-time .numInputWrapper span.arrowDown:after {
    border-top-color: var(--np-saffron, #F37420) !important;
}

/* ── Flatpickr date-picker overrides ────────────────────────── */
.flatpickr-input.np-input {
    cursor: pointer;
    background: #fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none'%3E%3Crect x='3' y='4' width='18' height='18' rx='3' stroke='%23B0A098' stroke-width='1.8'/%3E%3Cpath d='M3 9h18M8 2v4M16 2v4' stroke='%23B0A098' stroke-width='1.8' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat right 14px center;
    padding-right: 38px;
}

.flatpickr-calendar {
    border: 1px solid #E0D5CC !important;
    border-radius: 14px !important;
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.12) !important;
    font-family: var(--np-font, 'Noto Sans', sans-serif) !important;
}

.flatpickr-day.selected,
.flatpickr-day.selected:hover {
    background: var(--np-saffron, #F37420) !important;
    border-color: var(--np-saffron, #F37420) !important;
}

.flatpickr-day:hover {
    background: var(--np-bg-cream, #FFF8F0) !important;
    border-color: transparent !important;
}

.flatpickr-day.today {
    border-color: var(--np-saffron, #F37420) !important;
}

.flatpickr-months .flatpickr-month,
.flatpickr-weekdays {
    background: var(--np-bg-cream, #FFF8F0) !important;
}

.flatpickr-prev-month,
.flatpickr-next-month {
    fill: var(--np-saffron, #F37420) !important;
}

/* ── Tom Select overrides ────────────────────────────────────── */
.ts-wrapper.np-ts {
    --ts-border-radius: 10px;
    --ts-border-color: #E0D5CC;
    --ts-font-size: 15px;
    --ts-color: var(--np-text-dark, #3E2723);
}

.np-ts .ts-control {
    min-height: 46px;
    padding: 0 14px;
    border: 1.5px solid #E0D5CC;
    border-radius: 10px;
    background: #fff;
    box-shadow: none;
    font-size: 15px;
    color: var(--np-text-dark, #3E2723);
    display: flex;
    align-items: center;
    cursor: pointer;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.np-ts .ts-control:hover {
    border-color: #C8B8AE;
}

.np-ts.focus .ts-control {
    border-color: var(--np-saffron, #F37420) !important;
    box-shadow: 0 0 0 3px rgba(243, 116, 32, 0.12) !important;
}

.np-ts .ts-control input {
    font-size: 15px;
    color: var(--np-text-dark, #3E2723);
}

.np-ts .ts-control input::placeholder {
    color: #B0A098;
}

.np-ts .ts-dropdown {
    border: 1.5px solid #E0D5CC;
    border-radius: 10px;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.10);
    margin-top: 4px;
    overflow: hidden;
}

.np-ts .ts-dropdown .option {
    padding: 10px 14px;
    font-size: 14px;
    color: var(--np-text-dark, #3E2723);
    cursor: pointer;
    transition: background 0.15s;
}

.np-opt:hover,
.np-opt.active {
    background: var(--np-bg-cream, #FFF8F0);
    color: var(--np-saffron, #F37420);
}

.np-opt.selected {
    background: rgba(243, 116, 32, 0.08);
    color: var(--np-text-dark, #3E2723);
    font-weight: 600;
}

.np-opt.active.selected {
    background: rgba(243, 116, 32, 0.14);
    color: var(--np-saffron, #F37420);
}

.np-ts .ts-dropdown-content {
    max-height: 240px;
}

/* ── Autocomplete dropdown (city search) ────────────────────── */
.np-autocomplete-list {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    z-index: 1000;
    background: #fff;
    border: 1.5px solid #E0D5CC;
    border-top: none;
    border-radius: 0 0 10px 10px;
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.10);
    max-height: 240px;
    overflow-y: auto;
    list-style: none;
    padding: 4px 0;
    margin: 0;
}

.np-autocomplete-list li {
    padding: 10px 14px;
    font-size: 14px;
    color: var(--np-text-dark, #3E2723);
    cursor: pointer;
    transition: background 0.15s;
    border-bottom: 1px solid #F5F0EC;
}

.np-autocomplete-list li:last-child {
    border-bottom: none;
}

.np-autocomplete-list li:hover {
    background: var(--np-bg-cream, #FFF8F0);
    color: var(--np-saffron, #F37420);
}

/* ── Form card wrapper ──────────────────────────────────────── */
.np-form-card {
    background: var(--np-bg-light, #FFFBF5);
    border: 1px solid #F3D8B0;
    border-radius: 16px;
    padding: 32px 28px;
    box-shadow: 0 10px 30px rgba(218, 165, 32, 0.08);
}

/* ── Submit button ──────────────────────────────────────────── */
.np-submit-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 13px 36px;
    font-size: 16px;
    font-weight: 700;
    font-family: var(--np-font, 'Noto Sans', sans-serif);
    color: #fff;
    background: var(--np-grad-btn, linear-gradient(135deg, #b5310a 0%, #e05515 50%, #f7971e 100%));
    border: none;
    border-radius: 50px;
    cursor: pointer;
    box-shadow: 0 6px 20px rgba(243, 116, 32, 0.30);
    transition: transform 0.2s ease, box-shadow 0.2s ease, opacity 0.2s ease;
}

.np-submit-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 8px 28px rgba(243, 116, 32, 0.38);
}

.np-submit-btn:active {
    transform: translateY(0);
    box-shadow: 0 4px 14px rgba(243, 116, 32, 0.28);
}

.np-submit-btn:disabled {
    opacity: 0.55;
    cursor: not-allowed;
    transform: none;
    box-shadow: none;
}

.np-select-native option:checked,
.np-select-native option:hover {
    background-color: var(--np-saffron) !important;
    color: #fff !important;

}

.np-select-native:focus {
    outline: none;
    border-color: var(--np-saffron);
    box-shadow: none;
}