/*! Tailwind CSS v3.4.17 - 本地预编译版本 */
/* 此文件由项目中使用的 Tailwind 类名预编译生成 */

/* ===== Preflight (Modern Normalize) ===== */
*,::before,::after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}
::before,::after{--tw-content:''}
html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}
body{margin:0;line-height:inherit}
hr{height:0;color:inherit;border-top-width:1px}
abbr:where([title]){text-decoration:underline dotted}
h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}
a{color:inherit;text-decoration:inherit}
b,strong{font-weight:bolder}
code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}
small{font-size:80%}
sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}
sub{bottom:-.25em}
sup{top:-.5em}
table{text-indent:0;border-color:inherit;border-collapse:collapse}
button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}
button,select{text-transform:none}
button,input:where([type='button']),input:where([type='reset']),input:where([type='submit']){-webkit-appearance:button;background-color:transparent;background-image:none}
:-moz-focusring{outline:auto}
:-moz-ui-invalid{box-shadow:none}
progress{vertical-align:baseline}
::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}
[type='search']{-webkit-appearance:textfield;outline-offset:-2px}
::-webkit-search-decoration{-webkit-appearance:none}
::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}
summary{display:list-item}
blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}
fieldset{margin:0;padding:0}
legend{padding:0}
ol,ul,menu{list-style:none;margin:0;padding:0}
dialog{padding:0}
textarea{resize:vertical}
input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}
button,[role="button"]{cursor:pointer}
:disabled{cursor:default}
img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}
img,video{max-width:100%;height:auto}
[hidden]:where(:not([hidden="until-found"])){display:none}

/* ===== 自定义颜色变量（对应 tailwind.config 中的 extend.colors） ===== */
/* brand: DEFAULT=#B1D850, dark=#58770F, light=#C4E494 */
/* bg: page=#FBFFF7, card=#FFFFFF, sub=#E0EABB */
/* ink: primary=#24310E, secondary=#637338, tertiary=#9AAA70 */
/* like=#C4E494, danger=#B87272, success=#B1D850, link=#78A817 */

/* ===== Layout ===== */
.container{width:100%}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}
.fixed{position:fixed}
.absolute{position:absolute}
.relative{position:relative}
.sticky{position:sticky}
.inset-0{inset:0}
.top-0{top:0}
.top-6{top:1.5rem}
.top-full{top:100%}
.-top-10{top:-2.5rem}
.-top-20{top:-5rem}
.-top-32{top:-8rem}
.right-0{right:0}
.right-5{right:1.25rem}
.right-6{right:1.5rem}
.-right-10{right:-2.5rem}
.-right-20{right:-5rem}
.bottom-20{bottom:5rem}
.-bottom-8{bottom:-2rem}
.left-0{left:0}
.-left-32{left:-8rem}
.left-12{left:12px}
.z-10{z-index:10}
.z-30{z-index:30}
.z-40{z-index:40}
.z-80{z-index:80}
.\!z-\[100\]{z-index:100!important}
.z-\[100\]{z-index:100}

/* ===== Flexbox & Grid ===== */
.flex{display:flex}
.inline-flex{display:inline-flex}
.grid{display:grid}
.hidden{display:none}
.block{display:block}
.inline-block{display:inline-block}
.table{display:table}
.flex-col{flex-direction:column}
.flex-wrap{flex-wrap:wrap}
.flex-1{flex:1 1 0%}
.shrink-0{flex-shrink:0}
.items-center{align-items:center}
.items-start{align-items:flex-start}
.items-end{align-items:flex-end}
.justify-center{justify-content:center}
.justify-between{justify-content:space-between}
.justify-end{justify-content:flex-end}
.justify-around{justify-content:space-around}
.gap-1{gap:0.25rem}
.gap-1\.5{gap:0.375rem}
.gap-2{gap:0.5rem}
.gap-3{gap:0.75rem}
.gap-4{gap:1rem}
.gap-5{gap:1.25rem}
.gap-6{gap:1.5rem}
.gap-8{gap:2rem}

/* Grid columns */
.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.divide-x>*+*{border-left-width:1px}

/* ===== Spacing ===== */
.m-0{margin:0}
.mx-auto{margin-left:auto;margin-right:auto}
.mb-1{margin-bottom:0.25rem}
.mb-2{margin-bottom:0.5rem}
.mb-3{margin-bottom:0.75rem}
.mb-4{margin-bottom:1rem}
.mb-5{margin-bottom:1.25rem}
.mb-6{margin-bottom:1.5rem}
.mb-8{margin-bottom:2rem}
.mb-10{margin-bottom:2.5rem}
.mb-12{margin-bottom:3rem}
.mb-16{margin-bottom:4rem}
.ml-1{margin-left:0.25rem}
.ml-2{margin-left:0.5rem}
.ml-6{margin-left:1.5rem}
.ml-auto{margin-left:auto}
.mr-1{margin-right:0.25rem}
.mr-2{margin-right:0.5rem}
.mr-3{margin-right:0.75rem}
.mt-0\.5{margin-top:0.125rem}
.mt-1{margin-top:0.25rem}
.mt-2{margin-top:0.5rem}
.mt-3{margin-top:0.75rem}
.mt-4{margin-top:1rem}
.mt-5{margin-top:1.25rem}
.mt-6{margin-top:1.5rem}
.mt-8{margin-top:2rem}
.mt-10{margin-top:2.5rem}
.mt-16{margin-top:4rem}
.mt-20{margin-top:5rem}
.my-20{margin-top:5rem;margin-bottom:5rem}
.-mt-10{margin-top:-2.5rem}

.p-1{padding:0.25rem}
.p-2{padding:0.5rem}
.p-3{padding:0.75rem}
.p-4{padding:1rem}
.p-5{padding:1.25rem}
.p-6{padding:1.5rem}
.p-8{padding:2rem}
.px-2{padding-left:0.5rem;padding-right:0.5rem}
.px-3{padding-left:0.75rem;padding-right:0.75rem}
.px-4{padding-left:1rem;padding-right:1rem}
.px-5{padding-left:1.25rem;padding-right:1.25rem}
.px-6{padding-left:1.5rem;padding-right:1.5rem}
.px-10{padding-left:2.5rem;padding-right:2.5rem}
.px-18{padding-left:4.5rem;padding-right:4.5rem}
.py-1{padding-top:0.25rem;padding-bottom:0.25rem}
.py-0\.5{padding-top:0.125rem;padding-bottom:0.125rem}
.py-1\.5{padding-top:0.375rem;padding-bottom:0.375rem}
.py-2{padding-top:0.5rem;padding-bottom:0.5rem}
.py-3{padding-top:0.75rem;padding-bottom:0.75rem}
.py-4{padding-top:1rem;padding-bottom:1rem}
.py-5{padding-top:1.25rem;padding-bottom:1.25rem}
.py-10{padding-top:2.5rem;padding-bottom:2.5rem}
.py-16{padding-top:4rem;padding-bottom:4rem}
.py-20{padding-top:5rem;padding-bottom:5rem}
.py-24{padding-top:6rem;padding-bottom:6rem}
.pt-2{padding-top:0.5rem}
.pt-3{padding-top:0.75rem}
.pt-4{padding-top:1rem}
.pt-6{padding-top:1.5rem}
.pt-20{padding-top:5rem}
.pb-2{padding-bottom:0.5rem}
.pb-4{padding-bottom:1rem}
.pb-5{padding-bottom:1.25rem}
.pb-6{padding-bottom:1.5rem}
.pb-24{padding-bottom:6rem}
.pl-4{padding-left:1rem}

/* ===== Sizing ===== */
.w-6{width:1.5rem}
.w-7{width:1.75rem}
.w-8{width:2rem}
.w-9{width:2.25rem}
.w-10{width:2.5rem}
.w-12{width:3rem}
.w-14{width:3.5rem}
.w-16{width:4rem}
.w-24{width:6rem}
.w-40{width:10rem}
.w-48{width:12rem}
.w-64{width:16rem}
.w-72{width:18rem}
.w-96{width:24rem}
.w-full{width:100%}
.w-px{width:1px}
.w-\[300px\]{width:300px}
.w-\[340px\]{width:340px}
.h-6{height:1.5rem}
.h-7{height:1.75rem}
.h-8{height:2rem}
.h-9{height:2.25rem}
.h-10{height:2.5rem}
.h-12{height:3rem}
.h-14{height:3.5rem}
.h-16{height:4rem}
.h-24{height:6rem}
.h-40{height:10rem}
.h-48{height:12rem}
.h-64{height:16rem}
.h-72{height:18rem}
.h-96{height:24rem}
.min-h-screen{min-height:100vh}
.min-h-\[200px\]{min-height:200px}
.min-h-\[400px\]{min-height:400px}
.min-h-\[260px\]{min-height:260px}
.min-w-0{min-width:0}
.min-w-\[320px\]{min-width:320px}
.max-w-md{max-width:28rem}
.max-w-xl{max-width:36rem}
.max-w-2xl{max-width:42rem}
.max-w-3xl{max-width:48rem}
.max-w-5xl{max-width:64rem}
.max-w-6xl{max-width:72rem}
.max-w-7xl{max-width:80rem}
.max-w-none{max-width:none}
.max-w-\[92vw\]{max-width:92vw}
.max-h-\[90vh\]{max-height:90vh}

/* ===== Typography ===== */
.font-serif{font-family:"Noto Serif SC","Songti SC",STSong,SimSun,serif}
.font-hand{font-family:"Noto Serif SC","Songti SC",STSong,SimSun,serif}
.font-medium{font-weight:500}
.font-normal{font-weight:400}
.text-xs{font-size:0.75rem;line-height:1rem}
.text-sm{font-size:0.875rem;line-height:1.25rem}
.text-base{font-size:1rem;line-height:1.5rem}
.text-lg{font-size:1.125rem;line-height:1.75rem}
.text-xl{font-size:1.25rem;line-height:1.75rem}
.text-2xl{font-size:1.5rem;line-height:2rem}
.text-3xl{font-size:1.875rem;line-height:2.25rem}
.text-4xl{font-size:2.25rem;line-height:2.5rem}
.text-5xl{font-size:3rem;line-height:1}
.text-6xl{font-size:3.75rem;line-height:1}
.text-7xl{font-size:4.5rem;line-height:1}
.text-8xl{font-size:6rem;line-height:1}
.text-\[10px\]{font-size:10px}
.text-\[16px\]{font-size:16px}
.leading-none{line-height:1}
.leading-tight{line-height:1.25}
.leading-snug{line-height:1.375}
.leading-normal{line-height:1.5}
.leading-relaxed{line-height:1.625}
.leading-loose{line-height:2}
.tracking-widest{letter-spacing:0.1em}
.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
.italic{font-style:italic}
.uppercase{text-transform:uppercase}
.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.whitespace-pre-wrap{white-space:pre-wrap}
.text-left{text-align:left}
.text-center{text-align:center}
.text-right{text-align:right}
.underline{text-decoration-line:underline}
.underline-offset-2{text-underline-offset:2px}
.line-clamp-2{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}
.line-clamp-3{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3}

/* ===== Text Colors ===== */
.text-white{color:#fff}
.text-black{color:#000}
.text-brand{color:#B1D850}
.text-brand-dark{color:#58770F}
.text-brand-light{color:#C4E494}
.text-bg-sub{color:#E0EABB}
.text-ink-primary{color:#24310E}
.text-ink-secondary{color:#637338}
.text-ink-tertiary{color:#9AAA70}
.text-like{color:#C4E494}
.text-danger{color:#B87272}
.text-success{color:#B1D850}
.text-link{color:#78A817}

/* ===== Background Colors ===== */
.bg-white{background-color:#fff}
.bg-transparent{background-color:transparent}
.bg-brand{background-color:#B1D850}
.bg-brand-dark{background-color:#58770F}
.bg-brand-light{background-color:#C4E494}
.bg-bg-page{background-color:#FBFFF7}
.bg-bg-card{background-color:#FFFFFF}
.bg-bg-sub{background-color:#E0EABB}
.bg-ink-primary{background-color:#24310E}

/* Background with opacity */
.bg-bg-page\/85{background-color:rgba(251,255,247,0.85)}
.bg-bg-sub\/50{background-color:rgba(224,234,187,0.5)}
.bg-bg-sub\/60{background-color:rgba(224,234,187,0.6)}
.bg-brand-light\/20{background-color:rgba(196,228,148,0.2)}
.bg-brand-light\/30{background-color:rgba(196,228,148,0.3)}
.bg-like\/10{background-color:rgba(196,228,148,0.1)}
.bg-like\/15{background-color:rgba(196,228,148,0.15)}
.bg-like\/20{background-color:rgba(196,228,148,0.2)}
.bg-success\/15{background-color:rgba(177,216,80,0.15)}
.bg-link\/15{background-color:rgba(120,168,23,0.15)}
.bg-white\/70{background-color:rgba(255,255,255,0.7)}

/* ===== Border ===== */
.border{border-width:1px}
.border-b{border-bottom-width:1px}
.border-t{border-top-width:1px}
.border-l-2{border-left-width:2px}
.border-brand{border-color:#B1D850}
.border-brand-dark{border-color:#58770F}
.border-brand-light{border-color:#C4E494}
.border-like\/30{border-color:rgba(196,228,148,0.3)}
.\!border-0{border-width:0!important}

/* ===== Border Radius ===== */
.rounded{border-radius:0.25rem}
.rounded-lg{border-radius:0.5rem}
.rounded-xl{border-radius:0.75rem}
.rounded-2xl{border-radius:1rem}
.rounded-full{border-radius:9999px}

/* ===== Shadows ===== */
.shadow-lg{box-shadow:0 10px 15px -3px rgba(88,119,15,.08),0 4px 6px -4px rgba(88,119,15,.08)}
.shadow-lg.shadow-brand-light\/20{box-shadow:0 18px 36px -20px rgba(177,216,80,0.34),0 4px 10px -6px rgba(88,119,15,0.18)}

/* ===== Effects ===== */
.opacity-70{opacity:0.7}
.backdrop-blur{backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.blur-3xl{filter:blur(64px)}
.overflow-hidden{overflow:hidden}
.overflow-auto{overflow:auto}
.overflow-x-auto{overflow-x:auto}

/* ===== Transitions ===== */
.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:150ms}
.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:150ms}

/* ===== Transforms ===== */
.scale-125{transform:scale(1.25)}

/* ===== Cursor ===== */
.cursor-pointer{cursor:pointer}

/* ===== User Select ===== */
.select-none{user-select:none}

/* ===== Scroll ===== */
.snap-x{scroll-snap-type:x mandatory}
.snap-mandatory{scroll-snap-type:x mandatory}
.snap-start{scroll-snap-align:start}

/* ===== Gradients ===== */
.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-stops))}
.bg-gradient-to-b{background-image:linear-gradient(to bottom,var(--tw-gradient-stops))}
.from-\[\#EFECE8\]{--tw-gradient-from:#E0EABB var(--tw-gradient-from-position);--tw-gradient-to:rgba(224,234,187,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}
.via-\[\#F7F5F2\]{--tw-gradient-to:rgba(251,255,247,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#FFFFFF var(--tw-gradient-via-position),var(--tw-gradient-to)}
.to-\[\#E5DED4\]{--tw-gradient-to:#C4E494 var(--tw-gradient-to-position)}
.from-brand-light\/30{--tw-gradient-from:rgba(196,228,148,0.3) var(--tw-gradient-from-position);--tw-gradient-to:rgba(196,228,148,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}
.from-like\/20{--tw-gradient-from:rgba(196,228,148,0.2) var(--tw-gradient-from-position);--tw-gradient-to:rgba(196,228,148,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}
.from-success\/15{--tw-gradient-from:rgba(177,216,80,0.15) var(--tw-gradient-from-position);--tw-gradient-to:rgba(177,216,80,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}
.from-link\/15{--tw-gradient-from:rgba(120,168,23,0.15) var(--tw-gradient-from-position);--tw-gradient-to:rgba(120,168,23,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}
.from-white{--tw-gradient-from:#fff var(--tw-gradient-from-position);--tw-gradient-to:rgba(255,255,255,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}
.to-transparent{--tw-gradient-to:transparent var(--tw-gradient-to-position)}
.to-bg-sub{--tw-gradient-to:#E0EABB var(--tw-gradient-to-position)}

/* ===== Prose (for article content) ===== */
.prose{color:#24310E;max-width:65ch}
.prose p{margin-top:1.25em;margin-bottom:1.25em}
.prose h2{font-size:1.5em;font-weight:700;margin-top:2em;margin-bottom:1em}
.prose h3{font-size:1.25em;font-weight:600;margin-top:1.6em;margin-bottom:.6em}
.prose blockquote{border-left:3px solid #C4E494;padding-left:1em;font-style:italic;color:#637338}
.prose ul{list-style-type:disc;padding-left:1.625em}
.prose ol{list-style-type:decimal;padding-left:1.625em}
.prose li{margin-top:.5em;margin-bottom:.5em}
.prose code{font-size:.875em;background:#E0EABB;padding:2px 6px;border-radius:4px}
.prose pre{background:#24310E;color:#E0EABB;padding:1em;border-radius:8px;overflow-x:auto}
.prose a{color:#78A817;text-decoration:underline}

/* ===== Important overrides ===== */
.\!text-xl{font-size:1.25rem!important;line-height:1.75rem!important}
.\!font-medium{font-weight:500!important}
.\!px-0{padding-left:0!important;padding-right:0!important}
.focus\:\!shadow-none:focus{box-shadow:none!important}

/* ===== Peer variants ===== */
.peer:checked~.peer-checked\:bg-brand-dark{background-color:#58770F}
.peer:checked~.peer-checked\:bg-brand-light{background-color:#C4E494}
.peer:checked~.peer-checked\:text-white{color:#fff}
.peer:checked~.peer-checked\:border-brand-dark{border-color:#58770F}
.peer:checked~.peer-checked\:border-brand{border-color:#B1D850}

/* ===== Hover variants ===== */
.hover\:bg-bg-sub:hover{background-color:#E0EABB}
.hover\:bg-white:hover{background-color:#fff}
.hover\:bg-brand:hover{background-color:#B1D850}
.hover\:bg-brand-dark:hover{background-color:#58770F}
.hover\:bg-brand-light:hover{background-color:#C4E494}
.hover\:text-brand:hover{color:#B1D850}
.hover\:text-brand-dark:hover{color:#58770F}
.hover\:text-like:hover{color:#C4E494}
.hover\:text-danger:hover{color:#B87272}
.hover\:text-white:hover{color:#fff}
.hover\:underline:hover{text-decoration-line:underline}
.hover\:translate-x-1:hover{transform:translateX(0.25rem)}
.hover\:scale-125:hover{transform:scale(1.25)}

/* ===== Group hover ===== */
.group:hover .group-hover\:translate-x-1{transform:translateX(0.25rem)}
.group:hover .group-hover\:scale-125{transform:scale(1.25)}

/* ===== Focus variants ===== */
.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}

/* ===== Placeholder variants ===== */
.placeholder\:text-ink-tertiary::placeholder{color:#9B9590}

/* ===== Responsive: sm (640px) ===== */
@media(min-width:640px){
  .sm\:inline{display:inline}
  .sm\:flex-row{flex-direction:row}
  .sm\:px-6{padding-left:1.5rem;padding-right:1.5rem}
  .sm\:text-left{text-align:left}
  .sm\:text-7xl{font-size:4.5rem;line-height:1}
  .sm\:justify-start{justify-content:flex-start}
  .sm\:w-\[340px\]{width:340px}
}

/* ===== Responsive: md (768px) ===== */
@media(min-width:768px){
  .md\:flex{display:flex}
  .md\:hidden{display:none}
  .md\:inline-flex{display:inline-flex}
  .md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
  .md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
  .md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
  .md\:col-span-2{grid-column:span 2/span 2}
  .md\:text-8xl{font-size:6rem;line-height:1}
  .md\:flex-row{flex-direction:row}
}

/* ===== Responsive: lg (1024px) ===== */
@media(min-width:1024px){
  .lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
  .lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
  .lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
  .lg\:col-span-2{grid-column:span 2/span 2}
  .lg\:grid-cols-\[320px\2c 1fr\]{grid-template-columns:320px 1fr}
}

/* ===== Scroll bar style ===== */
.scrollbar-thin{scrollbar-width:thin}

/* ===== Space utilities ===== */
.space-y-1>*+*{margin-top:0.25rem}
.space-y-2>*+*{margin-top:0.5rem}
.space-y-3>*+*{margin-top:0.75rem}
.space-y-4>*+*{margin-top:1rem}
.space-y-5>*+*{margin-top:1.25rem}

/* ===== Outline ===== */
.outline-none{outline:2px solid transparent;outline-offset:2px}

/* ===== Gradient position vars ===== */
*,::before,::after{
  --tw-gradient-from-position: ;
  --tw-gradient-via-position: ;
  --tw-gradient-to-position: ;
}