@import "https://cdn.jsdelivr.net/npm/@chinese-fonts/lxgwwenkai@3.0.0/dist/LXGWWenKai-Regular/result.css";:root{--bg-base:#f9f7f2;--bg-card:#fff;--bg-muted:#f2f0ea;--wood-base:#a67b5b;--wood-dark:#7d5a43;--wood-light:#c4a484;--green-soft:#7a8b6e;--green-light:#a8b59d;--text-primary:#3d352e;--text-secondary:#7d7369;--text-muted:#a69e94;--border-soft:#e8e4dc;--border-card:#efede6;--shadow-soft:0 4px 20px #3d352e0f;--shadow-card-hover:0 8px 32px #3d352e1a;--font-display:"LXGW WenKai", "PingFang SC", "Microsoft YaHei", system-ui, sans-serif;--font-body:"LXGW WenKai", "PingFang SC", "Microsoft YaHei", system-ui, sans-serif;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:48px;--space-2xl:80px;--space-3xl:120px;--container-max:1700px;--container-padding:48px;--radius-sm:8px;--radius-md:16px;--radius-lg:24px;--radius-full:9999px;--ease-out-quart:cubic-bezier(.25, 1, .5, 1);--duration-fast:.15s;--duration-normal:.3s;--duration-slow:.5s;font-family:var(--font-body);color:var(--text-primary);background-color:var(--bg-base);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:18px;line-height:1.8}*{box-sizing:border-box}body{min-height:100vh;margin:0}#root{flex-direction:column;min-height:100vh;display:flex}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);color:var(--text-primary);margin:0;font-weight:600;line-height:1.3}p{margin:0}a{color:inherit;text-decoration:none}img{max-width:100%;height:auto;display:block}button{cursor:pointer;background:0 0;border:none;font-family:inherit}.container{width:100%;max-width:var(--container-max);padding-left:var(--container-padding);padding-right:var(--container-padding);margin:0 auto}@media (width<=1024px){:root{--container-padding:24px;--space-2xl:56px;--space-3xl:80px;font-size:16px}}@media (width<=640px){:root{--container-padding:16px}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-base)}::-webkit-scrollbar-thumb{background:var(--border-soft);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.header{z-index:100;transition:background-color var(--duration-normal) var(--ease-out-quart), box-shadow var(--duration-normal) var(--ease-out-quart);position:fixed;top:0;left:0;right:0}.header-scrolled{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background-color:#f9f7f2d9;box-shadow:0 1px #3d352e0d}.header-inner{justify-content:space-between;align-items:center;height:80px;display:flex}.logo{font-family:var(--font-display);color:var(--text-primary);transition:color var(--duration-fast) var(--ease-out-quart);align-items:center;gap:10px;font-size:1.25rem;font-weight:600;display:flex}.logo:hover{color:var(--wood-base)}.logo-icon{color:var(--wood-base);font-size:1.5rem}.nav-list{align-items:center;gap:8px;margin:0;padding:0;list-style:none;display:flex}.nav-link{border-radius:var(--radius-full);color:var(--text-secondary);transition:color var(--duration-fast) var(--ease-out-quart), background-color var(--duration-fast) var(--ease-out-quart);padding:10px 18px;font-size:.95rem;font-weight:500;display:block}.nav-link:hover{color:var(--wood-base);background-color:#a67b5b0f}.nav-link.active{color:var(--wood-dark);background-color:#a67b5b1a}.mobile-toggle{border-radius:var(--radius-sm);justify-content:center;align-items:center;width:44px;height:44px;display:none}.hamburger{background:var(--text-primary);width:24px;height:2px;transition:background-color var(--duration-fast) var(--ease-out-quart);display:block;position:relative}.hamburger:before,.hamburger:after{content:"";background:var(--text-primary);width:24px;height:2px;transition:transform var(--duration-fast) var(--ease-out-quart);position:absolute;left:0}.hamburger:before{top:-7px}.hamburger:after{top:7px}.hamburger.open{background:0 0}.hamburger.open:before{transform:translateY(7px)rotate(45deg)}.hamburger.open:after{transform:translateY(-7px)rotate(-45deg)}.mobile-nav{background:var(--bg-card);border-bottom:1px solid var(--border-soft);padding:var(--space-md) var(--container-padding);box-shadow:var(--shadow-soft);display:none;position:absolute;top:100%;left:0;right:0}.mobile-nav-list{margin:0;padding:0;list-style:none}.mobile-nav-link{color:var(--text-secondary);border-bottom:1px solid var(--border-soft);padding:14px 0;font-size:1rem;display:block}.mobile-nav-link.active{color:var(--wood-base)}@media (width<=768px){.nav{display:none}.mobile-toggle{display:flex}.mobile-nav{display:block}.header-inner{height:72px}}.footer{background:var(--bg-card);border-top:1px solid var(--border-soft);padding:var(--space-2xl) 0 var(--space-xl);margin-top:auto}.footer-inner{text-align:center;align-items:center;gap:var(--space-lg);flex-direction:column;display:flex}.footer-logo{font-family:var(--font-display);color:var(--text-primary);align-items:center;gap:10px;font-size:1.25rem;font-weight:600;display:flex}.footer-logo-icon{color:var(--wood-base);font-size:1.5rem}.footer-tagline{color:var(--text-secondary);margin-top:var(--space-sm);font-size:.95rem}.footer-copyright{color:var(--text-muted);font-size:.85rem}.hero-section{padding:var(--space-3xl) 0;background:linear-gradient(180deg, var(--bg-base) 0%, var(--bg-muted) 100%);border-bottom:1px solid var(--border-soft)}.hero-inner{gap:var(--space-2xl);grid-template-columns:1fr 1.2fr;align-items:center;min-height:60vh;display:grid}.hero-greeting{color:var(--green-soft);margin-bottom:var(--space-md);letter-spacing:.1em;font-size:.9rem;font-weight:500;display:inline-block}.hero-title{margin-bottom:var(--space-md);color:var(--text-primary);font-size:clamp(2.5rem,5vw,4.5rem)}.hero-tagline{color:var(--wood-base);margin-bottom:var(--space-lg);font-size:1.5rem;font-weight:500}.hero-desc{color:var(--text-secondary);max-width:520px;margin-bottom:var(--space-xl);line-height:1.8}.hero-actions{gap:var(--space-md);flex-wrap:wrap;display:flex}.hero-image{border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);transition:transform var(--duration-slow) var(--ease-out-quart);overflow:hidden;transform:rotate(2deg)}.hero-image:hover{transform:rotate(0)}.hero-image img{object-fit:cover;aspect-ratio:4/3;width:100%;height:100%}@media (width<=1024px){.hero-inner{text-align:center;grid-template-columns:1fr}.hero-desc{margin-left:auto;margin-right:auto}.hero-actions{justify-content:center}.hero-image{max-width:600px;margin:0 auto;transform:none}}.section-header{text-align:center;margin-bottom:var(--space-xl)}.section-label{color:var(--green-soft);letter-spacing:.15em;margin-bottom:var(--space-sm);text-transform:uppercase;font-size:.85rem;font-weight:500;display:inline-block}.section-title{color:var(--text-primary);font-size:clamp(1.75rem,3vw,2.5rem)}.featured-section{padding:var(--space-3xl) 0}.featured-card{color:inherit;text-decoration:none;display:block}.quote-section{padding:var(--space-3xl) 0;background:var(--bg-muted);border-top:1px solid var(--border-soft);border-bottom:1px solid var(--border-soft);text-align:center}.quote{margin:0}.quote p{font-family:var(--font-display);color:var(--text-primary);font-size:clamp(1.5rem,3vw,2.25rem);font-style:italic;line-height:1.6}.quote p:before{content:"“";color:var(--wood-base);vertical-align:middle;margin-right:4px;font-size:1.5em;line-height:0}.quote p:after{content:"”";color:var(--wood-base);vertical-align:middle;margin-left:4px;font-size:1.5em;line-height:0}.latest-section{padding:var(--space-3xl) 0}.latest-list{gap:var(--space-lg);max-width:900px;margin:0 auto var(--space-xl);flex-direction:column;display:flex}.latest-item{gap:var(--space-lg);padding:var(--space-md);background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-md);transition:all var(--duration-normal) var(--ease-out-quart);color:inherit;grid-template-columns:200px 1fr;align-items:center;text-decoration:none;display:grid}.latest-item:hover{box-shadow:var(--shadow-soft);transform:translate(8px)}.latest-item-image{border-radius:var(--radius-sm);aspect-ratio:4/3;overflow:hidden}.latest-item-image img{object-fit:cover;width:100%;height:100%;transition:transform var(--duration-slow) var(--ease-out-quart)}.latest-item:hover .latest-item-image img{transform:scale(1.05)}.latest-item-category{color:var(--green-soft);border-radius:var(--radius-full);margin-bottom:var(--space-sm);background:#7a8b6e1a;padding:3px 10px;font-size:.75rem;display:inline-block}.latest-item-title{margin-bottom:var(--space-sm);color:var(--text-primary);font-size:1.25rem}.latest-item-desc{color:var(--text-secondary);-webkit-line-clamp:2;margin-bottom:var(--space-sm);-webkit-box-orient:vertical;font-size:.95rem;line-height:1.7;display:-webkit-box;overflow:hidden}.latest-item-date{color:var(--text-muted);font-size:.85rem}.latest-actions{text-align:center}@media (width<=640px){.latest-item{grid-template-columns:1fr}.latest-item-image{aspect-ratio:16/9}}.category-tabs{justify-content:center;gap:var(--space-sm);margin-bottom:var(--space-xl);flex-wrap:wrap;display:flex}.category-tab{border-radius:var(--radius-full);color:var(--text-secondary);transition:all var(--duration-fast) var(--ease-out-quart);border:1.5px solid #0000;padding:10px 22px;font-size:.95rem;font-weight:500}.category-tab:hover{color:var(--wood-base);background:#a67b5b0f}.category-tab.active{color:var(--wood-dark);background:#a67b5b1a;border-color:#a67b5b33}.articles-grid{margin-bottom:var(--space-xl)}.article-card{color:inherit;text-decoration:none;display:block}.empty-state{text-align:center;padding:var(--space-2xl) 0;color:var(--text-secondary)}.article-detail{max-width:800px}.article-back{color:var(--text-secondary);margin-bottom:var(--space-xl);transition:color var(--duration-fast) var(--ease-out-quart);align-items:center;font-size:.95rem;display:inline-flex}.article-back:hover{color:var(--wood-base)}.article-header{text-align:center;margin-bottom:var(--space-xl)}.article-category{color:var(--green-soft);border-radius:var(--radius-full);margin-bottom:var(--space-md);background:#7a8b6e1a;padding:6px 14px;font-size:.85rem;display:inline-block}.article-title{margin-bottom:var(--space-md);font-size:clamp(2rem,4vw,3rem);line-height:1.3}.article-date{color:var(--text-muted);font-size:.9rem}.article-cover{border-radius:var(--radius-lg);margin-bottom:var(--space-xl);aspect-ratio:16/9;box-shadow:var(--shadow-soft);overflow:hidden}.article-cover img{object-fit:cover;width:100%;height:100%}.article-body{color:var(--text-primary);font-size:1.05rem;line-height:2}.article-body p{margin-bottom:var(--space-lg);text-indent:2em}.article-body p:first-of-type:first-letter{float:left;color:var(--wood-base);font-size:3em;line-height:1;font-family:var(--font-display);margin-top:-4px;margin-right:8px;font-weight:600}.lightbox{z-index:1000;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:var(--space-lg);animation:lightboxFadeIn var(--duration-normal) var(--ease-out-quart) forwards;background:#3d352ef0;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}@keyframes lightboxFadeIn{0%{opacity:0}to{opacity:1}}.lightbox-close{top:var(--space-lg);right:var(--space-lg);color:#fff;width:48px;height:48px;transition:background var(--duration-fast) var(--ease-out-quart), transform var(--duration-fast) var(--ease-out-quart);z-index:10;background:#ffffff1a;border-radius:50%;justify-content:center;align-items:center;font-size:1.75rem;display:flex;position:absolute}.lightbox-close:hover{background:#fff3;transform:rotate(90deg)}.lightbox-content{width:auto;max-width:min(95vw,1400px);max-height:95vh;animation:lightboxContentIn var(--duration-slow) var(--ease-out-quart) forwards;flex-direction:column;align-items:center;display:flex;position:relative}@keyframes lightboxContentIn{0%{opacity:0;transform:scale(.95)translateY(20px)}to{opacity:1;transform:scale(1)translateY(0)}}.lightbox-image{object-fit:contain;border-radius:var(--radius-md);width:auto;max-width:100%;height:auto;max-height:88vh;box-shadow:0 32px 100px #00000059}.lightbox-info{text-align:center;padding:var(--space-xl) var(--space-lg) var(--space-lg);color:#fff;border-radius:0 0 var(--radius-md) var(--radius-md);background:linear-gradient(#0000 0%,#3d352e99 30%,#3d352ed9 100%);position:absolute;bottom:0;left:0;right:0}.lightbox-category{color:#ffffffe6;border-radius:var(--radius-full);margin-bottom:var(--space-sm);background:#ffffff26;padding:4px 12px;font-size:.75rem;display:inline-block}.lightbox-title{color:#fff;margin-bottom:var(--space-sm);font-size:1.5rem}.lightbox-desc{color:#ffffffd9;line-height:1.7}@media (width<=640px){.lightbox{padding:var(--space-md)}.lightbox-image{border-radius:var(--radius-sm);max-height:78vh}.lightbox-info{padding:var(--space-lg) var(--space-md) var(--space-md)}.lightbox-title{font-size:1.1rem}.lightbox-desc{font-size:.85rem}}.works-grid{gap:var(--space-lg);grid-template-columns:repeat(3,1fr);display:grid}.work-card{border-radius:var(--radius-md);cursor:pointer;break-inside:avoid;margin-bottom:0;position:relative;overflow:hidden}.work-card:nth-child(3n+1){grid-row:span 2}.work-card:nth-child(5n){grid-row:span 1}.work-image{width:100%;height:100%;min-height:280px;position:relative}.work-image img{object-fit:cover;width:100%;height:100%;transition:transform var(--duration-slow) var(--ease-out-quart)}.work-card:hover .work-image img{transform:scale(1.05)}.work-overlay{padding:var(--space-lg);opacity:0;transition:opacity var(--duration-normal) var(--ease-out-quart);background:linear-gradient(#0000 0%,#3d352e66 60%,#3d352ebf 100%);flex-direction:column;justify-content:flex-end;display:flex;position:absolute;inset:0}.work-card:hover .work-overlay{opacity:1}.work-category{color:#ffffffe6;border-radius:var(--radius-full);margin-bottom:var(--space-sm);background:#ffffff26;width:fit-content;padding:4px 10px;font-size:.75rem;display:inline-block}.work-title{color:#fff;margin-bottom:var(--space-xs);font-size:1.25rem}.work-desc{color:#ffffffd9;-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.9rem;line-height:1.6;display:-webkit-box;overflow:hidden}@media (width<=1024px){.works-grid{grid-template-columns:repeat(2,1fr)}.work-card:nth-child(3n+1){grid-row:span 1}}@media (width<=640px){.works-grid{grid-template-columns:1fr}.work-overlay{opacity:1;background:linear-gradient(#0000 0%,#3d352e80 60%,#3d352ecc 100%)}}.timeline{max-width:900px;margin:0 auto;padding-left:40px;position:relative}.timeline:before{content:"";background:linear-gradient(180deg, var(--border-soft) 0%, var(--wood-light) 50%, var(--border-soft) 100%);width:2px;position:absolute;top:0;bottom:0;left:0}.timeline-item{padding-bottom:var(--space-xl);gap:var(--space-lg);grid-template-columns:120px 1fr;display:grid;position:relative}.timeline-item:before{content:"";background:var(--wood-base);border:3px solid var(--bg-card);width:10px;height:10px;box-shadow:0 0 0 2px var(--border-soft);border-radius:50%;position:absolute;top:8px;left:-44px}.timeline-date{text-align:right;flex-direction:column;align-items:flex-end;padding-top:4px;display:flex}.timeline-month{color:var(--text-secondary);font-size:.85rem}.timeline-day{color:var(--wood-base);font-size:2rem;font-weight:600;font-family:var(--font-display);margin:4px 0;line-height:1}.timeline-year{color:var(--text-muted);font-size:.8rem}.timeline-card{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-md);box-shadow:var(--shadow-soft);transition:transform var(--duration-normal) var(--ease-out-quart), box-shadow var(--duration-normal) var(--ease-out-quart);overflow:hidden}.timeline-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-4px)}.timeline-image{aspect-ratio:16/9;cursor:pointer;position:relative;overflow:hidden}.timeline-image:after{content:"↔";color:#fff;opacity:0;width:44px;height:44px;transition:opacity var(--duration-normal) var(--ease-out-quart), background var(--duration-fast) var(--ease-out-quart);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#3d352e80;border-radius:50%;justify-content:center;align-items:center;font-size:1.25rem;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.timeline-image:hover:after,.timeline-image:focus-visible:after{opacity:1}.timeline-image:focus-visible{outline:2px solid var(--wood-base);outline-offset:2px}.timeline-image img{object-fit:cover;width:100%;height:100%;transition:transform var(--duration-slow) var(--ease-out-quart)}.timeline-card:hover .timeline-image img{transform:scale(1.03)}.timeline-text{padding:var(--space-lg)}.timeline-mood{color:var(--green-soft);border-radius:var(--radius-full);margin-bottom:var(--space-sm);background:#7a8b6e1a;padding:4px 10px;font-size:.75rem;display:inline-block}.timeline-text p{color:var(--text-primary);font-size:1.05rem;line-height:1.8}@media (width<=640px){.timeline{padding-left:24px}.timeline-item{gap:var(--space-md);grid-template-columns:1fr}.timeline-item:before{left:-28px}.timeline-date{text-align:left;flex-direction:row;align-items:baseline;gap:8px}.timeline-day{font-size:1.5rem}}.about-intro{gap:var(--space-2xl);max-width:1000px;margin:0 auto var(--space-2xl);grid-template-columns:320px 1fr;align-items:center;display:grid}.about-avatar{border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);transition:transform var(--duration-slow) var(--ease-out-quart);overflow:hidden;transform:rotate(-2deg)}.about-avatar:hover{transform:rotate(0)}.about-avatar img{aspect-ratio:1;object-fit:cover;width:100%}.about-bio{padding:var(--space-lg) 0}.about-name{margin-bottom:var(--space-lg);color:var(--text-primary);font-size:2rem}.about-bio p{color:var(--text-secondary);font-size:1.1rem;line-height:2}.about-cards{gap:var(--space-lg);grid-template-columns:repeat(3,1fr);max-width:1000px;margin:0 auto;display:grid}.about-card{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-md);padding:var(--space-xl);box-shadow:var(--shadow-soft);transition:transform var(--duration-normal) var(--ease-out-quart), box-shadow var(--duration-normal) var(--ease-out-quart)}.about-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-4px)}.about-card-icon{color:var(--wood-base);margin-bottom:var(--space-md);font-size:1.5rem;display:block}.about-card h3{margin-bottom:var(--space-lg);font-size:1.25rem}.about-card ul{margin:0;padding:0;list-style:none}.about-card li{color:var(--text-secondary);border-bottom:1px solid var(--border-soft);padding:8px 0}.about-card li:last-child{border-bottom:none}.about-contact li{justify-content:space-between;gap:var(--space-md);display:flex}.about-contact li span:first-child{color:var(--text-muted);font-size:.9rem}.about-contact li span:last-child{color:var(--text-primary);font-size:.9rem}@media (width<=1024px){.about-intro{text-align:center;grid-template-columns:1fr}.about-avatar{max-width:280px;margin:0 auto;transform:none}.about-cards{grid-template-columns:1fr}}.not-found{text-align:center;padding-top:var(--space-2xl);padding-bottom:var(--space-3xl)}.not-found-code{font-family:var(--font-display);color:var(--wood-base);opacity:.2;margin-bottom:var(--space-md);font-size:8rem;font-weight:700;line-height:1;display:block}.not-found h1{margin-bottom:var(--space-md);font-size:2rem}.not-found p{color:var(--text-secondary);margin-bottom:var(--space-xl)}.admin-page{background:var(--bg-base);grid-template-columns:240px 1fr;min-height:100vh;display:grid}.admin-sidebar{background:var(--bg-card);border-right:1px solid var(--border-soft);padding:var(--space-xl);gap:var(--space-xl);flex-direction:column;height:100vh;display:flex;position:sticky;top:0}.admin-brand{font-family:var(--font-display);color:var(--text-primary);align-items:center;gap:10px;font-size:1.25rem;font-weight:600;display:flex}.admin-brand span:first-child{color:var(--wood-base);font-size:1.5rem}.admin-nav{gap:var(--space-sm);flex-direction:column;flex:1;display:flex}.admin-nav button{text-align:left;padding:var(--space-md);border-radius:var(--radius-sm);color:var(--text-secondary);transition:all var(--duration-fast) var(--ease-out-quart);font-size:1rem}.admin-nav button:hover,.admin-nav button.active{color:var(--wood-base);background:#a67b5b1a}.admin-logout{color:var(--text-muted);padding:var(--space-sm);text-align:left;transition:color var(--duration-fast) var(--ease-out-quart);font-size:.9rem}.admin-logout:hover{color:#c45c4a}.admin-change-pwd{color:var(--text-muted);padding:var(--space-sm);text-align:left;transition:color var(--duration-fast) var(--ease-out-quart);font-size:.9rem}.admin-change-pwd:hover{color:var(--wood-base)}.admin-main{padding:var(--space-2xl);position:relative}.admin-toast{top:var(--space-lg);right:var(--space-lg);background:var(--wood-base);color:#fff;padding:var(--space-md) var(--space-lg);border-radius:var(--radius-sm);box-shadow:var(--shadow-soft);animation:toastIn var(--duration-normal) var(--ease-out-quart);z-index:300;position:fixed}@keyframes toastIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.admin-header{margin-bottom:var(--space-xl);justify-content:space-between;align-items:center;display:flex}.admin-header h2{font-size:1.75rem}.admin-list{gap:var(--space-md);flex-direction:column;display:flex}.admin-list-item{padding:var(--space-lg);background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-md);transition:box-shadow var(--duration-fast) var(--ease-out-quart);justify-content:space-between;align-items:center;display:flex}.admin-list-item:hover{box-shadow:var(--shadow-soft)}.admin-list-info h4{margin-bottom:var(--space-xs);color:var(--text-primary);font-size:1.1rem}.admin-list-info p{color:var(--text-muted);font-size:.9rem}.admin-list-actions{gap:var(--space-sm);display:flex}.admin-empty{color:var(--text-secondary);text-align:center;padding:var(--space-2xl)}.admin-form{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-md);padding:var(--space-xl);max-width:800px}.admin-form h3{margin-bottom:var(--space-lg);font-size:1.5rem}.admin-field{gap:var(--space-sm);margin-bottom:var(--space-lg);flex-direction:column;display:flex}.admin-field span{color:var(--text-secondary);font-size:.95rem}.admin-field input,.admin-field textarea{padding:var(--space-md);border:1px solid var(--border-soft);border-radius:var(--radius-sm);background:var(--bg-base);transition:border-color var(--duration-fast) var(--ease-out-quart);font-family:inherit;font-size:1rem}.admin-field input:focus,.admin-field textarea:focus{border-color:var(--wood-base);outline:none}.admin-field textarea{resize:vertical;line-height:1.8}.admin-image-field{gap:var(--space-md);flex-direction:column;display:flex}.admin-image-preview{object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--border-soft);max-width:300px;max-height:200px}.admin-uploading{color:var(--wood-base);font-size:.9rem}.admin-form-actions{gap:var(--space-md);margin-top:var(--space-xl);display:flex}.btn-danger{color:#fff;border-radius:var(--radius-full);transition:all var(--duration-fast) var(--ease-out-quart);background:#c45c4a;padding:10px 20px;font-weight:500}.btn-danger:hover{background:#a84a3a}.admin-loading{min-height:100vh;color:var(--text-secondary);justify-content:center;align-items:center;display:flex}.admin-offline{text-align:center;min-height:100vh;padding:var(--space-2xl);flex-direction:column;justify-content:center;align-items:center;max-width:600px;margin:0 auto;display:flex}.admin-offline-icon{color:var(--wood-base);margin-bottom:var(--space-lg);font-size:3rem}.admin-offline h2{color:var(--text-primary);margin-bottom:var(--space-md);font-size:1.75rem}.admin-offline p{color:var(--text-secondary);margin-bottom:var(--space-lg);line-height:1.8}.admin-offline-steps{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-md);padding:var(--space-xl);text-align:left;width:100%;margin-bottom:var(--space-lg)}.admin-offline-steps h3{color:var(--text-primary);margin-bottom:var(--space-md);font-size:1.1rem}.admin-offline-steps ol{padding-left:var(--space-lg);color:var(--text-secondary);line-height:2}.admin-offline-steps code{background:var(--bg-base);font-family:var(--font-code);color:var(--wood-base);border-radius:4px;padding:2px 8px;font-size:.9rem}.admin-offline-note{color:var(--text-muted);font-size:.9rem}@media (width<=1024px){.admin-page{grid-template-columns:1fr}.admin-sidebar{flex-flow:wrap;align-items:center;height:auto;position:static}.admin-nav{flex-direction:row;flex:1}.admin-main{padding:var(--space-lg)}}.admin-modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;animation:fadeIn var(--duration-normal) var(--ease-out-quart);background:#0000004d;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.admin-modal{background:var(--bg-card);border-radius:var(--radius-md);padding:var(--space-2xl);width:100%;max-width:420px;box-shadow:0 20px 60px #00000026}.admin-modal h3{margin-bottom:var(--space-lg);color:var(--text-primary);font-size:1.25rem}.admin-pwd-error{color:#c45c4a;margin-bottom:var(--space-md);font-size:.9rem}.admin-login-page{background:var(--bg-base);min-height:100vh;padding:var(--space-lg);justify-content:center;align-items:center;display:flex}.admin-login-box{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-lg);padding:var(--space-2xl);width:100%;max-width:420px;box-shadow:var(--shadow-soft)}.admin-login-header{text-align:center;margin-bottom:var(--space-xl)}.admin-login-icon{color:var(--wood-base);margin-bottom:var(--space-md);font-size:3rem;display:block}.admin-login-header h1{margin-bottom:var(--space-xs);font-size:1.75rem}.admin-login-header p{color:var(--text-secondary)}.admin-login-form{gap:var(--space-md);flex-direction:column;display:flex}.admin-login-form label{color:var(--text-secondary);font-size:.9rem}.admin-login-form input{padding:var(--space-md);border:1px solid var(--border-soft);border-radius:var(--radius-sm);background:var(--bg-base);transition:border-color var(--duration-fast) var(--ease-out-quart);font-family:inherit;font-size:1rem}.admin-login-form input:focus{border-color:var(--wood-base);outline:none}.admin-login-error{color:#c45c4a;margin:0;font-size:.9rem}.main{flex:1;padding-top:80px}@media (width<=1024px){.main{padding-top:72px}}.page-section{padding-top:var(--space-2xl);padding-bottom:var(--space-3xl)}.page-header{text-align:center;margin-bottom:var(--space-2xl)}.page-header h1{margin-bottom:var(--space-md);font-size:clamp(2rem,4vw,3.5rem)}.page-header p{color:var(--text-secondary);max-width:600px;margin:0 auto;font-size:1.125rem}.card{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-md);transition:transform var(--duration-normal) var(--ease-out-quart), box-shadow var(--duration-normal) var(--ease-out-quart);overflow:hidden}.card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-4px)}.card-image-wrapper{aspect-ratio:16/10;overflow:hidden}.card-image-wrapper img{object-fit:cover;width:100%;height:100%;transition:transform var(--duration-slow) var(--ease-out-quart)}.card:hover .card-image-wrapper img{transform:scale(1.05)}.card-body{padding:var(--space-lg)}.card-tag{color:var(--green-soft);border-radius:var(--radius-full);margin-bottom:var(--space-sm);background:#7a8b6e1a;padding:4px 10px;font-size:.75rem;display:inline-block}.card-title{margin-bottom:var(--space-sm);color:var(--text-primary);font-size:1.25rem}.card-desc{color:var(--text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.95rem;line-height:1.7;display:-webkit-box;overflow:hidden}.card-meta{color:var(--text-muted);margin-top:var(--space-md);font-size:.85rem}.btn{border-radius:var(--radius-full);transition:all var(--duration-fast) var(--ease-out-quart);justify-content:center;align-items:center;padding:14px 32px;font-weight:500;display:inline-flex}.btn-primary{background:var(--wood-base);color:#fff}.btn-primary:hover{background:var(--wood-dark);box-shadow:var(--shadow-soft);transform:translateY(-2px)}.btn-secondary{color:var(--wood-base);border:1.5px solid var(--border-soft);background:0 0}.btn-secondary:hover{border-color:var(--wood-base);color:var(--wood-dark)}.fade-in{animation:fadeIn .6s var(--ease-out-quart) forwards;opacity:0;transform:translateY(20px)}@keyframes fadeIn{to{opacity:1;transform:translateY(0)}}.grid-3{gap:var(--space-xl);grid-template-columns:repeat(3,1fr);display:grid}.grid-4{gap:var(--space-lg);grid-template-columns:repeat(4,1fr);display:grid}@media (width<=1280px){.grid-4{grid-template-columns:repeat(3,1fr)}}@media (width<=1024px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.grid-3,.grid-4{grid-template-columns:1fr}}
