/* ===== 全局基础 ===== */
html{scroll-behavior:smooth;overflow-x:hidden}
body{font-family:"PingFang SC","Microsoft YaHei","Noto Serif SC",sans-serif}

/* ===== 侧栏导航 ===== */
.sidebar{background:linear-gradient(180deg,#1a1a2e 0%,#1e1a3a 50%,#1e1a2a 100%);position:relative}
.sidebar a{position:relative;transition:all .3s}
.sidebar a:hover,.sidebar a.active{color:#fff;background:rgba(255,255,255,.1)}
.sidebar-link{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:8px;color:rgba(255,255,255,.8);font-size:14px;transition:all .3s}
.sidebar-collapse-btn{position:absolute;right:-20px;top:50%;z-index:5;width:20px;height:48px;border-radius:0 6px 6px 0;border:1px solid rgba(255,255,255,.15);border-left:none;background:#1a1a2e;color:rgba(255,255,255,.6);cursor:pointer;display:none;align-items:center;justify-content:center;transition:all .3s;font-size:13px;transform:translateY(-50%)}
.sidebar-collapse-btn:hover{color:#fff;background:#1e1a3a}
@media(min-width:1200px){.sidebar-collapse-btn{display:flex}}
.sidebar-expand-btn{position:fixed;top:50%;left:0;z-index:50;width:20px;height:48px;border-radius:0 6px 6px 0;border:1px solid rgba(255,255,255,.15);border-left:none;background:#1a1a2e;color:rgba(255,255,255,.6);cursor:pointer;display:none;align-items:center;justify-content:center;transition:all .3s;font-size:13px;transform:translateY(-50%)}
.sidebar-expand-btn:hover{color:#fff;background:#1e1a3a}
@media(min-width:1200px){:root.sidebar-collapsed #sidebar{left:-220px!important}}
@media(min-width:1200px){:root.sidebar-collapsed .main-content{margin-left:0}}
@media(min-width:1200px){:root.sidebar-collapsed .sidebar-expand-btn{display:flex}}

/* ===== 移动端导航 ===== */
.mobile-nav{transform:translateX(-100%);transition:transform .3s,left .3s;position:fixed}
.mobile-nav.open{transform:translateX(0)}
@media(min-width:1200px){.mobile-nav{transform:translateX(0)!important;position:fixed!important;top:0;display:flex}.hamburger-xl{display:none!important}.main-content{margin-left:220px}}
.mask{opacity:0;pointer-events:none;transition:opacity .3s}
.mask.show{opacity:1;pointer-events:auto}

/* ===== 客片卡片（首页/列表页） ===== */
.work-card{transition:all .4s;cursor:pointer;position:relative;overflow:hidden}
.work-card .work-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.7),transparent 50%);opacity:0;transition:opacity .4s;display:flex;flex-direction:column;justify-content:flex-end;padding:20px;color:#fff}
.work-card:hover .work-overlay{opacity:1}
.work-card:hover{transform:scale(1.02)}

/* ===== 分类标签 ===== */
.search-tab a{transition:all .2s}
.search-tab a.active{background:#c2875e;color:#fff;border-color:#c2875e}
.tag-btn{display:inline-block;padding:6px 16px;font-size:13px;border-radius:6px;border:1px solid #d1d5db;color:#4b5563;transition:all .2s}
.tag-btn.active,.tag-btn:hover{background:#c2875e;color:#fff;border-color:#c2875e}

/* ===== 列表页 ===== */
.photo-info{transition:all .3s}
.photo-info:hover{box-shadow:0 4px 20px rgba(0,0,0,.08)}

/* ===== 首页 ===== */
.customer-card{transition:all .3s}
.customer-card:hover{transform:translateY(-4px)}
.gallery-filter a{transition:all .2s}
.gallery-filter a.active{background:#c2875e;color:#fff;border-color:#c2875e}

/* ===== 文章详情 ===== */
.article-body p{line-height:1.9;margin-bottom:1.2em;text-indent:2em}
.article-img{cursor:pointer}
#articleImages{overflow:hidden;width:100%}
#articleImages p{text-align:center;width:100%;max-width:100%;overflow:hidden}
#articleImages p img{max-width:100%!important;width:auto!important;height:auto!important;display:block!important;margin:0 auto;border-radius:8px}
.main-content{background:#fff;transition:margin-left .3s}
.flex:has(> wedding-sidebar){background:linear-gradient(180deg,#1a1a2e 0%,#1e1a3a 50%,#1e1a2a 100%)}

/* ===== 详情页全屏相册（Swiper） ===== */
.album{position:fixed;inset:0;z-index:100;background:rgba(0,0,0,.95);display:none;align-items:center;justify-content:center}
.album.show{display:flex}
.album .swiper{width:100%;height:100%;position:relative;overflow:hidden}
.album .swiper-wrapper{display:flex;height:100%}
.album .swiper-slide{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:100%;height:100%}
.album .swiper-slide img{max-width:94vw;max-height:94vh;object-fit:contain;border-radius:6px}
.album .close{position:absolute;top:20px;right:30px;color:#fff;font-size:36px;cursor:pointer;border:0;background:none;z-index:20;line-height:1}
.album .swiper-button-prev,
.album .swiper-button-next{color:#fff;opacity:.7;transition:opacity .2s}
.album .swiper-button-prev svg path,
.album .swiper-button-next svg path{fill:#fff!important}
.album .swiper-button-prev:hover,
.album .swiper-button-next:hover{opacity:1}
.album .swiper-button-prev{left:8px}
.album .swiper-button-next{right:8px}
.album .swiper-button-prev::after,
.album .swiper-button-next::after{font-size:28px}
.album .swiper-pagination,
.album .swiper-pagination-current,
.album .swiper-pagination-total{color:#fff!important;font-size:14px;letter-spacing:2px;bottom:30px;font-family:"PingFang SC","Microsoft YaHei",sans-serif}

/* ===== 相关推荐卡片 ===== */
.related-card{transition:all .3s}
.related-card:hover{transform:translateY(-4px)}

/* ===== 微电影列表页 ===== */
.film-card{transition:all .3s}
.film-card:hover{box-shadow:0 4px 20px rgba(0,0,0,.08)}
.film-card:hover .play-btn{transform:scale(1.1)}

/* ===== 面包屑分隔符 ===== */
.sep-before > * + *::before{content:">";margin:0 8px;color:#9ca3af;font-family:"宋体",SimSun,serif}

/* ===== 分页 ===== */
.pagination{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;padding:0;margin:24px 0}
.pagination>li{list-style:none}
.pagination>li>a,.pagination>li>span{display:flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 10px;border-radius:8px;font-size:13px;color:#6b7280;background:#fff;border:1px solid #e5e7eb;text-decoration:none;transition:all .2s}
.pagination>li>a:hover{color:#c2875e;border-color:#d4a373;background:#fdf2e9}
.pagination>.active>a,.pagination>.active>span{color:#fff;background:#c2875e;border-color:#c2875e}