/* ============================================================
   YiSha Admin Web - H5 Mobile Base Styles
   移动端基础样式：CSS变量、重置样式、工具类
   ============================================================ */

/* ---------- CSS 变量定义 ---------- */
:root {
    /* 主题色 */
    --mobile-primary: #2196F3;
    --mobile-primary-dark: #1976D2;
    --mobile-primary-light: #42A5F5;

    /* 背景色 */
    --mobile-bg: #F5F7FA;
    --mobile-card-bg: #FFFFFF;

    /* 文字色 */
    --mobile-text: #333333;
    --mobile-text-secondary: #666666;
    --mobile-text-light: #999999;
    --mobile-text-disabled: #CCCCCC;

    /* 边框色 */
    --mobile-border: #E5E7EB;
    --mobile-border-light: #F0F0F0;

    /* 阴影 */
    --mobile-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
    --mobile-shadow-lg: 0 4px 16px rgba(0, 0, 0, 0.12);

    /* 圆角 */
    --mobile-radius: 8px;
    --mobile-radius-sm: 4px;
    --mobile-radius-lg: 12px;

    /* 尺寸 */
    --mobile-header-height: 50px;
    --mobile-tab-height: 44px;
    --mobile-touch-target: 44px;

    /* 安全区域 */
    --mobile-safe-top: env(safe-area-inset-top, 0px);
    --mobile-safe-bottom: env(safe-area-inset-bottom, 0px);
    --mobile-safe-left: env(safe-area-inset-left, 0px);
    --mobile-safe-right: env(safe-area-inset-right, 0px);

    /* 间距 */
    --mobile-spacing-xs: 4px;
    --mobile-spacing-sm: 8px;
    --mobile-spacing-md: 12px;
    --mobile-spacing-lg: 16px;
    --mobile-spacing-xl: 24px;
}

/* ---------- 全局移动端基础样式 ---------- */
@media (max-width: 768px) {
    html {
        overflow-x: hidden;
        -webkit-text-size-adjust: 100%;
        -ms-text-size-adjust: 100%;
    }

    body {
        overflow-x: hidden;
        background: var(--mobile-bg);
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale;
    }

    /* 触控优化 */
    * {
        -webkit-tap-highlight-color: transparent;
        -webkit-touch-callout: none;
    }

    /* 输入框防止iOS自动缩放 */
    input,
    select,
    textarea,
    button {
        font-size: 16px !important;
    }

    /* 链接和按钮触控区域 */
    a,
    button,
    .btn {
        min-height: var(--mobile-touch-target);
        display: inline-flex;
        align-items: center;
        justify-content: center;
    }
}

/* ---------- 移动端工具类 ---------- */
@media (max-width: 768px) {
    /* 显示/隐藏 */
    .mobile-show {
        display: block !important;
    }

    .mobile-hide {
        display: none !important;
    }

    .mobile-visible {
        visibility: visible !important;
    }

    .mobile-invisible {
        visibility: hidden !important;
    }

    /* 间距 */
    .mobile-mt-xs { margin-top: var(--mobile-spacing-xs) !important; }
    .mobile-mt-sm { margin-top: var(--mobile-spacing-sm) !important; }
    .mobile-mt-md { margin-top: var(--mobile-spacing-md) !important; }
    .mobile-mt-lg { margin-top: var(--mobile-spacing-lg) !important; }
    .mobile-mt-xl { margin-top: var(--mobile-spacing-xl) !important; }

    .mobile-mb-xs { margin-bottom: var(--mobile-spacing-xs) !important; }
    .mobile-mb-sm { margin-bottom: var(--mobile-spacing-sm) !important; }
    .mobile-mb-md { margin-bottom: var(--mobile-spacing-md) !important; }
    .mobile-mb-lg { margin-bottom: var(--mobile-spacing-lg) !important; }
    .mobile-mb-xl { margin-bottom: var(--mobile-spacing-xl) !important; }

    .mobile-ml-xs { margin-left: var(--mobile-spacing-xs) !important; }
    .mobile-ml-sm { margin-left: var(--mobile-spacing-sm) !important; }
    .mobile-ml-md { margin-left: var(--mobile-spacing-md) !important; }
    .mobile-ml-lg { margin-left: var(--mobile-spacing-lg) !important; }
    .mobile-ml-xl { margin-left: var(--mobile-spacing-xl) !important; }

    .mobile-mr-xs { margin-right: var(--mobile-spacing-xs) !important; }
    .mobile-mr-sm { margin-right: var(--mobile-spacing-sm) !important; }
    .mobile-mr-md { margin-right: var(--mobile-spacing-md) !important; }
    .mobile-mr-lg { margin-right: var(--mobile-spacing-lg) !important; }
    .mobile-mr-xl { margin-right: var(--mobile-spacing-xl) !important; }

    .mobile-pt-xs { padding-top: var(--mobile-spacing-xs) !important; }
    .mobile-pt-sm { padding-top: var(--mobile-spacing-sm) !important; }
    .mobile-pt-md { padding-top: var(--mobile-spacing-md) !important; }
    .mobile-pt-lg { padding-top: var(--mobile-spacing-lg) !important; }
    .mobile-pt-xl { padding-top: var(--mobile-spacing-xl) !important; }

    .mobile-pb-xs { padding-bottom: var(--mobile-spacing-xs) !important; }
    .mobile-pb-sm { padding-bottom: var(--mobile-spacing-sm) !important; }
    .mobile-pb-md { padding-bottom: var(--mobile-spacing-md) !important; }
    .mobile-pb-lg { padding-bottom: var(--mobile-spacing-lg) !important; }
    .mobile-pb-xl { padding-bottom: var(--mobile-spacing-xl) !important; }

    .mobile-pl-xs { padding-left: var(--mobile-spacing-xs) !important; }
    .mobile-pl-sm { padding-left: var(--mobile-spacing-sm) !important; }
    .mobile-pl-md { padding-left: var(--mobile-spacing-md) !important; }
    .mobile-pl-lg { padding-left: var(--mobile-spacing-lg) !important; }
    .mobile-pl-xl { padding-left: var(--mobile-spacing-xl) !important; }

    .mobile-pr-xs { padding-right: var(--mobile-spacing-xs) !important; }
    .mobile-pr-sm { padding-right: var(--mobile-spacing-sm) !important; }
    .mobile-pr-md { padding-right: var(--mobile-spacing-md) !important; }
    .mobile-pr-lg { padding-right: var(--mobile-spacing-lg) !important; }
    .mobile-pr-xl { padding-right: var(--mobile-spacing-xl) !important; }

    /* 文字对齐 */
    .mobile-text-left { text-align: left !important; }
    .mobile-text-center { text-align: center !important; }
    .mobile-text-right { text-align: right !important; }

    /* 文字大小 */
    .mobile-text-xs { font-size: 12px !important; }
    .mobile-text-sm { font-size: 14px !important; }
    .mobile-text-md { font-size: 16px !important; }
    .mobile-text-lg { font-size: 18px !important; }
    .mobile-text-xl { font-size: 20px !important; }

    /* 文字颜色 */
    .mobile-text-primary { color: var(--mobile-primary) !important; }
    .mobile-text-secondary { color: var(--mobile-text-secondary) !important; }
    .mobile-text-light { color: var(--mobile-text-light) !important; }
    .mobile-text-disabled { color: var(--mobile-text-disabled) !important; }

    /* 背景色 */
    .mobile-bg-white { background-color: var(--mobile-card-bg) !important; }
    .mobile-bg-gray { background-color: var(--mobile-bg) !important; }
    .mobile-bg-primary { background-color: var(--mobile-primary) !important; }

    /* 边框 */
    .mobile-border { border: 1px solid var(--mobile-border) !important; }
    .mobile-border-top { border-top: 1px solid var(--mobile-border) !important; }
    .mobile-border-bottom { border-bottom: 1px solid var(--mobile-border) !important; }
    .mobile-border-left { border-left: 1px solid var(--mobile-border) !important; }
    .mobile-border-right { border-right: 1px solid var(--mobile-border) !important; }

    /* 圆角 */
    .mobile-rounded { border-radius: var(--mobile-radius) !important; }
    .mobile-rounded-sm { border-radius: var(--mobile-radius-sm) !important; }
    .mobile-rounded-lg { border-radius: var(--mobile-radius-lg) !important; }

    /* 阴影 */
    .mobile-shadow { box-shadow: var(--mobile-shadow) !important; }
    .mobile-shadow-lg { box-shadow: var(--mobile-shadow-lg) !important; }

    /* Flexbox */
    .mobile-flex { display: flex !important; }
    .mobile-flex-column { flex-direction: column !important; }
    .mobile-flex-row { flex-direction: row !important; }
    .mobile-flex-center { justify-content: center !important; align-items: center !important; }
    .mobile-flex-between { justify-content: space-between !important; }
    .mobile-flex-around { justify-content: space-around !important; }
    .mobile-flex-start { justify-content: flex-start !important; }
    .mobile-flex-end { justify-content: flex-end !important; }
    .mobile-align-center { align-items: center !important; }
    .mobile-align-start { align-items: flex-start !important; }
    .mobile-align-end { align-items: flex-end !important; }

    /* 宽度 */
    .mobile-w-full { width: 100% !important; }
    .mobile-w-auto { width: auto !important; }

    /* 高度 */
    .mobile-h-full { height: 100% !important; }
    .mobile-h-auto { height: auto !important; }
}

/* ---------- 移动端卡片组件 ---------- */
@media (max-width: 768px) {
    .mobile-card {
        background: var(--mobile-card-bg);
        border-radius: var(--mobile-radius);
        padding: var(--mobile-spacing-md);
        margin-bottom: var(--mobile-spacing-md);
        box-shadow: var(--mobile-shadow);
    }

    .mobile-card-header {
        font-size: 16px;
        font-weight: 600;
        color: var(--mobile-text);
        margin-bottom: var(--mobile-spacing-sm);
        padding-bottom: var(--mobile-spacing-sm);
        border-bottom: 1px solid var(--mobile-border-light);
    }

    .mobile-card-body {
        color: var(--mobile-text-secondary);
        font-size: 14px;
        line-height: 1.6;
    }

    .mobile-card-footer {
        margin-top: var(--mobile-spacing-sm);
        padding-top: var(--mobile-spacing-sm);
        border-top: 1px solid var(--mobile-border-light);
        display: flex;
        justify-content: flex-end;
        gap: var(--mobile-spacing-sm);
    }
}

/* ---------- 移动端按钮优化 ---------- */
@media (max-width: 768px) {
    .btn {
        min-height: var(--mobile-touch-target);
        padding: 10px 20px;
        font-size: 16px;
        border-radius: var(--mobile-radius-sm);
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: 6px;
    }

    .btn-block {
        width: 100%;
        display: flex;
    }

    .btn-group .btn {
        flex: 1;
    }
}

/* ---------- 移动端输入框优化 ---------- */
@media (max-width: 768px) {
    .form-control {
        min-height: var(--mobile-touch-target);
        font-size: 16px;
        padding: 10px 12px;
        border-radius: var(--mobile-radius-sm);
    }

    .form-control:focus {
        border-color: var(--mobile-primary);
        box-shadow: 0 0 0 2px rgba(33, 150, 243, 0.1);
    }

    textarea.form-control {
        min-height: 100px;
        resize: vertical;
    }
}

/* ---------- 移动端加载动画 ---------- */
@media (max-width: 768px) {
    .mobile-loading {
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        padding: var(--mobile-spacing-xl);
        color: var(--mobile-text-secondary);
    }

    .mobile-loading-spinner {
        width: 40px;
        height: 40px;
        border: 3px solid var(--mobile-border);
        border-top-color: var(--mobile-primary);
        border-radius: 50%;
        animation: mobile-spin 0.8s linear infinite;
    }

    @keyframes mobile-spin {
        to { transform: rotate(360deg); }
    }

    .mobile-loading-text {
        margin-top: var(--mobile-spacing-sm);
        font-size: 14px;
    }
}

/* ---------- 移动端空状态 ---------- */
@media (max-width: 768px) {
    .mobile-empty {
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        padding: var(--mobile-spacing-xl);
        color: var(--mobile-text-light);
        text-align: center;
    }

    .mobile-empty-icon {
        font-size: 48px;
        margin-bottom: var(--mobile-spacing-md);
        opacity: 0.5;
    }

    .mobile-empty-text {
        font-size: 14px;
        margin-bottom: var(--mobile-spacing-sm);
    }
}

/* ---------- 移动端分割线 ---------- */
@media (max-width: 768px) {
    .mobile-divider {
        height: 1px;
        background: var(--mobile-border);
        margin: var(--mobile-spacing-md) 0;
    }

    .mobile-divider-thick {
        height: 8px;
        background: var(--mobile-bg);
        margin: var(--mobile-spacing-md) 0;
    }
}
/* ============================================================
   YiSha Admin Web - H5 Mobile Layout Styles
   主框架布局适配：侧边栏、顶部导航、内容区
   ============================================================ */

/* ---------- 主框架布局 ---------- */
@media (max-width: 768px) {
    /* 主容器 */
    #wrapper {
        display: flex;
        flex-direction: column;
        min-height: 100vh;
    }

    /* 侧边栏抽屉 */
    .navbar-static-side,
    .navbar-default.navbar-static-side {
        position: fixed !important;
        left: -260px !important;
        top: 0 !important;
        bottom: 0 !important;
        width: 260px !important;
        z-index: 1050 !important;
        transition: left 0.3s ease !important;
        overflow-y: auto !important;
        overflow-x: hidden !important;
        background: #2f4050 !important;
        box-shadow: 2px 0 8px rgba(0, 0, 0, 0.15) !important;
        transform: translateZ(0); /* 硬件加速 */
    }

    /* 侧边栏打开状态 */
    body.drawer-open .navbar-static-side,
    body.drawer-open .navbar-default.navbar-static-side {
        left: 0 !important;
    }

    /* 修复侧边栏滚动问题 */
    .navbar-static-side .slimScrollDiv {
        overflow: visible !important;
        height: auto !important;
    }

    .navbar-static-side .sidebar-collapse {
        overflow: visible !important;
        height: auto !important;
    }

    /* 侧边栏菜单 */
    .navbar-static-side #side-menu {
        padding-bottom: 20px;
    }

    /* 侧边栏用户信息区域 */
    .navbar-static-side .nav-header {
        padding: 0 15px;
        height: 50px;
        min-height: 50px;
        display: flex;
        align-items: center;
    }

    .navbar-static-side .nav-header .profile-element {
        display: flex;
        align-items: center;
        gap: 12px;
        width: 100%;
    }

    .navbar-static-side .nav-header .image-left {
        flex-shrink: 0;
        line-height: 0;
    }

    .navbar-static-side .nav-header .image-left img {
        width: 40px;
        height: 40px;
        border-radius: 50%;
        display: block;
        margin: 0;
        padding: 0;
    }

    .navbar-static-side .nav-header .image-right {
        flex: 1;
        min-width: 0;
        line-height: 1;
        text-align: right;
        padding-right: 10px;
    }

    .navbar-static-side .nav-header .image-right .block {
        display: block;
        color: #ffffff;
        font-size: 14px;
        line-height: 1.5;
        margin: 0 !important;
        padding: 0;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .navbar-static-side .nav-header .image-right .text-xs {
        font-size: 12px;
        color: #ffffff;
        line-height: 1.5;
        margin: 0 !important;
        padding: 0;
    }

    .navbar-static-side #side-menu > li > a {
        padding: 14px 10px;
        font-size: 15px;
        color: #a7b1c2;
        display: flex;
        align-items: center;
    }

    .navbar-static-side #side-menu > li > a > i:first-child {
        margin-right: 10px;
    }

    .navbar-static-side #side-menu > li > a .nav-label {
        flex: 1;
        text-align: left;
    }

    /* 箭头图标靠右，由 metisMenu 控制旋转 */
    .navbar-static-side #side-menu > li > a .fa.arrow {
        margin-left: auto;
    }

    .navbar-static-side #side-menu > li > a:hover,
    .navbar-static-side #side-menu > li.active > a {
        background: #293846;
        color: #ffffff;
    }

    /* 子菜单静态展开 */
    .navbar-static-side #side-menu .nav-second-level,
    .navbar-static-side #side-menu .nav-third-level {
        position: static !important;
        width: 100% !important;
        background: #293846 !important;
        border: none !important;
        box-shadow: none !important;
        display: none; /* 默认隐藏 */
    }

    /* 展开状态的子菜单 */
    .navbar-static-side #side-menu > li.active > .nav-second-level {
        display: block !important;
    }

    .navbar-static-side #side-menu .nav-second-level > li.active > .nav-third-level {
        display: block !important;
    }

    .navbar-static-side #side-menu .nav-second-level li a,
    .navbar-static-side #side-menu .nav-third-level li a {
        padding: 10px 10px 10px 40px;
        font-size: 14px;
        color: #a7b1c2;
    }

    .navbar-static-side #side-menu .nav-third-level li a {
        padding-left: 50px;
    }

    /* 遮罩层 */
    .mobile-drawer-mask {
        display: none;
        position: fixed;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        background: rgba(0, 0, 0, 0.5);
        z-index: 1040;
        transition: opacity 0.3s ease;
    }

    body.drawer-open .mobile-drawer-mask {
        display: block;
    }

    /* 主内容区 */
    #page-wrapper {
        margin: 0 !important;
        min-height: 100vh;
        display: flex;
        flex-direction: column;
        background: var(--mobile-bg);
    }

    /* 顶部导航栏 */
    .navbar-static-top {
        position: fixed !important;
        top: 0;
        left: 0;
        right: 0;
        z-index: 1030;
        height: var(--mobile-header-height);
        margin: 0 !important;
        border: none !important;
        background: #3c8dbc;
        box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 0;
    }

    /* 汉堡菜单按钮 - 靠左 */
    .navbar-static-top .navbar-minimalize {
        color: #ffffff;
        font-size: 20px;
        padding: 0 15px;
        margin: 0;
        background: transparent;
        border: none;
        height: var(--mobile-header-height);
        display: flex;
        align-items: center;
        justify-content: center;
        order: -1; /* 确保在最左边 */
    }

    /* 顶部导航右侧 - 靠右 */
    .navbar-static-top .navbar-top-links {
        margin: 0;
        margin-left: auto; /* 推到最右边 */
        height: var(--mobile-header-height);
        display: flex;
        align-items: center;
        gap: 0;
    }

    .navbar-static-top .navbar-top-links > li {
        display: flex;
        align-items: center;
        height: 100%;
        margin: 0;
    }

    .navbar-static-top .navbar-top-links > li > a {
        color: #ffffff;
        padding: 0 15px !important; /* 覆盖原始的 padding: 15px 10px */
        height: 100% !important;
        min-height: 0 !important; /* 覆盖原始的 min-height: 50px */
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 8px; /* 头像和文字之间的间距 */
        line-height: 1 !important; /* 重置行高 */
    }

    /* 用户头像 */
    .navbar-static-top .user-image {
        width: 32px !important;
        height: 32px !important;
        border-radius: 50% !important;
        margin: 0 !important; /* 移除所有margin */
        padding: 0 !important; /* 移除所有padding */
        display: block !important;
        flex-shrink: 0;
        vertical-align: middle !important; /* 确保垂直居中 */
    }

    /* 用户名文字 */
    .navbar-static-top .hidden-xs {
        line-height: 1 !important;
        display: block !important;
        margin: 0 !important;
        padding: 0 !important;
    }

    /* 用户下拉菜单 */
    .navbar-static-top .dropdown-menu {
        position: absolute;
        right: 0;
        top: 100%;
        min-width: 160px;
        margin-top: 2px;
        border-radius: 0 0 var(--mobile-radius) var(--mobile-radius);
        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    }

    .navbar-static-top .dropdown-menu > li > a {
        padding: 12px 16px;
        font-size: 14px;
        min-height: var(--mobile-touch-target);
        display: flex;
        align-items: center;
    }

    /* 标签页区域（移动端隐藏） */
    .content-tabs {
        display: none !important;
    }

    /* 内容主区域 */
    #content-main {
        flex: 1 1 auto;
        margin-top: var(--mobile-header-height);
        padding: 0;
        overflow: auto;
        -webkit-overflow-scrolling: touch;
    }

    #content-main .YiSha_iframe {
        width: 100%;
        height: calc(100vh - var(--mobile-header-height));
        border: none;
    }
}

/* ---------- 列表页容器 ---------- */
@media (max-width: 768px) {
    .container-div {
        padding: var(--mobile-spacing-md);
    }

    .gray-bg {
        background: var(--mobile-bg) !important;
    }
}

/* ---------- 搜索区域 ---------- */
@media (max-width: 768px) {
    .search-collapse {
        margin-bottom: var(--mobile-spacing-md);
    }

    /* 搜索折叠按钮 */
    .mobile-search-toggle {
        width: 100%;
        margin-bottom: var(--mobile-spacing-sm);
        height: var(--mobile-touch-target);
        font-size: 14px;
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 6px;
        background: var(--mobile-card-bg);
        border: 1px solid var(--mobile-border);
        border-radius: var(--mobile-radius-sm);
        color: var(--mobile-text);
    }

    .mobile-search-toggle i {
        font-size: 16px;
    }

    /* 搜索内容容器 - 由JS控制显示/隐藏 */
    .mobile-search-content {
        background: var(--mobile-card-bg);
        border-radius: var(--mobile-radius);
        padding: var(--mobile-spacing-md);
        margin-top: var(--mobile-spacing-sm);
        box-shadow: var(--mobile-shadow);
    }

    /* 搜索表单 */
    .search-collapse .select-list {
        background: var(--mobile-card-bg);
        border-radius: var(--mobile-radius);
        padding: var(--mobile-spacing-md);
        box-shadow: var(--mobile-shadow);
    }

    .search-collapse.collapsed .select-list {
        display: none;
    }

    .search-collapse .select-list ul {
        padding: 0;
        margin: 0;
        list-style: none;
    }

    .search-collapse .select-list ul li {
        display: flex;
        flex-direction: column;
        margin-bottom: var(--mobile-spacing-md);
    }

    .search-collapse .select-list ul li:last-child {
        margin-bottom: 0;
    }

    /* 搜索表单标签 */
    .search-collapse .select-list ul li label {
        font-size: 14px;
        font-weight: 600;
        color: var(--mobile-text);
        margin-bottom: 6px;
        display: block;
    }

    /* 搜索表单输入框 */
    .search-collapse .select-list ul li input,
    .search-collapse .select-list ul li select {
        width: 100%;
        min-height: var(--mobile-touch-target);
        font-size: 16px;
        padding: 10px 12px;
        border: 1px solid var(--mobile-border);
        border-radius: var(--mobile-radius-sm);
    }

    /* 搜索按钮 */
    .search-collapse .select-list ul li .btn {
        width: 100%;
        margin-top: var(--mobile-spacing-sm);
    }

    /* 搜索区域下拉框宽度铺满 */
    .search-collapse .bootstrap-select,
    .search-collapse .bootstrap-select > .dropdown-toggle {
        width: 100% !important;
    }

    .search-collapse .bootstrap-select .dropdown-menu {
        width: 100% !important;
        max-width: 100% !important;
    }
}

/* ---------- 工具栏 ---------- */
@media (max-width: 768px) {
    .btn-group-sm,
    #toolbar {
        display: flex !important;
        flex-wrap: wrap;
        gap: var(--mobile-spacing-sm);
        margin-bottom: var(--mobile-spacing-md);
    }

    .btn-group-sm .btn,
    #toolbar .btn {
        flex: 1;
        min-width: 0;
        min-height: var(--mobile-touch-target);
        padding: 10px 12px;
        font-size: 14px;
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 4px;
        white-space: nowrap;
    }

    /* 按钮图标 */
    .btn-group-sm .btn i,
    #toolbar .btn i {
        font-size: 16px;
    }

    /* 隐藏部分按钮文字，只显示图标 */
    .btn-group-sm .btn .btn-text,
    #toolbar .btn .btn-text {
        display: none;
    }

    /* 更多操作下拉菜单 */
    .mobile-more-actions {
        position: relative;
    }

    .mobile-more-actions .dropdown-menu {
        position: absolute;
        right: 0;
        top: 100%;
        min-width: 120px;
        margin-top: 4px;
        background: var(--mobile-card-bg);
        border: 1px solid var(--mobile-border);
        border-radius: var(--mobile-radius);
        box-shadow: var(--mobile-shadow-lg);
        z-index: 1000;
    }

    .mobile-more-actions .dropdown-menu > li > a {
        padding: 12px 16px;
        font-size: 14px;
        color: var(--mobile-text);
        display: flex;
        align-items: center;
        gap: 8px;
    }

    .mobile-more-actions .dropdown-menu > li > a:hover {
        background: var(--mobile-bg);
    }
}

/* ---------- 表格容器 ---------- */
@media (max-width: 768px) {
    .select-table {
        margin-bottom: var(--mobile-spacing-md);
    }

    /* Bootstrap Table 容器 */
    .fixed-table-container {
        border: none !important;
        border-radius: var(--mobile-radius);
        overflow: hidden;
    }

    /* 表格工具栏 */
    .fixed-table-toolbar {
        background: var(--mobile-card-bg);
        padding: var(--mobile-spacing-sm);
        border-bottom: 1px solid var(--mobile-border);
    }

    /* 表格分页 */
    .fixed-table-pagination {
        background: var(--mobile-card-bg);
        padding: var(--mobile-spacing-md);
        border-top: 1px solid var(--mobile-border);
    }

    .fixed-table-pagination .pagination {
        margin: 0;
        display: flex;
        justify-content: center;
        flex-wrap: wrap;
        gap: 4px;
    }

    .fixed-table-pagination .pagination > li > a {
        min-width: var(--mobile-touch-target);
        min-height: var(--mobile-touch-target);
        padding: 10px 12px;
        font-size: 14px;
        border-radius: var(--mobile-radius-sm);
        display: flex;
        align-items: center;
        justify-content: center;
    }
}

/* ---------- 表单容器 ---------- */
@media (max-width: 768px) {
    .wrapper {
        padding: var(--mobile-spacing-md);
    }

    .form-horizontal {
        background: var(--mobile-card-bg);
        border-radius: var(--mobile-radius);
        padding: var(--mobile-spacing-md);
        box-shadow: var(--mobile-shadow);
    }

    /* 表单组垂直布局 */
    .form-horizontal .form-group {
        display: flex;
        flex-direction: column;
        margin-bottom: var(--mobile-spacing-lg);
    }

    .form-horizontal .form-group:last-child {
        margin-bottom: 0;
    }

    /* 表单标签 */
    .form-horizontal .control-label {
        text-align: left !important;
        padding: 0 0 6px 0 !important;
        font-size: 14px;
        font-weight: 600;
        color: var(--mobile-text);
        width: 100% !important;
        margin: 0;
    }

    .form-horizontal .form-group > div[class*="col-"],
    .form-horizontal .form-group > .form-control-static {
        width: 100% !important;
        padding: 0 !important;
        float: none !important;
        min-height: auto;
        word-break: break-word;
    }

    .form-horizontal .form-control-static pre,
    .form-horizontal pre {
        max-width: 100%;
        max-height: 55vh;
        overflow: auto;
        white-space: pre-wrap;
        word-break: break-word;
        -webkit-overflow-scrolling: touch;
    }

    .form-horizontal .bootstrap-select,
    .form-horizontal .bootstrap-select > .dropdown-toggle,
    .form-horizontal .select2-container {
        width: 100% !important;
    }

    .form-horizontal .bootstrap-select .dropdown-menu {
        max-width: 100%;
    }

    .form-horizontal .ztree {
        max-height: 45vh;
        overflow: auto;
        border: 1px solid var(--mobile-border);
        border-radius: var(--mobile-radius-sm);
        -webkit-overflow-scrolling: touch;
    }

    .form-horizontal .icon-drop {
        position: relative;
        width: 100% !important;
        max-height: 50vh !important;
        overflow: auto !important;
        -webkit-overflow-scrolling: touch;
    }

    .form-horizontal .ico-list {
        display: grid;
        grid-template-columns: repeat(auto-fill, minmax(44px, 1fr));
        gap: 6px;
    }

    .form-horizontal .ico-list .fa {
        min-width: 44px;
        min-height: 44px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        margin: 0;
    }

    .wrapper > .ztree,
    .wrapper .treeselect {
        max-height: calc(100vh - 48px);
        overflow: auto;
        -webkit-overflow-scrolling: touch;
    }

    /* 表单按钮组 */
    .form-horizontal .form-group .btn-group {
        display: flex;
        gap: var(--mobile-spacing-sm);
    }

    .form-horizontal .form-group .btn-group .btn {
        flex: 1;
    }

    /* 表单底部按钮 */
    .form-horizontal .footer-center,
    .form-horizontal .text-center {
        margin-top: var(--mobile-spacing-lg);
        padding-top: var(--mobile-spacing-lg);
        border-top: 1px solid var(--mobile-border);
        display: flex;
        gap: var(--mobile-spacing-sm);
    }

    .form-horizontal .footer-center .btn,
    .form-horizontal .text-center .btn {
        flex: 1;
    }
}

/* ---------- 表单内图片网格（grid-square）适配 ---------- */
@media (max-width: 768px) {
    /* 图片容器 - 移除固定高度和溢出裁剪 */
    .bodyLine {
        height: auto !important;
        min-height: 80px !important;
        overflow: visible !important;
    }

    /* 图片网格容器和子容器 - flex横向排列换行 */
    #mainImgDiv,
    #mainImgBase {
        display: flex !important;
        flex-wrap: wrap !important;
        align-items: flex-start !important;
        gap: 6px !important;
        width: 100% !important;
        overflow: visible !important;
    }

    /* 单个图片格子 */
    .grid-square {
        flex: 0 0 auto !important;
        width: 70px !important;
        height: 70px !important;
        overflow: hidden !important;
        border-radius: 6px !important;
        border: 1px solid var(--mobile-border) !important;
        position: relative !important;
    }

    .grid-square img {
        width: 100% !important;
        height: 100% !important;
        object-fit: cover !important;
        margin: 0 !important;
        display: block !important;
    }

    /* 上传触发区域 - 覆盖img-sm和box-a尺寸，保持PC原有十字绘制方式 */
    .uploadImg {
        float: none !important;
        width: 70px !important;
        min-width: 70px !important;
        max-width: 70px !important;
        height: 70px !important;
        min-height: 70px !important;
        max-height: 70px !important;
        border-width: 2px !important;
        border-style: dashed !important;
        border-color: #1890ff !important;
        border-radius: 6px !important;
        position: relative !important;
        cursor: pointer !important;
        background-color: #f0f7ff !important;
        box-sizing: border-box !important;
        overflow: visible !important;
    }

    /* 横线 - 沿用PC端的border-top + margin定位方式（兼容移动WebView） */
    .uploadImg::before {
        content: '' !important;
        position: absolute !important;
        left: 50% !important;
        top: 50% !important;
        width: 40px !important;
        height: 2px !important;
        margin-left: -20px !important;
        margin-top: -1px !important;
        border-top: 2px solid #1890ff !important;
        background: none !important;
    }

    /* 竖线 - 沿用PC端的border-left + margin定位方式 */
    .uploadImg::after {
        content: '' !important;
        position: absolute !important;
        left: 50% !important;
        top: 50% !important;
        height: 40px !important;
        width: 2px !important;
        margin-top: -20px !important;
        margin-left: -1px !important;
        border-left: 2px solid #1890ff !important;
        background: none !important;
    }

    /* 表单行按钮 - 移动端水平排列 */
    .form-group .btn-group {
        display: flex !important;
        gap: 4px !important;
    }

    .form-group .btn-group .btn {
        flex: 1 !important;
        white-space: nowrap !important;
        font-size: 13px !important;
        padding: 8px 10px !important;
        min-height: 40px !important;
        height: auto !important;
    }

    /* 非form-horizontal表单中的按钮 - 移动端全宽 */
    .panel-body .form-group > .col-sm-2 .btn {
        width: 100% !important;
        min-height: 40px !important;
        font-size: 13px !important;
        padding: 8px 10px !important;
        white-space: nowrap !important;
    }

    /* 非form-horizontal表单的col-sm-*竖向堆叠时保持行间距 */
    .panel-body .form-group > [class*="col-sm-"] {
        margin-bottom: 8px !important;
    }

    /* 控制标签 - 移动端左对齐（非form-horizontal场景） */
    .panel-body > .form-group > .control-label {
        text-align: left !important;
        display: block !important;
        width: 100% !important;
        margin-bottom: 6px !important;
    }
}

/* ---------- Tab 导航 ---------- */
@media (max-width: 768px) {
    .nav-tabs {
        display: flex;
        border-bottom: 2px solid var(--mobile-border);
        margin-bottom: var(--mobile-spacing-md);
        overflow-x: auto;
        overflow-y: hidden;
        -webkit-overflow-scrolling: touch;
        white-space: nowrap;
    }

    .nav-tabs > li {
        flex-shrink: 0;
    }

    .nav-tabs > li > a {
        padding: 12px 16px;
        font-size: 14px;
        color: var(--mobile-text-secondary);
        border: none;
        border-bottom: 2px solid transparent;
        margin: 0;
        display: flex;
        align-items: center;
        gap: 6px;
    }

    .nav-tabs > li.active > a,
    .nav-tabs > li > a:hover {
        background: transparent;
        color: var(--mobile-primary);
        border-bottom-color: var(--mobile-primary);
    }

    .tab-content {
        padding: 0;
    }

    .tab-pane {
        padding: var(--mobile-spacing-md);
        background: var(--mobile-card-bg);
        border-radius: var(--mobile-radius);
        box-shadow: var(--mobile-shadow);
    }
}

/* ---------- 面板 ---------- */
@media (max-width: 768px) {
    .panel {
        border: none;
        border-radius: var(--mobile-radius);
        box-shadow: var(--mobile-shadow);
        margin-bottom: var(--mobile-spacing-md);
    }

    .panel-heading {
        padding: var(--mobile-spacing-md);
        font-size: 16px;
        font-weight: 600;
        background: var(--mobile-card-bg);
        border-bottom: 1px solid var(--mobile-border);
        border-radius: var(--mobile-radius) var(--mobile-radius) 0 0;
    }

    .panel-body {
        padding: var(--mobile-spacing-md);
        background: var(--mobile-card-bg);
    }

    .panel-footer {
        padding: var(--mobile-spacing-md);
        background: var(--mobile-bg);
        border-top: 1px solid var(--mobile-border);
        border-radius: 0 0 var(--mobile-radius) var(--mobile-radius);
    }
}

/* ---------- 模态框/对话框 ---------- */
@media (max-width: 768px) {
    .modal-dialog {
        width: 95%;
        margin: 10px auto;
    }

    .modal-content {
        border-radius: var(--mobile-radius);
    }

    .modal-header {
        padding: var(--mobile-spacing-md);
        border-bottom: 1px solid var(--mobile-border);
    }

    .modal-title {
        font-size: 16px;
        font-weight: 600;
    }

    .modal-body {
        padding: var(--mobile-spacing-md);
        max-height: 60vh;
        overflow-y: auto;
    }

    .modal-footer {
        padding: var(--mobile-spacing-md);
        border-top: 1px solid var(--mobile-border);
        display: flex;
        gap: var(--mobile-spacing-sm);
    }

    .modal-footer .btn {
        flex: 1;
    }
}
/* ============================================================
   YiSha Admin Web - H5 Mobile Components Styles
   组件适配：表格、表单、弹窗、树形组件等
   ============================================================ */

/* ---------- Bootstrap Table 移动端适配 ---------- */
@media (max-width: 768px) {
    /* 隐藏表头 */
    .fixed-table-container thead {
        display: none !important;
    }

    /* 表格主体 */
    .fixed-table-container tbody {
        display: block;
    }

    /* 卡片化行 - 紧凑样式 */
    .fixed-table-container tbody > tr {
        display: block;
        background: #fff;
        border-radius: 6px;
        margin: 6px 4px;
        padding: 8px 10px;
        box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
        position: relative;
        border: 1px solid #e8e8e8;
        overflow: hidden;
    }

    /* 卡片化单元格 - 增加行间距 */
    .fixed-table-container tbody > tr > td {
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding: 8px 4px;
        border: none !important;
        border-bottom: 1px solid #f0f0f0 !important;
        font-size: 13px;
        width: 100%;
        box-sizing: border-box;
    }

    /* card-view 行间距和垂直居中 */
    .fixed-table-container tbody > tr > td .card-view {
        padding: 4px 0;
        display: flex !important;
        align-items: center !important;
        width: 100% !important;
    }

    .fixed-table-container tbody > tr > td:last-child {
        border-bottom: none !important;
    }

    /* 显示列名 */
    .fixed-table-container tbody > tr > td::before {
        content: attr(data-title);
        font-weight: 500;
        color: #666;
        margin-right: 8px;
        flex-shrink: 0;
        min-width: 70px;
        font-size: 12px;
    }

    /* card-view 标题样式修复 */
    .card-view-title {
        flex-shrink: 0 !important;
        min-width: 60px !important;
        max-width: 80px !important;
        width: auto !important;
        text-align: left !important;
        word-break: break-all !important;
        font-size: 12px !important;
        color: #666 !important;
        margin-right: 8px !important;
        padding-right: 4px !important;
    }

    /* card-view 容器 - 标题靠左，内容靠右 */
    .card-view {
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        width: 100% !important;
    }

    /* 单元格内容 */
    .fixed-table-container tbody > tr > td > * {
        flex: 1;
        text-align: right;
        min-width: 0 !important;
    }

    /* card-view-value 背景修复 */
    .card-view-value {
        background: transparent !important;
        padding: 0 !important;
        margin: 0 !important;
        text-align: right !important;
        flex: 1 !important;
        min-width: 0 !important;
        max-width: calc(100% - 90px) !important;
        display: flex !important;
        align-items: center !important;
        justify-content: flex-end !important;
        overflow-x: auto !important;
        overflow-y: hidden !important;
        -webkit-overflow-scrolling: touch !important;
    }

    /* 操作按钮区域 - 允许横向滚动 */
    .card-view-value:has(.btn) {
        overflow-x: auto !important;
        flex-wrap: nowrap !important;
        max-width: 100% !important;
    }

    .card-view-value.undefined {
        background: transparent !important;
    }

    /* card-view-value 内部所有元素垂直居中 */
    .card-view-value > * {
        display: inline-flex !important;
        align-items: center !important;
        line-height: 1.2 !important;
        flex-shrink: 0 !important;
    }

    /* card-view-value 内部按钮不收缩 */
    .card-view-value .btn {
        flex-shrink: 0 !important;
        white-space: nowrap !important;
    }

    /* card-view-value 内部元素 */
    .card-view-value > span,
    .card-view-value > strong {
        display: inline-flex !important;
        align-items: center !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        white-space: nowrap !important;
    }

    /* card-view-value 内部带颜色的 span */
    .card-view-value > span[style*="color"] {
        display: inline-flex !important;
        align-items: center !important;
        text-align: right !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        white-space: nowrap !important;
    }

    .card-view-value br {
        display: none !important;
    }

    .card-view-value .btn-xs {
        margin-left: 4px !important;
    }

    /* 操作按钮通用样式 */
    .card-view-value .btn-xs,
    .fixed-table-container .btn-xs {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        text-align: center !important;
        padding: 2px 8px !important;
        font-size: 12px !important;
        border-radius: 4px !important;
        color: #fff !important;
    }

    /* 移动端隐藏按钮图标 */
    .card-view-value .btn-xs i,
    .fixed-table-container .btn-xs i {
        display: none !important;
    }

    /* 查看按钮 - 蓝色 */
    .card-view-value .btn-info.btn-xs,
    .fixed-table-container .btn-info.btn-xs {
        background-color: #2196F3 !important;
        border-color: #2196F3 !important;
        color: #fff !important;
    }

    .card-view-value .btn-info.btn-xs:hover,
    .fixed-table-container .btn-info.btn-xs:hover {
        background-color: #1976D2 !important;
        border-color: #1976D2 !important;
    }

    /* 通过按钮 - 绿色 */
    .card-view-value .btn-success.btn-xs,
    .fixed-table-container .btn-success.btn-xs {
        background-color: #4CAF50 !important;
        border-color: #4CAF50 !important;
        color: #fff !important;
    }

    .card-view-value .btn-success.btn-xs:hover,
    .fixed-table-container .btn-success.btn-xs:hover {
        background-color: #388E3C !important;
        border-color: #388E3C !important;
    }

    /* 冻结按钮 - 橙色 */
    .card-view-value .btn-warning.btn-xs,
    .fixed-table-container .btn-warning.btn-xs {
        background-color: #FF9800 !important;
        border-color: #FF9800 !important;
        color: #fff !important;
    }

    .card-view-value .btn-warning.btn-xs:hover,
    .fixed-table-container .btn-warning.btn-xs:hover {
        background-color: #F57C00 !important;
        border-color: #F57C00 !important;
    }

    /* 异常/删除按钮 - 红色 */
    .card-view-value .btn-danger.btn-xs,
    .fixed-table-container .btn-danger.btn-xs {
        background-color: #F44336 !important;
        border-color: #F44336 !important;
        color: #fff !important;
    }

    .card-view-value .btn-danger.btn-xs:hover,
    .fixed-table-container .btn-danger.btn-xs:hover {
        background-color: #D32F2F !important;
        border-color: #D32F2F !important;
    }

    /* 微信按钮样式 */
    .card-view-value .btn-primary.btn-xs,
    .fixed-table-container .btn-primary.btn-xs {
        background-color: #07C160 !important;
        border-color: #07C160 !important;
        color: #fff !important;
        padding: 1px 6px !important;
        font-size: 11px !important;
        border-radius: 3px !important;
        line-height: 1.2 !important;
        margin: 0 !important;
    }

    .card-view-value .btn-primary.btn-xs i,
    .fixed-table-container .btn-primary.btn-xs i {
        font-size: 11px !important;
    }

    .card-view-value .btn-primary.btn-xs:hover,
    .fixed-table-container .btn-primary.btn-xs:hover {
        background-color: #06AD56 !important;
        border-color: #06AD56 !important;
    }

    /* editable 编辑样式 - 靠右对齐 */
    .fixed-table-container .editable {
        background: transparent !important;
        padding: 2px 6px !important;
        border-radius: 4px !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: flex-end !important;
        width: auto !important;
        max-width: 100% !important;
        word-break: break-all;
        line-height: 1.2 !important;
        text-align: right !important;
    }

    .fixed-table-container .editable:hover {
        background: #f5f5f5 !important;
    }

    .fixed-table-container .editable-click {
        border-bottom: none !important;
    }

    /* editable 弹窗样式修复 */
    .editable-container {
        width: 280px !important;
        max-width: 90vw !important;
    }

    .editable-container .editableform {
        width: 100% !important;
        display: flex !important;
        flex-direction: column !important;
        gap: 10px !important;
    }

    .editable-container .control-group,
    .editable-container .form-group {
        width: 100% !important;
        margin-bottom: 0 !important;
    }

    .editable-container .control-group > div {
        display: flex !important;
        flex-direction: column !important;
        gap: 10px !important;
        width: 100% !important;
    }

    .editable-container .editable-input {
        width: 100% !important;
    }

    .editable-container .form-control {
        width: 100% !important;
        font-size: 16px !important;
        height: 44px !important;
        border-radius: 6px !important;
    }

    .editable-container .editable-buttons {
        width: 100% !important;
        display: flex !important;
        gap: 10px !important;
        margin-top: 0 !important;
    }

    .editable-container .editable-buttons .btn {
        flex: 1 !important;
        height: 44px !important;
        font-size: 14px !important;
        border-radius: 6px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
    }

    /* popover 弹窗修复 */
    .popover {
        max-width: 280px !important;
        width: 280px !important;
        left: 10px !important;
        right: auto !important;
    }

    .popover.top,
    .popover.bottom {
        left: 10px !important;
        right: auto !important;
    }

    /* 移动端隐藏 popover 箭头 */
    .popover .arrow {
        display: none !important;
    }

    .popover .popover-content {
        padding: 12px !important;
        width: 100% !important;
    }

    /* editable 弹窗定位修复 */
    .editable-container.editable-popup {
        left: 10px !important;
        right: auto !important;
        margin-left: 0 !important;
    }

    /* 复选框列 */
    .fixed-table-container tbody > tr > td[data-field="ck"] {
        position: absolute;
        top: 8px;
        right: 8px;
        padding: 0;
        border: none;
    }

    .fixed-table-container tbody > tr > td[data-field="ck"]::before {
        display: none;
    }

    /* 操作列 */
    .fixed-table-container tbody > tr > td:last-child {
        flex-direction: row;
        flex-wrap: wrap;
        align-items: center;
        gap: 4px;
        padding-top: 6px;
        margin-top: 4px;
        justify-content: flex-end;
    }

    .fixed-table-container tbody > tr > td:last-child::before {
        display: none;
    }

    .fixed-table-container tbody > tr > td:last-child a {
        flex: 0 0 auto;
        text-align: center;
        padding: 4px 8px;
        background: #f5f5f5;
        border-radius: 4px;
        font-size: 12px;
    }

    /* 表格滑动操作 */
    .fixed-table-container tbody > tr.swipe-left {
        transform: translateX(-80px);
    }

    .swipe-delete-btn {
        position: absolute;
        right: -80px;
        top: 0;
        bottom: 0;
        width: 80px;
        background: #f44336;
        color: white;
        border: none;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        font-size: 12px;
        border-radius: 0 var(--mobile-radius) var(--mobile-radius) 0;
    }

    .swipe-delete-btn i {
        font-size: 18px;
        margin-bottom: 4px;
    }

    /* 表格加载状态 */
    .fixed-table-loading {
        background: rgba(255, 255, 255, 0.9);
    }

    /* 表格空状态 */
    .fixed-table-container .no-records-found {
        padding: var(--mobile-spacing-xl);
        text-align: center;
        color: var(--mobile-text-light);
    }
}

/* ---------- Select2 移动端适配 ---------- */
@media (max-width: 768px) {
    /* Select2 容器 */
    .select2-container {
        width: 100% !important;
    }

    /* Select2 选择框 */
    .select2-container .select2-selection {
        min-height: var(--mobile-touch-target);
        border: 1px solid var(--mobile-border);
        border-radius: var(--mobile-radius-sm);
    }

    .select2-container .select2-selection__rendered {
        line-height: var(--mobile-touch-target);
        padding: 0 12px;
        font-size: 16px;
    }

    .select2-container .select2-selection__arrow {
        height: var(--mobile-touch-target);
        right: 8px;
    }

    /* Select2 下拉菜单 */
    .select2-dropdown {
        border: 1px solid var(--mobile-border);
        border-radius: var(--mobile-radius);
        box-shadow: var(--mobile-shadow-lg);
        max-height: 60vh;
    }

    .select2-results__option {
        padding: 12px 16px;
        font-size: 16px;
        min-height: var(--mobile-touch-target);
        display: flex;
        align-items: center;
    }

    .select2-results__option--highlighted {
        background: var(--mobile-primary);
        color: white;
    }

    /* Select2 搜索框 */
    .select2-search--dropdown .select2-search__field {
        min-height: var(--mobile-touch-target);
        padding: 10px 12px;
        font-size: 16px;
        border: 1px solid var(--mobile-border);
        border-radius: var(--mobile-radius-sm);
    }
}

/* ---------- Laydate 日期选择器移动端适配 ---------- */
@media (max-width: 768px) {
    /* 日期选择器居中显示 */
    .layui-laydate {
        position: fixed !important;
        left: 50% !important;
        top: 50% !important;
        transform: translate(-50%, -50%) !important;
        width: 90% !important;
        max-width: 320px !important;
        z-index: 999999 !important;
        border-radius: 8px !important;
        box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3) !important;
    }

    .laydate-main-list-0 {
        width: 100% !important;
    }

    .layui-laydate-header {
        height: 50px;
        line-height: 50px;
        font-size: 16px;
    }

    .layui-laydate-header i {
        font-size: 18px;
        padding: 10px;
    }

    .layui-laydate-content {
        padding: 10px;
    }

    .layui-laydate-content th,
    .layui-laydate-content td {
        height: 44px;
        line-height: 44px;
        font-size: 14px;
    }

    .layui-laydate-footer {
        height: 50px;
        line-height: 50px;
        padding: 0 10px;
    }

    .layui-laydate-footer span {
        padding: 0 20px;
        font-size: 14px;
    }
}

/* ---------- Layer 弹窗移动端适配 ---------- */
@media (max-width: 768px) {
    /* Layer 弹窗容器 */
    .layui-layer {
        max-width: 95% !important;
        max-height: 90vh !important;
        border-radius: var(--mobile-radius);
    }

    .layui-layer-iframe {
        width: 95% !important;
        max-width: 95% !important;
    }

    /* Layer 标题栏 */
    .layui-layer-title {
        font-size: 16px !important;
        padding: 12px 15px !important;
        height: auto !important;
        line-height: 1.5 !important;
        background: var(--mobile-card-bg);
        border-bottom: 1px solid var(--mobile-border);
    }

    /* Layer 内容区 */
    .layui-layer-content {
        overflow-y: auto !important;
        -webkit-overflow-scrolling: touch;
    }

    .layui-layer-iframe .layui-layer-content {
        overflow: hidden !important;
    }

    /* Layer 按钮 */
    .layui-layer-btn {
        padding: var(--mobile-spacing-md);
        border-top: 1px solid var(--mobile-border);
        display: flex;
        gap: var(--mobile-spacing-sm);
    }

    .layui-layer-btn a {
        flex: 1;
        min-height: var(--mobile-touch-target) !important;
        line-height: var(--mobile-touch-target) !important;
        font-size: 16px !important;
        border-radius: var(--mobile-radius-sm);
    }

    /* Layer.msg 移动端消息提示 - 自适应宽度，居中显示 */
    .layui-layer-msg {
        width: auto !important;
        max-width: 85% !important;
        max-height: none !important;
        height: auto !important;
        left: 50% !important;
        margin-left: 0 !important;
        transform: translateX(-50%) !important;
    }
    .layui-layer-msg .layui-layer-content {
        padding-left: 42px !important;
    }

    /* Layer 弹窗标题栏 */
    .layui-layer-title {
        height: 50px !important;
        line-height: 50px !important;
        padding: 0 110px 0 15px !important;
        font-size: 16px !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
    }

    /* Layer 弹窗按钮容器 - 触摸友好设计 */
    .layui-layer-setwin {
        position: absolute !important;
        right: 8px !important;
        top: 5px !important;
        height: 40px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: flex-end !important;
        padding: 0 !important;
        z-index: 10 !important;
        gap: 8px !important;
    }

    /* Layer 按钮基础样式 - 大尺寸触摸友好 */
    .layui-layer-setwin a {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        width: 40px !important;
        height: 40px !important;
        margin: 0 !important;
        font-size: 0 !important;
        line-height: 1 !important;
        border-radius: 50% !important;
        background-color: rgba(0, 0, 0, 0.05) !important;
        -webkit-tap-highlight-color: transparent !important;
    }

    .layui-layer-setwin a:active {
        background-color: rgba(0, 0, 0, 0.15) !important;
    }

    /* 关闭按钮 - 使用 X 图标 */
    .layui-layer-setwin .layui-layer-close {
        background-color: rgba(220, 53, 69, 0.1) !important;
        background-image: none !important;
        position: relative !important;
        width: 40px !important;
        height: 40px !important;
    }

    .layui-layer-setwin .layui-layer-close::before,
    .layui-layer-setwin .layui-layer-close::after {
        content: '' !important;
        position: absolute !important;
        left: 50% !important;
        top: 50% !important;
        width: 18px !important;
        height: 2px !important;
        background-color: #dc3545 !important;
        border-radius: 1px !important;
    }

    .layui-layer-setwin .layui-layer-close::before {
        transform: translate(-50%, -50%) rotate(45deg) !important;
    }

    .layui-layer-setwin .layui-layer-close::after {
        transform: translate(-50%, -50%) rotate(-45deg) !important;
    }

    .layui-layer-setwin .layui-layer-close:active {
        background-color: rgba(220, 53, 69, 0.25) !important;
    }

    /* 最大化按钮 - 使用方框图标 */
    .layui-layer-setwin .layui-layer-max {
        background-image: none !important;
        position: relative !important;
    }

    .layui-layer-setwin .layui-layer-max::before {
        content: '' !important;
        position: absolute !important;
        left: 50% !important;
        top: 50% !important;
        width: 14px !important;
        height: 14px !important;
        border: 2px solid #666 !important;
        border-radius: 2px !important;
        transform: translate(-50%, -50%) !important;
    }

    /* 隐藏最小化按钮 */
    .layui-layer-setwin .layui-layer-min {
        display: none !important;
    }

    /* Layer 弹窗底部按钮栏 */
    .layui-layer-btn {
        padding: 10px 15px !important;
        display: flex !important;
        flex-direction: row-reverse !important;
        justify-content: flex-start !important;
        gap: 10px !important;
    }

    .layui-layer-btn a {
        height: 44px !important;
        line-height: 44px !important;
        padding: 0 20px !important;
        font-size: 16px !important;
        border-radius: 22px !important;
        flex: none !important;
        min-width: 80px !important;
    }

    .layui-layer-btn .layui-layer-btn0 {
        background-color: #2196F3 !important;
        border-color: #2196F3 !important;
        color: #fff !important;
    }

    .layui-layer-btn .layui-layer-btn1 {
        background-color: #fff !important;
        border-color: #ddd !important;
        color: #666 !important;
    }

    /* Layer 遮罩 */
    .layui-layer-shade {
        background: rgba(0, 0, 0, 0.5);
    }

    /* Layer 提示框 */
    .layui-layer-dialog {
        min-width: 280px;
        max-width: 90%;
    }

    .layui-layer-dialog .layui-layer-content {
        padding: var(--mobile-spacing-lg);
        font-size: 16px;
        line-height: 1.6;
    }
}

/* ---------- zTree 树形组件移动端适配 ---------- */
@media (max-width: 768px) {
    .ztree {
        padding: var(--mobile-spacing-sm);
    }

    .ztree li {
        padding: 4px 0;
    }

    .ztree li a {
        min-height: var(--mobile-touch-target);
        padding: 8px 12px;
        font-size: 15px;
        display: flex;
        align-items: center;
        border-radius: var(--mobile-radius-sm);
    }

    .ztree li a:hover,
    .ztree li a.curSelectedNode {
        background: var(--mobile-bg);
    }

    /* 树节点图标 */
    .ztree li span.button {
        width: 32px;
        height: 32px;
        line-height: 32px;
        background-position: center;
    }

    /* 树节点展开/收起按钮 */
    .ztree li span.button.switch {
        width: 32px;
        height: 32px;
    }

    /* 树节点复选框 */
    .ztree li span.button.chk {
        width: 20px;
        height: 20px;
        margin: 6px 8px 6px 0;
    }
}

/* ---------- Bootstrap FileInput 文件上传移动端适配 ---------- */
@media (max-width: 768px) {
    .file-input {
        margin-bottom: var(--mobile-spacing-md);
    }

    /* 上传按钮 */
    .btn-file {
        min-height: var(--mobile-touch-target);
        padding: 10px 20px;
        font-size: 16px;
    }

    /* 文件预览容器 */
    .file-preview {
        border-radius: var(--mobile-radius);
        border: 1px solid var(--mobile-border);
    }

    .file-preview-thumbnails {
        display: flex;
        flex-wrap: wrap;
        gap: var(--mobile-spacing-sm);
        padding: var(--mobile-spacing-sm);
    }

    /* 文件预览项 */
    .file-preview-frame {
        width: calc(50% - var(--mobile-spacing-sm) / 2);
        margin: 0;
        border-radius: var(--mobile-radius-sm);
        overflow: hidden;
    }

    .file-preview-frame .kv-file-content {
        height: 120px;
    }

    /* 文件操作按钮 */
    .file-footer-buttons {
        padding: 6px;
    }

    .file-footer-buttons button {
        min-width: 32px;
        min-height: 32px;
        padding: 6px;
    }

    /* 拖拽上传区域 */
    .file-drop-zone {
        min-height: 150px;
        padding: var(--mobile-spacing-lg);
        border: 2px dashed var(--mobile-border);
        border-radius: var(--mobile-radius);
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
    }

    .file-drop-zone-title {
        font-size: 16px;
        color: var(--mobile-text-secondary);
        margin-top: var(--mobile-spacing-sm);
    }
}

/* ---------- iCheck 复选框/单选框移动端适配 ---------- */
@media (max-width: 768px) {
    .icheckbox_square-green,
    .iradio_square-green {
        width: 24px !important;
        height: 24px !important;
        margin-right: 8px;
    }

    .icheckbox_square-green ins,
    .iradio_square-green ins {
        width: 24px !important;
        height: 24px !important;
    }

    /* 增大触控区域 */
    .icheck-label {
        padding: 10px 0;
        display: inline-flex;
        align-items: center;
        min-height: var(--mobile-touch-target);
    }
}

/* ---------- Bootstrap Carousel 轮播图移动端适配 ---------- */
@media (max-width: 768px) {
    .carousel {
        border-radius: var(--mobile-radius);
        overflow: hidden;
    }

    .carousel-inner {
        border-radius: var(--mobile-radius);
    }

    .carousel-item img {
        width: 100%;
        height: auto;
        max-height: 300px;
        object-fit: cover;
    }

    /* 轮播指示器 */
    .carousel-indicators {
        bottom: 10px;
    }

    .carousel-indicators li {
        width: 8px;
        height: 8px;
        border-radius: 50%;
        margin: 0 4px;
    }

    /* 轮播控制按钮 */
    .carousel-control-prev,
    .carousel-control-next {
        width: 44px;
        opacity: 0.8;
    }

    .carousel-control-prev-icon,
    .carousel-control-next-icon {
        width: 32px;
        height: 32px;
    }
}

/* ---------- Summernote 富文本编辑器移动端适配 ---------- */
@media (max-width: 768px) {
    .note-editor {
        border-radius: var(--mobile-radius);
    }

    /* 工具栏 */
    .note-toolbar {
        padding: var(--mobile-spacing-sm);
        background: var(--mobile-bg);
        border-bottom: 1px solid var(--mobile-border);
    }

    .note-toolbar .btn-group {
        margin: 2px;
    }

    .note-toolbar .btn {
        min-width: 36px;
        min-height: 36px;
        padding: 8px;
        font-size: 14px;
    }

    /* 编辑区 */
    .note-editable {
        min-height: 200px;
        padding: var(--mobile-spacing-md);
        font-size: 16px;
        line-height: 1.6;
    }

    /* 状态栏 */
    .note-statusbar {
        background: var(--mobile-bg);
        border-top: 1px solid var(--mobile-border);
    }
}

/* ---------- Bootstrap TreeTable 树形表格移动端适配 ---------- */
@media (max-width: 768px) {
    .treetable {
        display: block;
        overflow-x: auto;
    }

    .treetable tbody tr {
        display: block;
        background: var(--mobile-card-bg);
        border-radius: var(--mobile-radius);
        margin-bottom: var(--mobile-spacing-md);
        padding: var(--mobile-spacing-md);
        box-shadow: var(--mobile-shadow);
    }

    .treetable tbody tr td {
        display: block;
        padding: 6px 0;
        border: none;
        border-bottom: 1px solid var(--mobile-border-light);
    }

    .treetable tbody tr td:last-child {
        border-bottom: none;
    }

    /* 树形缩进 */
    .treetable tbody tr td .treegrid-indent {
        width: 16px;
        height: 16px;
    }

    .treetable tbody tr td .treegrid-expander {
        width: 24px;
        height: 24px;
        line-height: 24px;
        font-size: 16px;
    }
}
/* ============================================================
   YiSha Admin Web - H5 Mobile Pages Styles
   特殊页面适配：登录页、首页、图片上传等
   ============================================================ */

/* ---------- 登录页移动端适配 ---------- */
@media (max-width: 768px) {
    body.login {
        background-size: cover;
        background-position: center;
        padding: var(--mobile-spacing-md);
    }

    /* 登录卡片 */
    body.login .login-card {
        width: 100% !important;
        max-width: 420px !important;
        padding: var(--mobile-spacing-xl) var(--mobile-spacing-lg) !important;
        border-radius: var(--mobile-radius-lg) !important;
        box-shadow: var(--mobile-shadow-lg) !important;
        margin: 0 auto;
    }

    /* 登录标题 */
    body.login .login-title h1 {
        font-size: 24px !important;
        margin-bottom: var(--mobile-spacing-lg);
    }

    body.login .login-title p {
        font-size: 14px !important;
    }

    /* 登录表单 */
    body.login .form-input {
        font-size: 16px !important;
        padding: 12px 16px 12px 48px !important;
        min-height: var(--mobile-touch-target);
        border-radius: var(--mobile-radius-sm);
    }

    body.login .input-icon {
        width: 40px !important;
        height: var(--mobile-touch-target);
        display: flex;
        align-items: center;
        justify-content: center;
    }

    /* 验证码行 - 保持水平排列 */
    body.login .captcha-row {
        display: flex;
        flex-direction: row !important;
        gap: var(--mobile-spacing-sm) !important;
        align-items: center;
    }

    body.login .captcha-row .input-wrap {
        flex: 1;
    }

    body.login .captcha-input {
        width: 100% !important;
    }

    body.login .captcha-img-wrap {
        width: 100px !important;
        height: 46px;
        flex-shrink: 0;
        display: flex;
        align-items: center;
        justify-content: center;
    }

    body.login .captcha-img-wrap img {
        max-width: 100%;
        height: 40px;
        border-radius: var(--mobile-radius-sm);
    }

    /* 记住密码行 - 保持水平排列 */
    body.login .remember-row {
        display: flex;
        flex-direction: row !important;
        align-items: center !important;
        justify-content: space-between;
        gap: var(--mobile-spacing-sm);
        margin: var(--mobile-spacing-md) 0;
    }

    body.login .remember-row input[type="checkbox"] {
        width: 20px;
        height: 20px;
        flex-shrink: 0;
        margin: 0;
    }

    body.login .remember-row label {
        margin: 0 0 0 0.5rem !important;
        flex-shrink: 0;
        line-height: 20px;
        display: flex;
        align-items: center;
    }

    body.login .forgot-link {
        margin-left: auto !important;
        white-space: nowrap;
        line-height: 20px;
        display: flex;
        align-items: center;
    }

    /* 登录按钮 */
    body.login .btn-login {
        width: 100%;
        padding: 12px !important;
        font-size: 16px !important;
        min-height: var(--mobile-touch-target);
        border-radius: var(--mobile-radius-sm);
    }

    /* 页脚链接 */
    body.login .footer-links {
        margin-top: var(--mobile-spacing-lg);
        font-size: 12px;
        text-align: center;
    }

    body.login .footer-links a {
        padding: 8px 12px;
        display: inline-block;
    }
}

/* ---------- 首页/仪表板移动端适配 ---------- */
@media (max-width: 768px) {
    /* 欢迎页 */
    .welcome-container {
        padding: var(--mobile-spacing-md);
    }

    .welcome-card {
        background: var(--mobile-card-bg);
        border-radius: var(--mobile-radius);
        padding: var(--mobile-spacing-lg);
        margin-bottom: var(--mobile-spacing-md);
        box-shadow: var(--mobile-shadow);
    }

    .welcome-title {
        font-size: 20px;
        font-weight: 600;
        margin-bottom: var(--mobile-spacing-md);
    }

    .welcome-text {
        font-size: 14px;
        line-height: 1.6;
        color: var(--mobile-text-secondary);
    }

    /* 统计卡片 */
    .stats-container {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: var(--mobile-spacing-md);
        padding: var(--mobile-spacing-md);
    }

    .stat-card {
        background: var(--mobile-card-bg);
        border-radius: var(--mobile-radius);
        padding: var(--mobile-spacing-md);
        box-shadow: var(--mobile-shadow);
        text-align: center;
    }

    .stat-icon {
        font-size: 32px;
        margin-bottom: var(--mobile-spacing-sm);
        color: var(--mobile-primary);
    }

    .stat-value {
        font-size: 24px;
        font-weight: 600;
        color: var(--mobile-text);
        margin-bottom: 4px;
    }

    .stat-label {
        font-size: 12px;
        color: var(--mobile-text-secondary);
    }

    /* 快捷入口 */
    .quick-links {
        display: grid;
        grid-template-columns: repeat(4, 1fr);
        gap: var(--mobile-spacing-md);
        padding: var(--mobile-spacing-md);
    }

    .quick-link-item {
        display: flex;
        flex-direction: column;
        align-items: center;
        padding: var(--mobile-spacing-md);
        background: var(--mobile-card-bg);
        border-radius: var(--mobile-radius);
        box-shadow: var(--mobile-shadow);
        text-decoration: none;
        color: var(--mobile-text);
    }

    .quick-link-icon {
        font-size: 28px;
        margin-bottom: var(--mobile-spacing-sm);
        color: var(--mobile-primary);
    }

    .quick-link-text {
        font-size: 12px;
        text-align: center;
    }
}

/* ---------- 图片上传页面移动端适配 ---------- */
@media (max-width: 768px) {
    /* 图片上传容器 */
    .image-upload-container {
        padding: var(--mobile-spacing-md);
    }

    /* 图片预览网格 */
    .image-preview-grid {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: var(--mobile-spacing-md);
        margin-bottom: var(--mobile-spacing-md);
    }

    .image-preview-item {
        position: relative;
        aspect-ratio: 1;
        border-radius: var(--mobile-radius);
        overflow: hidden;
        background: var(--mobile-bg);
        box-shadow: var(--mobile-shadow);
    }

    .image-preview-item img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

    /* 图片操作按钮 */
    .image-actions {
        position: absolute;
        top: 4px;
        right: 4px;
        display: flex;
        gap: 4px;
    }

    .image-action-btn {
        width: 32px;
        height: 32px;
        border-radius: 50%;
        background: rgba(0, 0, 0, 0.6);
        color: white;
        border: none;
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 14px;
    }

    /* 添加图片按钮 */
    .add-image-btn {
        aspect-ratio: 1;
        border: 2px dashed var(--mobile-border);
        border-radius: var(--mobile-radius);
        background: var(--mobile-bg);
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        color: var(--mobile-text-secondary);
        cursor: pointer;
    }

    .add-image-btn i {
        font-size: 32px;
        margin-bottom: var(--mobile-spacing-sm);
    }

    .add-image-btn span {
        font-size: 12px;
    }

    /* 图片轮播编辑 */
    .carousel-editor {
        background: var(--mobile-card-bg);
        border-radius: var(--mobile-radius);
        padding: var(--mobile-spacing-md);
        box-shadow: var(--mobile-shadow);
    }

    .carousel-editor .carousel-item {
        position: relative;
    }

    .carousel-editor .carousel-item img {
        width: 100%;
        height: 250px;
        object-fit: cover;
        border-radius: var(--mobile-radius);
    }
}

/* ---------- 用户头像上传移动端适配 ---------- */
@media (max-width: 768px) {
    .portrait-upload-container {
        padding: var(--mobile-spacing-md);
        text-align: center;
    }

    /* 当前头像 */
    .current-portrait {
        width: 120px;
        height: 120px;
        border-radius: 50%;
        margin: 0 auto var(--mobile-spacing-lg);
        overflow: hidden;
        box-shadow: var(--mobile-shadow);
    }

    .current-portrait img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

    /* 裁剪容器 */
    .crop-container {
        background: var(--mobile-card-bg);
        border-radius: var(--mobile-radius);
        padding: var(--mobile-spacing-md);
        margin-bottom: var(--mobile-spacing-md);
        box-shadow: var(--mobile-shadow);
    }

    .crop-area {
        width: 100%;
        max-height: 300px;
        margin-bottom: var(--mobile-spacing-md);
    }

    /* 裁剪控制按钮 */
    .crop-controls {
        display: flex;
        gap: var(--mobile-spacing-sm);
        justify-content: center;
    }

    .crop-controls .btn {
        flex: 1;
        max-width: 120px;
    }
}

/* ---------- 密码修改页面移动端适配 ---------- */
@media (max-width: 768px) {
    .password-change-container {
        padding: var(--mobile-spacing-md);
    }

    .password-form {
        background: var(--mobile-card-bg);
        border-radius: var(--mobile-radius);
        padding: var(--mobile-spacing-lg);
        box-shadow: var(--mobile-shadow);
    }

    .password-form .form-group {
        margin-bottom: var(--mobile-spacing-lg);
    }

    .password-form .form-group label {
        display: block;
        font-size: 14px;
        font-weight: 600;
        color: var(--mobile-text);
        margin-bottom: 6px;
    }

    .password-form .form-group input {
        width: 100%;
        min-height: var(--mobile-touch-target);
        font-size: 16px;
        padding: 10px 12px;
        border: 1px solid var(--mobile-border);
        border-radius: var(--mobile-radius-sm);
    }

    /* 密码强度指示器 */
    .password-strength {
        margin-top: var(--mobile-spacing-sm);
        height: 4px;
        background: var(--mobile-border);
        border-radius: 2px;
        overflow: hidden;
    }

    .password-strength-bar {
        height: 100%;
        transition: width 0.3s ease, background-color 0.3s ease;
    }

    .password-strength-bar.weak {
        width: 33%;
        background: #f44336;
    }

    .password-strength-bar.medium {
        width: 66%;
        background: #ff9800;
    }

    .password-strength-bar.strong {
        width: 100%;
        background: #4caf50;
    }

    /* 密码提示 */
    .password-tips {
        margin-top: var(--mobile-spacing-md);
        padding: var(--mobile-spacing-md);
        background: var(--mobile-bg);
        border-radius: var(--mobile-radius-sm);
        font-size: 12px;
        color: var(--mobile-text-secondary);
        line-height: 1.6;
    }

    .password-tips ul {
        margin: 0;
        padding-left: 20px;
    }
}

/* ---------- 用户导入页面移动端适配 ---------- */
@media (max-width: 768px) {
    .import-container {
        padding: var(--mobile-spacing-md);
    }

    /* 导入步骤 */
    .import-steps {
        background: var(--mobile-card-bg);
        border-radius: var(--mobile-radius);
        padding: var(--mobile-spacing-md);
        margin-bottom: var(--mobile-spacing-md);
        box-shadow: var(--mobile-shadow);
    }

    .import-step {
        display: flex;
        align-items: flex-start;
        margin-bottom: var(--mobile-spacing-md);
    }

    .import-step:last-child {
        margin-bottom: 0;
    }

    .import-step-number {
        width: 28px;
        height: 28px;
        border-radius: 50%;
        background: var(--mobile-primary);
        color: white;
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 14px;
        font-weight: 600;
        flex-shrink: 0;
        margin-right: var(--mobile-spacing-sm);
    }

    .import-step-content {
        flex: 1;
    }

    .import-step-title {
        font-size: 14px;
        font-weight: 600;
        color: var(--mobile-text);
        margin-bottom: 4px;
    }

    .import-step-desc {
        font-size: 12px;
        color: var(--mobile-text-secondary);
        line-height: 1.5;
    }

    /* 模板下载 */
    .template-download {
        background: var(--mobile-card-bg);
        border-radius: var(--mobile-radius);
        padding: var(--mobile-spacing-md);
        margin-bottom: var(--mobile-spacing-md);
        box-shadow: var(--mobile-shadow);
        text-align: center;
    }

    .template-download .btn {
        width: 100%;
    }

    /* 文件上传区域 */
    .file-upload-area {
        background: var(--mobile-card-bg);
        border-radius: var(--mobile-radius);
        padding: var(--mobile-spacing-md);
        box-shadow: var(--mobile-shadow);
    }
}

/* ---------- 错误页面移动端适配 ---------- */
@media (max-width: 768px) {
    .error-container {
        padding: var(--mobile-spacing-xl);
        text-align: center;
        min-height: 100vh;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
    }

    .error-code {
        font-size: 72px;
        font-weight: 700;
        color: var(--mobile-primary);
        margin-bottom: var(--mobile-spacing-md);
    }

    .error-title {
        font-size: 20px;
        font-weight: 600;
        color: var(--mobile-text);
        margin-bottom: var(--mobile-spacing-sm);
    }

    .error-message {
        font-size: 14px;
        color: var(--mobile-text-secondary);
        margin-bottom: var(--mobile-spacing-xl);
        line-height: 1.6;
    }

    .error-actions {
        display: flex;
        flex-direction: column;
        gap: var(--mobile-spacing-sm);
        width: 100%;
        max-width: 300px;
    }

    .error-actions .btn {
        width: 100%;
    }
}

/* ---------- 皮肤切换页面移动端适配 ---------- */
@media (max-width: 768px) {
    .skin-selector {
        padding: var(--mobile-spacing-md);
    }

    .skin-options {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: var(--mobile-spacing-md);
    }

    .skin-option {
        background: var(--mobile-card-bg);
        border-radius: var(--mobile-radius);
        padding: var(--mobile-spacing-md);
        box-shadow: var(--mobile-shadow);
        text-align: center;
        cursor: pointer;
        transition: transform 0.2s ease, box-shadow 0.2s ease;
    }

    .skin-option:active {
        transform: scale(0.98);
    }

    .skin-option.active {
        box-shadow: 0 0 0 2px var(--mobile-primary);
    }

    .skin-preview {
        width: 100%;
        height: 80px;
        border-radius: var(--mobile-radius-sm);
        margin-bottom: var(--mobile-spacing-sm);
    }

    .skin-name {
        font-size: 14px;
        color: var(--mobile-text);
    }
}

/* ---------- 详情页面移动端适配 ---------- */
@media (max-width: 768px) {
    .detail-container {
        padding: var(--mobile-spacing-md);
    }

    .detail-card {
        background: var(--mobile-card-bg);
        border-radius: var(--mobile-radius);
        padding: var(--mobile-spacing-md);
        margin-bottom: var(--mobile-spacing-md);
        box-shadow: var(--mobile-shadow);
    }

    .detail-header {
        font-size: 16px;
        font-weight: 600;
        color: var(--mobile-text);
        margin-bottom: var(--mobile-spacing-md);
        padding-bottom: var(--mobile-spacing-sm);
        border-bottom: 1px solid var(--mobile-border);
    }

    .detail-row {
        display: flex;
        padding: var(--mobile-spacing-sm) 0;
        border-bottom: 1px solid var(--mobile-border-light);
    }

    .detail-row:last-child {
        border-bottom: none;
    }

    .detail-label {
        flex-shrink: 0;
        width: 100px;
        font-size: 14px;
        color: var(--mobile-text-secondary);
    }

    .detail-value {
        flex: 1;
        font-size: 14px;
        color: var(--mobile-text);
        word-break: break-all;
    }
}
