/*
Theme Name: DC Film School
Description: DC Film School custom theme
Version: 2.1
*/

@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+TC:wght@400;700;900&family=Noto+Sans+TC:wght@300;400;500;700&display=swap');

:root{
  --red:#e5251b;
  --dark:#0d0d0d;
  --mid:#1a1a1a;
  --white:#fff;
  --text:#1c1c1e;
  --muted:#8a8a8e;
  --border:#e2e2e7;
  --bg:#fafafa;
}

*{box-sizing:border-box;margin:0;padding:0;}
html{font-size:16px;scroll-behavior:smooth;}
body{font-family:'Noto Sans TC',-apple-system,sans-serif;color:var(--text);background:#fff;line-height:1.6;-webkit-font-smoothing:antialiased;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;height:auto;display:block;}

/* ─── HEADER ─── */
.site-header{background:var(--dark);position:sticky;top:0;z-index:200;box-shadow:0 2px 0 var(--red);}
.header-inner{max-width:1280px;margin:0 auto;padding:0 32px;height:60px;display:flex;align-items:center;gap:40px;}
.site-logo{font-family:'Noto Serif TC',serif;font-size:1.25rem;font-weight:900;color:#fff;letter-spacing:.04em;white-space:nowrap;}
.site-logo span{color:var(--red);}
.main-nav{flex:1;}
.main-nav ul{display:flex;list-style:none;gap:2px;}
.main-nav ul li a{display:block;padding:0 14px;height:60px;line-height:60px;font-size:.72rem;font-weight:500;color:rgba(255,255,255,.65);letter-spacing:.1em;text-transform:uppercase;transition:color .15s,background .15s;}
.main-nav ul li a:hover{color:#fff;background:rgba(255,255,255,.06);}

/* ─── HERO ─── */
.hero{background:var(--dark);padding:0;}
.hero-inner{max-width:1280px;margin:0 auto;padding:24px 32px;display:grid;grid-template-columns:1fr 310px;gap:24px;}

.hero-main{position:relative;border-radius:6px;overflow:hidden;background:#111;}
.hero-main>a{display:block;position:relative;}
.hero-main>a img{width:100%;height:440px;object-fit:cover;display:block;transition:transform .5s ease;opacity:.9;}
.hero-main:hover>a img{transform:scale(1.025);opacity:1;}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.88) 0%,rgba(0,0,0,.4) 50%,transparent 100%);pointer-events:none;}
.hero-content{position:absolute;bottom:0;left:0;right:0;padding:28px 28px 28px;}
.hero-cat{display:inline-block;background:var(--red);color:#fff;font-size:.6rem;font-weight:700;padding:4px 10px 3px;letter-spacing:.15em;text-transform:uppercase;margin-bottom:14px;border-radius:2px;}
.hero-title{font-family:'Noto Serif TC',serif;font-size:1.75rem;font-weight:900;color:#fff;line-height:1.35;margin-bottom:12px;text-shadow:0 1px 4px rgba(0,0,0,.4);}
.hero-title a{color:#fff;}
.hero-excerpt{font-size:.82rem;color:rgba(255,255,255,.75);line-height:1.75;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}

.hero-side{display:flex;flex-direction:column;justify-content:space-between;gap:0;}
.hero-side-item{display:grid;grid-template-columns:96px 1fr;gap:14px;align-items:start;padding:16px 0;border-bottom:1px solid rgba(255,255,255,.07);}
.hero-side-item:first-child{padding-top:0;}
.hero-side-item:last-child{border-bottom:none;padding-bottom:0;}
.hero-side-item .thumb{display:block;width:96px;height:64px;border-radius:4px;overflow:hidden;flex-shrink:0;}
.hero-side-item .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .35s;}
.hero-side-item:hover .thumb img{transform:scale(1.06);}
.hero-side-cat{font-size:.58rem;font-weight:700;color:var(--red);letter-spacing:.12em;text-transform:uppercase;margin-bottom:6px;}
.hero-side-title{font-size:.8rem;font-weight:500;color:rgba(255,255,255,.85);line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;}
.hero-side-title a{color:rgba(255,255,255,.85);transition:color .15s;}
.hero-side-title a:hover{color:#fff;}

/* ─── MAIN CONTENT ─── */
.container{max-width:1280px;margin:0 auto;padding:48px 32px;}

.section-header{display:flex;align-items:center;margin-bottom:32px;padding-bottom:0;}
.section-title{font-family:'Noto Serif TC',serif;font-size:.8rem;font-weight:900;letter-spacing:.18em;text-transform:uppercase;color:var(--text);padding-right:20px;white-space:nowrap;}
.section-line{flex:1;height:1px;background:var(--border);}
.section-red{width:40px;height:3px;background:var(--red);margin-right:12px;}

/* ─── POST GRID ─── */
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px 28px;}

.post-card{display:flex;flex-direction:column;}
.post-card-img{position:relative;border-radius:5px;overflow:hidden;aspect-ratio:16/9;background:#eee;margin-bottom:0;}
.post-card-img a{display:block;height:100%;}
.post-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease;}
.post-card:hover .post-card-img img{transform:scale(1.05);}
.post-card-cat{position:absolute;top:12px;left:12px;background:var(--red);color:#fff;font-size:.58rem;font-weight:700;padding:4px 10px 3px;border-radius:2px;letter-spacing:.1em;z-index:1;}
.no-thumb{display:flex;align-items:center;justify-content:center;width:100%;height:100%;background:#111;color:#333;font-size:2.5rem;}

.post-card-body{padding:18px 0 0;flex:1;display:flex;flex-direction:column;}
.post-card-title{font-family:'Noto Serif TC',serif;font-size:1rem;font-weight:700;line-height:1.5;margin-bottom:10px;flex:1;}
.post-card-title a{color:var(--text);transition:color .15s;}
.post-card-title a:hover{color:var(--red);}
.post-card-exc{font-size:.78rem;color:#666;line-height:1.75;margin-bottom:12px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.post-meta{font-size:.68rem;color:var(--muted);letter-spacing:.02em;}

/* ─── PAGINATION ─── */
.pagination{margin-top:56px;}
.pagination-inner{display:flex;align-items:center;justify-content:center;gap:20px;flex-wrap:wrap;}
.pagination ul{display:flex;gap:4px;list-style:none;align-items:center;}
.pagination ul li a,.pagination ul li span{display:flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 10px;font-size:.78rem;font-weight:500;border-radius:50%;color:var(--muted);transition:all .18s;border:none;background:transparent;}
.pagination ul li a:hover{background:var(--dark);color:#fff;}
.pagination ul li .current{background:var(--red);color:#fff;font-weight:700;}
.pagination ul li .dots{color:var(--muted);pointer-events:none;}
.pagination-jump{display:flex;align-items:center;gap:8px;font-size:.72rem;color:var(--muted);}
.pagination-jump input{width:52px;height:32px;text-align:center;border:1.5px solid var(--border);border-radius:4px;font-size:.78rem;outline:none;color:var(--text);transition:border-color .18s;}
.pagination-jump input:focus{border-color:var(--dark);}
.pagination-jump button{height:32px;padding:0 12px;background:var(--dark);color:#fff;border:none;border-radius:4px;font-size:.72rem;cursor:pointer;transition:background .18s;}
.pagination-jump button:hover{background:var(--red);}

/* ─── SINGLE ─── */
.single-post{max-width:1280px;margin:0 auto;padding:48px 32px;display:grid;grid-template-columns:1fr 300px;gap:64px;}
.single-cat{display:inline-block;background:var(--red);color:#fff;font-size:.62rem;font-weight:700;padding:4px 12px 3px;border-radius:2px;letter-spacing:.12em;margin-bottom:18px;}
.single-title{font-family:'Noto Serif TC',serif;font-size:2.1rem;font-weight:900;line-height:1.35;margin-bottom:18px;letter-spacing:.01em;}
.single-meta{font-size:.75rem;color:var(--muted);margin-bottom:32px;display:flex;gap:20px;padding-bottom:24px;border-bottom:1px solid var(--border);}
.single-thumb{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:6px;margin-bottom:36px;}
.entry-content{font-family:'Noto Serif TC',serif;font-size:1.05rem;line-height:2;color:#2c2c2e;}
.entry-content h2,.entry-content h3{font-weight:700;margin:2.2em 0 .8em;line-height:1.4;}
.entry-content p{margin-bottom:1.6em;}
.entry-content img{width:100%;border-radius:6px;margin:2em 0;}
.entry-content a{color:var(--red);text-decoration:underline;text-decoration-color:rgba(229,37,27,.35);}
.post-nav{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:56px;padding-top:36px;border-top:1px solid var(--border);}
.post-nav a{display:block;padding:20px;border:1px solid var(--border);border-radius:6px;transition:border-color .2s;}
.post-nav a:hover{border-color:var(--dark);}
.post-nav-dir{font-size:.65rem;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;margin-bottom:8px;}
.post-nav-title{font-family:'Noto Serif TC',serif;font-size:.9rem;font-weight:700;line-height:1.4;color:var(--text);}

/* ─── SIDEBAR ─── */
.sidebar{position:sticky;top:80px;}
.widget{margin-bottom:36px;}
.widget-title{font-family:'Noto Serif TC',serif;font-size:.78rem;font-weight:900;letter-spacing:.15em;text-transform:uppercase;margin-bottom:16px;padding-bottom:12px;border-bottom:2px solid var(--dark);}

/* ─── FOOTER ─── */
.site-footer{background:var(--dark);margin-top:80px;}
.footer-inner{max-width:1280px;margin:0 auto;padding:56px 32px 40px;display:grid;grid-template-columns:2.5fr 1fr 1fr;gap:48px;}
.footer-logo{font-family:'Noto Serif TC',serif;font-size:1.15rem;font-weight:900;color:#fff;margin-bottom:14px;display:block;}
.footer-logo span{color:var(--red);}
.footer-desc{font-size:.78rem;color:rgba(255,255,255,.45);line-height:1.8;}
.footer-col h4{font-size:.65rem;font-weight:700;color:rgba(255,255,255,.4);letter-spacing:.15em;text-transform:uppercase;margin-bottom:16px;}
.footer-col ul{list-style:none;}
.footer-col ul li{margin-bottom:10px;}
.footer-col ul li a{font-size:.8rem;color:rgba(255,255,255,.6);transition:color .15s;}
.footer-col ul li a:hover{color:#fff;}
.footer-bottom{max-width:1280px;margin:0 auto;padding:20px 32px;border-top:1px solid rgba(255,255,255,.07);display:flex;justify-content:space-between;align-items:center;}
.footer-bottom p{font-size:.68rem;color:rgba(255,255,255,.28);letter-spacing:.03em;}

/* ─── RESPONSIVE ─── */
@media(max-width:1024px){
  .hero-inner,.single-post{grid-template-columns:1fr;}
  .hero-main>a img{height:360px;}
  .hero-side{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
  .hero-side-item{border-bottom:none;padding:0;}
  .post-grid{grid-template-columns:repeat(2,1fr);}
  .footer-inner{grid-template-columns:1fr 1fr;}
}
@media(max-width:640px){
  .header-inner{padding:0 20px;}
  .main-nav{display:none;}
  .hero-inner{padding:16px 20px;}
  .container{padding:32px 20px;}
  .post-grid{grid-template-columns:1fr;gap:32px;}
  .hero-side{grid-template-columns:1fr;}
  .hero-title{font-size:1.3rem;}
  .footer-inner{grid-template-columns:1fr;padding:40px 20px 28px;}
  .footer-bottom{padding:16px 20px;flex-direction:column;gap:8px;text-align:center;}
}
body.single-post{display:block;padding:0;max-width:none;}
body.single-post main{display:block;width:100%;}
.cat-filter{display:flex;flex-wrap:wrap;gap:8px;padding:28px 0 4px;}
.cat-btn{display:inline-block;padding:7px 20px;border:1.5px solid #ddd;border-radius:20px;font-size:.72rem;font-weight:500;color:#444;text-decoration:none;letter-spacing:.05em;transition:all .18s;}
.cat-btn:hover,.cat-btn.active{background:#e5251b;border-color:#e5251b;color:#fff;}

/* === 閱讀進度條 === */
#dcfs-progress-bar{position:fixed;top:0;left:0;width:100%;height:3px;background:rgba(0,0,0,0.08);z-index:99999;}
#dcfs-progress{height:100%;width:0;background:linear-gradient(90deg,#e5251b,#ff6b35);transition:width .1s linear;}

/* === 卡片動態感 === */
@keyframes fadeInUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
.post-card{animation:fadeInUp .5s ease both;}
.post-card:nth-child(1){animation-delay:.05s}
.post-card:nth-child(2){animation-delay:.1s}
.post-card:nth-child(3){animation-delay:.15s}
.post-card:nth-child(4){animation-delay:.2s}
.post-card:nth-child(5){animation-delay:.25s}
.post-card:nth-child(6){animation-delay:.3s}
.post-card-img{overflow:hidden;border-radius:6px;aspect-ratio:16/9;background:#111;}
.post-card-img a img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease,opacity .3s;}
.post-card:hover .post-card-img a img{transform:scale(1.06);opacity:.88;}
.post-card-title a{transition:color .2s;}
.post-card-title a:hover{color:#e5251b;}

/* === Hero 更有電影感 === */
.hero-main>a img{transition:transform 8s ease;transform:scale(1.02);}
.hero-main:hover>a img{transform:scale(1.0);}
.hero-title a{text-shadow:0 2px 12px rgba(0,0,0,.4);transition:opacity .2s;}
.hero-title a:hover{opacity:.85;}

/* === 分類 filter 動態 === */
.cat-btn{transition:all .2s cubic-bezier(.4,0,.2,1);}
.cat-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(229,37,27,.2);}

/* ─── LOGIN NAV BUTTON ─── */
.main-nav ul li:last-child { margin-left: auto; }
.main-nav ul li:last-child a {
  background: var(--red);
  color: #fff !important;
  padding: 0 18px;
  height: 34px;
  line-height: 34px;
  border-radius: 4px;
  margin-top: 13px;
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .12em;
  transition: background .2s;
}
.main-nav ul li:last-child a:hover { background: #c41e15 !important; }

/* ─── LOGIN PAGE: hide RSS Feed ─── */
.login-card a[href*="feed"] { display: none !important; }
.login-card br { display: none; }
.login-card p { margin-bottom: 6px; }

/* ─── LOGIN PAGE: hide welcome line ─── */
.login-card p:first-of-type { display: none !important; }

/* ─── HEADER: logged-in member name ─── */
.main-nav ul li.menu-item-loggedin a {
  background: rgba(255,255,255,.1) !important;
  color: rgba(255,255,255,.85) !important;
  border-radius: 4px;
  font-size: .72rem;
  font-weight: 400;
  letter-spacing: .05em;
}
.main-nav ul li.menu-item-loggedin a:hover {
  background: rgba(255,255,255,.18) !important;
  color: #fff !important;
}

/* member SVG icon */
.main-nav ul li.menu-item-loggedin a::before {
  content: '';
  display: inline-block;
  width: 14px;
  height: 14px;
  margin-right: 6px;
  vertical-align: middle;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='rgba(255,255,255,.85)' stroke-width='2'%3E%3Ccircle cx='12' cy='8' r='4'/%3E%3Cpath d='M4 20c0-4 3.6-7 8-7s8 3 8 7'/%3E%3C/svg%3E") center/contain no-repeat;
}

/* Editor's Picks */
.editors-pick-section{margin-bottom:48px;padding-bottom:48px;border-bottom:1px solid var(--border);}
.ep-badge{position:absolute;top:12px;right:12px;background:#b8860b;color:#fff;font-size:.58rem;font-weight:700;padding:4px 10px 3px;border-radius:2px;letter-spacing:.1em;z-index:2;}

/* Mobile hamburger menu */
.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:36px;height:60px;background:none;border:none;cursor:pointer;padding:4px;margin-left:auto;flex-shrink:0;}
.nav-toggle span{display:block;width:22px;height:2px;background:rgba(255,255,255,.8);border-radius:2px;transition:all .25s;}
.nav-toggle.active span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-toggle.active span:nth-child(2){opacity:0;}
.nav-toggle.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
@media(max-width:640px){
  .nav-toggle{display:flex;}
  .main-nav{display:none;position:fixed;top:60px;left:0;right:0;background:var(--dark);z-index:199;border-top:1px solid rgba(255,255,255,.08);box-shadow:0 8px 24px rgba(0,0,0,.4);}
  .main-nav.open{display:block;}
  .main-nav ul{flex-direction:column;gap:0;}
  .main-nav ul li a{height:50px;line-height:50px;padding:0 28px;border-bottom:1px solid rgba(255,255,255,.05);}
  .main-nav ul li:last-child{margin-left:0;}
  .main-nav ul li:last-child a{margin:12px 20px;height:40px;line-height:40px;border-bottom:none;}
}

/* ─── SERIES ARCHIVE ─── */
.series-hero{background:var(--dark);padding:56px 32px 48px;border-bottom:3px solid var(--red);}
.series-hero-inner{max-width:800px;margin:0 auto;}
.series-label{font-size:.65rem;font-weight:700;color:var(--red);letter-spacing:.2em;text-transform:uppercase;margin-bottom:14px;}
.series-title{font-family:'Noto Serif TC',serif;font-size:2.2rem;font-weight:900;color:#fff;line-height:1.3;margin-bottom:14px;}
.series-desc{font-size:.9rem;color:rgba(255,255,255,.6);line-height:1.8;margin-bottom:14px;}
.series-count{font-size:.72rem;color:rgba(255,255,255,.35);letter-spacing:.08em;}

.series-list{display:flex;flex-direction:column;gap:0;}
.series-item{display:grid;grid-template-columns:48px 200px 1fr;gap:24px;align-items:start;padding:28px 0;border-bottom:1px solid var(--border);}
.series-item:last-child{border-bottom:none;}
.series-item-num{font-family:'Noto Serif TC',serif;font-size:1.8rem;font-weight:900;color:var(--border);line-height:1;padding-top:4px;}
.series-item-thumb{border-radius:5px;overflow:hidden;aspect-ratio:16/9;background:#eee;}
.series-item-thumb a{display:block;height:100%;}
.series-item-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .35s;}
.series-item:hover .series-item-thumb img{transform:scale(1.05);}
.series-item-cat{font-size:.6rem;font-weight:700;color:var(--red);letter-spacing:.12em;text-transform:uppercase;margin-bottom:8px;display:block;}
.series-item-title{font-family:'Noto Serif TC',serif;font-size:1.05rem;font-weight:700;line-height:1.5;margin-bottom:8px;}
.series-item-title a{color:var(--text);transition:color .15s;}
.series-item-title a:hover{color:var(--red);}
.series-item-exc{font-size:.78rem;color:#666;line-height:1.75;margin-bottom:10px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.series-item-meta{font-size:.68rem;color:var(--muted);}

@media(max-width:640px){
  .series-hero{padding:36px 20px 32px;}
  .series-title{font-size:1.5rem;}
  .series-item{grid-template-columns:32px 1fr;grid-template-rows:auto auto;gap:12px;}
  .series-item-thumb{grid-column:2;grid-row:1;}
  .series-item-body{grid-column:2;grid-row:2;}
  .series-item-num{grid-column:1;grid-row:1;}
}

/* ─── SERIES BANNER (single post) ─── */
.series-banner{background:#0d0d0d;border-left:4px solid var(--red);padding:16px 20px;border-radius:0 6px 6px 0;margin-bottom:28px;}
.series-banner-main{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:8px;}
.series-banner-label{font-size:.6rem;font-weight:700;color:var(--red);letter-spacing:.15em;text-transform:uppercase;flex-shrink:0;}
.series-banner-name{font-size:.9rem;font-weight:700;color:#fff;text-decoration:none;transition:opacity .15s;}
.series-banner-name:hover{opacity:.75;}
.series-banner-pos{font-size:.7rem;color:rgba(255,255,255,.35);margin-left:auto;white-space:nowrap;}
.series-banner-nav{display:flex;justify-content:space-between;gap:16px;border-top:1px solid rgba(255,255,255,.08);padding-top:10px;margin-top:4px;}
.series-banner-prev,.series-banner-next{font-size:.72rem;color:rgba(255,255,255,.5);text-decoration:none;transition:color .15s;max-width:46%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.series-banner-prev:hover,.series-banner-next:hover{color:#fff;}
.series-banner-next{text-align:right;}
