/* =============================================
 * 道谷伙伴 - 选择器组件样式
 * 复用项目已有 CSS 变量
 * ============================================= */

/* 选择器容器 */
.picker-wrap { position:relative; }
.picker-trigger { display:flex; align-items:center; justify-content:space-between; cursor:pointer; min-height:42px; }
.picker-trigger::after { content:'expand_more'; font-family:'Material Icons'; font-size:18px; color:var(--text-muted,#6B687D); }
.picker-trigger.has-value { color:var(--text,#F3F0FF); }
.picker-trigger:not(.has-value) { color:var(--text-muted,#6B687D); }

/* ===== 桌面端下拉框 ===== */
.picker-dropdown { position:absolute; top:100%; left:0; right:0; z-index:250; background:var(--bg-card,#1E1533); border:1px solid var(--border,#2D2547); border-radius:10px; box-shadow:0 8px 30px rgba(0,0,0,0.4); max-height:280px; display:none; overflow:hidden; margin-top:4px; }
.picker-dropdown.open { display:block; animation:pickerFadeIn 0.15s ease; }
.picker-search { padding:8px; border-bottom:1px solid var(--border,#2D2547); }
.picker-search input { width:100%; padding:8px 12px; background:var(--bg-input,#251D38); border:1px solid var(--border,#2D2547); border-radius:8px; color:var(--text,#F3F0FF); font-size:13px; outline:none; }
.picker-search input:focus { border-color:var(--primary,#7C3AED); }
.picker-search input::placeholder { color:var(--text-muted,#6B687D); }
.picker-options { max-height:220px; overflow-y:auto; padding:4px 0; }
.picker-options::-webkit-scrollbar { width:4px; }
.picker-options::-webkit-scrollbar-thumb { background:var(--border,#2D2547); border-radius:2px; }
.picker-option { padding:9px 14px; font-size:13px; cursor:pointer; transition:background 0.15s; color:var(--text,#F3F0FF); }
.picker-option:hover, .picker-option.active { background:rgba(var(--primary-rgb,124,58,237),0.15); color:var(--primary-light,#A78BFA); }
.picker-option.active { font-weight:600; }
.picker-empty { padding:20px; text-align:center; color:var(--text-muted,#6B687D); font-size:13px; }

/* 桌面端行级联选择器行 */
.picker-row { display:flex; gap:10px; }
.picker-row .picker-wrap { flex:1; }

/* ===== 移动端底部弹出层 ===== */
.picker-overlay { position:fixed; inset:0; background:rgba(0,0,0,0.5); z-index:250; display:none; }
.picker-overlay.open { display:block; animation:pickerFadeIn 0.15s ease; }
.picker-sheet { position:fixed; bottom:0; left:0; right:0; z-index:251; background:var(--bg-card,#1E1533); border-radius:16px 16px 0 0; max-height:70vh; display:none; overflow:hidden; }
.picker-sheet.open { display:flex; flex-direction:column; animation:pickerSlideUp 0.25s ease; }
.picker-sheet-header { display:flex; align-items:center; justify-content:space-between; padding:14px 16px; border-bottom:1px solid var(--border,#2D2547); flex-shrink:0; }
.picker-sheet-title { font-size:15px; font-weight:600; }
.picker-sheet-btn { padding:6px 16px; border-radius:8px; border:none; font-size:13px; cursor:pointer; }
.picker-sheet-cancel { background:transparent; color:var(--text-muted,#6B687D); }
.picker-sheet-confirm { background:var(--primary,#7C3AED); color:#fff; }
.picker-sheet-search { padding:10px 16px; border-bottom:1px solid var(--border,#2D2547); flex-shrink:0; }
.picker-sheet-search input { width:100%; padding:10px 14px; background:var(--bg-input,#251D38); border:1px solid var(--border,#2D2547); border-radius:10px; color:var(--text,#F3F0FF); font-size:14px; outline:none; }
.picker-sheet-search input:focus { border-color:var(--primary,#7C3AED); }
.picker-sheet-search input::placeholder { color:var(--text-muted,#6B687D); }

/* 移动端 tabs */
.picker-tabs { display:flex; border-bottom:1px solid var(--border,#2D2547); flex-shrink:0; }
.picker-tab { flex:1; padding:10px; text-align:center; font-size:13px; color:var(--text-muted,#6B687D); cursor:pointer; border-bottom:2px solid transparent; transition:all 0.2s; }
.picker-tab.active { color:var(--primary-light,#A78BFA); border-bottom-color:var(--primary,#7C3AED); }
.picker-tab .tab-val { font-size:12px; color:var(--primary-light,#A78BFA); margin-top:2px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }

.picker-sheet-list { flex:1; overflow-y:auto; padding:4px 0; -webkit-overflow-scrolling:touch; }
.picker-sheet-item { padding:12px 16px; font-size:14px; cursor:pointer; transition:background 0.15s; color:var(--text,#F3F0FF); display:flex; align-items:center; justify-content:space-between; }
.picker-sheet-item:active { background:rgba(var(--primary-rgb,124,58,237),0.15); }
.picker-sheet-item.active { color:var(--primary-light,#A78BFA); font-weight:500; }
.picker-sheet-item.active::after { content:'check'; font-family:'Material Icons'; font-size:18px; color:var(--primary,#7C3AED); }

/* ===== 动画 ===== */
@keyframes pickerFadeIn { from{opacity:0} to{opacity:1} }
@keyframes pickerSlideUp { from{transform:translateY(100%)} to{transform:translateY(0)} }

/* 支行搜索结果浮层 */
.branch-results { position:absolute; top:100%; left:0; right:0; z-index:250; background:var(--bg-card,#1E1533); border:1px solid var(--border,#2D2547); border-radius:10px; box-shadow:0 8px 30px rgba(0,0,0,0.4); max-height:200px; overflow-y:auto; display:none; margin-top:4px; }
.branch-results.open { display:block; }
.branch-item { padding:10px 14px; font-size:13px; cursor:pointer; color:var(--text,#F3F0FF); transition:background 0.15s; }
.branch-item:hover { background:rgba(var(--primary-rgb,124,58,237),0.15); }
.branch-loading { padding:16px; text-align:center; color:var(--text-muted,#6B687D); font-size:13px; }

/* ===== 自定义输入模态框 ===== */
.picker-modal-overlay { position:fixed; inset:0; background:rgba(0,0,0,0.55); z-index:500; display:flex; align-items:center; justify-content:center; animation:pickerFadeIn 0.15s ease; }
.picker-modal { background:var(--bg-card,#1E1533); border-radius:14px; width:88%; max-width:340px; overflow:hidden; animation:pickerModalIn 0.2s ease; }
.picker-modal-header { padding:18px 20px 10px; font-size:16px; font-weight:600; text-align:center; color:var(--text,#F3F0FF); }
.picker-modal-body { padding:8px 20px 18px; }
.picker-modal-input { width:100%; padding:12px 14px; background:var(--bg-input,#251D38); border:1px solid var(--border,#2D2547); border-radius:10px; color:var(--text,#F3F0FF); font-size:15px; outline:none; transition:border-color 0.2s; }
.picker-modal-input:focus { border-color:var(--primary,#7C3AED); }
.picker-modal-input::placeholder { color:var(--text-muted,#6B687D); }
.picker-modal-footer { display:flex; border-top:1px solid var(--border,#2D2547); }
.picker-modal-btn { flex:1; padding:14px; border:none; font-size:15px; cursor:pointer; text-align:center; transition:background 0.15s; }
.picker-modal-cancel { background:transparent; color:var(--text-muted,#6B687D); }
.picker-modal-cancel:active { background:rgba(255,255,255,0.05); }
.picker-modal-confirm { background:transparent; color:var(--primary-light,#A78BFA); font-weight:600; }
.picker-modal-confirm:active { background:rgba(var(--primary-rgb,124,58,237),0.15); }
.picker-modal-footer .picker-modal-btn + .picker-modal-btn { border-left:1px solid var(--border,#2D2547); }
@keyframes pickerModalIn { from{transform:scale(0.9);opacity:0} to{transform:scale(1);opacity:1} }

/* 双输入字段样式 */
.picker-modal-second-label {
    font-size:12px;
    color:var(--text-muted,#6B687D);
    margin:8px 0 4px;
}
.picker-modal-input-second { margin-top:8px; }

/* 手动输入选项样式 */
.picker-custom-option { color:var(--primary-light,#A78BFA); font-weight:500; border-top:1px solid var(--border,#2D2547); }
.picker-custom-option .material-icons { font-size:18px; vertical-align:middle; margin-right:6px; }

/* 跳过按钮（街道为空时引导） */
.picker-skip-btn {
    display:block;
    width:calc(100% - 32px);
    margin:12px 16px 24px;
    padding:12px;
    background:linear-gradient(135deg,var(--primary,#7C3AED),var(--primary-dark,#6D28D9));
    color:#fff;
    border:none;
    border-radius:10px;
    font-size:14px;
    font-weight:500;
    cursor:pointer;
    text-align:center;
}
