/* ============================================================
   holo-theme.css —— 影院级暗黑沉浸主题
   面向观众:制片人 / 艺术总监
   设计原则:画面是主角,文字是配角。纯黑糊脸,电影画幅,极简。
   这套主题覆盖在 style.css 之后加载,负责影视作品集的全部视觉。
   ============================================================ */

/* ---------- 设计令牌(别tm乱改,改一个崩一片) ---------- */
:root{
    --cine-black:#000;          /* 纯黑底,影院级就得黑到底 */
    --cine-ink:#070707;         /* 近黑,用于分区 */
    --cine-panel:#0d0d0d;       /* 卡片/面板 */
    --cine-line:rgba(255,255,255,.10); /* 极淡分隔线 */
    --cine-fog:#8c8c8c;         /* 次要灰字 */
    --cine-fog-2:#5a5a5a;       /* 更弱的灰 */
    --cine-white:#fff;
    --cine-gold:#c9a86a;        /* 克制的暖金,唯一的强调色 */
    --cine-gold-soft:rgba(201,168,106,.16);
    --font-poster:'Anton','Noto Sans SC',sans-serif; /* 海报黑体大标题 */
    --font-cn:'Noto Sans SC','Inter',sans-serif;
    --font-ui:'Inter','Noto Sans SC',sans-serif;
    --shot-ratio:42.55%;        /* 2.35:1 电影画幅 (1/2.35) */
}

/* ---------- 全局基调:把底色压到纯黑 ---------- */
html{scroll-behavior:smooth}
body{
    background:var(--cine-black);
    color:var(--cine-fog);
    font-family:var(--font-ui);
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
}
.cine ::selection{background:var(--cine-gold);color:#000}

/* 全站细微胶片颗粒 + 扫描线,营造监视器/胶片质感(克制,别糊) */
body::before{
    content:'';position:fixed;inset:0;z-index:9999;pointer-events:none;
    opacity:.045;mix-blend-mode:overlay;
    background-image:repeating-linear-gradient(0deg,#fff 0,#fff 1px,transparent 1px,transparent 3px);
}

/* ---------- 顶部导航:固定、透明、滚动后浮黑 ---------- */
.cine .header-area{
    position:fixed;top:0;left:0;width:100%;margin:0;z-index:1000;
    padding:26px 0;transition:.4s ease;
    background:linear-gradient(180deg,rgba(0,0,0,.75),rgba(0,0,0,0));
}
.cine .header-area.scrolled{
    padding:11px 0;background:rgba(0,0,0,.9);
    backdrop-filter:blur(14px);border-bottom:1px solid var(--cine-line);
}
/* 往下滑时:导航整体等比缩小(菜单字号 + 间距 + 按钮一起收,布局不变) */
.cine .header-area.scrolled .navbar .menu{gap:32px}
.cine .header-area.scrolled .navbar .menu li a{font-size:12px}
.cine .header-area.scrolled .theme-btn{padding:9px 20px;font-size:11px;border-color:transparent}
.cine .header-area .container{max-width:1320px;padding:0 40px}
/* 文字字标 logo(原模板 logo 是空的,这里直接给字) */
.cine .header-area .logo{
    width:auto;height:auto;font-family:var(--font-poster);
    font-size:24px;letter-spacing:1px;color:var(--cine-white);
    text-transform:uppercase;line-height:1;
}
.cine .header-area .logo .dot{color:var(--cine-gold)}
.cine .header-area .navbar .menu{gap:42px;transition:gap .4s ease}
@media(min-width:768px){
    .cine .header-area .gx-row{position:relative}
    .cine .header-area .navbar{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%)}
    .cine .header-area > .container > .gx-row > .theme-btn{position:absolute;right:0;top:50%;transform:translateY(-50%)}
}
.cine .header-area .navbar .menu li a{
    font-size:13px;letter-spacing:1.5px;text-transform:uppercase;
    color:var(--cine-fog);padding:6px 0;position:relative;font-weight:500;
    transition:font-size .4s ease,color .35s ease;
}
.cine .header-area .navbar .menu li a::after{
    content:'';position:absolute;left:0;bottom:0;width:0;height:1px;
    background:var(--cine-gold);transition:.35s;
}
.cine .header-area .navbar .menu li.active a,
.cine .header-area .navbar .menu li a:hover{color:var(--cine-white)}
.cine .header-area .navbar .menu li.active a::after,
.cine .header-area .navbar .menu li a:hover::after{width:100%}
.cine .header-area .theme-btn{
    background:transparent;border:1px solid var(--cine-line);color:#fff;
    border-radius:0;font-size:12px;letter-spacing:1.5px;text-transform:uppercase;
    padding:13px 26px;transition:padding .4s ease,font-size .4s ease,background .35s ease,border-color .35s ease;
}
.cine .header-area .theme-btn:hover{background:var(--cine-gold);border-color:var(--cine-gold);color:#000}

/* ---------- HERO:全屏沉浸,电影画幅 letterbox ---------- */
.cine-hero{
    position:relative;min-height:100vh;display:flex;align-items:center;
    overflow:hidden;background:var(--cine-black);
}
.cine-hero-media{position:absolute;inset:0;z-index:0}
.cine-hero-media img{
    width:100%;height:100%;object-fit:cover;
    filter:grayscale(.25) contrast(1.05) brightness(.55);
    transform:scale(1.06);animation:cine-kenburns 22s ease-in-out infinite alternate;
}
/* 暗角 + 渐变压暗,保证文字永远压得住画面 */
.cine-hero-media::after{
    content:'';position:absolute;inset:0;
    background:
        linear-gradient(90deg,rgba(0,0,0,.92) 0%,rgba(0,0,0,.55) 45%,rgba(0,0,0,.25) 100%),
        radial-gradient(120% 120% at 50% 50%,transparent 40%,rgba(0,0,0,.7) 100%);
}
/* 上下黑条 = 2.35:1 电影画幅的灵魂 */
.cine-letterbox{position:absolute;left:0;width:100%;height:8vh;background:#000;z-index:3;pointer-events:none}
.cine-letterbox.top{top:0}
.cine-letterbox.bottom{bottom:0}

.cine-hero-inner{position:relative;z-index:4;max-width:1320px;margin:0 auto;padding:0 40px;width:100%}
.cine-eyebrow{
    display:inline-flex;align-items:center;gap:14px;
    font-size:12px;letter-spacing:4px;text-transform:uppercase;color:var(--cine-gold);
    font-weight:600;margin-bottom:26px;
}
.cine-eyebrow::before{content:'';width:46px;height:1px;background:var(--cine-gold)}
.cine-title{
    font-family:var(--font-poster);color:var(--cine-white);
    font-size:clamp(64px,13vw,220px);line-height:.92;font-weight:400;
    text-transform:uppercase;letter-spacing:-.5px;margin:0;
}
.cine-title .thin{display:block;color:transparent;-webkit-text-stroke:1.5px rgba(255,255,255,.55)}
.cine-sub{
    font-family:var(--font-cn);color:var(--cine-fog);
    font-size:clamp(15px,1.4vw,19px);line-height:1.7;max-width:540px;
    margin:30px 0 0;font-weight:300;
}
.cine-cta-row{display:flex;align-items:center;gap:28px;margin-top:46px;flex-wrap:wrap}
.cine-play{
    display:inline-flex;align-items:center;gap:16px;
    background:var(--cine-white);color:#000;padding:16px 30px;
    font-size:13px;letter-spacing:2px;text-transform:uppercase;font-weight:600;
    transition:.35s;
}
.cine-play .ico{
    width:34px;height:34px;border-radius:50%;background:#000;color:#fff;
    display:flex;align-items:center;justify-content:center;font-size:12px;transition:.35s;
}
.cine-play:hover{background:var(--cine-gold);color:#000}
.cine-play:hover .ico{background:#000;color:var(--cine-gold)}
.cine-ghost-link{
    display:inline-flex;align-items:center;gap:10px;color:var(--cine-white);
    font-size:13px;letter-spacing:2px;text-transform:uppercase;font-weight:500;
    border-bottom:1px solid transparent;padding-bottom:4px;transition:.35s;
}
.cine-ghost-link:hover{color:var(--cine-gold);border-color:var(--cine-gold)}

.cine-scroll-hint{
    position:absolute;bottom:calc(8vh + 26px);left:50%;transform:translateX(-50%);z-index:4;
    display:flex;flex-direction:column;align-items:center;gap:10px;
    font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--cine-fog);
}
.cine-scroll-hint .bar{width:1px;height:54px;background:linear-gradient(var(--cine-gold),transparent);animation:cine-scroll 2s ease-in-out infinite}

/* ---------- REEL:一屏一个,大图糊脸 ---------- */
.cine-reel{background:var(--cine-black);padding:0}
.cine-reel-head{
    text-align:center;padding:130px 40px 70px;
}
.cine-reel-head .label{font-size:12px;letter-spacing:4px;text-transform:uppercase;color:var(--cine-gold);font-weight:600}
.cine-reel-head h2{
    font-family:var(--font-poster);color:#fff;font-weight:400;
    font-size:clamp(40px,7vw,108px);line-height:1;text-transform:uppercase;margin-top:18px;letter-spacing:-1px;
}

.cine-shot{
    position:relative;min-height:100vh;display:flex;align-items:flex-end;
    overflow:hidden;border-top:1px solid var(--cine-line);
}
.cine-shot-media{position:absolute;inset:0;z-index:0}
.cine-shot-media img{
    width:100%;height:100%;object-fit:cover;
    filter:grayscale(.15) contrast(1.04) brightness(.62);
    transition:transform 1.2s cubic-bezier(.2,.7,.2,1),filter 1.2s ease;
}
.cine-shot-media::after{
    content:'';position:absolute;inset:0;
    background:linear-gradient(0deg,rgba(0,0,0,.9) 0%,rgba(0,0,0,.35) 40%,rgba(0,0,0,.1) 100%);
}
.cine-shot:hover .cine-shot-media img{transform:scale(1.05);filter:grayscale(0) contrast(1.08) brightness(.72)}

.cine-shot-meta{position:relative;z-index:2;width:100%;max-width:1320px;margin:0 auto;padding:0 40px 9vh}
.cine-shot-no{
    font-family:var(--font-poster);font-size:clamp(40px,6vw,90px);line-height:1;
    color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.35);display:block;margin-bottom:14px;
}
.cine-shot-tags{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px}
.cine-shot-tags span{
    font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--cine-white);
    border:1px solid var(--cine-line);padding:7px 14px;background:rgba(0,0,0,.3);backdrop-filter:blur(6px);
}
.cine-shot-tags span.gold{border-color:var(--cine-gold);color:var(--cine-gold)}
.cine-shot-title{
    font-family:var(--font-poster);color:#fff;font-weight:400;text-transform:uppercase;
    font-size:clamp(34px,6vw,86px);line-height:.98;letter-spacing:-.5px;margin:0;max-width:14ch;
}
.cine-shot-role{color:var(--cine-fog);font-size:15px;margin-top:16px;font-family:var(--font-cn);font-weight:300;letter-spacing:.5px}
.cine-shot-link{
    display:inline-flex;align-items:center;gap:12px;margin-top:26px;
    color:#fff;font-size:12px;letter-spacing:2px;text-transform:uppercase;font-weight:600;transition:.35s;
}
.cine-shot-link .ico{width:42px;height:42px;border:1px solid var(--cine-line);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:.35s}
.cine-shot-link:hover{color:var(--cine-gold)}
.cine-shot-link:hover .ico{border-color:var(--cine-gold);background:var(--cine-gold-soft)}

/* ---------- STATS:极简横排数据条 ---------- */
.cine-stats{background:var(--cine-ink);border-top:1px solid var(--cine-line);border-bottom:1px solid var(--cine-line)}
.cine-stats .grid{max-width:1320px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr)}
.cine-stat{padding:70px 40px;text-align:center;border-left:1px solid var(--cine-line)}
.cine-stat:first-child{border-left:0}
.cine-stat .num{font-family:var(--font-poster);font-size:clamp(46px,5vw,76px);line-height:1;color:#fff}
.cine-stat .num .plus{color:var(--cine-gold)}
.cine-stat .cap{font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--cine-fog);margin-top:14px}

/* ---------- 作品集统一 CTA ---------- */
.cine-cta{
    position:relative;overflow:hidden;background:#000;
    padding:clamp(110px,15vh,175px) 40px;text-align:center;
    border-top:1px solid var(--cine-line);
}
/* 视频背景层:全屏铺满 */
.cine-cta__video{
    position:absolute;inset:0;width:100%;height:100%;
    object-fit:cover;z-index:0;pointer-events:none;
}
/* 暗罩:压暗视频 + 上下渐黑融入页面 + 中心暖金辉光,保证文字可读 */
.cine-cta__overlay{
    content:'';position:absolute;inset:0;z-index:1;pointer-events:none;
    background:
        radial-gradient(120% 85% at 50% 42%,rgba(201,168,106,.10),transparent 60%),
        linear-gradient(180deg,#000 0%,rgba(0,0,0,.55) 30%,rgba(0,0,0,.55) 70%,#000 100%),
        rgba(0,0,0,.35);
}
/* 居中横向细线 */
.cine-cta::after{
    content:'';position:absolute;left:50%;top:50%;width:min(760px,68vw);height:1px;z-index:2;
    transform:translate(-50%,-50%);background:linear-gradient(90deg,transparent,var(--cine-line),transparent);
    pointer-events:none;
}
.cine-cta__inner{
    position:relative;z-index:3;
    max-width:940px;margin:0 auto;
    display:flex;flex-direction:column;align-items:center;
}
.cine-cta__label,
.cine-cta .label{
    display:inline-flex;align-items:center;justify-content:center;gap:14px;
    font-size:11px;letter-spacing:4px;text-transform:uppercase;
    color:var(--cine-gold);font-weight:600;white-space:nowrap;
}
.cine-cta__label::before,
.cine-cta .label::before,
.cine-cta__label::after,
.cine-cta .label::after{
    content:'';width:42px;height:1px;background:var(--cine-gold);opacity:.75;
}
.cine-cta__title,
.cine-cta h2{
    position:relative;font-family:var(--font-cn);color:#fff;font-weight:600;
    font-size:clamp(42px,5.4vw,82px);line-height:1.18;letter-spacing:-.045em;
    margin:36px auto 0;max-width:820px;text-align:center;
}
.cine-cta__title::after,
.cine-cta h2::after{
    content:'DENG';position:absolute;left:50%;top:50%;z-index:-1;
    transform:translate(-50%,-43%);
    font-family:var(--font-poster);font-size:clamp(76px,13vw,170px);line-height:1;
    letter-spacing:.02em;color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.055);
    white-space:nowrap;pointer-events:none;
}
.cine-cta__title .stroke,
.cine-cta h2 .stroke{
    color:var(--cine-gold);-webkit-text-stroke:0;
}
.cine-cta__line{display:none}
.cine-cta__link,
.cine-cta .mail{
    display:inline-flex;align-items:center;justify-content:center;gap:12px;
    width:max-content;margin:46px auto 0;
    color:#000;background:#fff;border:1px solid #fff;
    font-family:var(--font-ui);font-size:13px;font-weight:700;
    letter-spacing:2px;text-transform:uppercase;padding:17px 34px;border-radius:100px;
    transition:background .35s ease,border-color .35s ease,color .35s ease,transform .35s ease;
}
.cine-cta__link i{font-size:1.1em;transition:transform .35s ease}
.cine-cta__link:hover,
.cine-cta .mail:hover{
    background:var(--cine-gold);border-color:var(--cine-gold);color:#000;transform:translateY(-2px);
}
.cine-cta__link:hover i{transform:translateX(5px)}

/* ---------- 页脚微调(沿用旧结构) ---------- */
.cine .footer-area{background:var(--cine-ink);border-top:1px solid var(--cine-line);padding:64px 0 56px}
.cine .footer-area .footer-content .footer-menu li a{letter-spacing:1.5px}
.cine .footer-area .footer-content .copyright span{color:var(--cine-gold)}

/* ---------- 动画 ---------- */
@keyframes cine-kenburns{from{transform:scale(1.06) translate(0,0)}to{transform:scale(1.14) translate(-1.5%,-1.5%)}}
@keyframes cine-scroll{0%,100%{transform:scaleY(.4);transform-origin:top;opacity:.4}50%{transform:scaleY(1);opacity:1}}

/* ---------- 响应式 ---------- */
@media(max-width:991px){
    .cine-stats .grid{grid-template-columns:1fr 1fr}
    .cine-stat:nth-child(3){border-left:0}
    .cine-stat:nth-child(-n+2){border-bottom:1px solid var(--cine-line)}
}
@media(max-width:767px){
    .cine .header-area .container{padding:0 22px}
    .cine .header-area .navbar .theme-btn{margin-top:40px}
    .cine-hero-inner,.cine-shot-meta,.cine-reel-head{padding-left:22px;padding-right:22px}
    .cine-letterbox{height:5vh}
    .cine-scroll-hint{display:none}
    .cine-cta-row{gap:18px}
    .cine-play{padding:14px 22px}
}
@media(max-width:575px){
    .cine-stats .grid{grid-template-columns:1fr}
    .cine-stat{border-left:0;border-bottom:1px solid var(--cine-line)}
    .cine-stat:last-child{border-bottom:0}
}

/* ============================================================
   内页通用模块(works / about / contact / work-details 共用)
   ============================================================ */

/* ---------- 内页页头 ---------- */
.cine-page-head{
    max-width:1320px;margin:0 auto;padding:200px 40px 56px;
}
.cine-page-head .label{font-size:12px;letter-spacing:4px;text-transform:uppercase;color:var(--cine-gold);font-weight:600}
.cine-page-head h1{
    font-family:var(--font-poster);color:#fff;font-weight:400;text-transform:uppercase;
    font-size:clamp(54px,11vw,150px);line-height:.92;letter-spacing:-1px;margin:18px 0 0;
}
.cine-page-head p{font-family:var(--font-cn);color:var(--cine-fog);font-size:clamp(14px,1.3vw,17px);line-height:1.8;max-width:620px;margin:26px 0 0;font-weight:300}

/* ---------- 分类筛选条 ---------- */
.cine-filter{max-width:1320px;margin:0 auto;padding:0 40px 50px;display:flex;gap:12px;flex-wrap:wrap}
.cine-filter button{
    background:transparent;border:1px solid var(--cine-line);color:var(--cine-fog);
    font-size:12px;letter-spacing:1.5px;text-transform:uppercase;padding:11px 22px;cursor:pointer;transition:.3s;font-family:var(--font-ui);
}
.cine-filter button:hover{color:#fff;border-color:rgba(255,255,255,.4)}
.cine-filter button.active{background:var(--cine-gold);border-color:var(--cine-gold);color:#000;font-weight:600}

/* ---------- 作品网格 ---------- */
.cine-works{padding:0 40px 40px}
.cine-works-grid{max-width:1320px;margin:0 auto;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px;align-items:start}
.cine-works-column{display:flex;min-width:0;flex-direction:column;gap:20px}
.cine-work-card{position:relative;display:block;overflow:hidden;background:var(--cine-panel);border:1px solid var(--cine-line);margin:0}
.cine-work-media{position:relative;overflow:hidden;aspect-ratio:16/9}
.cine-work-media img,.cine-work-media video{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(.2) contrast(1.05) brightness(.7);transition:transform 1s cubic-bezier(.2,.7,.2,1),filter .8s ease}
.cine-work-card:hover .cine-work-media img,.cine-work-card:hover .cine-work-media video{transform:scale(1.05);filter:grayscale(0) contrast(1.08) brightness(.85)}
.cine-work-media__play{position:absolute;right:16px;bottom:16px;z-index:3;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.45);border:1px solid var(--cine-line);color:#fff;font-size:16px;backdrop-filter:blur(4px);transition:.35s ease;pointer-events:none}
.cine-work-card:hover .cine-work-media__play{background:var(--cine-gold);color:#000;border-color:var(--cine-gold)}
.cine-work-card .corner{position:absolute;top:18px;left:20px;z-index:3;font-family:var(--font-poster);font-size:26px;color:#fff;opacity:.7}
.video-modal-open{overflow:hidden}
.cine-video-modal{position:fixed;inset:0;z-index:3000;display:flex;align-items:center;justify-content:center;padding:38px;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .28s ease,visibility .28s ease}
.cine-video-modal.is-open{opacity:1;visibility:visible;pointer-events:auto}
.cine-video-modal__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.88);backdrop-filter:blur(10px)}
.cine-video-modal__frame{position:relative;z-index:1;--modal-aspect:16 / 9;--modal-ratio:1.777;aspect-ratio:var(--modal-aspect);width:min(92vw,1180px,calc(82vh * var(--modal-ratio)));max-height:82vh;display:flex;align-items:center;justify-content:center;background:#030303;border:1px solid rgba(255,255,255,.14);box-shadow:0 36px 120px rgba(0,0,0,.72);transform:translateY(16px) scale(.98);transition:transform .32s cubic-bezier(.2,.7,.2,1),width .28s ease}
.cine-video-modal.is-open .cine-video-modal__frame{transform:none}
.cine-video-modal__player{width:100%;height:100%;object-fit:contain;background:#000;display:block}
.cine-video-modal__close{position:absolute;top:-1px;right:-1px;z-index:2;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.78);border:1px solid rgba(255,255,255,.18);color:#fff;font-family:var(--font-ui);font-size:14px;font-weight:700;cursor:pointer;transition:.25s ease}
.cine-video-modal__close:hover{background:var(--cine-gold);border-color:var(--cine-gold);color:#000}
.cine-work-body{position:absolute;left:0;bottom:0;width:100%;z-index:3;padding:28px;background:linear-gradient(0deg,rgba(0,0,0,.9),transparent)}
.cine-work-tags{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.cine-work-tags span{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:#fff;border:1px solid var(--cine-line);padding:6px 12px;background:rgba(0,0,0,.3)}
.cine-work-tags span.gold{border-color:var(--cine-gold);color:var(--cine-gold)}
.cine-work-body h3{font-family:var(--font-poster);color:#fff;font-weight:400;text-transform:uppercase;font-size:clamp(26px,3vw,44px);line-height:1;margin:0;letter-spacing:-.5px}
.cine-work-body .meta{color:var(--cine-fog);font-size:14px;margin:10px 0 0;font-family:var(--font-cn);font-weight:300}

/* ---------- 关于:人物 Hero ---------- */
.about-hero{position:relative;max-width:1320px;margin:0 auto;padding:200px 40px 70px;overflow:hidden}
.about-hero__inner{position:relative;z-index:2}
.about-hero__label{font-size:12px;letter-spacing:4px;text-transform:uppercase;color:var(--cine-gold);font-weight:600}
.about-hero__name{font-family:var(--font-poster);color:#fff;font-weight:400;text-transform:uppercase;font-size:clamp(64px,13vw,180px);line-height:.9;letter-spacing:-2px;margin:14px 0 0}
.about-hero__name .dot{color:var(--cine-gold)}
.about-hero__meta{display:flex;flex-wrap:wrap;gap:0;margin-top:48px;border-top:1px solid var(--cine-line)}
.about-hero__meta .m{flex:1;min-width:200px;padding:24px 30px 0 0;border-right:1px solid var(--cine-line)}
.about-hero__meta .m:last-child{border-right:0}
.about-hero__meta .k{display:block;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--cine-fog);margin-bottom:10px}
.about-hero__meta .v{font-family:var(--font-cn);color:#fff;font-size:clamp(15px,1.4vw,18px);font-weight:400}
.about-hero__meta .v.on{display:inline-flex;align-items:center;gap:9px;color:var(--cine-gold)}
.about-hero__meta .v.on::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--cine-gold);box-shadow:0 0 0 0 var(--cine-gold);animation:aboutPulse 2s infinite}
@keyframes aboutPulse{0%{box-shadow:0 0 0 0 rgba(201,168,106,.6)}70%{box-shadow:0 0 0 9px rgba(201,168,106,0)}100%{box-shadow:0 0 0 0 rgba(201,168,106,0)}}
.about-hero__mark{position:absolute;z-index:1;right:-10px;bottom:-34px;font-family:var(--font-poster);font-size:clamp(140px,28vw,420px);line-height:.7;color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.05);pointer-events:none;user-select:none}
/* 区块编号小标 */
.about-sec-no{display:block;font-family:var(--font-poster);font-size:14px;letter-spacing:2px;color:var(--cine-gold);margin-bottom:18px}

/* ---------- 关于:简介区 ---------- */
.cine-about{padding:0 40px 40px}
.cine-about-top{max-width:1320px;margin:0 auto;display:grid;grid-template-columns:430px 1fr;gap:70px;align-items:start}
.cine-about-photo{position:relative;overflow:hidden;border:1px solid var(--cine-line)}
.cine-about-photo img{width:100%;display:block;filter:grayscale(.3) contrast(1.05) brightness(.85)}
.cine-about-photo .badge{position:absolute;top:18px;right:18px;font-size:11px;letter-spacing:2px;color:var(--cine-gold);border:1px solid var(--cine-gold);padding:7px 13px;background:rgba(0,0,0,.4)}
.cine-about-photo img{height:574px;object-fit:cover;object-position:center 25%}
.cine-about-intro .label{font-size:12px;letter-spacing:4px;text-transform:uppercase;color:var(--cine-gold);font-weight:600}
.cine-about-intro h2{font-family:var(--font-poster);color:#fff;font-weight:400;text-transform:uppercase;font-size:clamp(36px,5vw,72px);line-height:.98;letter-spacing:-.5px;margin:16px 0 30px}
/* 编辑式自述大标题(参考稿) */
.about-lead{font-family:var(--font-cn) !important;text-transform:none !important;font-weight:700;font-size:clamp(26px,2.8vw,40px) !important;line-height:1.45 !important;letter-spacing:0 !important;color:#fff;margin:6px 0 34px !important}
.about-lead .gold{color:var(--cine-gold)}
.cine-about-intro p{font-family:var(--font-cn);color:#a8a8a8;font-size:16px;line-height:1.9;margin:0 0 22px;font-weight:300}
.cine-about-intro p strong{color:#fff;font-weight:600}
.about-toolbox{margin-top:38px}
.about-toolbox__label{display:block;font-size:12px;letter-spacing:2.5px;color:var(--cine-gold);font-weight:600;margin-bottom:18px}
.cine-sign{font-family:var(--font-poster);font-size:40px;color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.4);margin-top:36px;text-transform:uppercase}
.cine-sign span{color:var(--cine-gold);-webkit-text-stroke:0}

/* ---------- 关于:履历 / 教育 / 能力(杂志章节式) ---------- */
.cine-resume{position:relative;padding:120px 40px;border-top:1px solid var(--cine-line);margin-top:60px;overflow:hidden}
.cine-resume__mark{position:absolute;z-index:1;top:50px;right:-20px;font-family:var(--font-poster);font-size:clamp(90px,16vw,240px);line-height:.8;letter-spacing:-2px;color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.045);pointer-events:none;user-select:none}
.resume-inner{position:relative;z-index:2;max-width:1320px;margin:0 auto}
/* 章节头:大编号 + 标题 */
.resume-head{display:flex;gap:40px;align-items:flex-start;margin-bottom:70px}
.resume-head__no{font-family:var(--font-poster);font-size:clamp(40px,5vw,80px);line-height:.8;color:transparent;-webkit-text-stroke:1px var(--cine-gold);flex-shrink:0}
.resume-head__label{display:block;font-size:12px;letter-spacing:4px;text-transform:uppercase;color:var(--cine-gold);font-weight:600;margin-bottom:18px}
.resume-head__title{font-family:var(--font-cn);font-weight:700;color:#fff;font-size:clamp(26px,3.4vw,46px);line-height:1.3;letter-spacing:0;margin:0}
.resume-head__title .gold{color:var(--cine-gold)}
/* 履历行:左侧大年份锚点 */
.resume-rows{border-top:1px solid var(--cine-line)}
.resume-row{position:relative;display:grid;grid-template-columns:200px 1fr;gap:56px;align-items:start;padding:46px 24px 46px 0;border-bottom:1px solid var(--cine-line);transition:padding .4s ease,background .4s ease}
.resume-row:hover{padding-left:24px;background:linear-gradient(90deg,rgba(255,255,255,.018),transparent 50%)}
.resume-row__yr{display:flex;flex-direction:column;flex-shrink:0}
.resume-row__yr .from{font-family:var(--font-poster);font-size:clamp(44px,4.4vw,64px);line-height:.85;color:#fff;letter-spacing:-1px;transition:color .4s ease}
.resume-row__yr .to{font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--cine-fog-2);margin-top:12px}
.resume-row:hover .resume-row__yr .from{color:var(--cine-gold)}
.resume-row__bd{padding-top:6px}
.resume-row__bd h4{font-family:var(--font-cn);color:#fff;font-size:clamp(20px,1.8vw,25px);font-weight:600;margin:0 0 14px;display:flex;align-items:baseline;gap:16px;flex-wrap:wrap}
.resume-row__bd h4 .co{font-family:var(--font-ui);font-size:12px;font-weight:400;letter-spacing:1.5px;text-transform:uppercase;color:var(--cine-gold);border-left:1px solid rgba(201,168,106,.4);padding-left:16px}
.resume-row__bd p{font-family:var(--font-cn);color:var(--cine-fog);font-size:15px;line-height:1.8;margin:0;font-weight:300;max-width:640px}
/* 教育背景:独立金边卡片 */
.resume-edu{margin-top:80px}
.resume-edu__label{display:block;font-family:var(--font-cn);font-size:clamp(20px,2vw,26px);font-weight:600;color:#fff;margin-bottom:30px;padding-bottom:18px;border-bottom:1px solid var(--cine-line)}
.resume-edu__card{position:relative;display:flex;align-items:center;gap:48px;background:linear-gradient(120deg,var(--cine-gold-soft),transparent 55%);border:1px solid var(--cine-line);border-left:2px solid var(--cine-gold);padding:42px 48px;overflow:hidden;transition:border-color .4s ease,transform .4s ease}
.resume-edu__card:hover{transform:translateY(-3px)}
.resume-edu__year{font-family:var(--font-poster);font-size:clamp(24px,2.6vw,38px);letter-spacing:.5px;color:var(--cine-gold);flex-shrink:0}
.resume-edu__bd{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);max-width:52%;text-align:center;z-index:1}
.resume-edu__bd h4{font-family:var(--font-cn);color:#fff;font-size:clamp(20px,1.8vw,26px);font-weight:600;margin:0;display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap}
.resume-edu__bd .deg{font-family:var(--font-ui);font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--cine-gold);border:1px solid rgba(201,168,106,.4);padding:5px 11px;font-weight:500}
.resume-edu__bd p{font-family:var(--font-cn);color:var(--cine-fog);font-size:14px;line-height:1.75;margin:0;font-weight:300}
.resume-edu__ico{position:absolute;right:-10px;bottom:-20px;font-size:150px;color:rgba(201,168,106,.07);pointer-events:none}
/* 能力:标题 + 两列技能网格 */
.resume-skills{margin-top:80px}
.resume-skills__label{display:block;font-family:var(--font-cn);font-size:clamp(20px,2vw,26px);font-weight:600;color:#fff;margin-bottom:38px;padding-bottom:18px;border-bottom:1px solid var(--cine-line)}
.resume-skills__grid{display:grid;grid-template-columns:1fr 1fr;gap:34px 70px}
.cine-skill{display:grid;grid-template-columns:58px minmax(0,1fr);align-items:start;gap:12px;margin:0}
.cine-skill .skill-icon{font-size:58px;line-height:1;color:var(--cine-gold);filter:drop-shadow(0 0 7px rgba(201,168,106,.32));opacity:.95}
.cine-skill .skill-badge{
    width:58px;height:58px;display:flex;align-items:center;justify-content:center;
    background:#050505;border:1px solid rgba(255,255,255,.16);color:#fff;
    font-family:var(--font-ui);font-size:25px;font-weight:500;letter-spacing:0;
    filter:none;opacity:1;
}
.cine-skill .skill-main{min-width:0;padding-top:3px}
.cine-skill .row-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:13px}
.cine-skill .name{font-family:var(--font-cn);color:#fff;font-size:15px;font-weight:400}
.cine-skill .pct{font-family:var(--font-poster);color:var(--cine-gold);font-size:19px;line-height:1;display:inline-block;min-width:3ch;text-align:right;font-variant-numeric:tabular-nums;transition:transform .12s ease,filter .12s ease}
.cine-skill .pct.is-rolling{filter:blur(.25px)}
.cine-skill .track{flex:1 1 auto;min-width:0;height:3px;background:var(--cine-line);position:relative;overflow:hidden}
.cine-skill .fill{position:relative;height:100%;background:linear-gradient(90deg,rgba(201,168,106,.35),var(--cine-gold));box-shadow:0 0 10px rgba(201,168,106,.5);transform-origin:left center;will-change:transform;overflow:hidden}
.cine-skill .fill::after{
    content:'';position:absolute;top:0;bottom:0;width:90px;left:-110px;
    background:linear-gradient(90deg,transparent,rgba(255,244,204,.9),transparent);
    opacity:0;transform:translateX(0);pointer-events:none;
}
.cine-skill.is-counted .fill::after{animation:skillLineSweep 2.65s .12s ease-out forwards}
@keyframes skillLineSweep{
    0%{opacity:0;transform:translateX(0)}
    12%{opacity:.9}
    100%{opacity:0;transform:translateX(740px)}
}
.resume-dataset{margin-top:92px;border-top:1px solid var(--cine-line);padding-top:72px}
.resume-dataset__head{display:grid;grid-template-columns:auto minmax(0,1fr);gap:36px;align-items:start;margin-bottom:34px}
.resume-dataset__label{display:block;font-size:12px;letter-spacing:3px;text-transform:uppercase;color:var(--cine-gold);font-weight:600;margin-bottom:16px}
.resume-dataset h3{font-family:var(--font-cn);font-size:clamp(28px,3.2vw,48px);line-height:1.18;color:#fff;font-weight:700;letter-spacing:0;margin:0 0 18px}
.resume-dataset h3 span{color:var(--cine-gold)}
.resume-dataset p{font-family:var(--font-cn);max-width:900px;color:var(--cine-fog);font-size:15px;line-height:1.85;margin:0;font-weight:300}
.resume-dataset__media,.resume-workflow__media{
    position:relative;margin:0;padding:0;border:1px solid rgba(201,168,106,.24);border-radius:18px;overflow:hidden;
    background:
        radial-gradient(circle at 12% 12%,rgba(201,168,106,.16),transparent 26%),
        radial-gradient(circle at 80% 85%,rgba(122,163,206,.13),transparent 34%),
        linear-gradient(135deg,rgba(255,255,255,.045),rgba(255,255,255,.01) 42%,rgba(201,168,106,.045));
    box-shadow:0 30px 90px rgba(0,0,0,.36),inset 0 1px 0 rgba(255,255,255,.06);
}
.resume-dataset__media::before,.resume-workflow__media::before{
    content:'';position:absolute;inset:0;z-index:0;
    background:linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px);
    background-size:42px 42px;opacity:.42;pointer-events:none;
}
.resume-dataset__media > img,.resume-workflow__media > img{
    position:relative;z-index:1;display:block;width:100%;height:auto;border-radius:0;
    filter:saturate(.95) contrast(1.04);box-shadow:0 20px 60px rgba(0,0,0,.32);
}
.resume-workflow{margin-top:92px;border-top:1px solid var(--cine-line);padding-top:72px}
.resume-workflow__head{display:grid;grid-template-columns:auto minmax(0,1fr);gap:36px;align-items:start;margin-bottom:38px}
.resume-workflow__label{display:block;font-size:12px;letter-spacing:3px;text-transform:uppercase;color:var(--cine-gold);font-weight:600;margin-bottom:16px}
.resume-workflow h3{font-family:var(--font-cn);font-size:clamp(28px,3.2vw,48px);line-height:1.18;color:#fff;font-weight:700;letter-spacing:0;margin:0 0 18px}
.resume-workflow h3 span{color:var(--cine-gold)}
.resume-workflow p{font-family:var(--font-cn);max-width:920px;color:var(--cine-fog);font-size:15px;line-height:1.85;margin:0;font-weight:300}
.resume-workflow__panel{
    position:relative;display:grid;grid-template-columns:1fr 48px 1fr 48px 1fr 48px 1fr;gap:0;align-items:stretch;
    min-height:300px;padding:36px;border:1px solid rgba(201,168,106,.24);border-radius:18px;overflow:hidden;
    background:
        radial-gradient(circle at 12% 12%,rgba(201,168,106,.16),transparent 26%),
        radial-gradient(circle at 80% 85%,rgba(122,163,206,.13),transparent 34%),
        linear-gradient(135deg,rgba(255,255,255,.045),rgba(255,255,255,.01) 42%,rgba(201,168,106,.045));
    box-shadow:0 30px 90px rgba(0,0,0,.36),inset 0 1px 0 rgba(255,255,255,.06);
}
.resume-workflow__panel::before{
    content:'';position:absolute;inset:0;z-index:0;
    background:linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px);
    background-size:42px 42px;opacity:.42;pointer-events:none;
}
.workflow-node,.workflow-output,.workflow-link{position:relative;z-index:1}
.workflow-node{
    display:flex;flex-direction:column;justify-content:space-between;min-height:220px;padding:26px 24px;
    border:1px solid rgba(255,255,255,.13);border-radius:14px;
    background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.025));
    transition:transform .35s ease,border-color .35s ease,background .35s ease;
}
.workflow-node:hover{transform:translateY(-4px);border-color:rgba(201,168,106,.48);background:linear-gradient(180deg,rgba(201,168,106,.14),rgba(255,255,255,.03))}
.workflow-node__eyebrow{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:rgba(201,168,106,.88);font-weight:700}
.workflow-node strong{display:block;margin-top:34px;font-family:var(--font-cn);font-size:clamp(19px,1.6vw,26px);line-height:1.2;color:#fff;font-weight:700}
.workflow-node em{font-family:var(--font-cn);font-style:normal;color:rgba(230,230,230,.58);font-size:13px;line-height:1.65;margin-top:16px}
.workflow-link{align-self:center;height:1px;background:linear-gradient(90deg,rgba(201,168,106,.1),var(--cine-gold),rgba(201,168,106,.1))}
.workflow-link::after{content:'';position:absolute;right:-4px;top:50%;width:8px;height:8px;border-top:1px solid var(--cine-gold);border-right:1px solid var(--cine-gold);transform:translateY(-50%) rotate(45deg)}
.workflow-output{
    grid-column:1/-1;margin-top:22px;display:flex;align-items:center;justify-content:space-between;gap:22px;
    padding:22px 26px;border:1px solid rgba(201,168,106,.38);border-radius:999px;
    background:linear-gradient(90deg,rgba(201,168,106,.2),rgba(255,255,255,.04),rgba(122,163,206,.12));
}
.workflow-output span{font-size:11px;letter-spacing:3px;color:var(--cine-gold);font-weight:800}
.workflow-output strong{font-family:var(--font-cn);font-size:22px;color:#fff;font-weight:700}
.workflow-output em{font-family:var(--font-cn);font-size:13px;color:rgba(255,255,255,.62);font-style:normal}
.resume-dataset-board{
    min-height:680px;padding:34px 44px 36px;
    background:
        radial-gradient(circle at 18% 72%,rgba(201,168,106,.18),transparent 26%),
        radial-gradient(circle at 78% 22%,rgba(95,150,199,.16),transparent 32%),
        linear-gradient(135deg,#172b3d 0%,#0b1824 48%,#08111b 100%);
}
.resume-dataset-board::after{
    content:'';position:absolute;inset:0;z-index:0;
    background:linear-gradient(rgba(255,255,255,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);
    background-size:28px 28px;opacity:.16;pointer-events:none;
}
.dataset-board__title,.dataset-board__subtitle,.dataset-board__folders,.dataset-board__note{position:relative;z-index:4}
.dataset-board__title{font-family:var(--font-cn);text-align:center;color:#edf6ff;font-size:clamp(24px,3vw,42px);font-weight:700;letter-spacing:0;margin-top:4px}
.dataset-board__title strong{color:#f1c83d;font-weight:800}
.dataset-board__subtitle{max-width:900px;margin:16px auto 26px;text-align:center;color:rgba(230,239,248,.84);font-size:16px;line-height:1.8;letter-spacing:2px}
.dataset-board__folders{display:grid;grid-template-columns:1fr 44px repeat(4,1fr);gap:28px;align-items:center;max-width:1120px;margin:0 auto 28px}
.dataset-folder{display:flex;flex-direction:column;align-items:center;gap:10px;color:#dbe8f3;font-family:var(--font-ui);font-style:normal;font-size:12px}
.dataset-folder img{width:min(100%,150px);height:auto;display:block;filter:drop-shadow(0 16px 18px rgba(0,0,0,.32))}
.dataset-folder em{font-style:normal;white-space:nowrap}
.dataset-arrow{display:flex;align-items:center;justify-content:center;color:#ffe07a;font-size:25px;filter:drop-shadow(0 0 10px rgba(255,224,122,.35))}
.dataset-board__files{position:absolute;z-index:2;right:44px;bottom:58px;width:72%;max-width:940px;height:auto;opacity:.93;mix-blend-mode:screen;filter:saturate(.9) contrast(1.02) brightness(1.05)}
.dataset-board__person{position:absolute;z-index:3;left:18px;bottom:-8px;width:min(40%,470px);height:auto;filter:drop-shadow(28px 16px 32px rgba(0,0,0,.46))}
.dataset-board__note{position:absolute;z-index:4;right:46px;bottom:28px;width:min(56%,760px);font-family:var(--font-cn);font-size:13px;line-height:1.7;color:rgba(232,238,244,.8);text-align:left}
/* ---------- 节点开发 / Custom Nodes ---------- */
.resume-ComfyUI{margin-top:92px;border-top:1px solid var(--cine-line);padding-top:72px}
.resume-ComfyUI__head{display:grid;grid-template-columns:auto minmax(0,1fr);gap:36px;align-items:start;margin-bottom:38px}
.resume-ComfyUI__label{display:block;font-size:12px;letter-spacing:3px;text-transform:uppercase;color:var(--cine-gold);font-weight:600;margin-bottom:16px}
.resume-ComfyUI h3{font-family:var(--font-cn);font-size:clamp(28px,3.2vw,48px);line-height:1.18;color:#fff;font-weight:700;letter-spacing:0;margin:0 0 18px}
.resume-ComfyUI h3 span{color:var(--cine-gold)}
.resume-ComfyUI > .resume-ComfyUI__head p{font-family:var(--font-cn);max-width:920px;color:var(--cine-fog);font-size:15px;line-height:1.85;margin:0;font-weight:300}
.resume-ComfyUI__panel{
    position:relative;display:grid;grid-template-columns:1.72fr 1fr;gap:10px 16px;
    padding:34px;border:1px solid rgba(201,168,106,.24);border-radius:18px;overflow:hidden;
    background:
        radial-gradient(circle at 12% 12%,rgba(201,168,106,.16),transparent 26%),
        radial-gradient(circle at 80% 85%,rgba(122,163,206,.13),transparent 34%),
        linear-gradient(135deg,rgba(255,255,255,.045),rgba(255,255,255,.01) 42%,rgba(201,168,106,.045));
    box-shadow:0 30px 90px rgba(0,0,0,.36),inset 0 1px 0 rgba(255,255,255,.06);
}
.resume-ComfyUI__panel::before{
    content:'';position:absolute;inset:0;z-index:0;
    background:
        linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px),
        linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px);
    background-size:42px 42px;opacity:.42;pointer-events:none;
}
.comfy-board__title{
    position:relative;z-index:1;grid-column:1/-1;text-align:center;margin-bottom:6px;
}
.comfy-board__title strong{
    display:block;font-family:var(--font-cn);font-size:clamp(30px,3.1vw,46px);line-height:1.15;color:#fff;font-weight:800;letter-spacing:1px;
}
.comfy-board__title span{color:#f2cf2f;margin-left:.2em}
.comfy-board__title p{
    margin:14px 0 10px;font-family:var(--font-cn);font-size:clamp(15px,1.5vw,21px);line-height:1.65;color:rgba(255,255,255,.88);letter-spacing:5px;font-weight:300;
}
.comfy-code-window{
    position:relative;z-index:1;min-height:620px;background:rgba(5,11,14,.64);border:1px solid rgba(255,255,255,.1);
    box-shadow:0 18px 48px rgba(0,0,0,.32);
    border-radius:10px;overflow:hidden;
}
.comfy-code-window::after{
    content:'';position:absolute;inset:0;z-index:2;pointer-events:none;
    background:linear-gradient(90deg,transparent,rgba(201,168,106,.14),transparent);
    opacity:0;transform:translateX(-100%);
}
.comfy-code-window.is-decrypting::after{animation:comfyDecryptScan 3.4s cubic-bezier(.16,1,.3,1) forwards}
@keyframes comfyDecryptScan{
    0%{opacity:0;transform:translateX(-100%)}
    14%{opacity:.9}
    100%{opacity:0;transform:translateX(100%)}
}
.comfy-code-window pre{
    margin:0;padding:22px 22px 18px 18px;height:100%;overflow:hidden;border-radius:inherit;
    color:#f3f8fb;font-family:Consolas,'Courier New',monospace;font-size:14px;line-height:1.38;text-shadow:0 0 7px rgba(255,255,255,.08);
}
.comfy-code-window code{white-space:pre-wrap}
.comfy-code-window code.is-lined{display:block;counter-reset:codeLine}
.code-line{
    position:relative;display:block;min-height:1.38em;padding-left:48px;white-space:pre-wrap;
}
.code-line::before{
    counter-increment:codeLine;content:counter(codeLine);
    position:absolute;left:0;top:0;width:32px;text-align:right;
    color:rgba(201,168,106,.48);font-variant-numeric:tabular-nums;text-shadow:none;
    user-select:none;
}
.code-line.is-empty::before{color:rgba(201,168,106,.22)}
.comfy-code-window.is-decrypting .code-line{color:rgba(238,246,250,.94);text-shadow:0 0 12px rgba(201,168,106,.2)}
.comfy-code-window.is-decrypting .code-line::selection{background:rgba(201,168,106,.28)}
.comfy-file-system{position:relative;z-index:1;display:grid;grid-template-rows:144px 1fr;gap:16px;min-width:0;min-height:620px;overflow:hidden}
.comfy-project-files,.comfy-plugin-grid{
    position:relative;overflow:hidden;
    background:
        linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px),
        linear-gradient(rgba(255,255,255,.018) 1px,transparent 1px),
        rgba(5,6,7,.72);
    background-size:54px 54px,54px 54px,100% 100%;
    border:1px solid rgba(255,255,255,.08);border-radius:10px;box-shadow:0 14px 34px rgba(0,0,0,.28);
}
.comfy-project-files{
    display:grid;grid-template-columns:repeat(4,1fr);gap:22px;align-items:center;padding:20px 26px 18px;min-height:144px;
}
.comfy-os-item,.comfy-plugin-grid span{
    display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:7px;min-width:0;
    font-family:var(--font-ui);font-size:11px;color:rgba(255,255,255,.86);text-align:center;
}
.comfy-os-item em,.comfy-plugin-grid em{font-style:normal;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.comfy-plugin-grid{
    display:grid;grid-template-columns:repeat(6,minmax(0,1fr));grid-auto-rows:58px;gap:6px 14px;
    padding:18px 24px 24px;align-content:start;min-height:460px;
}
.comfy-plugin-grid span{gap:5px;font-size:8.5px;line-height:1.18}
.os-folder,.os-python,.os-doc,.os-gear{
    position:relative;display:block;flex:0 0 auto;background-position:center;background-repeat:no-repeat;background-size:contain;
    filter:drop-shadow(0 5px 5px rgba(0,0,0,.28));
}
.os-folder{width:86px;height:66px;background-image:url("../images/comfy-icon-folder.svg")}
.os-python{width:54px;height:66px;background-image:url("https://img.alicdn.com/imgextra/i2/2232095120/O1CN01hHJ8z91nh10QW12Wr_!!2232095120.png")}
.os-gear{width:58px;height:66px;background-image:url("../images/comfy-icon-gear-file.svg")}
.os-doc{width:52px;height:66px;background-image:url("../images/comfy-icon-doc-file.svg")}
.comfy-plugin-grid .os-python{width:33px;height:40px}
/* ---------- 联系页 ---------- */
.cine-contact-wrap{position:relative;max-width:1320px;margin:0 auto;padding:0 40px 120px}
/* 编号式联系条目:整行可点,金色滑入 */
.contact-index{position:relative;z-index:2;border-top:1px solid var(--cine-line)}
.contact-index li{border-bottom:1px solid var(--cine-line)}
.contact-index a,.contact-index .static{
    position:relative;display:flex;align-items:center;gap:34px;
    padding:38px 24px;overflow:hidden;
}
.contact-index a{transition:padding .45s cubic-bezier(.2,.7,.2,1)}
/* 金色填充从左滑入 */
.contact-index a::before{
    content:'';position:absolute;inset:0;z-index:0;background:var(--cine-gold);
    transform:scaleX(0);transform-origin:left;transition:transform .45s cubic-bezier(.2,.7,.2,1);
}
.contact-index a:hover{padding-left:40px}
.contact-index a:hover::before{transform:scaleX(1)}
.contact-index .idx{
    position:relative;z-index:1;font-family:var(--font-poster);font-size:clamp(20px,2vw,26px);
    color:var(--cine-fog-2);min-width:52px;transition:color .35s;
}
.contact-index .body{position:relative;z-index:1;display:flex;flex-direction:column;gap:9px;flex:1}
.contact-index .k{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--cine-fog);transition:color .35s}
.contact-index .v{font-family:var(--font-poster);text-transform:uppercase;font-size:clamp(26px,3.4vw,48px);line-height:1;letter-spacing:-.5px;color:#fff;transition:color .35s}
.contact-index .arrow{position:relative;z-index:1;font-size:26px;color:var(--cine-fog-2);transform:translateX(-6px);opacity:0;transition:.4s}
.contact-index a:hover .idx,.contact-index a:hover .k,.contact-index a:hover .v,.contact-index a:hover .arrow{color:#000}
.contact-index a:hover .arrow{opacity:1;transform:translateX(0)}
/* 巨型描边水印字 */
.contact-mark{
    position:absolute;right:24px;bottom:54px;z-index:1;pointer-events:none;
    font-family:var(--font-poster);text-transform:uppercase;
    font-size:clamp(60px,13vw,190px);line-height:.86;text-align:right;letter-spacing:-2px;
    color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.12);
}
.contact-mark span{color:transparent;-webkit-text-stroke:1px var(--cine-gold-soft)}
/* 联系页大标题:粗宋体两行,第二行金色(参考稿) */
.contact-headline{font-family:'Noto Serif SC',serif !important;font-weight:900;text-transform:none !important;letter-spacing:0 !important;line-height:1.02 !important;font-size:clamp(58px,10vw,140px) !important}
.contact-headline .l1,.contact-headline .l2{display:block}
.contact-headline .l1{color:#f2f0ea}
.contact-headline .l2{color:var(--cine-gold);text-indent:1.1em}

/* 微信二维码灯箱 */
.qr-modal{position:fixed;inset:0;z-index:2000;display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s}
.qr-modal.is-open{opacity:1;visibility:visible}
.qr-modal__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.82);backdrop-filter:blur(8px)}
.qr-modal__card{position:relative;z-index:1;background:var(--cine-panel);border:1px solid var(--cine-line);padding:40px 40px 34px;text-align:center;max-width:340px;width:100%;transform:translateY(16px) scale(.96);transition:transform .35s cubic-bezier(.2,.7,.2,1)}
.qr-modal.is-open .qr-modal__card{transform:none}
.qr-modal__close{position:absolute;top:14px;right:14px;width:38px;height:38px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--cine-line);color:var(--cine-fog);font-size:18px;cursor:pointer;transition:.3s}
.qr-modal__close:hover{background:var(--cine-gold);border-color:var(--cine-gold);color:#000}
.qr-modal__label{display:block;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--cine-gold);font-weight:600;margin-bottom:22px}
.qr-modal__card img{width:100%;max-width:none;aspect-ratio:1;object-fit:cover;background:transparent;padding:0;display:block;margin:0 auto}
.qr-modal__tip{font-family:var(--font-cn);color:var(--cine-fog);font-size:13px;margin:22px 0 0;font-weight:300}

/* ---------- 作品详情 ---------- */
.cine-wd-hero{position:relative;height:88vh;min-height:560px;overflow:hidden;display:flex;align-items:flex-end}
.cine-wd-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:grayscale(.15) contrast(1.05) brightness(.6)}
.cine-wd-hero::after{content:'';position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.92),rgba(0,0,0,.2) 60%,rgba(0,0,0,.4))}
.cine-wd-hero .inner{position:relative;z-index:2;max-width:1320px;margin:0 auto;padding:0 40px 8vh;width:100%}
.cine-wd-hero .tags{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.cine-wd-hero .tags span{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:#fff;border:1px solid var(--cine-line);padding:7px 13px;background:rgba(0,0,0,.3)}
.cine-wd-hero .tags span.gold{border-color:var(--cine-gold);color:var(--cine-gold)}
.cine-wd-hero h1{font-family:var(--font-poster);color:#fff;font-weight:400;text-transform:uppercase;font-size:clamp(46px,9vw,128px);line-height:.92;letter-spacing:-1px;margin:0}
.cine-wd-body{padding:90px 40px}
.cine-wd-grid{max-width:1320px;margin:0 auto;display:grid;grid-template-columns:330px 1fr;gap:80px;align-items:start}
.cine-wd-specs li{display:flex;justify-content:space-between;gap:20px;padding:16px 0;border-bottom:1px solid var(--cine-line)}
.cine-wd-specs li:first-child{padding-top:0}
.cine-wd-specs .k{font-size:12px;letter-spacing:1px;text-transform:uppercase;color:var(--cine-fog)}
.cine-wd-specs .v{font-family:var(--font-cn);color:#fff;font-size:15px;text-align:right}
.cine-wd-text h2{font-family:var(--font-poster);color:#fff;font-weight:400;text-transform:uppercase;font-size:clamp(28px,3.5vw,46px);line-height:1;margin:0 0 30px;letter-spacing:-.5px}
.cine-wd-text p{font-family:var(--font-cn);color:#cfcfcf;font-size:16px;line-height:1.95;margin:0 0 24px;font-weight:300}
.cine-wd-gallery{padding:0 40px 90px;max-width:1400px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:24px}
.cine-wd-gallery .shot{overflow:hidden;border:1px solid var(--cine-line);aspect-ratio:16/9}
.cine-wd-gallery .shot.full{grid-column:1 / -1;aspect-ratio:21/9}
.cine-wd-gallery .shot img{width:100%;height:100%;object-fit:cover;filter:grayscale(.15) contrast(1.05) brightness(.78);transition:.8s}
.cine-wd-gallery .shot:hover img{filter:grayscale(0) contrast(1.08) brightness(.9);transform:scale(1.03)}
.cine-wd-nav{border-top:1px solid var(--cine-line)}
.cine-wd-nav a{max-width:1320px;margin:0 auto;padding:50px 40px;display:flex;align-items:center;justify-content:space-between;gap:30px}
.cine-wd-nav .dir{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--cine-fog);margin-bottom:10px}
.cine-wd-nav .ttl{font-family:var(--font-poster);color:#fff;font-size:clamp(28px,4vw,52px);text-transform:uppercase;line-height:1;transition:.3s}
.cine-wd-nav a:hover .ttl{color:var(--cine-gold)}

/* ---------- 内页响应式 ---------- */
@media(max-width:991px){
    .cine-about-top,.cine-contact-wrap,.cine-wd-grid{grid-template-columns:1fr;gap:50px}
    .cine-page-head{padding-top:150px}
    .about-hero{padding-top:150px}
    .about-hero__meta .m{flex:1 1 100%;border-right:0;border-bottom:1px solid var(--cine-line);padding:22px 0}
    .about-hero__meta .m:last-child{border-bottom:0}
    .resume-skills__grid{grid-template-columns:1fr;gap:28px}
    .resume-row{grid-template-columns:140px 1fr;gap:34px}
}
@media(max-width:991px){
    .cine-works-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:600px){
    .cine-works-grid{grid-template-columns:1fr}
}
@media(max-width:767px){
    .cine-wd-gallery{grid-template-columns:1fr}
    .cine-cta{padding:82px 22px;text-align:center}
    .cine-cta__inner{display:flex;gap:0}
    .cine-cta__title,.cine-cta h2{font-size:clamp(34px,11vw,52px);letter-spacing:-.03em}
    .cine-cta__title::after,.cine-cta h2::after{font-size:clamp(58px,20vw,92px);white-space:nowrap}
    .cine-cta__link,.cine-cta .mail{margin-top:34px}
    .contact-index a,.contact-index .static{gap:18px;padding:26px 0}
    .contact-index a:hover{padding-left:0}
    .contact-index .idx{min-width:34px;font-size:18px}
    .contact-index .arrow{display:none}
    .contact-mark{position:static;text-align:left;margin-top:54px;-webkit-text-stroke-width:1px}
    .resume-head{flex-direction:column;gap:18px;margin-bottom:50px}
    .resume-row{grid-template-columns:1fr;gap:14px;padding:30px 0}
    .resume-row:hover{padding-left:0}
    .resume-row__yr{flex-direction:row;align-items:baseline;gap:12px}
    .cine-skill{grid-template-columns:38px minmax(0,1fr);gap:10px}
    .cine-skill .skill-icon{font-size:38px}
    .cine-skill .skill-badge{width:38px;height:38px;font-size:17px}
    .cine-skill .row-top{gap:18px}
    .resume-dataset{margin-top:64px;padding-top:46px}
    .resume-dataset__head{grid-template-columns:1fr;gap:18px;margin-bottom:24px}
    .resume-dataset__media,.resume-workflow__media{border-radius:12px;padding:0}
    .resume-dataset__media > img,.resume-workflow__media > img{border-radius:0}
    .resume-workflow{margin-top:64px;padding-top:46px}
    .resume-workflow__head{grid-template-columns:1fr;gap:18px;margin-bottom:24px}
    .resume-workflow__panel{grid-template-columns:1fr;gap:14px;padding:22px;min-height:0;border-radius:12px}
    .workflow-node{min-height:160px;padding:22px 20px}
    .workflow-node strong{margin-top:24px}
    .workflow-link{height:34px;width:1px;justify-self:center;background:linear-gradient(180deg,rgba(201,168,106,.1),var(--cine-gold),rgba(201,168,106,.1))}
    .workflow-link::after{right:auto;left:50%;top:auto;bottom:-1px;transform:translateX(-50%) rotate(135deg)}
    .workflow-output{border-radius:14px;flex-direction:column;align-items:flex-start}
    .resume-dataset-board{min-height:560px;padding:24px 18px 28px}
    .dataset-board__title{text-align:left;font-size:24px}
    .dataset-board__subtitle{text-align:left;margin:12px 0 20px;font-size:13px;letter-spacing:1px}
    .dataset-board__folders{grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:18px}
    .dataset-arrow{display:none}
    .dataset-folder img{width:86px}
    .dataset-folder em{font-size:10px}
    .dataset-board__files{right:-130px;bottom:74px;width:118%;opacity:.74}
    .dataset-board__person{left:-58px;bottom:-2px;width:58%;max-width:320px}
    .dataset-board__note{left:18px;right:18px;bottom:22px;width:auto;font-size:12px}
    .resume-ComfyUI{margin-top:64px;padding-top:46px}
    .resume-ComfyUI__head{grid-template-columns:1fr;gap:18px;margin-bottom:24px}
    .resume-ComfyUI__panel{grid-template-columns:1fr;gap:14px;padding:18px;border-width:1px;border-radius:14px}
    .comfy-board__title strong{font-size:26px}
    .comfy-board__title p{font-size:13px;letter-spacing:2px}
    .comfy-code-window{min-height:410px}
    .comfy-code-window pre{font-size:10px;line-height:1.35;padding:16px 12px 14px 10px}
    .code-line{padding-left:36px}
    .code-line::before{width:24px}
    .comfy-file-system{grid-template-rows:112px 1fr;gap:12px;min-height:520px}
    .comfy-project-files{grid-template-columns:repeat(4,1fr);gap:10px;padding:14px 10px;min-height:112px}
    .comfy-plugin-grid{grid-template-columns:repeat(4,minmax(0,1fr));grid-auto-rows:54px;gap:7px 6px;padding:12px 8px 24px;min-height:390px}
    .os-folder{width:50px;height:38px}
    .os-python,.os-doc,.os-gear{width:34px;height:42px}
    .comfy-plugin-grid .os-python{width:24px;height:31px}
    .resume-edu__card{flex-direction:column;align-items:flex-start;gap:20px;padding:32px 26px}
    .resume-edu__bd{position:relative;left:auto;top:auto;transform:none;max-width:none;text-align:left}
    .resume-edu__bd h4{justify-content:flex-start}
    .cine-page-head,.cine-filter,.cine-works,.cine-about,.cine-resume,.cine-contact-wrap,.cine-wd-body,.cine-wd-gallery{padding-left:22px;padding-right:22px}
    .cine-wd-hero .inner{padding-left:22px;padding-right:22px}
}
