petstore-frontend/dist/dev/mp-weixin/app.wxss
2026-04-12 22:57:48 +08:00

355 lines
8.4 KiB
Plaintext

/* ============================================================
宠伴生活馆 - 全局样式
============================================================ */
page {
margin: 0;
padding: 0;
box-sizing: border-box;
background: linear-gradient(180deg, #f7f9fc 0%, #f3f6fa 100%);
font-family: -apple-system, BlinkMacSystemFont, 'PingFang SC', 'Helvetica Neue', Helvetica, Arial, sans-serif;
color: #1f2937;
font-size: 15px;
-webkit-font-smoothing: antialiased;
}
/* ---- 输入框 ---- */
.van-field {
background: #ffffff !important;
border: 1px solid #dfe5ee !important;
border-radius: 12px !important;
padding: 10px 14px !important;
font-size: 15px !important;
color: #1f2937 !important;
min-height: 44px !important;
width: 100% !important;
box-sizing: border-box !important;
transition: border-color 0.2s, box-shadow 0.2s;
}
.van-field:focus {
border-color: #22c55e !important;
box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.14) !important;
}
.van-field::-moz-placeholder { color: #9aa4b2 !important;
}
.van-field::placeholder { color: #9aa4b2 !important;
}
/* ---- 按钮 ---- */
.van-button {
border-radius: 12px !important;
font-size: 15px !important;
height: 44px !important;
line-height: 44px !important;
font-weight: 600 !important;
display: inline-flex !important;
align-items: center !important;
justify-content: center !important;
}
.van-button--primary {
background: linear-gradient(135deg, #22c55e 0%, #16a34a 100%) !important;
border: 1px solid #16a34a !important;
color: #fff !important;
box-shadow: 0 8px 20px rgba(34, 197, 94, 0.28) !important;
}
.van-button--primary:active { transform: translateY(1px);
}
.van-button--block { width: 100% !important; margin-top: 12px !important;
}
.van-button--small {
height: 34px !important;
line-height: 34px !important;
font-size: 13px !important;
padding: 0 14px !important;
border-radius: 8px !important;
background: #07c160 !important;
border: 1px solid #07c160 !important;
color: #fff !important;
flex-shrink: 0;
}
.van-button[disabled] {
background: #c8e8d8 !important;
border-color: #c8e8d8 !important;
color: #fff !important;
box-shadow: none !important;
}
button::after { border: none !important;
}
/* ---- 单元格组(卡片化) ---- */
.van-cell-group {
background: #fff !important;
border-radius: 18px !important;
overflow: hidden;
margin: 0 !important;
border: 1px solid #e7edf5;
box-shadow: 0 6px 20px rgba(15, 23, 42, 0.04);
}
.van-cell {
padding: 14px 16px !important;
background: #fff !important;
font-size: 15px !important;
min-height: 48px !important;
}
.van-cell::after {
left: 16px !important;
right: 16px !important;
border-color: #eef2f7 !important;
}
.van-cell--link:active { background: #fafafa !important;
}
.van-cell__title { color: #111827 !important; font-size: 15px !important;
}
.van-cell__value { color: #6b7280 !important; font-size: 14px !important;
}
.van-cell__arrow { color: #c3ccd8 !important; font-size: 16px !important; margin-left: 4px;
}
.van-cell__icon { margin-right: 10px !important;
}
/* ---- 标签 ---- */
.van-tag {
border-radius: 6px !important;
font-size: 12px !important;
padding: 2px 8px !important;
}
.van-tag--warning { background: #fff3e8 !important; color: #ff6b35 !important;
}
.van-tag--primary { background: #e8f7ef !important; color: #07c160 !important;
}
.van-tag--success { background: #f0f0f0 !important; color: #888 !important;
}
.van-tag--default { background: #f5f5f5 !important; color: #999 !important;
}
/* ---- 通用卡片容器 ---- */
.card-section {
background: #fff;
border-radius: 16px;
overflow: hidden;
margin: 0 16px;
}
/* ---- 通用弹窗 ---- */
.popup-mask {
position: fixed;
top: 0; left: 0; right: 0; bottom: 0;
background: rgba(0,0,0,0.5);
z-index: 200;
display: flex;
align-items: flex-end;
justify-content: center;
}
.popup-content {
background: #fff;
border-radius: 20px 20px 0 0;
width: 100%;
max-height: 85vh;
display: flex;
flex-direction: column;
}
.popup-header {
display: flex;
justify-content: space-between;
align-items: center;
padding: 18px 20px 14px;
border-bottom: 1px solid #f0f0f0;
flex-shrink: 0;
}
.popup-title { font-size: 17px; font-weight: 600; color: #1a1a1a;
}
.popup-close { font-size: 20px; color: #bbb;
}
.popup-body { padding: 16px 20px; overflow-y: auto; flex: 1;
}
.popup-footer { padding: 8px 20px max(env(safe-area-inset-bottom), 20px); flex-shrink: 0;
}
/* ---- 字段标签 ---- */
.field-label {
font-size: 14px;
color: #666;
margin-bottom: 8px;
margin-top: 14px;
font-weight: 500;
}
.field-label:first-child { margin-top: 0;
}
/* ---- 表单卡片(用于登录/注册页) ---- */
.form-card {
background: #fff;
border-radius: 22px;
padding: 28px 24px;
border: 1px solid #e8edf4;
box-shadow: 0 14px 40px rgba(15, 23, 42, 0.12);
}
/* ---- 主色调 ---- */
:root {
--space-8: 8px;
--space-12: 12px;
--space-16: 16px;
--space-24: 24px;
--pet-green: #16a34a;
--pet-green-light: #e8f7ef;
--pet-orange: #f97316;
--pet-orange-light: #fff7ed;
--pet-bg: #f5f7fb;
--pet-text: #111827;
--pet-subtext: #6b7280;
--pet-border: #e5ebf3;
--pet-card-shadow: 0 8px 24px rgba(15, 23, 42, 0.06);
}
/* Dark mode tokens (预埋,按需启用) */
@media (prefers-color-scheme: dark) {
:root {
--pet-bg: #0f172a;
--pet-text: #e5e7eb;
--pet-subtext: #94a3b8;
--pet-border: #334155;
}
}
/* ---- 通用 TabBar 样式(顶部状态栏) ---- */
.van-tabs {
display: flex;
background: #fff;
border-bottom: 1px solid #f0f0f0;
padding: 0 16px;
}
.van-tabs__tab {
flex: 1;
text-align: center;
padding: 12px 0;
font-size: 15px;
color: #999;
cursor: pointer;
position: relative;
}
.van-tabs__tab.active {
color: #07c160;
font-weight: 600;
}
.van-tabs__tab.active::after {
content: '';
position: absolute;
bottom: 0;
left: 50%;
transform: translateX(-50%);
width: 40px;
height: 3px;
background: #07c160;
border-radius: 2px;
}
/* ---- 通用页面头部 ---- */
[class*='-nav'] {
border-bottom-left-radius: 16px;
border-bottom-right-radius: 16px;
box-sizing: border-box;
}
.nav-title {
letter-spacing: 0.3px;
}
.nav-back {
font-weight: 700;
width: 28px;
height: 28px;
border-radius: 8px;
display: inline-flex;
align-items: center;
justify-content: center;
transition: transform 0.16s ease, background-color 0.16s ease, opacity 0.16s ease;
-webkit-tap-highlight-color: transparent;
}
.nav-back:active {
transform: scale(0.94);
opacity: 0.9;
background: rgba(255, 255, 255, 0.15);
}
/* ---- 空状态统一 ---- */
.empty {
margin: 24px 16px;
padding: 22px 16px;
background: #ffffff;
border: 1px solid var(--pet-border);
border-radius: 14px;
color: var(--pet-subtext);
text-align: center;
}
/* ---- 页面布局工具类 ---- */
.page-shell {
min-height: 100vh;
background: var(--pet-bg);
padding-bottom: 120rpx;
}
.page-section {
margin: var(--space-16);
}
.section-gap {
margin-top: var(--space-12);
}
/* ---- 常用内容间距 ---- */
.module-title {
font-size: 12px;
color: #94a3b8;
font-weight: 700;
margin-bottom: var(--space-8);
}
.form-field-wrap {
padding: 6px var(--space-16) var(--space-12);
}
/* ---- 文本层级工具类 ---- */
.text-title {
font-size: 18px;
font-weight: 700;
color: var(--pet-text);
}
.text-body {
font-size: 14px;
color: var(--pet-text);
line-height: 1.5;
}
.text-sub {
font-size: 12px;
color: var(--pet-subtext);
}
/* ---- 导航头工具类 ---- */
.nav-gradient {
background: linear-gradient(135deg, #22c55e 0%, #16a34a 100%);
box-shadow: 0 8px 20px rgba(34, 197, 94, 0.25);
}
/* ---- 微交互:统一点击反馈 ---- */
.van-button,
.order-item,
.gallery-item,
.menu-card,
.card-section,
.user-card {
transition: transform 0.16s ease, box-shadow 0.2s ease, opacity 0.16s ease;
-webkit-tap-highlight-color: transparent;
}
.van-button:active,
.order-item:active,
.gallery-item:active,
.menu-card:active,
.card-section:active,
.user-card:active {
transform: translateY(1px) scale(0.995);
opacity: 0.97;
}
page {
margin: 0;
padding: 0;
box-sizing: border-box;
background: #f5f5f5;
font-family: -apple-system, BlinkMacSystemFont, 'PingFang SC', 'Helvetica Neue', Helvetica, Arial, sans-serif;
}
page{--status-bar-height:25px;--top-window-height:0px;--window-top:0px;--window-bottom:0px;--window-left:0px;--window-right:0px;--window-magin:0px}[data-c-h="true"]{display: none !important;}