/**
 * 前台扩展样式
 * 前台中，非标准商城功能的样式要单独写在这个文件中，包括修改主题样式等。能不修改home.css就尽量不修改，以免影响其他主题的样式。
 * 依赖 home.css 中的公共基础（如 .member-panel、.page-head 等），请在 home.css 之后加载。
 */

/* ========== 站长名下裂变分组卡片 ========== */
.stationmaster-groups-panel {
    padding: 4px 0 2px;
}

.stationmaster-section-head {
    margin-bottom: 14px;
}

.stationmaster-groups-title {
    font-size: 18px;
    font-weight: 700;
    margin: 0 0 8px;
    color: #2a2a2a;
    display: flex;
    align-items: center;
    gap: 8px;
}

.stationmaster-groups-title i {
    color: #e54545;
    font-size: 20px;
}

.stationmaster-groups-hint {
    font-size: 14px;
    color: #8a8a8a;
    line-height: 1.55;
    margin: 0;
}

.stationmaster-group-cards {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.stationmaster-card {
    background: #fff;
    border-radius: 14px;
    border: 1px solid #f0f0f0;
    box-shadow: 0 4px 14px rgba(228, 54, 64, 0.07);
    overflow: hidden;
}

.stationmaster-card-top {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    padding: 12px 14px;
    background: linear-gradient(135deg, rgba(255, 106, 101, 0.09) 0%, rgba(255, 60, 60, 0.06) 100%);
    border-bottom: 1px solid rgba(255, 200, 200, 0.55);
}

.stationmaster-card-id {
    display: flex;
    align-items: baseline;
    gap: 8px;
}

.sm-id-label {
    font-size: 14px;
    color: #888;
    font-weight: 500;
}

.sm-gid {
    font-size: 19px;
    color: #d23a3a;
    letter-spacing: 0.02em;
}

.sm-status-pill {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 13px;
    font-weight: 600;
    padding: 5px 12px;
    border-radius: 999px;
    white-space: nowrap;
}

.sm-status-pill i {
    font-size: 7px;
    opacity: 0.85;
}

.sm-status-live {
    background: #e8f7ee;
    color: #1e7a45;
    border: 1px solid #c5e8d1;
}

.sm-status-off {
    background: #f3f4f6;
    color: #6b7280;
    border: 1px solid #e5e7eb;
}

.stationmaster-card-leader {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 14px 10px;
}

.sm-leader-icon {
    width: 44px;
    height: 44px;
    border-radius: 12px;
    background: linear-gradient(145deg, #fff5f5, #ffe8e8);
    border: 1px solid #ffd6d6;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #e54545;
    font-size: 20px;
    flex-shrink: 0;
}

.sm-leader-text {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
}

.sm-leader-name {
    font-size: 17px;
    font-weight: 700;
    color: #2f2f2f;
    line-height: 1.3;
}

.sm-leader-account {
    font-size: 14px;
    color: #9099a6;
}

.stationmaster-card-meta {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    padding: 0 14px 14px;
}

.sm-meta-cell {
    background: #fafbfc;
    border-radius: 10px;
    padding: 10px 10px 8px;
    border: 1px solid #f0f2f5;
}

.sm-meta-cell.sm-meta-wide {
    grid-column: 1 / -1;
}

.sm-meta-origin-time {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.sm-origin-line {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    white-space: nowrap;
    font-size: 15px;
    line-height: 1.4;
}

.sm-origin-label {
    color: #9ca3af;
    font-size: 13px;
    flex-shrink: 0;
}

.sm-origin-val {
    font-weight: 700;
    color: #4b5563;
    overflow: hidden;
    text-overflow: ellipsis;
}

.sm-time-line {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 10px;
    flex-wrap: wrap;
}

.sm-time-line .sm-meta-label {
    margin-bottom: 0;
}

.sm-meta-label {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 13px;
    color: #9ca3af;
    margin-bottom: 4px;
}

.sm-meta-label i {
    font-size: 14px;
    opacity: 0.9;
}

.sm-meta-value {
    display: block;
    font-size: 15px;
    font-weight: 600;
    color: #374151;
}

.sm-meta-sub {
    display: block;
    font-size: 13px;
    color: #94a3b8;
    margin-top: 2px;
}

.sm-meta-time {
    font-size: 14px;
    font-weight: 600;
    color: #4b5563;
}

/* ========== 分组游戏页：英雄区、提示、网络树 ========== */
.group-page-panel {
    padding: 8px 0 12px;
}

.group-hero-card {
    border-radius: 16px;
    padding: 16px 14px 14px;
    background: linear-gradient(135deg, #ff6d67 0%, #ff4c4f 55%, #ef3941 100%);
    color: #fff;
    box-shadow: 0 10px 22px rgba(232, 69, 76, 0.24);
    position: relative;
    overflow: hidden;
}

.group-hero-card::before,
.group-hero-card::after {
    content: '';
    position: absolute;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.13);
    pointer-events: none;
}

.group-hero-card::before {
    width: 120px;
    height: 120px;
    right: -34px;
    top: -48px;
}

.group-hero-card::after {
    width: 68px;
    height: 68px;
    left: -22px;
    bottom: -24px;
}

.group-hero-top {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 8px;
}

.group-hero-chip {
    height: 22px;
    line-height: 22px;
    padding: 0 9px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.22);
    font-size: 12px;
    letter-spacing: 0.6px;
}

.group-hero-status {
    height: 22px;
    line-height: 22px;
    padding: 0 10px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.2);
    font-size: 13px;
    font-weight: 600;
}

.group-hero-card h3 {
    position: relative;
    z-index: 1;
    margin: 0 0 10px;
    font-size: 22px;
    letter-spacing: 0.3px;
}

.group-hero-sub {
    position: relative;
    z-index: 1;
    margin: 0 0 12px;
    opacity: 0.95;
    line-height: 1.6;
    font-size: 15px;
}

.group-hero-grid {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
}

.group-hero-item {
    background: rgba(255, 255, 255, 0.14);
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 10px;
    padding: 8px 10px;
}

.group-hero-item span {
    display: block;
    font-size: 13px;
    opacity: 0.86;
    margin-bottom: 4px;
}

.group-hero-item strong {
    display: block;
    font-size: 17px;
    line-height: 1.3;
    font-weight: 700;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.group-msg {
    border-radius: 10px;
    padding: 10px 12px;
    font-size: 15px;
}

.group-msg.is-success {
    background: #eaf9ef;
    color: #1f7a3f;
    border: 1px solid #cbeed7;
}

.group-msg.is-error {
    background: #fff0f0;
    color: #bf2d2d;
    border: 1px solid #ffd4d4;
}

.group-msg.is-info {
    background: #eef5ff;
    color: #2c5cae;
    border: 1px solid #d5e5ff;
}

.group-status-tip {
    border-radius: 10px;
    padding: 11px 12px;
    font-size: 15px;
}

.group-status-danger {
    background: #fff2f2;
    color: #bf2d2d;
    border: 1px solid #ffd8d8;
}

.group-tree-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 12px;
}

.group-tree-head h3 {
    margin: 0;
    font-size: 18px;
    font-weight: 700;
}

.group-tree-head span {
    color: #888;
    font-size: 14px;
}

.group-tree-wrap {
    overflow-x: auto;
    padding-bottom: 4px;
}

.group-tree-row {
    display: grid;
    gap: 8px;
    margin-bottom: 26px;
    position: relative;
}

.group-tree-row.row-0 {
    grid-template-columns: 1fr;
    max-width: 180px;
    margin-left: auto;
    margin-right: auto;
}

.group-tree-row.row-1 {
    grid-template-columns: repeat(4, minmax(72px, 1fr));
    margin-top: 30px;
}

.group-tree-row.row-2,
.group-tree-row.row-3 {
    grid-template-columns: repeat(8, minmax(0, 1fr));
    gap: 6px;
    margin-top: 30px;
}

.group-tree-row.row-1::before,
.group-tree-row.row-2::before,
.group-tree-row.row-3::before {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    top: -15px;
    border-top: 1px dashed #ffd2d2;
}

.group-tree-row.row-1::before {
    left: 50%;
    right: auto;
    width: 76%;
    transform: translateX(-50%);
}

.group-tree-row.row-0 .group-node::after,
.group-tree-row.row-1 .group-node::after {
    content: '';
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    bottom: -16px;
    width: 1px;
    height: 16px;
    background: #ffd2d2;
    pointer-events: none;
}

.group-tree-row.row-2::before,
.group-tree-row.row-3::before {
    display: none;
}

.group-node {
    min-height: 64px;
    border-radius: 10px;
    padding: 7px 6px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    position: relative;
}

.group-tree-row.row-1 .group-node::before,
.group-tree-row.row-2 .group-node::before,
.group-tree-row.row-3 .group-node::before {
    content: '';
    position: absolute;
    top: -16px;
    left: 50%;
    width: 1px;
    height: 16px;
    background: #ffd2d2;
    pointer-events: none;
}

/* 第3/4行按规则两两归属同一上级，画4段小横线（每段覆盖2个节点） */
.group-tree-row.row-2 .group-node:nth-child(odd)::after,
.group-tree-row.row-3 .group-node:nth-child(odd)::after {
    content: '';
    position: absolute;
    top: -16px;
    left: 50%;
    width: calc(100% + 6px);
    border-top: 1px dashed #ffd2d2;
    pointer-events: none;
}

.group-tree-row.row-2 .group-node,
.group-tree-row.row-3 .group-node {
    min-height: 54px;
    border-radius: 8px;
    padding: 5px 4px;
}

.group-node.is-active {
    background: #fff7f7;
    border: 1px solid #ffd7d7;
    color: #333;
}

.group-node.is-empty {
    background: #f9fafb;
    border: 1px dashed #d8dde6;
    color: #99a0aa;
}

.group-node .node-no {
    position: absolute;
    top: 4px;
    left: 6px;
    font-size: 10px;
    color: #9b9b9b;
}

.group-tree-row.row-1 .group-node .node-no {
    position: static;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 4px;
    color: #a2a2a2;
    font-size: 11px;
}

.node-leader-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 18px;
    border-radius: 999px;
    padding: 0 8px;
    background: rgba(255, 255, 255, 0.82);
    color: #d04848;
    font-size: 11px;
    font-weight: 600;
    margin: 0 auto 4px;
}

.group-node b {
    font-size: 12px;
    line-height: 1.3;
    margin-top: 6px;
    max-width: 100%;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.group-join-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 42px;
    height: 22px;
    border-radius: 999px;
    background: #ff4d4f;
    color: #fff;
    font-size: 12px;
    font-weight: 600;
    margin-top: 3px;
    border: 0;
    cursor: pointer;
    position: relative;
    z-index: 2;
}

.group-node small {
    font-size: 10px;
    color: #8b93a0;
    margin-top: 2px;
    max-width: 100%;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.group-tree-row.row-2 .group-node b,
.group-tree-row.row-3 .group-node b {
    font-size: 11px;
    margin-top: 0;
}

.group-tree-row.row-2 .group-node small,
.group-tree-row.row-3 .group-node small {
    font-size: 9px;
}

/* 网络树节点保持小字号，避免挤占窄屏 */
.group-node .node-ref-active {
    font-size: 9px;
    color: #c45a5a;
    margin-top: 1px;
    line-height: 1.2;
}

.group-tree-row.row-2 .group-node .node-ref-active,
.group-tree-row.row-3 .group-node .node-ref-active {
    font-size: 8px;
}

.node-bgno {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-style: normal;
    font-size: 26px;
    color: rgba(120, 133, 156, 0.16);
    font-weight: 700;
    line-height: 1;
    pointer-events: none;
    z-index: 0;
}

.group-node b,
.group-node small,
.group-node .node-no {
    position: relative;
    z-index: 1;
}
