@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+TC:wght@400;600&family=Noto+Sans+TC:wght@300;400&family=Playfair+Display:ital,wght@0,400;0,600;1,400&display=swap');
:root{--rose:#F2A5B0;--rose-light:#FAE5E8;--rose-deep:#D4697A;--blush:#FFF0F2;--peach:#FDE8D8;--warm-white:#FFFCFA;--cream:#FDF8F4;--text-dark:#2D2020;--text-mid:#6B4F52;--text-light:#A08085;--gold:#C9996A;--gold-light:#F5E8D8;--border:rgba(212,105,122,0.12);--shadow-soft:0 4px 24px rgba(242,165,176,0.18);--shadow-card:0 2px 12px rgba(212,105,122,0.10);--radius:16px;--radius-sm:8px;--font-serif:'Playfair Display','Noto Serif TC',serif;--font-sans:'Noto Sans TC',sans-serif}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-sans);background:var(--warm-white);color:var(--text-dark);font-size:16px;line-height:1.8;font-weight:300}
h1,h2,h3{font-family:var(--font-serif);font-weight:600;line-height:1.3;color:var(--text-dark)}
h1{font-size:clamp(1.8rem,4vw,2.8rem)}h2{font-size:clamp(1.4rem,3vw,2rem)}h3{font-size:clamp(1.1rem,2vw,1.4rem)}
p{line-height:1.9;color:var(--text-mid);margin-bottom:1rem}
a{color:var(--rose-deep);text-decoration:none;transition:color 0.2s}a:hover{color:var(--rose)}
.nav{position:sticky;top:0;z-index:100;background:rgba(255,252,250,0.95);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:0 5%}
.nav-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:64px}
.nav-logo{font-family:var(--font-serif);font-size:1.5rem;font-weight:600;color:var(--rose-deep);letter-spacing:0.02em}
.nav-logo span{color:var(--gold);font-style:italic}
.nav-links{display:flex;gap:2rem;list-style:none}
.nav-links a{font-size:0.875rem;font-weight:400;color:var(--text-mid);transition:color 0.2s;white-space:nowrap}
.nav-links a:hover{color:var(--rose-deep)}
.nav-hamburger{display:none;cursor:pointer}
.nav-hamburger span{display:block;width:22px;height:1.5px;background:var(--text-mid);margin:5px 0;transition:all 0.3s}
.hero{background:linear-gradient(135deg,var(--blush) 0%,var(--peach) 50%,var(--rose-light) 100%);padding:80px 5% 60px;text-align:center;position:relative;overflow:hidden}
.hero-inner{max-width:700px;margin:0 auto;position:relative;z-index:1}
.hero-eyebrow{font-size:0.75rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--gold);font-weight:400;margin-bottom:1.2rem}
.hero h1{margin-bottom:1.2rem}.hero h1 em{font-style:italic;color:var(--rose-deep)}
.hero-desc{font-size:1rem;color:var(--text-mid);max-width:520px;margin:0 auto 2rem}
.hero-cta{display:inline-flex;gap:1rem;flex-wrap:wrap;justify-content:center}
.btn-primary{display:inline-block;background:var(--rose-deep);color:white;padding:12px 28px;border-radius:50px;font-size:0.875rem;font-weight:400;letter-spacing:0.06em;transition:all 0.3s;border:none;cursor:pointer;text-decoration:none}
.btn-primary:hover{background:var(--rose);color:white;transform:translateY(-2px);box-shadow:0 8px 20px rgba(212,105,122,0.3)}
.btn-outline{display:inline-block;background:transparent;color:var(--rose-deep);padding:12px 28px;border-radius:50px;font-size:0.875rem;font-weight:400;letter-spacing:0.06em;border:1px solid var(--rose-deep);transition:all 0.3s;cursor:pointer}
.btn-outline:hover{background:var(--rose-light);transform:translateY(-2px)}
.section{padding:60px 5%;max-width:1200px;margin:0 auto}
.section-header{text-align:center;margin-bottom:3rem}
.section-eyebrow{font-size:0.7rem;letter-spacing:0.22em;text-transform:uppercase;color:var(--gold);font-weight:400;display:block;margin-bottom:0.8rem}
.section-title{margin-bottom:0.8rem}.section-subtitle{color:var(--text-light);font-size:0.95rem;max-width:500px;margin:0 auto}
.categories-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem}
.category-pill{display:flex;flex-direction:column;align-items:center;gap:0.5rem;padding:1.4rem 1rem;background:var(--cream);border:1px solid var(--border);border-radius:var(--radius);text-align:center;transition:all 0.3s;cursor:pointer;text-decoration:none}
.category-pill:hover{background:var(--blush);border-color:var(--rose);transform:translateY(-3px);box-shadow:var(--shadow-card)}
.category-icon{font-size:1.8rem;line-height:1}.category-name{font-size:0.85rem;font-weight:400;color:var(--text-mid)}
.articles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.8rem}
.article-card{background:white;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);transition:all 0.3s;display:flex;flex-direction:column}
.article-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft);border-color:var(--rose)}
.card-img{width:100%;aspect-ratio:16/9;background:linear-gradient(135deg,var(--peach),var(--rose-light));display:flex;align-items:center;justify-content:center;font-size:2.5rem;min-height:180px}
.card-body{padding:1.2rem 1.4rem;flex:1;display:flex;flex-direction:column}
.card-category{font-size:0.7rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--gold);font-weight:400;margin-bottom:0.6rem}
.card-title{font-family:var(--font-serif);font-size:1.05rem;font-weight:600;line-height:1.5;color:var(--text-dark);margin-bottom:0.7rem}
.card-synopsis{font-size:0.875rem;color:var(--text-light);line-height:1.7;flex:1;margin-bottom:1rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-meta{font-size:0.75rem;color:var(--text-light);display:flex;align-items:center;gap:0.5rem}
.featured-card{background:white;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);transition:all 0.3s;display:grid;grid-template-columns:1fr 1fr}
.featured-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft)}
.featured-img{background:linear-gradient(135deg,var(--blush),var(--peach));display:flex;align-items:center;justify-content:center;font-size:4rem;min-height:280px}
.featured-body{padding:2.5rem;display:flex;flex-direction:column;justify-content:center}
.article-layout{display:grid;grid-template-columns:1fr 320px;gap:3rem;max-width:1100px;margin:0 auto;padding:3rem 5%;align-items:start}
.article-header{margin-bottom:2rem}
.article-category-tag{display:inline-block;background:var(--gold-light);color:var(--gold);font-size:0.7rem;letter-spacing:0.14em;text-transform:uppercase;padding:4px 14px;border-radius:50px;margin-bottom:1rem}
.article-title{margin-bottom:1rem}
.article-meta{font-size:0.825rem;color:var(--text-light);display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.article-cover{width:100%;border-radius:var(--radius);aspect-ratio:16/9;background:linear-gradient(135deg,var(--peach),var(--rose-light));display:flex;align-items:center;justify-content:center;font-size:5rem;margin-bottom:2rem;min-height:300px}
.article-content{font-size:1rem;line-height:2;color:var(--text-mid)}
.article-content h2{font-size:1.4rem;margin:2rem 0 1rem;padding-left:1rem;border-left:3px solid var(--rose)}
.article-content p{margin-bottom:1.4rem}
.article-content img{width:100%;border-radius:var(--radius-sm);margin:1.5rem 0}
.sidebar{position:sticky;top:80px}
.sidebar-card{background:var(--cream);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;margin-bottom:1.5rem}
.sidebar-card h4{font-family:var(--font-serif);font-size:1rem;font-weight:600;color:var(--text-dark);margin-bottom:1.2rem;padding-bottom:0.8rem;border-bottom:1px solid var(--border)}
.sidebar-list{list-style:none}
.sidebar-list li{padding:0.5rem 0;border-bottom:1px solid var(--border)}
.sidebar-list li:last-child{border:none}
.sidebar-list a{font-size:0.875rem;color:var(--text-mid)}
.sidebar-list a:hover{color:var(--rose-deep)}
.footer{background:var(--text-dark);color:rgba(255,255,255,0.6);padding:3rem 5% 2rem;margin-top:4rem}
.footer-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr;gap:3rem;padding-bottom:2rem;border-bottom:1px solid rgba(255,255,255,0.1);margin-bottom:2rem}
.footer-brand .nav-logo{color:var(--rose-light);font-size:1.3rem}
.footer-brand p{font-size:0.875rem;margin-top:0.8rem;line-height:1.7}
.footer h5{font-size:0.7rem;letter-spacing:0.15em;text-transform:uppercase;color:white;font-weight:400;margin-bottom:1rem}
.footer ul{list-style:none}.footer ul li{margin-bottom:0.6rem}
.footer ul a{font-size:0.875rem;color:rgba(255,255,255,0.5)}
.footer ul a:hover{color:var(--rose-light)}
.footer-bottom{text-align:center;font-size:0.8rem}
.loading-state{text-align:center;padding:4rem 2rem;color:var(--text-light)}
.loading-spinner{width:32px;height:32px;border-radius:50%;border:2px solid var(--rose-light);border-top-color:var(--rose-deep);animation:spin 0.8s linear infinite;margin:0 auto 1rem}
@keyframes spin{to{transform:rotate(360deg)}}
.error-state{text-align:center;padding:4rem 2rem;color:var(--text-light)}
.error-state h2{color:var(--text-mid);margin-bottom:0.8rem}
.breadcrumb{display:flex;gap:0.5rem;align-items:center;font-size:0.8rem;color:var(--text-light);padding:1rem 5%;max-width:1100px;margin:0 auto}
.breadcrumb a{color:var(--text-light)}.breadcrumb a:hover{color:var(--rose-deep)}
.breadcrumb span{color:var(--rose);font-size:0.6rem}
.pagination{display:flex;justify-content:center;gap:0.5rem;margin-top:3rem;flex-wrap:wrap}
.pagination a,.pagination span{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;font-size:0.875rem;transition:all 0.2s;border:1px solid var(--border);color:var(--text-mid)}
.pagination a:hover{background:var(--blush);border-color:var(--rose);color:var(--rose-deep)}
.pagination .active{background:var(--rose-deep);border-color:var(--rose-deep);color:white}
@keyframes fadeInUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.fade-in{animation:fadeInUp 0.5s ease forwards;opacity:0}
@media(max-width:768px){
.nav-links{display:none}.nav-hamburger{display:block}
.nav-links.open{display:flex;flex-direction:column;position:absolute;top:64px;left:0;right:0;background:var(--warm-white);padding:1rem 5%;border-bottom:1px solid var(--border);gap:1rem}
.hero{padding:60px 5% 50px}
.featured-card{grid-template-columns:1fr}
.featured-img{min-height:200px}
.article-layout{grid-template-columns:1fr}
.sidebar{position:static}
.footer-inner{grid-template-columns:1fr;gap:2rem}
.articles-grid{grid-template-columns:1fr}
}