Files
menav/assets/styles/_search.css

307 lines
6.7 KiB
CSS
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
/* ============================================
Search Box Component
============================================ */
/* 搜索框容器 - 固定在顶部 */
.search-container {
width: 100%;
display: flex;
justify-content: center;
padding: 0 2rem;
margin-bottom: 1rem;
position: sticky;
top: 0;
/* 搜索框必须始终位于页面内容之上,避免搜索结果卡片滚动时遮挡 */
z-index: 200;
}
/* 分类切换按钮 */
.category-toggle {
position: fixed;
bottom: 5rem;
right: var(--spacing-xl);
width: 2.5rem;
height: 2.5rem;
border-radius: var(--radius-lg);
background: rgba(var(--card-bg-rgb), 0.65);
border: 1px solid var(--border-color);
backdrop-filter: blur(12px);
-webkit-backdrop-filter: blur(12px);
color: var(--text-color);
display: flex;
align-items: center;
justify-content: center;
cursor: pointer;
transition: all var(--transition-normal);
transition-timing-function: var(--transition-bounce);
z-index: 100;
box-shadow: 0 4px 16px var(--shadow-color);
}
.category-toggle:hover {
transform: translateY(-2px);
background: rgba(var(--card-bg-rgb), 0.75);
box-shadow: 0 6px 20px var(--shadow-color);
color: var(--accent-color);
}
.category-toggle:active {
transform: translateY(0);
box-shadow: 0 2px 8px var(--shadow-color);
}
.category-toggle i {
font-size: 18px;
}
/* 搜索框 */
.search-box {
position: relative;
width: 100%;
max-width: 600px;
display: flex;
align-items: stretch;
--search-status-right: 0.9rem;
--search-hint-right: 1.6rem;
background: rgba(var(--card-bg-rgb), 0.65);
border: 1px solid var(--border-color);
backdrop-filter: blur(12px);
-webkit-backdrop-filter: blur(12px);
border-radius: var(--radius-lg);
box-shadow: 0 4px 16px var(--shadow-color);
transition:
background var(--transition-normal),
border-color var(--transition-normal),
box-shadow var(--transition-normal);
}
.search-box:focus-within {
border-color: rgba(var(--accent-rgb), 0.55);
box-shadow:
0 0 0 1px rgba(var(--accent-rgb), 0.28),
0 0 18px rgba(var(--accent-rgb), 0.18),
0 6px 24px var(--shadow-color);
}
.search-box::after {
content: '';
position: absolute;
right: var(--search-status-right);
top: 50%;
transform: translateY(-50%);
width: 6px;
height: 6px;
border-radius: 50%;
opacity: 0;
transition: all var(--transition-normal);
pointer-events: none;
}
.search-box.has-results::after {
background-color: var(--success-color);
opacity: 1;
}
.search-box.no-results::after {
background-color: var(--error-color);
opacity: 1;
}
.search-box input {
flex: 1;
min-width: 0;
width: 100%;
padding: var(--spacing-md) calc(var(--spacing-lg) + 4.8rem) var(--spacing-md) var(--spacing-md);
border: none;
border-radius: 0 var(--radius-lg) var(--radius-lg) 0;
background-color: transparent;
color: var(--text-color);
font-family: inherit;
font-weight: inherit;
font-size: 1rem;
transition:
background-color var(--transition-normal),
color var(--transition-normal);
box-shadow: none;
}
.search-box input:focus {
outline: none;
background-color: rgba(var(--card-bg-rgb), 0.25);
box-shadow: none;
}
.search-box input::placeholder {
color: var(--text-muted);
font-family: inherit;
font-weight: inherit;
}
.search-shortcut-hint {
position: absolute;
top: 50%;
right: var(--search-hint-right);
transform: translateY(-50%);
padding: 0.1rem 0.4rem;
border: 1px solid var(--border-color);
border-radius: var(--radius-md);
background: rgba(var(--card-bg-rgb), 0.25);
font-size: 0.78rem;
line-height: 1.2;
color: var(--text-muted);
opacity: 0.65;
pointer-events: none;
user-select: none;
}
.search-box:focus-within .search-shortcut-hint {
opacity: 0.85;
}
/* 搜索引擎前缀按钮方案B输入框前缀一体化 */
.search-engine-button {
display: flex;
align-items: center;
gap: 0.5rem;
padding: 0 0.75rem;
width: 120px;
flex: 0 0 120px;
border: none;
border-right: 1px solid var(--border-color);
border-radius: var(--radius-lg) 0 0 var(--radius-lg);
background: transparent;
color: var(--text-muted);
cursor: pointer;
font: inherit;
transition:
background var(--transition-normal),
color var(--transition-normal),
transform var(--transition-normal);
}
.search-engine-button:hover {
background: rgba(var(--card-bg-rgb), 0.25);
}
.search-engine-button:focus-visible {
outline: 2px solid var(--accent-color);
outline-offset: 2px;
}
.search-box:focus-within .search-engine-button {
color: var(--accent-color);
}
.search-engine-icon {
display: grid;
place-items: center;
height: 1.2em;
width: 1.2em;
min-width: 1.2em;
font-size: 1.25rem;
line-height: 1;
text-align: center;
flex: 0 0 1.2em;
}
.search-engine-icon.search-engine-icon-svg {
font-size: 1.25rem;
}
.search-engine-icon.search-engine-icon-svg svg {
width: 100%;
height: 100%;
display: block;
}
.search-engine-label {
flex: 1;
min-width: 0;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
font-size: 0.95rem;
}
.search-box.dropdown-open .search-engine-button {
background: rgba(var(--card-bg-rgb), 0.25);
}
/* 搜索引擎下拉菜单 */
.search-engine-dropdown {
position: absolute;
top: calc(100% + 6px);
left: 0;
background: rgba(var(--card-bg-rgb), 0.9);
backdrop-filter: blur(12px);
-webkit-backdrop-filter: blur(12px);
border-radius: var(--radius-md);
box-shadow: 0 4px 15px var(--shadow-color);
display: none;
z-index: 100;
padding: 0.35rem;
border: 1px solid var(--border-color);
min-width: 190px;
flex-direction: column;
gap: 0.25rem;
}
.search-engine-dropdown.active {
display: flex;
animation: fadeIn 0.2s ease-out forwards;
}
.search-engine-option {
display: flex;
align-items: center;
justify-content: flex-start;
gap: 0.6rem;
width: 100%;
height: 40px;
padding: 0 0.75rem;
border: none;
border-radius: var(--radius-md);
cursor: pointer;
transition: all 0.2s ease;
background: transparent;
color: var(--text-color);
font: inherit;
}
.search-engine-option:hover {
background: rgba(var(--card-bg-rgb), 0.22);
}
.search-engine-option:focus-visible {
outline: 2px solid var(--accent-color);
outline-offset: 2px;
}
.search-engine-option.active {
background-color: var(--secondary-bg);
color: var(--text-bright);
}
.search-engine-option i {
display: grid;
place-items: center;
position: static;
transform: none;
font-size: 1.25rem;
width: 1.35em;
height: 1.35em;
line-height: 1;
text-align: center;
flex: 0 0 1.35em;
}
.search-engine-option i.search-engine-option-svg svg {
width: 100%;
height: 100%;
display: block;
}
.search-engine-option-label {
font-size: 0.95rem;
}