/* 项目管理页面专用：顶部筛选 + 底部弹出日期选择器 */
.project-list-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 10px;
    flex-wrap: wrap;
}

.project-header-right {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}
.project-header-right .add-form {
    position: static;
    z-index: auto;
}
.project-header-right .add-btn {
    padding: 9px 16px;
    font-size: 0.88rem;
    box-shadow: 0 4px 14px rgba(107, 158, 255, 0.2);
}
.project-header-right .add-btn:hover {
    box-shadow: 0 6px 16px rgba(107, 158, 255, 0.25);
}

/* 表头内搜索框（与下拉同一行）继承下列 .project-search-input--in-table */
.project-search-input::placeholder {
    color: var(--color-text-muted, #5b6e8c);
}
.project-search-input:hover {
    border-color: rgba(124, 110, 255, 0.45);
}
.project-search-input:focus {
    border-color: #7c6eff;
    box-shadow: 0 0 0 3px rgba(124, 110, 255, 0.12);
    outline: none;
}

.project-filter {
    display: inline-flex;
    padding: 2px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.85);
    border: 1px solid rgba(110, 130, 200, 0.28);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

.filter-btn {
    border: none;
    background: transparent;
    color: var(--color-text-muted, #5b6e8c);
    font-size: 0.82rem;
    padding: 6px 12px;
    border-radius: 999px;
    cursor: pointer;
}
.filter-btn.active {
    background: var(--primary-gradient-btn, linear-gradient(135deg, #6b9eff, #7c6eff));
    color: #fff;
}
.filter-btn:not(.active):hover {
    background: rgba(124, 110, 255, 0.1);
    color: #2c5a8c;
}

/* 项目列表：整块表格外框（含搜索+筛选表头）；控件统一高度变量 */
.project-list-table-frame {
    --project-filter-ctrl-h: 2.25rem;
    margin-top: 6px;
    padding: 14px 14px 12px;
    border-radius: 16px;
    border: 1px solid rgba(110, 130, 200, 0.26);
    background: linear-gradient(165deg, rgba(255, 255, 255, 0.99) 0%, rgba(248, 250, 255, 0.96) 42%, rgba(244, 246, 252, 0.98) 100%);
    box-shadow:
        0 4px 26px rgba(72, 88, 128, 0.08),
        0 1px 0 rgba(255, 255, 255, 0.9) inset;
    -webkit-overflow-scrolling: touch;
}
.project-list-table-frame #projectTable {
    border-radius: 12px;
    overflow: hidden;
}

/* 筛选行：分区线、顶角圆角、与表格外框衔接（equipment-list 外包边见 base.css） */
.project-list-table-frame thead .project-thead-filters th {
    border-left: 1px solid rgba(110, 130, 200, 0.14);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.99) 0%, rgba(246, 248, 255, 0.94) 100%);
}
.project-list-table-frame thead .project-thead-filters th:first-child {
    border-left: none;
    border-top-left-radius: 10px;
}
.project-list-table-frame thead .project-thead-filters th:last-child {
    border-top-right-radius: 10px;
}
/* 项目列表：表头第一行 — 搜索（跨编号+名称）与人员下拉 */
.project-thead-filters th {
    vertical-align: middle;
    padding: 8px 8px;
    background: rgba(255, 255, 255, 0.72);
    border-bottom: 1px solid rgba(110, 130, 200, 0.2);
    font-weight: normal;
}
.project-list-table-frame .project-thead-filters th {
    border-bottom-color: rgba(110, 130, 200, 0.18);
}
.project-thead-filters + tr th {
    border-top: none;
}
.project-th-filter-spacer {
    background: rgba(252, 253, 255, 0.85);
}
.project-list-table-frame .project-th-filter-spacer {
    background: linear-gradient(180deg, rgba(250, 251, 252, 0.98) 0%, rgba(242, 244, 248, 0.93) 100%);
}
.project-th-search {
    min-width: 10rem;
    padding-left: 10px;
    padding-right: 10px;
}
/* 表内：搜索与下拉同高、同字号 */
.project-search-input--in-table,
.project-role-select--in-table {
    height: var(--project-filter-ctrl-h, 2.25rem);
    min-height: var(--project-filter-ctrl-h, 2.25rem);
    max-height: var(--project-filter-ctrl-h, 2.25rem);
    box-sizing: border-box;
    font-size: 0.8125rem;
    line-height: var(--project-filter-ctrl-h, 2.25rem);
    border-radius: 10px;
    border: 1px solid rgba(110, 130, 200, 0.32);
    background-color: #fff;
    color: var(--color-text, #2c3e4f);
    box-shadow: 0 1px 3px rgba(45, 55, 85, 0.06);
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.project-search-input--in-table {
    display: block;
    width: 100%;
    min-width: 0;
    margin: 0;
    padding: 0 10px;
    line-height: var(--project-filter-ctrl-h, 2.25rem);
    -webkit-appearance: none;
    appearance: none;
}
.project-th-filter {
    min-width: 6.5rem;
    max-width: 11rem;
}
.project-role-select {
    padding: 0 28px 0 10px;
    border-radius: 10px;
    border: 1px solid rgba(110, 130, 200, 0.32);
    background-color: #fff;
    color: var(--color-text, #2c3e4f);
    font-size: 0.8125rem;
    cursor: pointer;
    appearance: none;
    -webkit-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%238fa3d4' d='M2.5 4.5L6 8l3.5-3.5'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 10px center;
    box-shadow: 0 1px 3px rgba(45, 55, 85, 0.06);
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.project-role-select--in-table {
    display: block;
    width: 100%;
    min-width: 0;
    max-width: none;
    padding: 0 26px 0 10px;
    /* 与搜索框同高；部分浏览器忽略 select 的 line-height，用固定高度对齐 */
    line-height: normal;
    background-position: right 9px center;
}
.project-role-select:hover {
    border-color: rgba(124, 110, 255, 0.45);
}
.project-role-select:focus {
    outline: none;
    border-color: #7c6eff;
    box-shadow: 0 0 0 3px rgba(124, 110, 255, 0.12);
}

/* —— 自定义人员下拉（表头筛选 + 表单）：隐藏原生 select，按钮 + fixed 列表 —— */
.project-dd {
    position: relative;
    width: 100%;
    min-width: 0;
}
.project-dd--table {
    max-width: none;
}
select.project-dd-native {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    clip-path: inset(50%);
    white-space: nowrap;
    border: 0;
    opacity: 0;
    pointer-events: none;
}
.project-dd-trigger {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    width: 100%;
    margin: 0;
    font-family: inherit;
    text-align: left;
    cursor: pointer;
    box-sizing: border-box;
    transition:
        border-color 0.2s ease,
        box-shadow 0.2s ease,
        background 0.2s ease;
}
.project-dd-trigger--table {
    height: var(--project-filter-ctrl-h, 2.25rem);
    min-height: var(--project-filter-ctrl-h, 2.25rem);
    max-height: var(--project-filter-ctrl-h, 2.25rem);
    padding: 0 30px 0 10px;
    border-radius: 10px;
    border: 1px solid rgba(110, 130, 200, 0.32);
    background-color: #fff;
    color: var(--color-text, #2c3e4f);
    font-size: 0.8125rem;
    font-weight: 500;
    line-height: 1.2;
    box-shadow: 0 1px 3px rgba(45, 55, 85, 0.06);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.project-dd-trigger--form {
    padding: 9px 34px 9px 12px;
    border-radius: 12px;
    border: 1px solid rgba(110, 130, 200, 0.3);
    background: linear-gradient(180deg, #fff 0%, rgba(252, 253, 255, 0.98) 100%);
    color: var(--color-text, #2c3e4f);
    font-size: 0.9rem;
    font-weight: 500;
    line-height: 1.35;
    box-shadow: 0 1px 2px rgba(72, 88, 128, 0.05);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.project-dd-trigger--placeholder {
    color: var(--color-text-muted, #8b9bb8);
    font-weight: 400;
}
.project-dd-trigger::after {
    content: '';
    flex-shrink: 0;
    width: 10px;
    height: 10px;
    margin-left: auto;
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2394a8d4' d='M2.5 4.5L6 8l3.5-3.5'/%3E%3C/svg%3E")
        center / contain no-repeat;
    opacity: 0.88;
    transition: transform 0.2s ease, opacity 0.2s ease;
}
.project-dd.open .project-dd-trigger::after {
    transform: rotate(180deg);
    opacity: 1;
}
.project-dd-trigger--table:hover,
.project-dd-trigger--form:hover {
    border-color: rgba(124, 110, 255, 0.42);
}
.project-dd-trigger--table:focus {
    outline: none;
    border-color: #7c6eff;
    box-shadow: 0 0 0 3px rgba(124, 110, 255, 0.12);
}
.project-dd-trigger--form:focus {
    outline: none;
    border-color: #7c6eff;
    box-shadow: 0 0 0 3px rgba(124, 110, 255, 0.15);
}
.project-dd.open .project-dd-trigger--table,
.project-dd.open .project-dd-trigger--form {
    border-color: rgba(124, 110, 255, 0.55);
    box-shadow:
        0 0 0 3px rgba(124, 110, 255, 0.12),
        0 4px 14px rgba(107, 158, 255, 0.12);
}
.project-dd-list {
    list-style: none;
    margin: 0;
    padding: 6px;
    box-sizing: border-box;
    overflow-x: hidden;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    border-radius: 14px;
    border: 1px solid rgba(110, 130, 200, 0.22);
    background: linear-gradient(165deg, rgba(255, 255, 255, 0.99) 0%, rgba(248, 250, 255, 0.98) 55%, rgba(244, 246, 252, 0.99) 100%);
    box-shadow:
        0 4px 6px -1px rgba(60, 72, 100, 0.06),
        0 16px 40px -12px rgba(72, 88, 140, 0.22),
        0 0 0 1px rgba(255, 255, 255, 0.6) inset;
    scrollbar-width: thin;
    scrollbar-color: rgba(124, 110, 255, 0.35) transparent;
}
.project-dd-list[hidden] {
    display: none !important;
}
.project-dd.open .project-dd-list:not([hidden]) {
    animation: project-dd-fade 0.16s ease;
}
/* 列表挂到 body 时不在 .project-dd.open 下，与项目列表/新增项目下拉一致补动画 */
body > ul.project-dd-list:not([hidden]) {
    animation: project-dd-fade 0.16s ease;
}
@keyframes project-dd-fade {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}
.project-dd-list li[role='option'] {
    display: flex;
    align-items: center;
    margin: 2px 0;
    padding: 9px 12px 9px 14px;
    border-radius: 10px;
    font-size: 0.875rem;
    line-height: 1.35;
    color: var(--color-text, #2c3e4f);
    cursor: pointer;
    transition:
        background 0.15s ease,
        color 0.15s ease,
        transform 0.12s ease;
}
.project-dd-list li[role='option']:first-child {
    margin-top: 0;
}
.project-dd-list li[role='option']:last-child {
    margin-bottom: 0;
}
.project-dd-list li[role='option']:hover {
    background: rgba(124, 110, 255, 0.1);
    color: #1e3a5c;
}
.project-dd-list li.project-dd-option--selected {
    background: linear-gradient(120deg, rgba(107, 158, 255, 0.16), rgba(124, 110, 255, 0.14));
    color: #2a4a7a;
    font-weight: 600;
    box-shadow: 0 1px 0 rgba(255, 255, 255, 0.85) inset;
}
.project-dd-list li.project-dd-option--selected::before {
    content: '';
    flex-shrink: 0;
    width: 6px;
    height: 6px;
    margin-right: 8px;
    border-radius: 50%;
    background: linear-gradient(135deg, #6b9eff, #7c6eff);
}

/* 须高于 .form-container(10100)，否则在「新增/修改项目」弹窗里选日期会被挡在下一层 */
.dp-mask {
    position: fixed;
    left: 0; top: 0; right: 0; bottom: 0;
    background: rgba(22, 32, 52, 0.48);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    z-index: 11000;
    display: none;
}

.dp-sheet {
    position: fixed;
    left: 0; right: 0; bottom: 0;
    z-index: 11050;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.99) 0%, rgba(248, 250, 255, 0.97) 100%);
    border-top: 1px solid rgba(110, 130, 200, 0.24);
    box-shadow:
        0 -8px 32px rgba(72, 88, 128, 0.1),
        0 -1px 0 rgba(255, 255, 255, 0.9) inset;
    border-top-left-radius: 20px;
    border-top-right-radius: 20px;
    padding: 16px 16px 18px;
    transform: translateY(110%);
    transition: transform 0.22s cubic-bezier(0.32, 0.72, 0, 1);
    max-width: min(720px, 100%);
    margin: 0 auto;
    max-height: 90vh;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}
.dp-sheet.show {
    transform: translateY(0);
}

.dp-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 10px;
}

.dp-title {
    color: var(--color-text, #2c3e4f);
    font-weight: 600;
    letter-spacing: 0.06em;
    font-size: 0.95rem;
}
.dp-actions {
    display: flex;
    gap: 8px;
}
.dp-btn {
    padding: 6px 10px;
    border-radius: 999px;
    border: 1px solid rgba(110, 130, 200, 0.35);
    background: rgba(255, 255, 255, 0.9);
    color: #2c5a8c;
    cursor: pointer;
    font-size: 0.85rem;
}
.dp-btn:hover {
    filter: brightness(1.08);
}

.dp-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 6px;
}

.dp-week {
    color: var(--color-text-muted, #5b6e8c);
    font-size: 0.78rem;
    text-align: center;
    padding: 4px 0 8px;
}
.dp-day {
    text-align: center;
    padding: 10px 0;
    border-radius: 12px;
    border: 1px solid rgba(110, 130, 200, 0.22);
    color: var(--color-text, #2c3e4f);
    background: rgba(255, 255, 255, 0.9);
    cursor: pointer;
    user-select: none;
    font-size: 0.88rem;
}
.dp-day.muted {
    opacity: 0.35;
}
.dp-day:hover {
    border-color: rgba(77,163,255,0.75);
}
.dp-day.selected {
    background: linear-gradient(135deg, rgba(107,158,255,0.22), rgba(124,110,255,0.18));
    border-color: rgba(124,110,255,0.55);
}
/* 未选中时标出「今天」，避免 iOS 等环境下默认日期在面板里看不出来 */
.dp-day.dp-day-today {
    font-weight: 700;
    border-color: rgba(100, 150, 220, 0.55);
    box-shadow: 0 0 0 2px rgba(142, 180, 255, 0.35);
}

.date-input {
    cursor: pointer;
}

.end-date-cell {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}
.deadline-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 20px;
    padding: 1px 8px;
    border-radius: 999px;
    border: 1px solid transparent;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.02em;
}
.deadline-badge.deadline-low {
    color: #65749b;
    background: rgba(170, 184, 220, 0.22);
    border-color: rgba(141, 161, 212, 0.35);
}
.deadline-badge.deadline-mid {
    color: #8e6838;
    background: rgba(236, 201, 151, 0.24);
    border-color: rgba(220, 177, 114, 0.4);
}
.deadline-badge.deadline-high {
    color: #a15835;
    background: rgba(247, 178, 144, 0.25);
    border-color: rgba(231, 146, 103, 0.45);
}
.deadline-badge.deadline-urgent {
    color: #a23f4f;
    background: rgba(245, 156, 171, 0.28);
    border-color: rgba(230, 109, 131, 0.5);
}
.project-row.near-deadline {
    font-weight: 600;
}
.project-row.near-deadline-low td {
    color: #5e6f93;
}
.project-row.near-deadline-mid td {
    color: #7a6240;
}
.project-row.near-deadline-high td {
    color: #8d5138;
}
.project-row.near-deadline-urgent td {
    color: #8f3a49;
}

#projectTable td:nth-child(9) .op-actions {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    flex-wrap: wrap;
}
#projectTable td:nth-child(9) .btn-delete {
    margin-left: 0;
}
/* 用户权限下可访问的项目行：表绿 */
.project-row.project-row-has-access {
    background: rgba(74, 196, 142, 0.12);
    border-left: 3px solid rgba(74, 196, 142, 0.55);
}
.project-row.project-row-has-access td:first-child {
    position: relative;
    padding-left: 66px;
}
.project-row.project-row-has-access td:first-child::before {
    content: "可查看";
    position: absolute;
    left: 10px;
    top: 50%;
    transform: translateY(-50%);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 44px;
    height: 20px;
    padding: 0 8px;
    border-radius: 999px;
    background: rgba(74, 196, 142, 0.2);
    border: 1px solid rgba(74, 196, 142, 0.35);
    color: #2f7a58;
    font-size: 0.74rem;
    font-weight: 600;
    letter-spacing: 0.02em;
}

/* 项目页 project.html 布局与导航（原内联样式） */
#authGuard {
    position: fixed; left: 0; top: 0; right: 0; bottom: 0;
    background: rgba(246, 249, 252, 0.92);
    z-index: 9999;
    display: flex; align-items: center; justify-content: center;
    color: var(--color-text-muted, #5b6e8c); font-size: 1rem;
    backdrop-filter: blur(6px);
}
#pageContent {
    display: none;
}
.nav-bar-flex {
    display: flex; justify-content: space-between; align-items: center;
    flex-wrap: wrap; gap: 10px;
}
.nav-right {
    display: flex; align-items: center; gap: 10px;
}
.nav-link {
    color: var(--color-link, #5b7cbd);
    text-decoration: none;
    padding: 6px 12px;
    border-radius: 10px;
    border: 1px solid rgba(110,130,200,0.35);
    background: rgba(255,255,255,0.75);
    font-size: 0.9rem;
    transition: color 0.2s, background 0.2s, border-color 0.2s;
}
.nav-link:hover {
    color: #2c5a8c;
    background: rgba(124,110,255,0.1);
    border-color: rgba(124,110,255,0.45);
}
.nav-btn-complete {
    color: #1f8a5c;
    padding: 6px 12px;
    border-radius: 40px;
    border: 1px solid rgba(42, 157, 106, 0.45);
    background: rgba(42, 157, 106, 0.1);
    font-size: 0.9rem;
    cursor: pointer;
    transition: color 0.2s, background 0.2s, border-color 0.2s;
}
.nav-btn-complete:hover:not(:disabled) {
    color: #176648;
    background: rgba(42, 157, 106, 0.18);
    border-color: rgba(42, 157, 106, 0.55);
}
.nav-btn-complete:disabled {
    opacity: 0.85;
    cursor: default;
    color: var(--color-text-muted, #5b6e8c);
    border-color: rgba(110, 130, 200, 0.3);
    background: rgba(110, 130, 200, 0.08);
}
.nav-account {
    color: var(--color-text, #2c3e4f);
    padding: 0 4px;
}
.nav-logout {
    padding: 6px 12px;
    border-radius: 40px;
    border: 1px solid rgba(255,138,122,0.45);
    background: rgba(255,138,122,0.1);
    color: #c74a3a;
    cursor: pointer;
    font-size: 0.9rem;
}
.nav-logout:hover {
    background: rgba(255,138,122,0.18);
}
.global-top-right {
    position: fixed;
    top: 0; 
    right: 0;
    z-index: 9998;
    display: flex; 
    align-items: center; 
    gap: 12px;
    padding: 12px 20px;
    background: var(--color-bg-nav, rgba(255, 255, 255, 0.88));
    border-bottom-left-radius: 16px;
    box-shadow: var(--shadow-nav, 0 2px 12px rgba(0, 0, 0, 0.04));
    backdrop-filter: blur(12px);
}
.global-top-right a {
    color: var(--color-link, #5b7cbd);
    text-decoration: none;
    font-size: 0.9rem;
    font-weight: 500;
    padding: 8px 16px;
    border-radius: 10px;
    border: 1px solid rgba(110,130,200,0.35);
    background: var(--primary-gradient-nav, linear-gradient(135deg, rgba(107, 158, 255, 0.12) 0%, rgba(124, 110, 255, 0.1) 100%));
    transition: all 0.25s ease;
    box-shadow: 0 2px 8px rgba(0,0,0,0.04);
}
.global-top-right a:hover {
    color: #2c5a8c;
    background: var(--primary-gradient-nav-hover, linear-gradient(135deg, rgba(107, 158, 255, 0.22) 0%, rgba(124, 110, 255, 0.18) 100%));
    border-color: rgba(124,110,255,0.45);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(107, 158, 255, 0.15);
}
.global-top-right .gt-account {
    color: var(--color-text, #2c3e4f);
    padding: 0 8px;
    font-weight: 500;
    font-size: 0.95rem;
}
.global-top-right .gt-logout {
    padding: 8px 16px;
    border-radius: 40px;
    border: 1px solid rgba(255,138,122,0.45);
    background: rgba(255,138,122,0.1);
    color: #c74a3a;
    cursor: pointer;
    font-size: 0.9rem;
    font-weight: 500;
    transition: all 0.25s ease;
    box-shadow: 0 2px 8px rgba(0,0,0,0.04);
}
.global-top-right .gt-logout:hover {
    background: rgba(255,138,122,0.18);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(255,138,122,0.15);
    color: #c74a3a;
}

/* 项目新增/编辑弹窗视觉与按钮布局优化 */
#projectFormContainer.form-container {
    background: var(--modal-mask-bg, linear-gradient(165deg, rgba(32, 42, 58, 0.45) 0%, rgba(22, 32, 48, 0.55) 100%));
    backdrop-filter: blur(10px) saturate(1.05);
    -webkit-backdrop-filter: blur(10px) saturate(1.05);
}
#projectFormContainer .form-content {
    width: min(92vw, 620px);
    max-width: 620px;
    padding: 0;
    border-radius: var(--radius-lg, 24px);
}
#projectFormContainer .form-content h2 {
    margin-bottom: 14px;
}
#projectFormContainer #projectForm {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px 14px;
}
#projectFormContainer #projectForm .form-group:first-of-type {
    grid-column: 1 / -1;
}
#projectFormContainer .form-actions {
    grid-column: 1 / -1;
    margin-top: 6px;
    justify-content: flex-end;
    gap: 10px;
}
#projectFormContainer .form-actions .btn-cancel,
#projectFormContainer .form-actions .btn-submit {
    min-width: 104px;
    padding: 9px 16px;
    font-weight: 600;
}

@media (max-width: 780px) {
    #projectFormContainer #projectForm {
        grid-template-columns: minmax(0, 1fr);
    }
}

/* 项目详情页 project_detail.html 独有样式（原内联） */
#detailAuthGuard {
    position: fixed; left: 0; top: 0; right: 0; bottom: 0;
    background: rgba(246, 249, 252, 0.92);
    z-index: 9999;
    display: flex; align-items: center; justify-content: center;
    color: var(--color-text-muted, #5b6e8c); font-size: 1rem;
    backdrop-filter: blur(6px);
}

/* 整页与内容区、区块与浅色卡片一致 */
.project-detail-page {
    background: transparent;
}
.project-detail-page .content {
    min-height: 280px;
    background: transparent;
}
.project-detail-page .detail-section {
    background: rgba(255, 255, 255, 0.95);
    border: 1px solid rgba(120, 135, 185, 0.14);
    box-shadow: var(--shadow-card, 0 4px 24px rgba(80, 95, 120, 0.06));
    /* 关闭毛玻璃，否则祖先会形成 fixed 定位包含块，材料表「是否购买/到货」下拉用 position:fixed 时会与触发按钮错位 */
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
}
.project-detail-page .detail-section h2,
.project-detail-page .detail-section h3,
.project-detail-page .detail-section strong {
    color: var(--color-text, #3d4a56);
}
.project-detail-page .detail-basic-grid,
.project-detail-page .detail-subrow,
.project-detail-page .detail-status-flag,
.project-detail-page .detail-materials-links,
.project-detail-page .detail-section-tip {
    color: var(--color-text-muted, #6b7788);
}
/* PCB 图为「无」时隐藏 PCB打板情况 整块 */
.project-detail-page .detail-section.detail-section-pcb-board-hidden {
    display: none !important;
}
/* 图片预览区与原理图设计等区块背景一致 */
.project-detail-page .detail-image-preview,
.project-detail-page #schematicPreview,
.project-detail-page .detail-img-item,
.project-detail-page .detail-img-item-placeholder {
    background: rgba(255, 255, 255, 0.65);
    border-radius: 10px;
    min-height: 40px;
    border: 1px solid rgba(110, 130, 200, 0.18);
}
.project-detail-page .detail-image-preview-multi {
    background: transparent;
}
/* 拖入图片到该区块上传时的视觉反馈 */
.project-detail-page .detail-section.detail-section-drag-over {
    outline: 2px dashed rgba(124, 110, 255, 0.65);
    outline-offset: 4px;
    border-radius: var(--radius-lg, 16px);
    background: rgba(124, 110, 255, 0.06);
    transition: outline-color 0.15s ease, background 0.15s ease;
}
/* 单张图时弱化边框，避免明显“框架”感 */
.project-detail-page .detail-image-preview-multi .detail-img-item:only-child {
    border-color: rgba(103, 132, 255, 0.2);
    max-width: 100%;
}

/* 项目进度条（项目信息与项目详细功能之间） */
.detail-progress-section {
    margin-bottom: 28px;
    padding: 20px 18px;
    background: rgba(255, 255, 255, 0.72);
    border-radius: var(--radius-lg, 20px);
    border: 1px solid rgba(110, 130, 200, 0.2);
    box-shadow: var(--shadow-card, 0 12px 32px rgba(0, 0, 0, 0.08));
}
.detail-progress-title {
    font-size: 1.02rem;
    font-weight: 600;
    color: var(--color-text, #2c3e4f);
    margin-bottom: 14px;
    letter-spacing: 0.01em;
}
.detail-progress-bar {
    height: 14px;
    border-radius: 999px;
    background: rgba(110, 130, 200, 0.12);
    box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.06);
    overflow: hidden;
    margin-bottom: 18px;
    border: 1px solid rgba(110, 130, 200, 0.2);
}
.detail-progress-fill {
    height: 100%;
    border-radius: 999px;
    background: linear-gradient(90deg, #7c6eff, #9b8cff);
    width: 0%;
    transition: width 0.4s cubic-bezier(0.34, 1.2, 0.64, 1);
    box-shadow: 0 0 8px rgba(124, 110, 255, 0.5);
}
.detail-progress-steps {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 10px 14px;
}
.detail-progress-step {
    font-size: 0.8rem;
    color: var(--color-text-muted, #5b6e8c);
    padding: 6px 12px;
    border-radius: 999px;
    background: rgba(155, 168, 230, 0.1);
    border: 1px solid rgba(120, 135, 185, 0.18);
    transition: color 0.25s ease, background 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease;
}
.detail-progress-step.done {
    color: #2f7a60;
    background: rgba(130, 200, 170, 0.16);
    border-color: rgba(100, 180, 150, 0.34);
    box-shadow: 0 0 0 1px rgba(100, 180, 150, 0.1);
}

.detail-select {
    min-width: 100px;
}

.detail-current-tag {
    display: inline-block;
    padding: 6px 12px;
    border-radius: 999px;
    background: rgba(155, 168, 230, 0.14);
    color: #5d6d87;
    font-size: 0.95rem;
}
.btn-confirm {
    color: #4b3bdb;
    background: rgba(124, 110, 255, 0.12);
    border: 1px solid rgba(124, 110, 255, 0.45);
    font-weight: 600;
}
.btn-confirm:hover {
    color: #3d2fc4;
    background: rgba(124, 110, 255, 0.2);
    border-color: #7c6eff;
}
.btn-save {
    color: #1f8a5c;
    background: rgba(42, 157, 106, 0.12);
    border: 1px solid rgba(42, 157, 106, 0.45);
    font-weight: 600;
}
.btn-save:hover {
    color: #176648;
    background: rgba(42, 157, 106, 0.2);
    border-color: rgba(42, 157, 106, 0.55);
}

.detail-subrow label {
    min-width: 42px;
    color: var(--color-text, #3d4a56);
    font-size: 0.88rem;
    font-weight: 500;
}
.detail-subrow select {
    background: #fff;
    color: var(--color-text, #2c3e4f);
    border: 1px solid rgba(110, 130, 200, 0.3);
    border-radius: 10px;
    padding: 8px 12px;
    font-size: 0.9rem;
    min-width: 96px;
    cursor: pointer;
    transition: border-color 0.2s, box-shadow 0.2s;
}
.detail-subrow select:hover {
    border-color: rgba(124, 110, 255, 0.45);
}
.detail-subrow select:focus {
    border-color: #7c6eff;
    box-shadow: 0 0 0 3px rgba(124, 110, 255, 0.15);
    outline: none;
}
.detail-subrow select option {
    background: #fff;
    color: var(--color-text, #2c3e4f);
}

.detail-section input[type="text"],
.detail-section .detail-img-input,
.detail-section .detail-img-textarea,
.detail-material-form input[type="text"] {
    background: #fff;
    color: var(--color-text, #2c3e4f);
    border: 1px solid rgba(110, 130, 200, 0.3);
    border-radius: 10px;
    padding: 8px 12px;
    font-size: 0.9rem;
    transition: border-color 0.2s, box-shadow 0.2s;
}
.detail-section input[type="text"]::placeholder,
.detail-section .detail-img-textarea::placeholder,
.detail-material-form input[type="text"]::placeholder {
    color: var(--color-text-muted, #5b6e8c);
}
.detail-section input[type="text"]:hover,
.detail-section .detail-img-textarea:hover,
.detail-material-form input[type="text"]:hover {
    border-color: rgba(124, 110, 255, 0.45);
}
.detail-section input[type="text"]:focus,
.detail-section .detail-img-textarea:focus,
.detail-material-form input[type="text"]:focus {
    border-color: #7c6eff;
    box-shadow: 0 0 0 3px rgba(124, 110, 255, 0.15);
    outline: none;
}

.detail-textarea {
    background: #fff !important;
    color: var(--color-text, #2c3e4f) !important;
    border: 1px solid rgba(110, 130, 200, 0.3) !important;
    border-radius: 12px !important;
    padding: 10px 14px !important;
    font-size: 0.92rem !important;
    line-height: 1.55;
    transition: border-color 0.2s, box-shadow 0.2s;
}
.detail-textarea::placeholder {
    color: var(--color-text-muted, #5b6e8c);
}
.detail-textarea:hover {
    border-color: rgba(124, 110, 255, 0.45) !important;
}
.detail-textarea:focus {
    border-color: #7c6eff !important;
    box-shadow: 0 0 0 3px rgba(124, 110, 255, 0.15);
    outline: none;
}

.detail-img-loading {
    display: inline-block;
    color: var(--color-text-muted, #5b6e8c);
    font-size: 0.9rem;
    padding: 8px 0;
}
.detail-img-item-placeholder {
    min-height: 200px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.detail-img-placeholder-bg {
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(135deg, rgba(246, 249, 252, 0.95) 0%, rgba(238, 242, 248, 0.98) 100%);
    border-radius: inherit;
    pointer-events: none;
}
.detail-img-item-fail + .btn-retry-img,
.btn-retry-img {
    margin-top: 8px;
    padding: 6px 12px;
    font-size: 0.85rem;
    color: #3d6ab8;
    background: rgba(110, 130, 200, 0.1);
    border: 1px solid rgba(110, 130, 200, 0.35);
    border-radius: 8px;
    cursor: pointer;
}
.btn-retry-img:hover {
    background: rgba(124, 110, 255, 0.14);
    border-color: rgba(124, 110, 255, 0.45);
}
/* 图片未完全加载前不显示，避免只显示 1/3 再补全；占位高度与预览区一致，整块不被切断 */
.detail-img-item img.detail-img-pending {
    opacity: 0;
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    min-height: 200px;
    object-fit: contain;
    pointer-events: none;
}
.project-detail-page .detail-img-item,
.project-detail-page .detail-image-preview-multi .detail-img-item {
    min-height: 200px;
    aspect-ratio: 4/3;
}
.project-detail-page .detail-image-preview-multi .detail-img-item img {
    object-fit: contain;
}
.detail-subrow {
    gap: 10px;
    margin-bottom: 8px;
}

/* 电路图/PCB 图片行：标签与保存垂直居中，保存右对齐与完成同列 */
#schematicInputRow,
#pcbInputRow {
    display: flex;
    align-items: center;
    flex: 1;
    min-width: 0;
    gap: 10px;
}
.detail-img-actions {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-left: auto;
    flex-shrink: 0;
}
.detail-file-input {
    position: absolute;
    width: 0;
    height: 0;
    opacity: 0;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
}
.btn-upload {
    color: #3d6ab8;
    background: rgba(110, 130, 200, 0.1);
    border: 1px solid rgba(110, 130, 200, 0.4);
    font-weight: 500;
}
.btn-upload:hover {
    color: #2c5a8c;
    background: rgba(124, 110, 255, 0.14);
    border-color: #7c6eff;
}
.btn-upload:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}
#schematicInputRow .detail-img-actions,
#pcbInputRow .detail-img-actions {
    margin-left: auto;
}
#schematicInputRow .btn-save,
#pcbInputRow .btn-save {
    margin-left: 0;
}
.detail-material-form .form-row {
    gap: 10px;
}

#materialTable .mat-dropdown {
    position: relative;
    display: inline-block;
    width: 100%;
    min-width: 72px;
}
#materialTable .mat-dropdown-trigger {
    position: relative;
    width: 100%;
    text-align: left;
    background: #fff;
    color: var(--color-text, #2c3e4f);
    border: 1px solid rgba(110, 130, 200, 0.3);
    border-radius: 8px;
    padding: 6px 10px;
    font-size: 0.85rem;
    cursor: pointer;
    transition: border-color 0.2s, box-shadow 0.2s;
    padding-right: 24px;
}
#materialTable .mat-dropdown-trigger::after {
    content: '';
    position: absolute;
    right: 8px;
    top: 50%;
    margin-top: -3px;
    border: 5px solid transparent;
    border-top-color: #8b9ec4;
}
#materialTable .mat-dropdown-trigger.mat-value-no {
    color: #ff6b6b;
    font-weight: 600;
}
#materialTable .mat-dropdown:hover .mat-dropdown-trigger {
    border-color: rgba(124, 110, 255, 0.45);
}
#materialTable .mat-dropdown-open .mat-dropdown-trigger {
    border-color: #7c6eff;
    box-shadow: 0 0 0 3px rgba(124, 110, 255, 0.15);
}

#materialTable .mat-dropdown-list {
    position: absolute;
    left: 0;
    top: 100%;
    margin: 4px 0 0;
    padding: 4px 0;
    min-width: 100%;
    list-style: none;
    background: #fff;
    border: 1px solid rgba(110, 130, 200, 0.28);
    border-radius: 10px;
    box-shadow: var(--shadow-card, 0 12px 32px rgba(0, 0, 0, 0.08));
    z-index: 10000;
    display: none;
}
#materialTable .mat-dropdown-open .mat-dropdown-list {
    display: block;
}
/* 器件清单下拉打开时用 fixed 脱离表格容器，避免被裁剪；滚动/缩放时由 JS 更新位置，始终对齐触发按钮 */
#materialTable .mat-dropdown-list.mat-dropdown-list-fixed {
    position: fixed;
    margin: 0;
    left: var(--mat-list-left, 0);
    top: var(--mat-list-top, 0);
    min-width: var(--mat-list-width, 72px);
    z-index: 10000;
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.1), 0 0 0 1px rgba(110, 130, 200, 0.12);
}
#materialTable .mat-dropdown-list [role="option"] {
    padding: 8px 12px;
    font-size: 0.88rem;
    color: var(--color-text, #2c3e4f);
    cursor: pointer;
    transition: background 0.15s;
}
#materialTable .mat-dropdown-list [role="option"]:hover {
    background: rgba(124, 110, 255, 0.08);
}
#materialTable .mat-dropdown-list [role="option"]:first-child {
    border-radius: 4px 4px 0 0;
}
#materialTable .mat-dropdown-list [role="option"]:last-child {
    border-radius: 0 0 4px 4px;
}

.detail-material-form .btn-submit {
    min-width: 80px;
    padding: 8px 18px;
    font-size: 0.9rem;
    font-weight: 600;
    border-radius: 40px;
    border: 1px solid rgba(42, 157, 106, 0.45);
    background: rgba(42, 157, 106, 0.12);
    color: #1f8a5c;
    cursor: pointer;
    transition: border-color 0.2s, background 0.2s, color 0.2s;
}
.detail-material-form .btn-submit:hover {
    background: rgba(42, 157, 106, 0.2);
    color: #176648;
    border-color: rgba(42, 157, 106, 0.55);
}
.detail-material-form .btn-submit:active {
    transform: scale(0.98);
}

.data-loading-block {
    text-align: center;
    padding: 32px 24px;
    color: var(--color-text-muted, #5b6e8c);
    font-size: 0.95rem;
}
.data-loading-row {
    color: var(--color-text-muted, #5b6e8c) !important;
}
.content.detail-readonly #materialTable th:last-child,
.content.detail-readonly #materialTable td:last-child {
    display: none;
}

/* 项目详情页确认弹窗使用 base.css 公共样式，无需重复定义 */

/* 从常购器材选择弹层 */
.mat-equipment-picker-wrap {
    position: fixed;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    z-index: 10000;
    display: none;
    align-items: flex-start;
    justify-content: flex-start;
    pointer-events: none;
}
.mat-equipment-picker-wrap.mat-equipment-picker-open {
    display: block;
    pointer-events: auto;
}
.mat-equipment-picker-mask {
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    background: rgba(44, 62, 79, 0.35);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}
.mat-equipment-picker-dialog {
    position: fixed;
    z-index: 1;
    width: min(480px, calc(100vw - 24px));
    max-width: 480px;
    max-height: min(80vh, calc(100vh - 24px));
    margin: 0;
    background: rgba(255, 255, 255, 0.96);
    border: 1px solid rgba(110, 130, 200, 0.22);
    border-radius: var(--radius-lg, 20px);
    box-shadow: var(--shadow-card, 0 12px 32px rgba(0, 0, 0, 0.08));
    display: flex;
    flex-direction: column;
}
.mat-equipment-picker-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    border-bottom: 1px solid rgba(110, 130, 200, 0.18);
}
.mat-equipment-picker-title {
    margin: 0;
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--color-text, #2c3e4f);
}
.mat-equipment-picker-close {
    width: 32px;
    height: 32px;
    padding: 0;
    border: none;
    background: transparent;
    color: var(--color-text-muted, #5b6e8c);
    font-size: 1.5rem;
    line-height: 1;
    cursor: pointer;
    border-radius: 8px;
    transition: color 0.2s, background 0.2s;
}
.mat-equipment-picker-close:hover {
    color: var(--color-text, #2c3e4f);
    background: rgba(124, 110, 255, 0.1);
}
.mat-equipment-picker-body {
    padding: 16px 20px 20px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.mat-equipment-search {
    width: 100%;
    box-sizing: border-box;
    background: #fff;
    color: var(--color-text, #2c3e4f);
    border: 1px solid rgba(110, 130, 200, 0.3);
    border-radius: 12px;
    padding: 10px 14px;
    font-size: 0.9rem;
}
.mat-equipment-search::placeholder {
    color: var(--color-text-muted, #5b6e8c);
}
.mat-equipment-search:focus {
    outline: none;
    border-color: #7c6eff;
    box-shadow: 0 0 0 3px rgba(124, 110, 255, 0.15);
}
.mat-equipment-list {
    max-height: 280px;
    overflow-y: auto;
    border: 1px solid rgba(110, 130, 200, 0.22);
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.85);
}
.mat-equipment-list::-webkit-scrollbar {
    width: 8px;
}
.mat-equipment-list::-webkit-scrollbar-track {
    background: rgba(103, 132, 255, 0.1);
    border-radius: 4px;
}
.mat-equipment-list::-webkit-scrollbar-thumb {
    background: rgba(103, 132, 255, 0.4);
    border-radius: 4px;
}
.mat-equipment-item {
    padding: 12px 14px;
    font-size: 0.9rem;
    color: var(--color-text, #2c3e4f);
    cursor: pointer;
    border-bottom: 1px solid rgba(110, 130, 200, 0.12);
    transition: background 0.15s;
}
.mat-equipment-item:last-child {
    border-bottom: none;
}
.mat-equipment-item:hover {
    background: rgba(124, 110, 255, 0.08);
}
.mat-equipment-list-empty {
    padding: 24px 16px;
    text-align: center;
    color: var(--color-text-muted, #5b6e8c);
    font-size: 0.9rem;
}
.mat-equipment-picker-tip {
    margin: 0;
    font-size: 0.8rem;
    color: var(--color-text-muted, #5b6e8c);
}
.detail-material-form .btn-pick-equipment {
    padding: 8px 14px;
    font-size: 0.85rem;
    border-radius: 40px;
    border: 1px solid rgba(110, 130, 200, 0.35);
    background: rgba(110, 130, 200, 0.08);
    color: #2c5a8c;
    cursor: pointer;
    transition: border-color 0.2s, background 0.2s, color 0.2s;
}
.detail-material-form .btn-pick-equipment:hover {
    background: rgba(124, 110, 255, 0.12);
    border-color: #7c6eff;
    color: #2c5a8c;
}

.detail-materials-links {
    margin-top: 8px;
    padding: 8px 0;
}
.detail-materials-links .detail-material-link {
    color: var(--color-link, #5b7cbd);
    text-decoration: none;
    word-break: break-all;
}
.detail-materials-links .detail-material-link:hover {
    text-decoration: underline;
}

.detail-input-url {
    width: 100%;
    max-width: 720px;
    min-height: 48px;
    padding: 12px 16px;
    border-radius: 12px;
    border: 1px solid rgba(110, 130, 200, 0.3);
    background: #fff;
    color: var(--color-text, #2c3e4f);
    font-size: 1rem;
    line-height: 1.55;
}
.detail-input-url::placeholder {
    color: var(--color-text-muted, #5b6e8c);
}

/* 软件/硬件资料大输入框：支持粘贴多行网盘分享文案 */
.detail-subrow-materials {
    align-items: flex-start;
    gap: 12px;
}
.detail-materials-label {
    flex-shrink: 0;
    padding-top: 12px;
}
.detail-materials-textarea {
    max-width: 100%;
    min-height: 4.5rem;
    resize: vertical;
    font-family: inherit;
    white-space: pre-wrap;
    word-break: break-all;
}
.detail-materials-textarea.detail-input-url {
    padding: 14px 18px;
    font-size: 0.95rem;
    line-height: 1.5;
}
.detail-lock-tip {
    margin-left: 8px;
    font-size: 0.85rem;
    color: var(--color-text-muted, #5b6e8c);
}

/* ===== 布局精修：项目页/详情页区块放置 ===== */
.container {
    max-width: var(--layout-max-width, 78rem);
}

.content {
    gap: 16px;
}

.project-detail-page .detail-section {
    padding: 18px;
}

.project-detail-page .detail-section-header {
    margin-bottom: 10px;
}

.project-detail-page .detail-subrow {
    align-items: flex-start;
    gap: 10px;
}

.project-detail-page .detail-subrow > label {
    min-width: 64px;
    margin-top: 8px;
}

.project-detail-page .detail-img-textarea,
.project-detail-page .detail-input-url,
.project-detail-page .detail-textarea {
    width: 100%;
}

.project-detail-page .detail-img-actions {
    margin-left: 0;
}

.project-detail-page .detail-image-preview {
    margin-top: 10px;
}

.project-detail-page .table-wrap {
    margin-top: 8px;
}

/* 金额管理（仅部分人可见）：分区 + 网格，总金额通栏 */
.project-detail-page .detail-finance-section {
    border-left: 3px solid rgba(124, 110, 255, 0.45);
    padding-left: 17px;
}
.project-detail-page .detail-finance-section .detail-finance-tip {
    margin-bottom: 14px;
    line-height: 1.55;
    max-width: none;
}
.project-detail-page .detail-finance-panel {
    margin-bottom: 6px;
    width: 100%;
    min-width: 0;
}
.project-detail-page .detail-finance-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px 22px;
    padding: 16px 18px 18px;
    width: 100%;
    max-width: none;
    box-sizing: border-box;
    background: linear-gradient(165deg, rgba(124, 110, 255, 0.07) 0%, rgba(255, 255, 255, 0.5) 48%, rgba(110, 160, 220, 0.05) 100%);
    border: 1px solid rgba(110, 130, 200, 0.22);
    border-radius: 14px;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65);
}
.project-detail-page .detail-finance-grid .detail-finance-row {
    margin-bottom: 0;
}
/* 两列单元：标题 + 金额与标记横向排列 */
.project-detail-page .detail-finance-cell {
    margin-bottom: 0;
    padding: 12px 14px;
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.78);
    border: 1px solid rgba(110, 130, 200, 0.22);
    box-sizing: border-box;
    min-width: 0;
    box-shadow: 0 1px 0 rgba(255, 255, 255, 0.9) inset;
}
.project-detail-page .detail-finance-cell-head {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--color-text, #3d4a56);
    margin-bottom: 8px;
    letter-spacing: 0.02em;
    line-height: 1.3;
}
.project-detail-page .detail-finance-cell-body {
    display: flex;
    align-items: stretch;
    gap: 10px;
    flex-wrap: nowrap;
}
.project-detail-page .detail-finance-cell--amount-only .detail-input-finance--in-cell {
    flex: 1;
    width: 100%;
    max-width: none;
}
.project-detail-page .detail-input-finance--in-cell {
    flex: 1;
    min-width: 0;
    width: auto;
}
/* 金额管理结账标记：与项目列表筛选同款 .project-dd / .project-dd-list，仅限制在金额格内宽度 */
.project-detail-page .detail-finance-cell-body .project-dd {
    flex: 0 0 5.75rem;
    min-width: 5.25rem;
    max-width: 7rem;
    width: auto;
    align-self: stretch;
}
.project-detail-page .detail-finance-cell-body .project-dd-trigger--table {
    height: auto;
    min-height: 2.625rem;
    max-height: none;
}
.project-detail-page .detail-finance-row--total {
    grid-column: 1 / -1;
    padding-bottom: 4px;
    margin-bottom: 2px;
    border-bottom: 1px dashed rgba(110, 130, 200, 0.28);
    gap: 8px;
}
/* 总金额：字色加深；略缩标签列 + 减小间距，使输入框相对左移 */
.project-detail-page .detail-finance-section .detail-finance-row--total > label {
    flex: 0 0 6.5rem;
    min-width: 6.5rem;
    max-width: 38%;
    font-weight: 700;
    color: #111827;
}
.project-detail-page .detail-finance-section .detail-finance-row {
    display: flex;
    align-items: center;
    flex-wrap: nowrap;
    gap: 12px;
}
.project-detail-page .detail-finance-section .detail-finance-row > label {
    flex: 0 0 7.5rem;
    min-width: 7.5rem;
    max-width: 42%;
    margin-top: 0;
    font-size: 0.88rem;
    font-weight: 500;
    color: var(--color-text-muted, #5b6e8c);
    line-height: 1.35;
}
.project-detail-page .detail-input-finance {
    flex: 1;
    min-width: 0;
    max-width: none;
    width: 100%;
    padding: 9px 12px;
    border-radius: 10px;
}
.project-detail-page .detail-finance-row--total .detail-input-finance {
    max-width: none;
    margin-left: -2px;
}
.project-detail-page .detail-finance-row-note {
    align-items: flex-start;
    margin-top: 12px;
    padding-top: 4px;
    width: 100%;
    max-width: none;
    box-sizing: border-box;
}
.project-detail-page .detail-finance-row-note > label {
    flex: 0 0 7.5rem;
    min-width: 7.5rem;
    padding-top: 10px;
}
.project-detail-page .detail-finance-note {
    flex: 1;
    min-width: 0;
    width: 100%;
    max-width: none;
    min-height: 80px;
    border-radius: 12px;
    padding: 10px 12px;
}

@media (max-width: 980px) {
    .project-detail-page .detail-finance-cell-body {
        flex-wrap: wrap;
    }
    .project-detail-page .detail-finance-cell-body .project-dd {
        flex: 1 1 100%;
        max-width: none;
    }
    .project-detail-page .detail-finance-grid {
        grid-template-columns: 1fr;
        max-width: none;
        padding: 14px 14px 16px;
    }
    .project-detail-page .detail-finance-row--total {
        border-bottom: none;
        padding-bottom: 0;
        margin-bottom: 0;
    }
    .project-detail-page .detail-finance-row--total .detail-input-finance {
        max-width: none;
    }
    .project-detail-page .detail-finance-section .detail-finance-row {
        flex-wrap: wrap;
    }
    .project-detail-page .detail-finance-section .detail-finance-row > label {
        flex: 0 0 100%;
        max-width: none;
        min-width: 0;
    }
    .project-detail-page .detail-finance-row-note > label {
        flex: 0 0 100%;
        min-width: 0;
        padding-top: 0;
    }
    .project-detail-page .detail-subrow > label {
        min-width: auto;
        width: 100%;
        margin-top: 0;
    }
    .project-detail-page .detail-img-actions {
        width: 100%;
        justify-content: flex-end;
    }
    .project-detail-page .detail-material-form .form-row {
        display: grid;
        grid-template-columns: minmax(0, 1fr) 110px;
        gap: 8px;
    }
}

@media (max-width: 768px) {
    .project-detail-page .detail-section {
        padding: 14px;
    }
    .content {
        gap: 12px;
    }
}

/* ===== 项目列表页 project.html：手机浏览器适配 ===== */
@media (max-width: 48rem) {
    .project-list-header {
        flex-direction: column;
        align-items: stretch;
        gap: 10px;
    }

    .project-list-header h2 {
        margin-bottom: 0;
    }

    .project-header-right {
        width: 100%;
        flex-direction: column;
        align-items: stretch;
        gap: 8px;
    }

    .project-search-input {
        width: 100%;
        min-width: 0;
        max-width: none;
    }

    .project-filter {
        width: 100%;
        justify-content: center;
        box-sizing: border-box;
    }

    .project-header-right .add-form {
        width: 100%;
        display: flex;
        justify-content: center;
    }

    .project-header-right .add-btn {
        width: 100%;
        max-width: 20rem;
    }

    /* 宽表横向滚动，避免列被压扁 */
    #pageContent .equipment-list .table-wrap {
        margin-left: -2px;
        margin-right: -2px;
        max-width: none;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: thin;
    }

    .project-list-table-frame {
        padding: 10px 8px 8px;
        border-radius: 12px;
        margin-left: -2px;
        margin-right: -2px;
    }

    #projectTable {
        min-width: 56rem;
    }

    #projectTable th,
    #projectTable td {
        padding: 7px 6px;
        font-size: 0.78rem;
    }

    .project-row.project-row-has-access td:first-child {
        padding-left: 52px;
    }

    .project-row.project-row-has-access td:first-child::before {
        left: 5px;
        min-width: 38px;
        height: 18px;
        font-size: 0.65rem;
        padding: 0 5px;
    }

    .end-date-cell {
        flex-direction: column;
        align-items: flex-start;
        gap: 4px;
    }

    .dp-sheet {
        padding-bottom: calc(1rem + env(safe-area-inset-bottom, 0px));
    }

    #projectFormContainer .form-content {
        max-height: min(88dvh, calc(100vh - 2rem));
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
    }
}
