/* 引入 Font Awesome */
@import url('https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.7.2/css/all.min.css');

/* 全局变量 - 古典金色系 */
.nm-wannianli {
    --wl-bg: #d4d2ba;
    --wl-text: #1e1e1e;
    --wl-accent: #c2a15b;
    --wl-yi: #c2a15b;
    --wl-ji: #8b5e3c;
    --wl-border: #dad7c5;
    --wl-card-bg: #f0efe1;
    --wl-header-bg: linear-gradient(135deg, #1e1e1e 0%, #c2a15b 100%);
    --wl-card-border: #dad7c5;
    
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    max-width: 1280px;
    margin: 2rem auto;
    background: var(--wl-bg);
    border-radius: 28px;
    box-shadow: 0 8px 30px rgba(0,0,0,0.05);
    padding: 1.5rem;
}

/* 左右栏布局（英雄卡片 + 日历网格）等高无缝隙 */
.nm-wannianli .wl-layout-grid {
    display: grid;
    grid-template-columns: 320px 1fr;
    gap: 0;
    margin-bottom: 2rem;
    background: var(--wl-card-bg);
    border-radius: 28px;
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05);
}

/* 左侧英雄卡片区域 */
.nm-wannianli .wl-hero-area {
    background: linear-gradient(135deg, #1e1e1e 0%, #c2a15b 100%);
    padding: 1.5rem;
    color: #fffdf7;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.nm-wannianli .wl-hero-header {
    flex-shrink: 0;
}
.nm-wannianli .wl-hero-body {
    flex: 1;
}

/* 英雄卡片内容样式 */
.nm-wannianli .wl-hero-day {
    font-size: 3.8rem;
    font-weight: 800;
    letter-spacing: 2px;
}

.nm-wannianli .wl-hero-sub {
    font-size: 1.05rem;
    display: flex;
    gap: 1rem;
    opacity: 0.9;
    margin-bottom: 0.75rem;
}

.nm-wannianli .wl-hero-lunar {
    font-size: 1.7rem;
    font-weight: 600;
    letter-spacing: 1px;
    margin-bottom: 0.5rem;
}

.nm-wannianli .wl-hero-ganzhi {
    font-size: 1rem;
    opacity: 0.9;
    margin-bottom: 0.8rem;
}

.nm-wannianli .wl-hero-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: 1rem;
}

.nm-wannianli .wl-badge {
    font-size: 0.85rem;
    background: rgba(255,255,255,0.2);
    backdrop-filter: blur(4px);
    border-radius: 40px;
    padding: 0.2rem 0.8rem;
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
}

.nm-wannianli .wl-hero-birthday-tip {
    font-size: 0.85rem;
    opacity: 0.7;
    margin-bottom: 0.5rem;
    cursor: pointer;
}

.nm-wannianli .wl-hero-notices {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: auto;
}

.nm-wannianli .wl-notice {
    font-size: 0.85rem;
    background: rgba(0,0,0,0.2);
    border-radius: 30px;
    padding: 0.25rem 0.9rem;
    font-weight: 600;
}

.nm-wannianli .wl-notice em {
    font-style: normal;
    font-weight: 800;
    background: rgba(255,255,255,0.2);
    padding: 0 0.2rem;
    border-radius: 20px;
    margin-left: 0.3rem;
}

/* 添加日程按钮（右上角） */
.nm-wannianli .wl-schedule-add-btn {
    font-size: 0.9rem;
    background: rgba(255,255,255,0.15);
    border: none;
    border-radius: 40px;
    padding: 0.3rem 0.8rem;
    margin-bottom: 1rem;
    cursor: pointer;
    transition: 0.2s;
    float: right;
}
.nm-wannianli .wl-schedule-add-btn:hover {
    background: rgba(255,255,255,0.3);
}

/* 右侧日历区域 */
.nm-wannianli .nm-wannianli-calendar {
    background: var(--wl-card-bg);
    padding: 1rem;
    margin: 0;
    box-shadow: none;
    border-radius: 0;
    display: flex;
    flex-direction: column;
}

/* 日历顶部导航工具栏 */
.nm-wannianli .calendar-controls {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
    margin-bottom: 1.5rem;
    background: rgba(0,0,0,0.03);
    padding: 0.5rem 1rem;
    border-radius: 60px;
    flex-wrap: wrap;
}

.nm-wannianli .calendar-controls .nm-btn {
    background: var(--wl-card-bg);
    border: 1px solid var(--wl-border);
    padding: 0.4rem 1rem;
    border-radius: 40px;
    font-weight: 500;
    color: var(--wl-text);
    cursor: pointer;
    transition: all 0.2s ease;
    font-size: 0.85rem;
}
.nm-wannianli .calendar-controls .nm-btn:hover {
    background: var(--wl-accent);
    border-color: var(--wl-accent);
    color: white;
    transform: translateY(-1px);
}
.nm-wannianli .calendar-controls .current-date-title {
    font-size: 1.2rem;
    font-weight: 600;
    color: var(--wl-text);
    margin: 0 0.5rem;
    min-width: 140px;
    text-align: center;
}
.nm-wannianli .calendar-controls .today-btn {
    background: var(--wl-accent);
    color: white;
    border: none;
}
.nm-wannianli .calendar-controls .today-btn:hover {
    background: #a88540;
}

/* 星期头部 */
.nm-wannianli .week-header {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 0.5rem;
    padding: 0.75rem 0;
    border-bottom: 1px solid var(--wl-border);
    margin-bottom: 0.75rem;
}
.nm-wannianli .week-header div {
    text-align: center;
    font-weight: 600;
    color: var(--wl-text);
    opacity: 0.7;
    font-size: 0.85rem;
}

/* 日期网格 */
.nm-wannianli .days-container {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 0.5rem;
}

.nm-wannianli .day-item {
    background: white;
    border-radius: 20px;
    padding: 0.75rem 0.25rem;
    text-align: center;
    cursor: pointer;
    transition: all 0.2s;
    border: 1px solid var(--wl-border);
    box-shadow: 0 1px 2px rgba(0,0,0,0.02);
}
.nm-wannianli .day-item:hover {
    transform: translateY(-2px);
    background: var(--wl-bg);
    border-color: var(--wl-accent);
}
.nm-wannianli .day-item.active {
    background: var(--wl-accent);
    border-color: var(--wl-accent);
    color: white;
}
.nm-wannianli .day-item.today {
    border-color: var(--wl-accent);
    box-shadow: 0 0 0 2px rgba(194,161,91,0.3);
}
.nm-wannianli .day-item.other-month {
    opacity: 0.5;
    background: var(--wl-bg);
}
.nm-wannianli .solar-day {
    font-size: 1.2rem;
    font-weight: 600;
    line-height: 1.3;
}
.nm-wannianli .lunar-day {
    font-size: 0.7rem;
    color: #606266;
}
.nm-wannianli .day-item.active .lunar-day {
    color: rgba(255,255,255,0.85);
}
.nm-wannianli .day-item.weekend .solar-day,
.nm-wannianli .day-item.weekend .lunar-day {
    color: var(--wl-ji);
}
.nm-wannianli .day-item.festival .lunar-day {
    color: #a55c3c;
    font-weight: 500;
}
.nm-wannianli .day-item.jieqi .lunar-day {
    color: var(--wl-accent);
    font-weight: 500;
}

/* 响应式：移动端切换为堆叠 */
@media (max-width: 768px) {
    .nm-wannianli .wl-layout-grid {
        grid-template-columns: 1fr;
    }
    .nm-wannianli .wl-hero-area {
        border-radius: 28px 28px 0 0;
    }
    .nm-wannianli .nm-wannianli-calendar {
        border-radius: 0 0 28px 28px;
    }
    .nm-wannianli .calendar-controls {
        gap: 0.5rem;
    }
    .nm-wannianli .calendar-controls .nm-btn {
        padding: 0.3rem 0.7rem;
        font-size: 0.75rem;
    }
}

/* 下方详情区域样式（与之前相同，保持不变） */
.nm-wannianli-detail {
    margin-top: 2rem;
}
.nm-wannianli .yi-ji {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem;
    margin-bottom: 2rem;
}
.nm-wannianli .yi-col,
.nm-wannianli .ji-col {
    background: var(--wl-card-bg);
    border-radius: 24px;
    padding: 1rem 1.2rem;
    border: 1px solid var(--wl-border);
}
.nm-wannianli .yi-head,
.nm-wannianli .ji-head {
    font-weight: 700;
    font-size: 1.2rem;
    margin-bottom: 1rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}
.nm-wannianli .yi-head i { color: var(--wl-yi); }
.nm-wannianli .ji-head i { color: var(--wl-ji); }
.nm-wannianli .yi-items,
.nm-wannianli .ji-items {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}
.nm-wannianli .yi-items span {
    background: rgba(194,161,91,0.1);
    color: var(--wl-yi);
    padding: 0.25rem 0.9rem;
    border-radius: 40px;
    font-size: 0.8rem;
}
.nm-wannianli .ji-items span {
    background: rgba(139,94,60,0.1);
    color: var(--wl-ji);
    padding: 0.25rem 0.9rem;
    border-radius: 40px;
    font-size: 0.8rem;
}

.nm-wannianli .detail-cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.2rem;
    margin-bottom: 2rem;
}
.nm-wannianli .detail-card {
    background: var(--wl-card-bg);
    border-radius: 20px;
    padding: 1rem;
    border: 1px solid var(--wl-border);
    transition: all 0.2s ease;
}
.nm-wannianli .detail-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 14px rgba(0,0,0,0.05);
    border-color: var(--wl-accent);
}
.nm-wannianli .detail-card h4 {
    font-size: 0.9rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--wl-accent);
    margin-bottom: 0.75rem;
    border-left: 4px solid var(--wl-accent);
    padding-left: 0.75rem;
    display: flex;
    align-items: center;
    gap: 0.4rem;
}
.nm-wannianli .detail-row {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    font-size: 0.85rem;
    margin-bottom: 0.5rem;
    padding: 0.3rem 0;
    border-bottom: 1px dashed var(--wl-border);
}
.nm-wannianli .detail-row:last-child {
    border-bottom: none;
}
.nm-wannianli .detail-key {
    font-weight: 600;
    color: var(--wl-text);
    opacity: 0.75;
}
.nm-wannianli .detail-val {
    font-weight: 500;
    color: var(--wl-text);
    text-align: right;
}
.nm-wannianli .detail-val em {
    font-style: normal;
    background: rgba(194,161,91,0.1);
    padding: 0.1rem 0.4rem;
    border-radius: 20px;
    font-size: 0.75rem;
    margin-left: 0.3rem;
    font-weight: 600;
    color: var(--wl-accent);
}
@media (max-width: 900px) {
    .nm-wannianli .detail-cards { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
    .nm-wannianli .detail-cards { grid-template-columns: 1fr; }
    .nm-wannianli .yi-ji { grid-template-columns: 1fr; }
}

.nm-wannianli .wl-tabs {
    margin-top: 2rem;
    background: var(--wl-card-bg);
    border-radius: 28px;
    padding: 1rem;
}
.nm-wannianli .tab-nav {
    display: flex;
    gap: 0.75rem;
    border-bottom: 2px solid var(--wl-border);
    margin-bottom: 1.5rem;
    padding-bottom: 0.5rem;
}
.nm-wannianli .tab-btn {
    background: none;
    border: none;
    padding: 0.75rem 1.5rem;
    font-size: 1.1rem;
    font-weight: 600;
    border-radius: 40px;
    cursor: pointer;
    color: var(--wl-text);
    transition: all 0.2s ease;
}
.nm-wannianli .tab-btn:hover {
    background: rgba(194,161,91,0.1);
    color: var(--wl-accent);
}
.nm-wannianli .tab-btn.active {
    background: var(--wl-accent);
    color: white;
    box-shadow: 0 2px 8px rgba(194,161,91,0.3);
}

.nm-wannianli .tab-panel[data-panel="shensha"] {
    display: flex;
    flex-direction: column;
    gap: 1.2rem;
}
.nm-wannianli .jishen,
.nm-wannianli .xiongsha {
    background: var(--wl-bg);
    border-radius: 20px;
    padding: 1rem 1.2rem;
    font-size: 1rem;
    line-height: 1.5;
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 0.75rem;
}
.nm-wannianli .jishen {
    border-left: 6px solid var(--wl-yi);
}
.nm-wannianli .xiongsha {
    border-left: 6px solid var(--wl-ji);
}
.nm-wannianli .jishen::before {
    content: "✨ 吉神：";
    font-weight: 700;
    color: var(--wl-yi);
    margin-right: 0.5rem;
}
.nm-wannianli .xiongsha::before {
    content: "⚠️ 凶煞：";
    font-weight: 700;
    color: var(--wl-ji);
    margin-right: 0.5rem;
}
.nm-wannianli .jishen span,
.nm-wannianli .xiongsha span {
    display: inline-block;
    background: rgba(194,161,91,0.1);
    padding: 0.3rem 1rem;
    border-radius: 30px;
    font-size: 0.95rem;
    font-weight: 500;
    margin: 0.1rem;
}
.nm-wannianli .xiongsha span {
    background: rgba(139,94,60,0.1);
    color: var(--wl-ji);
}

.nm-wannianli .tab-panel[data-panel="chongsha"] {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 1rem;
}
.nm-wannianli .chongsha-item {
    background: var(--wl-bg);
    border-radius: 16px;
    padding: 0.9rem 1rem;
    font-size: 0.95rem;
    display: flex;
    align-items: center;
    gap: 1rem;
    transition: 0.2s;
}
.nm-wannianli .chongsha-item:hover {
    transform: translateX(4px);
    background: rgba(194,161,91,0.05);
}
.nm-wannianli .chongsha-item::before {
    font-family: "Font Awesome 6 Free";
    font-weight: 900;
    font-size: 1.2rem;
    width: 1.8rem;
    text-align: center;
    color: var(--wl-accent);
}
.nm-wannianli .chongsha-item:first-child::before { content: "\f0e7"; }
.nm-wannianli .chongsha-item:nth-child(2)::before { content: "\f072"; }
.nm-wannianli .chongsha-item:nth-child(3)::before { content: "\f06d"; }
.nm-wannianli .chongsha-item:nth-child(4)::before { content: "\f005"; }
.nm-wannianli .chongsha-item:nth-child(5)::before { content: "\f133"; }
.nm-wannianli .chongsha-item:nth-child(6)::before { content: "\f185"; }

.nm-wannianli .tab-panel[data-panel="shichen"] {
    overflow-x: auto;
}
.nm-wannianli .time-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.9rem;
    background: #fff;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05);
}
.nm-wannianli .time-table th {
    background: #f1f5f9;
    color: #1e293b;
    padding: 0.9rem 0.6rem;
    font-weight: 700;
    font-size: 0.9rem;
    text-align: center;
    border-bottom: 1px solid #e2e8f0;
}
.nm-wannianli .time-table td {
    padding: 0.8rem 0.5rem;
    text-align: center;
    border-bottom: 1px solid #eef2f6;
    vertical-align: middle;
    background: #fff;
    color: #334155;
}
.nm-wannianli .time-table tr:last-child td {
    border-bottom: none;
}
.nm-wannianli .time-table tr:nth-child(even) td {
    background: #fafbfc;
}
.nm-wannianli .time-table tr:hover td {
    background: #f1f5f9;
}
.nm-wannianli .time-table td:first-child {
    font-weight: 600;
    color: #1e293b;
}
.nm-wannianli .time-table .ji-text {
    color: #10b981;
    font-weight: 600;
}
.nm-wannianli .time-table .xiong-text {
    color: #ef4444;
    font-weight: 600;
}
.nm-wannianli .time-table td:nth-child(5),
.nm-wannianli .time-table td:nth-child(6) {
    font-size: 0.8rem;
    color: #5a7f9e;
    line-height: 1.4;
}

@media (max-width: 768px) {
    .nm-wannianli .tab-btn {
        padding: 0.5rem 1rem;
        font-size: 0.9rem;
    }
    .nm-wannianli .time-table {
        font-size: 0.75rem;
    }
    .nm-wannianli .time-table th,
    .nm-wannianli .time-table td {
        padding: 0.5rem 0.2rem;
    }
    .nm-wannianli .chongsha-item {
        font-size: 0.85rem;
    }
}

.nm-wannianli .tab-panel {
    display: none !important;
}
.nm-wannianli .tab-panel.active {
    display: block !important;
}