.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 20px;font-size:var(--text-sm);font-weight:var(--weight-medium);font-family:inherit;border-radius:var(--radius-md);border:1px solid transparent;cursor:pointer;transition:all .2s;white-space:nowrap;text-decoration:none;line-height:1.4}.btn:active{transform:scale(.97)}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover{background:var(--primary-hover);border-color:var(--primary-hover);text-decoration:none}.btn-secondary{background:var(--bg2);color:var(--text);border-color:var(--border)}.btn-secondary:hover{background:var(--bg3);border-color:var(--text3);text-decoration:none}.btn-ghost{background:transparent;color:var(--text2);border-color:transparent}.btn-ghost:hover{background:var(--bg2);color:var(--text);text-decoration:none}.btn-sm{padding:4px 12px;font-size:var(--text-xs)}.btn-lg{padding:12px 28px;font-size:var(--text-base)}.nav-bar{position:sticky;top:0;z-index:100;height:var(--nav-height);background:var(--bg);border-bottom:1px solid var(--border);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:#ffffffd9}[data-theme=dark] .nav-bar{background:#0d0d0dd9}.nav-inner{max-width:var(--max-width);margin:0 auto;height:100%;display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-lg)}.nav-brand{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--text-lg);font-weight:var(--weight-bold);color:var(--text);text-decoration:none;flex-shrink:0}.nav-brand:hover{color:var(--primary);text-decoration:none}.nav-brand-logo{width:28px;height:28px;border-radius:var(--radius-sm);background:var(--primary);display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:var(--weight-bold)}.desktop-nav{display:flex;align-items:center;gap:var(--space-xs)}.nav-link{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;font-size:var(--text-sm);color:var(--text2);border-radius:var(--radius-md);transition:all .2s;text-decoration:none;white-space:nowrap}.nav-link:hover{background:var(--bg2);color:var(--text);text-decoration:none}.nav-link.active{color:var(--primary);background:var(--primary-light);font-weight:var(--weight-medium)}.nav-actions{display:flex;align-items:center;gap:var(--space-sm)}.nav-search{display:flex;align-items:center;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-full);padding:0 14px;height:36px;gap:6px;transition:border-color .2s}.nav-search:focus-within{border-color:var(--primary)}.nav-search input{border:none;background:none;outline:none;font-size:var(--text-sm);color:var(--text);font-family:inherit;width:160px}.nav-search input::placeholder{color:var(--text3);opacity:1;font-style:italic}input::placeholder,textarea::placeholder{color:var(--text3);opacity:1;font-style:italic}.theme-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--border);border-radius:var(--radius-md);background:transparent;cursor:pointer;color:var(--text2);font-size:16px;transition:all .2s}.theme-toggle:hover{background:var(--bg2);color:var(--text)}.hamburger-btn{display:none;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:none;cursor:pointer;color:var(--text);font-size:20px;border-radius:var(--radius-md);transition:background .2s}.hamburger-btn:hover{background:var(--bg2)}.mobile-drawer{position:fixed;top:var(--nav-height);left:0;right:0;bottom:0;z-index:99;background:var(--bg);padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-xs);transform:translate(100%);transition:transform .3s ease;overflow-y:auto}.mobile-drawer.open{transform:translate(0)}.mobile-drawer .nav-link{width:100%;padding:var(--space-md) var(--space-lg);font-size:var(--text-base);border-radius:var(--radius-md)}.mobile-drawer .nav-search{width:100%;margin-top:var(--space-md)}.mobile-drawer .nav-search input{width:100%}@media (max-width: 767px){.desktop-nav,.nav-search.desktop-only{display:none}.hamburger-btn{display:flex}}@media (min-width: 768px){.hamburger-btn,.mobile-drawer{display:none}}.main-content{min-height:calc(100vh - var(--nav-height));padding:var(--space-xl) 0}.section-divider{height:1px;background:var(--divider);margin:var(--space-2xl) 0;border:none}.header{position:sticky;top:0;z-index:100;height:var(--nav-height);border-bottom:1px solid var(--border);background:var(--nav-bg, var(--bg))}.header-inner{max-width:var(--max-width);margin:0 auto;height:100%;display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-lg)}.logo{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--text-lg);font-weight:var(--weight-bold);color:var(--text);text-decoration:none}.nav-links{display:flex;align-items:center;gap:var(--space-xs)}.nav-toggle{display:none;padding:8px;background:none;border:none;cursor:pointer;color:var(--text2)}.nav-drawer-link{display:block;padding:var(--space-sm) var(--space-lg);font-size:var(--text-base);color:var(--text);text-decoration:none;border-bottom:1px solid var(--border-light)}.nav-drawer-link:hover{background:var(--bg2)}.main{min-height:calc(100vh - var(--nav-height) - 200px)}.footer{border-top:1px solid var(--border);padding:var(--space-xl) var(--space-lg);text-align:center;font-size:var(--text-xs);color:var(--text3);background:var(--bg)}@media (max-width: 767px){.nav-links{display:none}.nav-links .theme-toggle{display:none}.nav-toggle{display:flex}.nav-drawer{display:flex}.nav-drawer--open{display:flex}}.gs-wrap{position:relative}.gs-bar{display:flex;align-items:center;gap:var(--space-sm);padding:0 var(--space-md)}.gs-input{flex:1;border:none;background:transparent;font-size:var(--text-base);color:var(--text);outline:none;font-family:inherit}.gs-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:transparent;cursor:pointer;color:var(--text2);border-radius:var(--radius-sm)}.gs-btn:hover{background:var(--bg2);color:var(--text)}.gs-cat-wrap{display:flex;flex-direction:column;gap:2px}.gs-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);cursor:pointer;border-radius:var(--radius-sm);transition:background .15s}.gs-item:hover{background:var(--bg2)}.gs-item-icon{font-size:16px;width:24px;text-align:center;flex-shrink:0}.gs-item-text{font-size:var(--text-sm);color:var(--text)}.gs-cat-arrow{margin-left:auto;font-size:12px;color:var(--text3)}.gs-empty{padding:var(--space-lg);text-align:center;font-size:var(--text-sm);color:var(--text3)}.hero{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--space-4xl) var(--space-lg) var(--space-2xl);background:linear-gradient(180deg,var(--primary-light),var(--bg))}.hero-title{font-size:var(--text-3xl);font-weight:var(--weight-bold);color:var(--text);margin-bottom:var(--space-sm);line-height:var(--leading-tight)}.hero-desc{font-size:var(--text-lg);color:var(--text2);margin-bottom:var(--space-xl);max-width:500px;line-height:var(--leading-normal)}.hero-cta{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);width:100%;max-width:520px}.hero-cta .pill-bar{display:flex;gap:var(--space-sm);flex-wrap:wrap;justify-content:center}.hero-cta .pill{display:inline-flex;align-items:center;gap:4px;padding:4px 14px;border-radius:var(--radius-full);font-size:var(--text-sm);color:var(--text2);background:var(--surface);border:1px solid var(--border);cursor:pointer;transition:all .2s;text-decoration:none}.hero-cta .pill:hover{border-color:var(--primary);color:var(--primary);text-decoration:none}.hero-featured{display:flex;align-items:center;gap:var(--space-lg);padding:var(--space-lg);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);margin-top:var(--space-xl);box-shadow:var(--shadow-sm)}.hero-featured-content{display:flex;flex-direction:column;gap:var(--space-xs)}.hero-featured-content .label{font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--primary);text-transform:uppercase;letter-spacing:.05em}.section{padding:var(--space-3xl) 0;max-width:var(--max-width);margin:0 auto;padding-left:var(--space-lg);padding-right:var(--space-lg)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-xl)}.section-header .see-all{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--primary);text-decoration:none}.section-header .see-all:hover{text-decoration:underline}.home-categories{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:var(--space-md)}.home-cat-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-xs);padding:var(--space-lg) var(--space-md);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);text-decoration:none;transition:all .25s ease}.home-cat-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md);transform:translateY(-2px);text-decoration:none}.home-cat-icon{font-size:28px;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--primary-light);border-radius:var(--radius-md)}.home-cat-name{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text)}.home-cat-count{font-size:var(--text-xs);color:var(--text3)}.shot-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-lg)}.shot-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:all .25s ease;cursor:pointer}.shot-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.shot-card-body{padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-sm)}.shot-card-title{font-size:var(--text-lg);font-weight:var(--weight-semibold);color:var(--text);line-height:var(--leading-tight);display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}.shot-card-stats{display:flex;align-items:center;gap:var(--space-md);font-size:var(--text-xs);color:var(--text3);padding-top:var(--space-sm);border-top:1px solid var(--border-light)}.card-badge{display:inline-block;padding:2px 10px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--weight-medium)}.fade-in{animation:fadeInUp .6s cubic-bezier(.16,1,.3,1) both}.stagger-fade>*{animation:fadeInUp .35s cubic-bezier(.16,1,.3,1) backwards}.stagger-fade>*:nth-child(1){animation-delay:0ms}.stagger-fade>*:nth-child(2){animation-delay:50ms}.stagger-fade>*:nth-child(3){animation-delay:.1s}.stagger-fade>*:nth-child(4){animation-delay:.15s}.stagger-fade>*:nth-child(5){animation-delay:.2s}.stagger-children>*{animation:fadeInUp .35s cubic-bezier(.16,1,.3,1) backwards}.label{font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--primary);text-transform:uppercase;letter-spacing:.05em}.text-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.feed-card{display:flex;align-items:flex-start;gap:var(--space-lg);padding:var(--space-lg);background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-card);transition:box-shadow .2s ease,transform .2s ease,background .2s ease;cursor:default}.feed-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-1px);background:var(--surface-hover)}.feed-card.clickable{cursor:pointer}.feed-card-icon{flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--primary-light);border-radius:var(--radius-md);font-size:22px;color:var(--primary)}.feed-card-body{flex:1;min-width:0}.feed-card-title{font-size:var(--text-base);font-weight:var(--weight-semibold);color:var(--text);line-height:1.4;margin-bottom:2px}.feed-card-title a{color:inherit;transition:color .15s}.feed-card-title a:hover{color:var(--primary);text-decoration:none}.feed-card-desc{font-size:var(--text-sm);color:var(--text2);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-top:2px}.feed-card-meta{display:flex;flex-wrap:wrap;gap:var(--space-md);margin-top:var(--space-xs);font-size:var(--text-xs);color:var(--text3)}.feed-card-meta>span{display:inline-flex;align-items:center;gap:3px}.feed-card-extra{flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;gap:var(--space-xs);font-size:var(--text-xs);color:var(--text3);white-space:nowrap}.feed-card-tag{display:inline-flex;align-items:center;font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--primary);background:var(--primary-light);padding:2px 10px;border-radius:var(--radius-full);line-height:1.5}.grid-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-xl);transition:all .25s ease;box-shadow:var(--shadow-card)}.grid-card:hover{border-color:var(--primary);box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}.grid-card-accent{position:relative;overflow:hidden}.grid-card-accent:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--card-accent)}.grid-card-icon{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:var(--primary-light);border-radius:var(--radius-md);font-size:20px;margin-bottom:var(--space-sm)}.grid-card h3,.grid-card-title{font-size:var(--text-lg);font-weight:var(--weight-semibold);line-height:1.4;margin-bottom:var(--space-xs)}.grid-card h3 a{color:var(--text)}.grid-card h3 a:hover{color:var(--primary);text-decoration:none}.grid-card-desc{font-size:var(--text-sm);color:var(--text2);line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.grid-card-meta{display:flex;gap:var(--space-md);margin-top:var(--space-md);font-size:var(--text-xs);color:var(--text3)}.card-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg)}.card-section-header h2{font-size:var(--text-xl);font-weight:var(--weight-bold)}.card-section-header .see-all{font-size:var(--text-sm);color:var(--text2);transition:color .15s}.card-section-header .see-all:hover{color:var(--primary)}.card-grid{display:grid;gap:var(--space-lg)}.article-card-grid{display:grid;gap:var(--space-lg);grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.article-card-grid .feed-card{padding:var(--space-lg)}.article-card-grid .feed-card-title{font-size:var(--text-lg)}@media (max-width: 767px){.article-card-grid{grid-template-columns:1fr}}.card-grid-2{grid-template-columns:repeat(auto-fill,minmax(340px,1fr))}.card-grid-3{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.feed-card,.grid-card{animation:cardEnter .35s ease-out backwards}.feed-card:nth-child(1),.grid-card:nth-child(1){animation-delay:0ms}.feed-card:nth-child(2),.grid-card:nth-child(2){animation-delay:40ms}.feed-card:nth-child(3),.grid-card:nth-child(3){animation-delay:80ms}.feed-card:nth-child(4),.grid-card:nth-child(4){animation-delay:.12s}.feed-card:nth-child(5),.grid-card:nth-child(5){animation-delay:.16s}.feed-card:nth-child(6),.grid-card:nth-child(6){animation-delay:.2s}.feed-card:nth-child(7),.grid-card:nth-child(7){animation-delay:.24s}.feed-card:nth-child(8),.grid-card:nth-child(8){animation-delay:.28s}.feed-card:nth-child(9),.grid-card:nth-child(9){animation-delay:.32s}.feed-card:nth-child(10),.grid-card:nth-child(10){animation-delay:.36s}@media (max-width: 767px){.feed-card{flex-direction:row;gap:var(--space-md);padding:var(--space-md)}.feed-card-icon{width:40px;height:40px;font-size:18px}.feed-card-extra{display:none}.grid-card{padding:var(--space-md)}.card-grid-2,.card-grid-3{grid-template-columns:1fr}}.article-detail{max-width:780px;margin:0 auto}.article-detail h1{font-size:var(--text-2xl);line-height:1.3;margin-bottom:var(--space-md);font-weight:var(--weight-bold)}.article-detail .article-content{font-size:var(--text-base);line-height:var(--leading-relaxed);color:var(--text)}.article-detail .article-content h2{font-size:var(--text-xl);margin:var(--space-2xl) 0 var(--space-md);color:var(--primary)}.article-detail .article-content p{margin-bottom:var(--space-md)}.article-detail .article-content blockquote{border-left:3px solid var(--accent);padding:var(--space-sm) var(--space-lg);margin:var(--space-lg) 0;background:var(--accent-light);border-radius:0 var(--radius-md) var(--radius-md) 0;color:var(--text2)}.article-detail .article-tags{display:flex;gap:var(--space-xs);flex-wrap:wrap;margin-top:var(--space-2xl);padding-top:var(--space-lg);border-top:1px solid var(--border)}.article-detail .article-tags span{font-size:var(--text-xs);background:var(--bg2);color:var(--text2);padding:4px 12px;border-radius:var(--radius-full)}.article-detail .article-source{margin-top:var(--space-lg);font-size:var(--text-xs);color:var(--text3)}.article-meta-row{display:flex;flex-wrap:wrap;gap:var(--space-md);align-items:center;font-size:var(--text-sm);color:var(--text3);margin-bottom:var(--space-lg);padding-bottom:var(--space-lg);border-bottom:1px solid var(--border)}.article-meta-row span{display:inline-flex;align-items:center;gap:4px}.article-feed{display:flex;flex-direction:column;gap:var(--space-sm)}.article-feed-card{display:flex;align-items:flex-start;gap:var(--space-lg);padding:var(--space-lg);background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-card);transition:box-shadow .2s ease,transform .2s ease}.article-feed-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-1px)}.article-feed-badge{flex-shrink:0;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--primary-light);border-radius:var(--radius-md);font-size:20px}.article-feed-body{flex:1;min-width:0}.article-feed-body h3{font-size:var(--text-base);font-weight:var(--weight-semibold);line-height:1.4;margin-bottom:2px}.article-feed-body h3 a{color:var(--text);transition:color .15s}.article-feed-body h3 a:hover{color:var(--primary);text-decoration:none}.article-feed-body .summary{font-size:var(--text-sm);color:var(--text2);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-top:2px}.article-feed-meta{display:flex;flex-wrap:wrap;gap:var(--space-md);margin-top:var(--space-xs);font-size:var(--text-xs);color:var(--text3)}.article-feed-meta>span{display:inline-flex;align-items:center;gap:3px}.article-feed-extra{flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;gap:var(--space-xs);font-size:var(--text-xs);color:var(--text3);white-space:nowrap}.article-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);transition:all .25s ease}.article-card:hover{border-color:var(--primary);box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}.article-card .cat{display:inline-block;font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--primary);background:var(--primary-light);padding:2px 10px;border-radius:var(--radius-full);margin-bottom:var(--space-sm)}.article-card h3{font-size:var(--text-lg);font-weight:var(--weight-semibold);line-height:1.4;margin-bottom:var(--space-xs)}.article-card h3 a{color:var(--text);transition:color .15s}.article-card h3 a:hover{color:var(--primary);text-decoration:none}.article-card .summary{color:var(--text2);font-size:var(--text-sm);line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.article-card .meta{display:flex;gap:var(--space-md);margin-top:var(--space-md);font-size:var(--text-xs);color:var(--text3)}@media (max-width: 767px){.article-card{padding:var(--space-md)}}.article-feed-cat{display:inline-flex;font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--primary);background:var(--primary-light);padding:2px 10px;border-radius:var(--radius-full)}@media (min-width: 768px) and (max-width: 1024px){.article-detail{max-width:640px}.article-feed-card{gap:var(--space-md);padding:var(--space-md)}.article-feed-badge{width:40px;height:40px;font-size:18px}}@media (max-width: 767px){.article-feed-card{gap:var(--space-md);padding:var(--space-md)}.article-feed-badge{width:36px;height:36px;font-size:16px}.article-feed-extra{display:none}.article-detail h1{font-size:var(--text-xl)}}.nav-section{margin-bottom:var(--space-2xl)}.nav-section-title{font-size:var(--text-lg);font-weight:var(--weight-semibold);color:var(--text);margin-bottom:var(--space-md);display:flex;align-items:center;gap:var(--space-sm)}.nav-section-count{font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--text3);background:var(--bg2);padding:2px 8px;border-radius:var(--radius-full)}.nav-grid-5{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--space-md)}.nav-card{display:flex;flex-direction:column;padding:var(--space-md);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;min-height:100px}.nav-card:hover{border-color:var(--primary);box-shadow:var(--shadow-card-hover);transform:translateY(-1px)}.nav-card-name{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text);margin-bottom:var(--space-xs)}.nav-card-desc{font-size:var(--text-xs);color:var(--text3);line-height:var(--leading-normal);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.nav-section-more{grid-column:1 / -1;text-align:center;padding-top:var(--space-sm)}.nav-view-more{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--primary);text-decoration:none}.nav-view-more:hover{text-decoration:underline}@media (max-width: 1023px){.nav-grid-5{grid-template-columns:repeat(3,1fr)}}@media (max-width: 767px){.nav-grid-5{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.nav-grid-5{grid-template-columns:1fr}}.go-title{font-size:var(--text-2xl);font-weight:var(--weight-bold);color:var(--text);margin-bottom:var(--space-lg)}.go-count{font-size:var(--text-sm);color:var(--text3);margin-bottom:var(--space-xl);padding-bottom:var(--space-md);border-bottom:1px solid var(--border)}.go-back{display:inline-flex;align-items:center;gap:var(--space-xs);font-size:var(--text-sm);color:var(--primary);text-decoration:none;margin-bottom:var(--space-md)}.go-back:hover{text-decoration:underline}.pagination{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);margin:var(--space-xl) 0}.pagination-btn{padding:6px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);cursor:pointer;font-size:var(--text-sm)}.pagination-btn:hover{border-color:var(--primary);color:var(--primary)}.pagination-pages{display:flex;gap:2px}.search-header{margin-bottom:var(--space-xl)}.search-header h2{font-size:var(--text-xl);margin-bottom:var(--space-xs)}.search-result-count{font-size:var(--text-sm);color:var(--text3);margin-bottom:0}.search-tabs{display:flex;gap:0;margin-bottom:var(--space-lg);border-bottom:1px solid var(--border)}.search-tab{padding:var(--space-sm) var(--space-lg);font-size:var(--text-sm);background:none;border:none;cursor:pointer;color:var(--text2);border-bottom:2px solid transparent;transition:all .2s;font-family:inherit}.search-tab:hover{color:var(--text)}.search-tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:var(--weight-semibold)}.search-feed{display:flex;flex-direction:column;gap:var(--space-sm)}.search-result-item{display:flex;align-items:flex-start;gap:var(--space-lg);padding:var(--space-lg);background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-card);transition:box-shadow .2s ease,transform .2s ease}.search-result-item:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-1px)}.search-result-body{flex:1;min-width:0}.search-result-body h4{font-size:var(--text-base);margin-bottom:var(--space-xs)}.search-result-body h4 a{font-weight:var(--weight-semibold);color:var(--text);transition:color .15s}.search-result-body h4 a:hover{color:var(--primary);text-decoration:none}.search-result-body .desc{font-size:var(--text-sm);color:var(--text2);line-height:1.6;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.search-result-meta{font-size:var(--text-xs);color:var(--text3);margin-top:var(--space-xs);display:flex;gap:var(--space-md);flex-wrap:wrap}.search-result-extra{flex-shrink:0;font-size:var(--text-xs);color:var(--text3);white-space:nowrap}.empty-state{text-align:center;padding:var(--space-3xl) var(--space-lg);color:var(--text3)}.empty-state .empty-icon{font-size:48px;margin-bottom:var(--space-md);opacity:.4}.empty-state p{font-size:var(--text-base);margin-bottom:var(--space-xs)}.empty-state .hint{font-size:var(--text-sm);color:var(--text4)}@media (max-width: 767px){.search-result-item{gap:var(--space-md);padding:var(--space-md)}.search-result-extra{display:none}.search-tabs{overflow-x:auto}.search-tab{padding:var(--space-sm) var(--space-md);white-space:nowrap}}.search-results{max-width:var(--max-width);margin:0 auto;padding:var(--space-lg)}.search-list{display:flex;flex-direction:column;gap:var(--space-md)}.result-count{font-size:var(--text-sm);color:var(--text3);margin-bottom:var(--space-lg)}.result-meta{font-size:var(--text-xs);color:var(--text3)}.search-submit-btn{display:inline-flex;align-items:center;gap:var(--space-xs);padding:8px 20px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;font-size:var(--text-sm);font-weight:var(--weight-medium)}.pill-group{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.data-tabs{display:flex;flex-wrap:wrap;gap:var(--space-xs);margin-bottom:var(--space-xl)}.category-tab{padding:6px 16px;border-radius:var(--radius-full);font-size:var(--text-sm);background:var(--bg2);color:var(--text2);border:1px solid transparent;cursor:pointer;transition:all .2s;font-family:inherit;white-space:nowrap}.category-tab:hover{border-color:var(--primary);color:var(--primary)}.category-tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}.ingredient-feed{display:flex;flex-direction:column;gap:var(--space-sm)}.ingredient-card{display:flex;align-items:flex-start;gap:var(--space-lg);padding:var(--space-lg);background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-card);transition:box-shadow .2s ease,transform .2s ease;cursor:pointer}.ingredient-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-1px)}.ingredient-icon{flex-shrink:0;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--primary-light);border-radius:var(--radius-md);font-size:20px}.ingredient-body{flex:1;min-width:0}.ingredient-name-row{display:flex;align-items:baseline;gap:var(--space-sm);flex-wrap:wrap}.ingredient-name{font-size:var(--text-base);font-weight:var(--weight-semibold);color:var(--text)}.ingredient-latin{font-size:var(--text-sm);color:var(--text3);font-style:italic;font-family:var(--font-mono)}.ingredient-tags{display:flex;gap:var(--space-xs);flex-wrap:wrap;margin-top:var(--space-xs)}.ingredient-tag{font-size:var(--text-xs);color:var(--primary);background:var(--primary-light);padding:2px 10px;border-radius:var(--radius-full)}.ingredient-meta{display:flex;gap:var(--space-md);flex-wrap:wrap;font-size:var(--text-xs);color:var(--text3);margin-top:var(--space-xs)}.ingredient-meta span{display:inline-flex;align-items:center;gap:4px}.ingredient-extra{flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;gap:var(--space-xs);font-size:var(--text-xs);color:var(--text3);white-space:nowrap}.ingredient-detail{max-width:780px;margin:0 auto}.ingredient-detail .back-link{display:inline-flex;align-items:center;gap:4px;font-size:var(--text-sm);color:var(--primary);margin-bottom:var(--space-lg);cursor:pointer;border:none;background:none;font-family:inherit;padding:4px 8px;border-radius:var(--radius-md);transition:background .15s}.ingredient-detail .back-link:hover{background:var(--primary-light)}.ingredient-detail h1{font-size:var(--text-2xl);margin-bottom:var(--space-xs)}.ingredient-detail .detail-latin{font-size:var(--text-sm);color:var(--text3);font-style:italic;margin-bottom:var(--space-sm)}@media (max-width: 767px){.ingredient-card{gap:var(--space-md);padding:var(--space-md)}.ingredient-icon{width:36px;height:36px;font-size:16px}.ingredient-extra{display:none}.data-tabs{overflow-x:auto;flex-wrap:nowrap;padding-bottom:var(--space-xs);-webkit-overflow-scrolling:touch}.category-tab{flex-shrink:0}}.two-col-layout{display:grid;grid-template-columns:260px 1fr;gap:var(--space-xl);max-width:var(--max-width);margin:0 auto;padding:var(--space-lg)}.two-col-sidebar{display:flex;flex-direction:column;gap:var(--space-md)}.two-col-main{min-width:0}.sidebar-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-md)}.sidebar-card-title{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text);margin-bottom:var(--space-sm)}.sidebar-text{font-size:var(--text-xs);color:var(--text3);line-height:var(--leading-normal)}.region-group-header{font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--text2);text-transform:uppercase;letter-spacing:.05em;padding:var(--space-xs) 0;margin-top:var(--space-md)}@media (max-width: 767px){.two-col-layout{grid-template-columns:1fr}}.login-page{min-height:calc(100vh - var(--nav-height));display:flex;align-items:center;justify-content:center;padding:var(--space-lg);background:var(--bg)}.login-box{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-2xl);box-shadow:var(--shadow-lg)}.login-box h1{font-size:var(--text-2xl);font-weight:var(--weight-bold);color:var(--text);margin-bottom:var(--space-xs);text-align:center}.login-box .subtitle{font-size:var(--text-sm);color:var(--text2);margin-bottom:var(--space-xl);text-align:center}.form-group{display:flex;flex-direction:column;gap:var(--space-xs);margin-bottom:var(--space-md)}.form-group label{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text)}.form-group input{width:100%;padding:var(--space-sm) var(--space-md);font-size:var(--text-base);color:var(--text);background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);transition:border-color .2s,box-shadow .2s}.form-group input:focus{outline:none;border-color:var(--primary);box-shadow:var(--shadow-glow)}.btn-primary{width:100%;padding:var(--space-sm) var(--space-lg);font-size:var(--text-base);font-weight:var(--weight-medium);color:#fff;background:var(--primary);border:none;border-radius:var(--radius-md);cursor:pointer;transition:background .2s;margin-top:var(--space-md)}.btn-primary:hover{background:var(--primary-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.error-msg{padding:var(--space-sm) var(--space-md);font-size:var(--text-sm);color:var(--error);background:#d03a2e1a;border:1px solid var(--error);border-radius:var(--radius-md);margin-bottom:var(--space-md)}@font-face{font-family:Inter;src:url(https://fonts.gstatic.com/s/inter/v13/UcC73FwrK3iLTeHuS_nVMrMxCp50SsVuUSw.woff2) format("woff2");font-weight:400 700;font-style:normal;font-display:swap}:root{--primary: #1a7a4e;--primary-hover: #0f5e38;--primary-light: #e6f4ed;--primary-glow: rgba(26, 122, 78, .08);--accent: #c8954a;--accent-light: #faf1e4;--bg: #fcfcfc;--bg2: #f5f5f5;--bg3: #eeeeee;--bg-warm: #f9f7f4;--surface: #ffffff;--surface-hover: #fafafa;--text: #1a1a1a;--text2: #666666;--text3: #999999;--text4: #bbbbbb;--border: #eaeaea;--border-light: #f0f0f0;--border-focus: #1a7a4e;--divider: #efefef;--success: #22a65e;--warning: #d68a1c;--error: #d03a2e;--info: #2c7ab1;--shadow-xs: 0 1px 2px rgba(0,0,0,.04);--shadow-sm: 0 1px 3px rgba(0,0,0,.05), 0 1px 2px rgba(0,0,0,.03);--shadow-md: 0 4px 12px rgba(0,0,0,.06), 0 1px 3px rgba(0,0,0,.04);--shadow-lg: 0 8px 24px rgba(0,0,0,.07), 0 2px 6px rgba(0,0,0,.04);--shadow-xl: 0 16px 40px rgba(0,0,0,.08), 0 4px 12px rgba(0,0,0,.05);--shadow-glow: 0 0 0 3px var(--primary-glow);--shadow-card: 0 1px 3px rgba(0,0,0,.04), 0 1px 2px rgba(0,0,0,.02);--shadow-card-hover: 0 4px 14px rgba(0,0,0,.07), 0 2px 4px rgba(0,0,0,.04);--card-accent: linear-gradient(90deg, var(--primary), var(--accent));--font-sans-cn: "PingFang SC", "Microsoft YaHei", "Noto Sans SC", system-ui, -apple-system, sans-serif;--font-sans-en: "Inter", "SF Pro Text", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "SF Mono", "Cascadia Code", Menlo, Consolas, monospace;--font-display: var(--font-sans-en);--font-body: var(--font-sans-cn);--text-xs: clamp(.72rem, .12vw + .69rem, .78rem);--text-sm: clamp(.83rem, .14vw + .79rem, .9rem);--text-base: clamp(.94rem, .16vw + .89rem, 1rem);--text-lg: clamp(1.06rem, .24vw + .99rem, 1.18rem);--text-xl: clamp(1.2rem, .35vw + 1.09rem, 1.4rem);--text-2xl: clamp(1.35rem, .54vw + 1.17rem, 1.65rem);--text-3xl: clamp(1.5rem, .82vw + 1.21rem, 2rem);--weight-normal: 400;--weight-medium: 500;--weight-semibold: 600;--weight-bold: 700;--leading-tight: 1.2;--leading-normal: 1.6;--leading-relaxed: 1.75;--tracking-wide: .04em;--tracking-wider: .08em;--space-2xs: clamp(.125rem, .14vw + .09rem, .25rem);--space-xs: clamp(.25rem, .14vw + .21rem, .375rem);--space-sm: clamp(.5rem, .28vw + .42rem, .75rem);--space-md: clamp(.75rem, .42vw + .63rem, 1rem);--space-lg: clamp(1rem, .56vw + .85rem, 1.5rem);--space-xl: clamp(1.5rem, .84vw + 1.26rem, 2rem);--space-2xl: clamp(2rem, 1.12vw + 1.69rem, 3rem);--space-3xl: clamp(3rem, 1.68vw + 2.54rem, 4rem);--space-4xl: clamp(4rem, 2.24vw + 3.38rem, 6rem);--radius-xs: 2px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--max-width: 1280px;--nav-height: 64px}[data-theme=dark]{--primary: #52b788;--primary-hover: #74c69d;--primary-light: #1a3a2a;--primary-glow: rgba(82, 183, 136, .12);--accent: #d4a259;--accent-light: #2d2418;--bg: #0d0d0d;--bg2: #141414;--bg3: #1e1e1e;--bg-warm: #11100e;--surface: #1a1a1a;--surface-hover: #222222;--text: #e0e0e0;--text2: #888888;--text3: #555555;--text4: #3a3a3a;--border: #252525;--border-light: #202020;--border-focus: #52b788;--divider: #1e1e1e;--shadow-xs: 0 1px 2px rgba(0,0,0,.2);--shadow-sm: 0 1px 3px rgba(0,0,0,.25);--shadow-md: 0 4px 12px rgba(0,0,0,.3);--shadow-lg: 0 8px 24px rgba(0,0,0,.35);--shadow-xl: 0 16px 40px rgba(0,0,0,.4);--shadow-glow: 0 0 0 3px rgba(82, 183, 136, .15);--shadow-card: 0 1px 3px rgba(0,0,0,.15), 0 1px 2px rgba(0,0,0,.1);--shadow-card-hover: 0 4px 14px rgba(0,0,0,.25), 0 2px 4px rgba(0,0,0,.15);--card-accent: linear-gradient(90deg, var(--primary), var(--accent))}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:var(--font-body);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;font-synthesis:none;transition:background-color .3s ease,color .3s ease,border-color .3s ease}h1,h2,h3,h4,h5,h6{line-height:var(--leading-tight);font-weight:var(--weight-bold);color:var(--text)}h1{font-size:var(--text-3xl)}h2{font-size:var(--text-2xl)}h3{font-size:var(--text-xl)}h4{font-size:var(--text-lg)}p{margin-bottom:var(--space-md)}.label{font-size:var(--text-xs);font-weight:var(--weight-medium);letter-spacing:var(--tracking-wide);color:var(--text3)}a{color:var(--primary);text-decoration:none;transition:color .15s}a:hover{color:var(--primary-hover)}blockquote{margin:var(--space-lg) 0;padding:var(--space-md) var(--space-lg);border-left:3px solid var(--primary);background:var(--primary-light);border-radius:var(--radius-sm);color:var(--text2);font-style:italic}code{font-family:var(--font-mono);font-size:.9em;background:var(--bg2);padding:2px 6px;border-radius:var(--radius-xs)}.container{max-width:var(--max-width);margin:0 auto;padding:0 var(--space-lg);width:100%;container-type:inline-size}.container-narrow{max-width:720px;margin:0 auto;padding:0 var(--space-lg);container-type:inline-size}::selection{background:var(--primary-light);color:var(--primary-hover)}:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--text4);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text3)}.search-highlight{background:#fce8b2;color:#8a5e00;font-weight:var(--weight-semibold);font-style:normal;padding:0 2px;border-radius:var(--radius-xs)}[data-theme=dark] .search-highlight{background:#d4a2594d;color:var(--accent)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.line-clamp-1{display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.line-clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.line-clamp-3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes cardEnter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .35s ease-out}.fade-in-up{animation:fadeInUp .25s ease-out}.stagger-children>*{animation:fadeInUp .35s ease-out backwards}.stagger-children>*:nth-child(1){animation-delay:0ms}.stagger-children>*:nth-child(2){animation-delay:50ms}.stagger-children>*:nth-child(3){animation-delay:.1s}.stagger-children>*:nth-child(4){animation-delay:.15s}.stagger-children>*:nth-child(5){animation-delay:.2s}.stagger-children>*:nth-child(6){animation-delay:.25s}.stagger-children>*:nth-child(7){animation-delay:.3s}.stagger-children>*:nth-child(8){animation-delay:.35s}.stagger-children>*:nth-child(9){animation-delay:.4s}.stagger-children>*:nth-child(10){animation-delay:.45s}
