*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*
! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com
*/*,:after,:before{box-sizing:border-box;border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-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{line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;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,pre,samp{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,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif;background:radial-gradient(circle at top left,#fffaf3 0,#f9f5f0 45%,#f4ece3 100%);color:#5d4037;-webkit-font-smoothing:antialiased}.page{margin-left:auto;margin-right:auto;display:flex;min-height:100vh;max-width:56rem;flex-direction:column;padding:1rem 1.25rem}@media (min-width:768px){.page{padding:2rem 1.5rem}}.header{justify-content:space-between;padding-bottom:1rem}.brand,.header{display:flex;align-items:center}.brand{gap:.75rem}.brand-logo{display:flex;height:2.5rem;width:2.5rem;align-items:center;justify-content:center;border-radius:1rem;background-image:linear-gradient(to right,var(--tw-gradient-stops));--tw-gradient-from:#fdba74 var(--tw-gradient-from-position);--tw-gradient-to:hsla(31,97%,72%,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to);--tw-gradient-to:rgba(251,146,60,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#fb923c var(--tw-gradient-via-position),var(--tw-gradient-to);--tw-gradient-to:#fdba74 var(--tw-gradient-to-position);--tw-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1);--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow);--tw-shadow-color:rgba(251,146,60,.35);--tw-shadow:var(--tw-shadow-colored)}.brand-logo span{font-size:1.125rem;--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.brand-logo span,.brand-text-title{line-height:1.75rem;font-weight:700;letter-spacing:.05em}.brand-text-title{font-size:1.25rem}@media (min-width:768px){.brand-text-title{font-size:1.5rem;line-height:2rem}}.brand-text-subtitle{margin-top:.25rem}.brand-text-subtitle,.header-pill{font-size:.75rem;line-height:1rem;--tw-text-opacity:1;color:rgb(141 110 99/var(--tw-text-opacity,1))}.header-pill{display:flex;align-items:center;gap:.375rem;border-radius:999px;border-width:1px;padding:.375rem .75rem;--tw-backdrop-blur:blur(4px);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);background-color:hsla(0,0%,100%,.8);border-color:rgba(255,178,133,.4)}.header-pill-dot{height:.5rem;width:.5rem;border-radius:999px;--tw-bg-opacity:1;background-color:rgb(251 146 60/var(--tw-bg-opacity,1));--tw-shadow:0 0 0 6px rgba(255,183,77,.25);--tw-shadow-colored:0 0 0 6px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.main{margin-top:.5rem;display:grid;grid-template-columns:repeat(1,minmax(0,1fr));align-items:flex-start;gap:1.5rem}@media (min-width:768px){.main{grid-template-columns:1.35fr 1fr;gap:2rem}}.main{background:linear-gradient(90deg,rgba(255,161,100,.5),hsla(0,0%,100%,.95),transparent)}.hero{position:relative;overflow:hidden;border-radius:1.5rem;border-width:1px;padding:1.25rem;--tw-shadow:0 14px 30px rgba(0,0,0,.08);--tw-shadow-colored:0 14px 30px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}@media (min-width:768px){.hero{padding:1.5rem}}.hero{background:linear-gradient(90deg,rgba(255,161,100,.5),hsla(0,0%,100%,.95),transparent);border-color:rgba(255,204,188,.5)}.hero-badge{margin-bottom:.75rem;display:inline-flex;align-items:center;gap:.5rem;border-radius:999px;padding:.25rem .75rem;font-size:.75rem;line-height:1rem;--tw-text-opacity:1;color:rgb(141 110 99/var(--tw-text-opacity,1));background-color:rgba(255,243,224,.9)}.hero-badge-dot{height:.375rem;width:.375rem;border-radius:999px;--tw-bg-opacity:1;background-color:rgb(249 115 22/var(--tw-bg-opacity,1));--tw-shadow:0 0 0 4px rgba(255,112,67,.3);--tw-shadow-colored:0 0 0 4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.hero-title{margin-top:.25rem;margin-bottom:.25rem;font-size:1.5rem;line-height:2rem;font-weight:700;line-height:1.25}@media (min-width:768px){.hero-title{margin-top:.5rem;margin-bottom:.5rem;font-size:1.875rem;line-height:2.25rem}}.hero-title span{--tw-text-opacity:1;color:rgb(249 115 22/var(--tw-text-opacity,1))}.hero-subtitle{margin-bottom:1.25rem;font-size:.875rem;line-height:1.25rem;--tw-text-opacity:1;color:rgb(141 110 99/var(--tw-text-opacity,1))}.search-area{margin-bottom:1rem;display:flex;flex-direction:column;gap:.75rem}.search-input-wrap{display:flex;align-items:stretch;gap:.5rem;border-radius:999px;background-color:hsla(0,0%,100%,.9);padding:.25rem .875rem;--tw-shadow:inset 0 2px 4px 0 rgba(0,0,0,.05);--tw-shadow-colored:inset 0 2px 4px 0 var(--tw-shadow-color);--tw-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1);--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow);box-shadow:inset 0 0 0 1px rgba(156,163,175,.08),0 10px 24px rgba(93,64,55,.08)}.search-prefix{display:flex;align-items:center;gap:.375rem;white-space:nowrap;border-right-width:1px;padding-right:.375rem;color:rgb(141 110 99/var(--tw-text-opacity,1));border-right-color:rgba(156,163,175,.08)}.search-prefix,.search-prefix-pill{font-size:.75rem;line-height:1rem;--tw-text-opacity:1}.search-prefix-pill{border-radius:999px;padding:.125rem .375rem;color:rgb(249 115 22/var(--tw-text-opacity,1));background-color:rgba(249,115,22,.08)}.search-input{min-width:0;flex:1 1 0%;border-style:none;background-color:transparent;padding:.5rem;font-size:.875rem;line-height:1.25rem;--tw-text-opacity:1;color:rgb(93 64 55/var(--tw-text-opacity,1));outline:2px solid transparent;outline-offset:2px}.search-input::-moz-placeholder{color:rgba(141,110,99,.85)}.search-input::placeholder{color:rgba(141,110,99,.85)}.search-button{display:flex;cursor:pointer;align-items:center;justify-content:center;white-space:nowrap;border-radius:999px;border-style:none;background-image:linear-gradient(to bottom right,var(--tw-gradient-stops));--tw-gradient-from:#f97316 var(--tw-gradient-from-position);--tw-gradient-to:rgba(249,115,22,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to);--tw-gradient-to:#fb923c var(--tw-gradient-to-position);padding-left:1.25rem;padding-right:1.25rem;font-size:.875rem;line-height:1.25rem;font-weight:600;--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1));--tw-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1);--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow);--tw-shadow-color:rgba(249,115,22,.45);--tw-shadow:var(--tw-shadow-colored);outline:2px solid transparent;outline-offset:2px;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.search-button:hover{--tw-translate-y:-0.125rem;--tw-shadow:0 20px 25px -5px rgba(0,0,0,.1),0 8px 10px -6px rgba(0,0,0,.1);--tw-shadow-colored:0 20px 25px -5px var(--tw-shadow-color),0 8px 10px -6px var(--tw-shadow-color);--tw-shadow-color:rgba(249,115,22,.6);--tw-shadow:var(--tw-shadow-colored);--tw-brightness:brightness(1.05);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.search-button:active,.search-button:hover{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.search-button:active{--tw-translate-y:0.125rem;--tw-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1);--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color);--tw-shadow-color:rgba(249,115,22,.5);--tw-shadow:var(--tw-shadow-colored)}.search-button,.search-button:active{transform:scale(.98) translateY(1px)}.search-hints{margin-top:.25rem;display:flex;flex-wrap:wrap;gap:.375rem}.hint-pill{cursor:pointer;border-radius:999px;border-width:1px;border-color:hsla(32,98%,83%,.7);background-color:rgba(255,247,237,.95);padding:.25rem .5rem;font-size:.75rem;line-height:1rem;--tw-text-opacity:1;color:rgb(141 110 99/var(--tw-text-opacity,1));transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.hint-pill:hover{--tw-translate-y:-0.125rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));--tw-bg-opacity:1;background-color:rgb(255 237 213/var(--tw-bg-opacity,1))}.hero-meta{margin-top:.5rem;display:flex;align-items:center;justify-content:space-between;gap:.625rem;font-size:.75rem;line-height:1rem;--tw-text-opacity:1;color:rgb(141 110 99/var(--tw-text-opacity,1))}.meta-group{display:flex;flex-wrap:wrap;gap:.875rem}.meta-item{display:inline-flex;align-items:center;gap:.25rem;border-radius:999px;padding:.125rem .5rem;background-color:hsla(0,0%,100%,.7);border:1px dashed rgba(255,204,188,.5)}.meta-item-dot{height:.375rem;width:.375rem;border-radius:999px;--tw-bg-opacity:1;background-color:rgb(74 222 128/var(--tw-bg-opacity,1))}.meta-right{opacity:.9}.recommend-section{display:flex;flex-direction:column;gap:.75rem}.section-title{display:flex;align-items:center;justify-content:space-between;font-size:.875rem;line-height:1.25rem;font-weight:600;--tw-text-opacity:1;color:rgb(141 110 99/var(--tw-text-opacity,1))}.section-title span{font-size:.75rem;line-height:1rem;font-weight:400;color:rgba(141,110,99,.85)}.cards{display:flex;flex-direction:column;gap:.75rem}.book-card{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:.5rem;border-radius:12px;border-width:1px;padding:.75rem;--tw-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1);--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}@media (min-width:768px){.book-card{grid-template-columns:1fr auto}}.book-card{background-color:hsla(0,0%,100%,.98);border-color:rgba(255,204,188,.7);box-shadow:0 10px 24px rgba(93,64,55,.08),0 0 0 1px rgba(93,64,55,.08)}.book-main{min-width:0}.book-title-row{margin-bottom:.25rem;display:flex;align-items:center;gap:.5rem}.book-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.875rem;line-height:1.25rem;font-weight:600}@media (min-width:768px){.book-title{font-size:1rem;line-height:1.5rem}}.book-tag{border-radius:999px;padding:.125rem .375rem;color:rgb(249 115 22/var(--tw-text-opacity,1));background-color:rgba(249,115,22,.08)}.book-author,.book-tag{font-size:.75rem;line-height:1rem;--tw-text-opacity:1}.book-author{margin-bottom:.25rem;color:rgb(141 110 99/var(--tw-text-opacity,1))}.book-desc,.book-reason{font-size:.75rem;line-height:1rem;line-height:1.625;color:rgba(93,64,55,.96)}.book-reason-label{margin-right:.25rem;color:rgba(249,115,22,.95)}.book-chip,.book-reason-label{font-size:.75rem;line-height:1rem}.book-chip{max-width:5rem;align-self:flex-start;border-radius:.75rem;--tw-bg-opacity:1;background-color:rgb(255 237 213/var(--tw-bg-opacity,1));padding:.375rem .5rem;text-align:center;--tw-text-opacity:1;color:rgb(124 45 18/var(--tw-text-opacity,1))}@media (min-width:768px){.book-chip{align-self:flex-start}}.footer{margin-top:1.5rem;text-align:center;font-size:.75rem;line-height:1rem;color:rgba(141,110,99,.85)}.loading-spinner{display:inline-block;height:1rem;width:1rem}@keyframes spin{to{transform:rotate(1turn)}}.loading-spinner{animation:spin 1s linear infinite;border-radius:999px;border:2px solid;border-right:2px solid transparent}@media (max-width:768px){.page{padding:1rem .875rem}.header{flex-direction:column;align-items:flex-start;gap:.5rem}.main{margin-top:.25rem;grid-template-columns:repeat(1,minmax(0,1fr));gap:1.25rem}.hero{padding:1rem}.search-input-wrap{padding-left:.75rem}.search-prefix{display:none}.search-button{padding-left:1rem;padding-right:1rem;font-size:.75rem;line-height:1rem}.hero-meta{flex-direction:column;align-items:flex-start}.book-card{grid-template-columns:repeat(1,minmax(0,1fr));padding:.75rem}.book-chip{justify-self:start}}@media (max-width:480px){.brand-text-title,.hero-title{font-size:1.25rem;line-height:1.75rem}}.mt-2{margin-top:.5rem}.rounded{border-radius:.25rem}.rounded-lg{border-radius:18px}.border{border-width:1px}.border-green-200{--tw-border-opacity:1;border-color:rgb(187 247 208/var(--tw-border-opacity,1))}.border-red-200{--tw-border-opacity:1;border-color:rgb(254 202 202/var(--tw-border-opacity,1))}.bg-green-50{--tw-bg-opacity:1;background-color:rgb(240 253 244/var(--tw-bg-opacity,1))}.bg-red-50{--tw-bg-opacity:1;background-color:rgb(254 242 242/var(--tw-bg-opacity,1))}.px-3{padding-left:.75rem;padding-right:.75rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.text-green-600{--tw-text-opacity:1;color:rgb(22 163 74/var(--tw-text-opacity,1))}.text-red-500{--tw-text-opacity:1;color:rgb(239 68 68/var(--tw-text-opacity,1))}