/* ════════════════════════════════════════════════════════════════════
   Bachpan.com — User preferences modal + profile bar.
   Mirrors Mock HTML/bachpan-preferences.html.
   Relies on the global :root design tokens defined in bachpan-design-system.css.
   ════════════════════════════════════════════════════════════════════ */

/* ── Profile preferences card (logged-in /account/preferences) ─────── */
.bp-pref-section { background: var(--bp-surface); border: 1px solid var(--bp-border); border-radius: var(--r-lg); padding: 1.1rem 1.35rem; margin-bottom: 1rem; box-shadow: var(--shadow-sm); }
.bp-pref-section__header { display: flex; align-items: center; justify-content: space-between; margin-bottom: .85rem; padding-bottom: .7rem; border-bottom: 1px solid var(--bp-border); }
.bp-pref-section__title { font-size: .88rem; font-weight: 700; display: flex; align-items: center; gap: .42rem; }
.bp-pref-section__title svg { width: 15px; height: 15px; color: var(--bp-nav); }
.bp-pref-section__edit { display: inline-flex; align-items: center; gap: .28rem; font-size: .72rem; font-weight: 600; color: var(--bp-nav); cursor: pointer; border: 1.5px solid var(--bp-accent-md); background: var(--bp-accent-lt); padding: .22rem .65rem; border-radius: var(--r-full); transition: all .15s; }
.bp-pref-section__edit:hover { background: var(--bp-nav); color: #fff; border-color: var(--bp-nav); }
.bp-pref-section__edit svg { width: 11px; height: 11px; }

.bp-pref-row { display: flex; align-items: flex-start; gap: .85rem; padding: .55rem 0; border-bottom: 1px solid var(--bp-border); }
.bp-pref-row:last-child { border-bottom: none; }
.bp-pref-row__label { font-size: .72rem; font-weight: 600; color: var(--bp-text-3); min-width: 70px; padding-top: .15rem; }
.bp-pref-row__chips { display: flex; flex-wrap: wrap; gap: .3rem; }

.bp-pref-chip { display: inline-flex; align-items: center; gap: .22rem; padding: .2rem .6rem; border-radius: var(--r-full); font-size: .7rem; font-weight: 600; border: 1px solid; }
.bp-pref-chip--any { background: var(--bp-bg); color: var(--bp-text-2); border-color: var(--bp-border-md); }
.bp-pref-chip--rel-h { background: var(--hindu-lt); color: var(--hindu-text); border-color: var(--hindu-md); }
.bp-pref-chip--rel-m { background: #E4F5ED; color: #0A3D22; border-color: #86D4A8; }
.bp-pref-chip--rel-c { background: #E4EEF8; color: #0A2C58; border-color: #A8C4E8; }
.bp-pref-chip--rel-s { background: #FDF2DF; color: #503A0A; border-color: #D4A85A; }
.bp-pref-chip--rel-j { background: #F0F8F0; color: #164016; border-color: #86C886; }
.bp-pref-chip--rel-b { background: #F5F0FF; color: #3C1599; border-color: #C9B8F5; }
.bp-pref-chip--gen-b { background: var(--bp-boy-lt); color: var(--bp-boy-text); border-color: var(--bp-boy-border); }
.bp-pref-chip--gen-g { background: var(--bp-girl-lt); color: var(--bp-girl-text); border-color: var(--bp-girl-border); }
.bp-pref-chip--lang  { background: var(--bp-rashi-lt); color: var(--bp-rashi); border-color: #C9C4ED; }

/* ── Guest preferences bar (anon visitors) ──────────────────────────── */
.bp-guest-prefs { background: var(--bp-surface); border: 1px solid var(--bp-border); border-radius: var(--r-lg); padding: .85rem 1.1rem; margin-bottom: 1rem; box-shadow: var(--shadow-sm); display: flex; align-items: center; gap: .75rem; flex-wrap: wrap; }
.bp-guest-prefs__icon { color: var(--bp-nav); flex-shrink: 0; }
.bp-guest-prefs__body { flex: 1; min-width: 0; }
.bp-guest-prefs__label { font-size: .72rem; font-weight: 600; color: var(--bp-text-1); margin-bottom: .22rem; }
.bp-guest-prefs__chips { display: flex; flex-wrap: wrap; gap: .28rem; }
.bp-guest-prefs__empty { font-size: .75rem; color: var(--bp-text-3); font-style: italic; }
.bp-guest-prefs__actions { display: flex; gap: .38rem; margin-left: auto; }
.bp-guest-prefs__btn { display: inline-flex; align-items: center; gap: .25rem; height: 32px; padding: 0 .85rem; border-radius: var(--r-full); font-size: .72rem; font-weight: 600; cursor: pointer; transition: all .15s; text-decoration: none; }
.bp-guest-prefs__btn--edit { background: var(--bp-accent-lt); color: var(--bp-nav); border: 1.5px solid var(--bp-accent-md); }
.bp-guest-prefs__btn--edit:hover { background: var(--bp-nav); color: #fff; border-color: var(--bp-nav); }
.bp-guest-prefs__btn--reset { background: transparent; color: var(--bp-text-3); border: 1.5px solid var(--bp-border-md); }
.bp-guest-prefs__btn--reset:hover { border-color: var(--bp-text-2); color: var(--bp-text-2); }
.bp-guest-prefs__btn svg { width: 12px; height: 12px; }

/* ════════════════════════════════════════════════════════════════════
   PREFERENCES MODAL
   ════════════════════════════════════════════════════════════════════ */
.bp-prefmodal { position: fixed; inset: 0; z-index: 900; background: rgba(28,43,58,.55); backdrop-filter: blur(3px); display: none; align-items: center; justify-content: center; padding: 1rem; }
.bp-prefmodal.is-open { display: flex; animation: bpPrefFadeIn .2s ease-out; }
@keyframes bpPrefFadeIn { from { opacity: 0; } to { opacity: 1; } }

.bp-prefmodal__dialog { background: var(--bp-surface); border-radius: var(--r-lg); box-shadow: var(--shadow-lg); width: 100%; max-width: 560px; max-height: 92vh; display: flex; flex-direction: column; animation: bpPrefSlideUp .2s ease-out; }
@keyframes bpPrefSlideUp { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: translateY(0); } }

.bp-prefmodal__head { background: linear-gradient(135deg, #0B3D6E, var(--bp-nav)); padding: 1.35rem 1.5rem 1.1rem; border-radius: var(--r-lg) var(--r-lg) 0 0; position: relative; overflow: hidden; flex-shrink: 0; }
.bp-prefmodal__head::after { content: ''; position: absolute; right: -20px; top: -20px; width: 140px; height: 140px; border-radius: 50%; border: 20px solid rgba(255,255,255,.05); pointer-events: none; }
.bp-prefmodal__eyebrow { font-size: .65rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: rgba(255,255,255,.6); margin-bottom: .35rem; }
.bp-prefmodal__title { font-size: 1.15rem; font-weight: 700; color: #fff; margin-bottom: .3rem; line-height: 1.2; }
.bp-prefmodal__sub { font-size: .76rem; color: rgba(255,255,255,.7); line-height: 1.5; }
.bp-prefmodal__close { position: absolute; top: .85rem; right: .85rem; width: 28px; height: 28px; border-radius: 50%; border: 1.5px solid rgba(255,255,255,.3); background: rgba(255,255,255,.1); display: flex; align-items: center; justify-content: center; cursor: pointer; transition: all .15s; }
.bp-prefmodal__close:hover { background: rgba(255,255,255,.22); }
.bp-prefmodal__close svg { width: 12px; height: 12px; color: #fff; }

.bp-prefmodal__body { flex: 1; overflow-y: auto; padding: 1.25rem 1.5rem .5rem; scrollbar-width: thin; scrollbar-color: var(--bp-border-md) transparent; }
.bp-prefmodal__body::-webkit-scrollbar { width: 4px; }
.bp-prefmodal__body::-webkit-scrollbar-thumb { background: var(--bp-border-md); border-radius: 2px; }

.bp-prefmodal__section { margin-bottom: 1.35rem; }
.bp-prefmodal__section:last-child { margin-bottom: .5rem; }
.bp-prefmodal__section-header { display: flex; align-items: center; gap: .5rem; margin-bottom: .78rem; }
.bp-prefmodal__section-icon { width: 32px; height: 32px; border-radius: var(--r-md); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.bp-prefmodal__section-icon svg { width: 15px; height: 15px; }
.bp-prefmodal__section-icon--rel  { background: var(--hindu-lt);     border: 1px solid var(--hindu-md); color: var(--hindu-text); }
.bp-prefmodal__section-icon--gen  { background: var(--bp-boy-lt);    border: 1px solid var(--bp-boy-border); color: var(--bp-boy); }
.bp-prefmodal__section-icon--lang { background: var(--bp-rashi-lt);  border: 1px solid #C9C4ED;       color: var(--bp-rashi); }
.bp-prefmodal__section-label { font-size: .82rem; font-weight: 700; color: var(--bp-text-1); }
.bp-prefmodal__section-hint  { font-size: .65rem; color: var(--bp-text-3); margin-top: .08rem; }

.bp-prefmodal__any { display: flex; align-items: center; gap: .55rem; padding: .52rem .75rem; border-radius: var(--r-md); border: 1.5px solid var(--bp-border-md); background: var(--bp-bg); cursor: pointer; margin-bottom: .6rem; transition: all .15s; user-select: none; }
.bp-prefmodal__any:hover { border-color: var(--bp-nav); }
.bp-prefmodal__any.is-on { border-color: var(--bp-nav); background: var(--bp-accent-lt); }
.bp-prefmodal__check { width: 18px; height: 18px; border-radius: 4px; border: 1.5px solid var(--bp-border-md); background: var(--bp-surface); display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: all .15s; }
.bp-prefmodal__any.is-on .bp-prefmodal__check { background: var(--bp-nav); border-color: var(--bp-nav); }
.bp-prefmodal__any.is-on .bp-prefmodal__check::after { content: '✓'; font-size: .62rem; color: #fff; font-weight: 700; }
.bp-prefmodal__any-label { font-size: .78rem; font-weight: 600; color: var(--bp-text-2); }
.bp-prefmodal__any.is-on .bp-prefmodal__any-label { color: var(--bp-nav); }
.bp-prefmodal__any-badge { font-size: .6rem; font-weight: 600; padding: .08rem .42rem; border-radius: var(--r-full); background: var(--bp-bg); border: 1px solid var(--bp-border-md); color: var(--bp-text-3); margin-left: .25rem; }
.bp-prefmodal__any-sub { font-size: .65rem; color: var(--bp-text-3); margin-left: auto; }

.bp-prefmodal__or { display: flex; align-items: center; gap: .5rem; font-size: .65rem; font-weight: 600; color: var(--bp-text-3); margin-bottom: .6rem; text-transform: uppercase; letter-spacing: .05em; }
.bp-prefmodal__or::before, .bp-prefmodal__or::after { content: ''; flex: 1; height: 1px; background: var(--bp-border); }

/* ── Religion option grid ── */
.bp-prefmodal__rel-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: .42rem; }
@media (max-width: 400px) { .bp-prefmodal__rel-grid { grid-template-columns: repeat(2, 1fr); } }
.bp-prefmodal__rel { display: flex; align-items: center; gap: .52rem; padding: .58rem .72rem; border-radius: var(--r-md); border: 1.5px solid var(--bp-border-md); background: transparent; cursor: pointer; transition: all .15s; text-align: left; font-family: inherit; }
.bp-prefmodal__rel:hover { border-color: var(--bp-nav); background: var(--bp-accent-lt); }
.bp-prefmodal__rel.is-on { border-color: var(--bp-nav); background: var(--bp-accent-lt); }
.bp-prefmodal__rel-icon { font-size: 1.1rem; flex-shrink: 0; line-height: 1; }
.bp-prefmodal__rel-name { font-size: .73rem; font-weight: 600; color: var(--bp-text-1); display: block; line-height: 1.2; }
.bp-prefmodal__rel[data-r="Hindu"].is-on     { background: var(--hindu-lt); border-color: var(--hindu); }
.bp-prefmodal__rel[data-r="Muslim"].is-on    { background: #E4F5ED; border-color: #1A7A4A; }
.bp-prefmodal__rel[data-r="Christian"].is-on { background: #E4EEF8; border-color: #1A4A8A; }
.bp-prefmodal__rel[data-r="Sikh"].is-on      { background: #FDF2DF; border-color: #8B6914; }
.bp-prefmodal__rel[data-r="Jain"].is-on      { background: #F0F8F0; border-color: #2E7A2E; }
.bp-prefmodal__rel[data-r="Buddhist"].is-on  { background: #F5F0FF; border-color: #6B38C0; }

/* ── Gender option grid ── */
.bp-prefmodal__gen-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: .42rem; }
.bp-prefmodal__gen { padding: .65rem .55rem; border-radius: var(--r-md); border: 1.5px solid var(--bp-border-md); background: transparent; cursor: pointer; transition: all .15s; text-align: center; font-family: inherit; }
.bp-prefmodal__gen:hover { border-color: var(--bp-nav); }
.bp-prefmodal__gen.is-on { border-color: var(--bp-nav); }
.bp-prefmodal__gen[data-g="Boy"].is-on  { background: var(--bp-boy-lt);  border-color: var(--bp-boy); }
.bp-prefmodal__gen[data-g="Girl"].is-on { background: var(--bp-girl-lt); border-color: var(--bp-girl); }
.bp-prefmodal__gen[data-g="Both"].is-on { background: linear-gradient(135deg, var(--bp-boy-lt), var(--bp-girl-lt)); border-color: var(--bp-rashi); }
.bp-prefmodal__gen-emoji { font-size: 1.55rem; display: block; margin-bottom: .3rem; line-height: 1; }
.bp-prefmodal__gen-name  { font-size: .76rem; font-weight: 600; color: var(--bp-text-1); display: block; }
.bp-prefmodal__gen-sub   { font-size: .6rem; color: var(--bp-text-3); margin-top: .1rem; display: block; }

/* ── Language pills ── */
.bp-prefmodal__lang-grid { display: flex; flex-wrap: wrap; gap: .35rem; }
.bp-prefmodal__lang { display: inline-flex; align-items: center; gap: .28rem; padding: .28rem .72rem; border-radius: var(--r-full); border: 1.5px solid var(--bp-border-md); background: transparent; cursor: pointer; font-size: .72rem; font-weight: 500; color: var(--bp-text-2); transition: all .14s; user-select: none; font-family: inherit; }
.bp-prefmodal__lang:hover { border-color: var(--bp-rashi); color: var(--bp-rashi); }
.bp-prefmodal__lang.is-on { border-color: var(--bp-rashi); background: var(--bp-rashi-lt); color: var(--bp-rashi); font-weight: 600; }
.bp-prefmodal__lang-native { font-family: 'Noto Sans Devanagari', 'Noto Sans', sans-serif; }

/* ── Footer ── */
.bp-prefmodal__foot { display: flex; align-items: center; justify-content: space-between; gap: .65rem; padding: .85rem 1.5rem; border-top: 1px solid var(--bp-border); background: var(--bp-bg); border-radius: 0 0 var(--r-lg) var(--r-lg); flex-shrink: 0; flex-wrap: wrap; }
.bp-prefmodal__info { font-size: .68rem; color: var(--bp-text-3); flex: 1; }
.bp-prefmodal__actions { display: flex; gap: .45rem; align-items: center; }
.bp-prefmodal__skip { height: 36px; padding: 0 1rem; border-radius: var(--r-full); border: 1.5px solid var(--bp-border-md); background: transparent; font-size: .74rem; font-weight: 600; cursor: pointer; color: var(--bp-text-2); transition: all .15s; }
.bp-prefmodal__skip:hover { border-color: var(--bp-text-2); }
.bp-prefmodal__save { height: 36px; padding: 0 1.35rem; border-radius: var(--r-full); border: none; background: var(--bp-nav); color: #fff; font-size: .76rem; font-weight: 700; cursor: pointer; display: inline-flex; align-items: center; gap: .3rem; transition: opacity .15s; }
.bp-prefmodal__save:hover { opacity: .9; }
.bp-prefmodal__save:disabled { opacity: .55; cursor: progress; }
.bp-prefmodal__save svg { width: 13px; height: 13px; }

/* ── Success state ── */
.bp-prefmodal__success { display: none; padding: 2.25rem 1.5rem; text-align: center; }
.bp-prefmodal__success.is-on { display: block; animation: bpPrefFadeIn .2s; }
.bp-prefmodal__success-icon { font-size: 2.75rem; margin-bottom: .65rem; animation: bpPrefBounce .4s ease-out; }
@keyframes bpPrefBounce { 0% { transform: scale(.5); } 65% { transform: scale(1.12); } 100% { transform: scale(1); } }
.bp-prefmodal__success-title { font-size: 1.05rem; font-weight: 700; margin-bottom: .35rem; }
.bp-prefmodal__success-sub   { font-size: .78rem; color: var(--bp-text-2); line-height: 1.65; margin-bottom: 1.1rem; }
.bp-prefmodal__success-chips { display: flex; flex-wrap: wrap; gap: .3rem; justify-content: center; margin-bottom: 1.15rem; }
.bp-prefmodal__success-done  { height: 36px; padding: 0 1.35rem; border-radius: var(--r-full); border: none; background: var(--bp-nav); color: #fff; font-size: .76rem; font-weight: 700; cursor: pointer; }

/* Hidden helper — used by the success-state toggle so we don't sprinkle inline styles. */
.bp-prefmodal__hidden { display: none !important; }

/* Page blur when modal open — applied to <body class="bp-prefmodal-open"> */
.bp-prefmodal-open { overflow: hidden; }
.bp-prefmodal-open .bp-page-content { filter: blur(2px); pointer-events: none; }

/* Top-bar preferences shortcut — sits next to the language dropdown. */
.bp-topbar-prefs { display: inline-flex; align-items: center; gap: .3rem; padding: 0 .35rem; height: 22px; border: 1px solid rgba(255,255,255,.18); background: transparent; color: rgba(255,255,255,.78); border-radius: var(--r-full, 999px); font-size: .65rem; font-weight: 600; font-family: inherit; cursor: pointer; transition: all .14s; }
.bp-topbar-prefs:hover { background: rgba(255,255,255,.1); color: #fff; border-color: rgba(255,255,255,.35); }
.bp-topbar-prefs svg { color: inherit; flex-shrink: 0; }
