@import"https://cdn-uicons.flaticon.com/3.0.0/uicons-regular-straight/css/uicons-regular-straight.css";@import"https://cdn-uicons.flaticon.com/3.0.0/uicons-regular-rounded/css/uicons-regular-rounded.css";@import"https://cdn-uicons.flaticon.com/3.0.0/uicons-solid-rounded/css/uicons-solid-rounded.css";@import"https://cdn-uicons.flaticon.com/3.0.0/uicons-bold-straight/css/uicons-bold-straight.css";@import"https://cdn-uicons.flaticon.com/3.0.0/uicons-solid-straight/css/uicons-solid-straight.css";@import"https://cdn-uicons.flaticon.com/3.0.0/uicons-bold-rounded/css/uicons-bold-rounded.css";*,:before,:after{--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: rgb(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: rgb(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: }*,: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;-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{margin:0;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,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::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}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}.container{width:100%}@media (min-width: 640px){.container{max-width:640px}}@media (min-width: 768px){.container{max-width:768px}}@media (min-width: 1024px){.container{max-width:1024px}}@media (min-width: 1280px){.container{max-width:1280px}}@media (min-width: 1536px){.container{max-width:1536px}}.absolute{position:absolute}.relative{position:relative}.right-3{right:.75rem}.top-1\/2{top:50%}.mx-auto{margin-left:auto;margin-right:auto}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-6{margin-bottom:1.5rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-6{margin-top:1.5rem}.block{display:block}.flex{display:flex}.table{display:table}.table-row{display:table-row}.grid{display:grid}.contents{display:contents}.h-10{height:2.5rem}.h-24{height:6rem}.h-32{height:8rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-\[48px\]{height:48px}.h-\[80vh\]{height:80vh}.max-h-\[calc\(100vh-120px\)\]{max-height:calc(100vh - 120px)}.min-h-\[700px\]{min-height:700px}.min-h-screen{min-height:100vh}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-full{width:100%}.max-w-3xl{max-width:48rem}.max-w-4xl{max-width:56rem}.max-w-5xl{max-width:64rem}.max-w-\[700px\]{max-width:700px}.max-w-\[90\%\]{max-width:90%}.max-w-md{max-width:28rem}.max-w-xs{max-width:20rem}.flex-1{flex:1 1 0%}.-translate-y-1\/2{--tw-translate-y: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.resize-none{resize:none}.list-inside{list-style-position:inside}.list-disc{list-style-type:disc}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-col{flex-direction:column}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-6{gap:1.5rem}.space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(.5rem * var(--tw-space-x-reverse));margin-left:calc(.5rem * calc(1 - var(--tw-space-x-reverse)))}.space-x-3>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(.75rem * var(--tw-space-x-reverse));margin-left:calc(.75rem * calc(1 - var(--tw-space-x-reverse)))}.space-y-10>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(2.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(2.5rem * var(--tw-space-y-reverse))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.space-y-5>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.25rem * var(--tw-space-y-reverse))}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-pre-line{white-space:pre-line}.rounded{border-radius:.25rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.border-b{border-bottom-width:1px}.border-t{border-top-width:1px}.border-\[\#adb5bd\]{--tw-border-opacity: 1;border-color:rgb(173 181 189 / var(--tw-border-opacity, 1))}.border-\[\#d0bfff\]{--tw-border-opacity: 1;border-color:rgb(208 191 255 / var(--tw-border-opacity, 1))}.border-gray-300{--tw-border-opacity: 1;border-color:rgb(209 213 219 / var(--tw-border-opacity, 1))}.bg-\[\#e9ecef\]{--tw-bg-opacity: 1;background-color:rgb(233 236 239 / var(--tw-bg-opacity, 1))}.bg-blue-500{--tw-bg-opacity: 1;background-color:rgb(59 130 246 / var(--tw-bg-opacity, 1))}.bg-blue-600{--tw-bg-opacity: 1;background-color:rgb(37 99 235 / var(--tw-bg-opacity, 1))}.bg-gray-100{--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1))}.bg-gray-300{--tw-bg-opacity: 1;background-color:rgb(209 213 219 / var(--tw-bg-opacity, 1))}.bg-gray-50{--tw-bg-opacity: 1;background-color:rgb(249 250 251 / var(--tw-bg-opacity, 1))}.bg-green-100{--tw-bg-opacity: 1;background-color:rgb(220 252 231 / var(--tw-bg-opacity, 1))}.bg-red-100{--tw-bg-opacity: 1;background-color:rgb(254 226 226 / var(--tw-bg-opacity, 1))}.bg-white{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-10{padding-top:2.5rem;padding-bottom:2.5rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.py-8{padding-top:2rem;padding-bottom:2rem}.pl-10{padding-left:2.5rem}.pr-10{padding-right:2.5rem}.pt-4{padding-top:1rem}.text-left{text-align:left}.text-center{text-align:center}.text-2xl{font-size:1.5rem;line-height:2rem}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-semibold{font-weight:600}.text-blue-600{--tw-text-opacity: 1;color:rgb(37 99 235 / var(--tw-text-opacity, 1))}.text-gray-500{--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.text-gray-600{--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity, 1))}.text-gray-700{--tw-text-opacity: 1;color:rgb(55 65 81 / var(--tw-text-opacity, 1))}.text-gray-800{--tw-text-opacity: 1;color:rgb(31 41 55 / var(--tw-text-opacity, 1))}.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))}.text-red-600{--tw-text-opacity: 1;color:rgb(220 38 38 / var(--tw-text-opacity, 1))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.opacity-70{opacity:.7}.shadow{--tw-shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-lg{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(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)}.shadow-md{--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.filter{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)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}html,body,#root{height:100%}body{margin:0;font-family:var(--ff-sans);color:var(--ink);background:var(--bg)}.page-root{min-height:100vh;display:flex;flex-direction:column;background:var(--bg);color:var(--ink)}.section{padding:48px 0}.section--muted{background:var(--bg-muted);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.container{width:min(1120px,92%);margin:0 auto}.hero{position:relative;background-image:linear-gradient(#323232e5,#3232324d),url(/assets/mainlibrary-DBPmt0D_.jpg);background-size:cover;background-position:center;padding:clamp(64px,10vw,128px) 0;border-bottom:1px solid var(--line)}.hero__content{width:min(1120px,92%);margin:0 auto}.hero__title{font-family:var(--ff-serif);font-size:clamp(28px,4vw,44px);font-weight:800;color:#fff}.hero__subtitle{margin-top:10px;font-family:var(--ff-sans);font-size:clamp(16px,2.2vw,20px);color:#fff;opacity:.9}.hero__accent{margin-top:20px;width:160px;height:4px;border-radius:999px;background:linear-gradient(90deg,#78bba8,#78bba8)}.actions{display:flex;flex-wrap:nowrap;gap:16px;overflow-x:auto;padding-bottom:8px}.actions::-webkit-scrollbar{height:6px}.actions::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}.action-card{flex:0 0 calc((100% - 48px)/4);min-width:240px;max-width:320px;display:flex;flex-direction:column;align-items:flex-start;background:var(--surface);border-radius:var(--radius-sm);border:1px solid var(--line);padding:18px 16px;text-align:left;box-shadow:var(--shadow-1)}.action-card:focus-visible{outline:2px solid var(--accent-2);outline-offset:2px}.action-card__icon{font-size:34px;color:var(--accent);margin-bottom:8px}.action-card__title{font-size:20px;font-weight:800;color:var(--heading)}.action-card__desc{font-size:14px;color:var(--ink-muted)}.container.actions{display:flex!important;flex-direction:row!important;flex-wrap:nowrap!important;gap:16px!important;overflow-x:auto;padding-bottom:8px}.container.actions>.action-card,.container.actions>.button-column,.container.actions>.button-column2{flex:0 0 calc((100% - 48px)/4)!important;min-width:240px;max-width:320px;margin:0!important}.container.actions>.button-column,.container.actions>.button-column2{display:flex;flex-direction:column;align-items:flex-start}.section__header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:20px}.section__title{font-family:var(--ff-serif);font-size:clamp(22px,3vw,30px);font-weight:800;color:var(--heading)}.slider{position:relative;display:block}.slider__track{display:grid;grid-template-columns:repeat(var(--cols, 5),minmax(0,1fr));gap:25px;align-items:start}@media (max-width: 1280px){.slider__track{--cols: 4}}@media (max-width: 1024px){.slider__track{--cols: 3}}@media (max-width: 768px){.slider__track{--cols: 2}}@media (max-width: 480px){.slider__track{--cols: 1}}.slider__nav{position:absolute;top:50%;transform:translateY(-50%) translateZ(0);transform-origin:center;z-index:2;width:40px;height:40px;line-height:40px;display:flex;align-items:center;justify-content:center;font-size:18px;border:1px solid var(--line);border-radius:999px;background-color:#f3f1ea;color:var(--accent);cursor:pointer;transition:none;animation:none;-webkit-tap-highlight-color:transparent;will-change:auto}.slider__nav--prev{left:var(--nav-offset, -100px);right:auto}.slider__nav--next{right:var(--nav-offset, -100px);left:auto}.slider__nav:disabled{opacity:.5;cursor:not-allowed}.slider__nav:focus-visible{outline:2px solid var(--accent-2);outline-offset:2px}.slider__nav,.slider__nav:hover,.slider__nav:active,.slider__nav:focus{top:50%!important;transform:translateY(-50%) translateZ(0)!important;transition:none!important}.slider.slider--abs{position:relative;display:block}.slider__dots{display:inline-flex;gap:6px}.dot{width:8px;height:8px;border-radius:999px;background:#d6d3c8}.dot.is-active{background:var(--accent-2)}@media (max-width: 768px){.slider__nav--prev{left:4px}.slider__nav--next{right:4px}}.book-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);box-shadow:var(--shadow-1);padding:12px;min-height:330px;display:flex;flex-direction:column;align-items:center;gap:23px}.book-card.is-ghost{opacity:0;pointer-events:none}.book-card__media{aspect-ratio:var(--media-ratio, 4 / 5);border-radius:8px;background:#eeece5;display:grid;place-items:center;overflow:hidden}.book-card__media img{width:100%;height:100%;-o-object-fit:contain;object-fit:contain;display:block}.book-card__title{height:60px;display:grid;place-items:center;text-align:center;padding:0 8px;align-items:center;justify-content:center}.title-text{font-size:15px;line-height:1.4;color:var(--heading);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;word-break:keep-all;white-space:normal}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:20px;overflow-x:auto;padding-bottom:8px}.two-col::-webkit-scrollbar{height:6px}.two-col::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);box-shadow:var(--shadow-1);padding:20px;display:flex;flex-direction:column;min-height:260px}.panel__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.panel__title{font-family:var(--ff-serif);font-size:20px;font-weight:800;color:var(--heading);padding-left:5px}.notice{display:flex;flex-direction:column;gap:12px}.notice__item{display:flex;align-items:center;justify-content:space-between;background:var(--bg);border:1px solid var(--line);border-radius:8px;padding:10px 12px}.notice__text{color:var(--heading);font-size:16px;line-height:1.4;margin-right:12px}.notice__date{color:var(--ink-muted);font-size:14px}.button-ellipses{background:none;border:1px solid var(--line);border-radius:8px;font-size:18px;cursor:pointer;line-height:1;padding:4px 10px;color:var(--accent)}.button-ellipses:focus-visible{outline:2px solid var(--accent-2);outline-offset:2px}.discard-list-1{overflow-y:auto;max-height:260px;padding-right:6px;display:flex;flex-direction:column;gap:12px}.discard-item{background:var(--bg);border:1px solid var(--line);border-radius:8px;padding:10px 12px}.discard-item__icon{font-size:18px;color:var(--accent)}.action-card{transition:transform .18s ease,box-shadow .18s ease,background-color .18s ease,border-color .18s ease;padding-left:20px;padding-right:20px}.action-card:hover{transform:translateY(-2px);box-shadow:0 8px 20px #00000014;background-color:#f6f4ed;border-color:#e2ded2}.action-card:active{transform:translateY(0);box-shadow:var(--shadow-1)}.action-card__icon{transition:color .18s ease,transform .18s ease}.action-card:hover .action-card__icon{color:var(--accent-2);transform:translateY(-1px)}.slider__nav{transition:transform .12s ease,background-color .12s ease,box-shadow .12s ease}.slider__nav:hover:not(:disabled){transform:translateY(-1px);background-color:#ede9dd;box-shadow:0 4px 10px #00000014}.slider__nav:active:not(:disabled){transform:translateY(0);box-shadow:none}.book-card{transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.book-card:hover{transform:translateY(-2px);box-shadow:0 8px 20px #00000014;border-color:#e0ddd3}.notice__item,.discard-item{transition:background-color .16s ease,border-color .16s ease}.notice__item:hover,.discard-item:hover{background-color:var(--bg-muted);border-color:#ddd7c8}.link{transition:color .12s ease,text-decoration-color .12s ease;padding-right:5px}.link:hover{color:var(--accent-2);text-decoration-color:var(--accent-2)}.link_recommend{padding-right:26px;transition:color .12s ease,text-decoration-color .12s ease}.link_recommend:hover{color:var(--accent-2);text-decoration-color:var(--accent-2)}.container.two-col{display:flex!important;flex-direction:row!important;flex-wrap:nowrap!important;gap:20px!important;align-items:stretch;overflow-x:auto;padding-bottom:8px}.container.two-col>.panel{flex:0 0 calc((100% - 20px)/2)!important;min-width:360px;margin:0!important}.container.two-col::-webkit-scrollbar{height:6px}.container.two-col::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}@media (prefers-reduced-motion: reduce){.action-card,.action-card__icon,.slider__nav,.book-card,.notice__item,.discard-item,.link{transition:none!important;transform:none!important;box-shadow:none!important}}.hover\:bg-\[\#f3f0ff\]:hover{--tw-bg-opacity: 1;background-color:rgb(243 240 255 / var(--tw-bg-opacity, 1))}.hover\:bg-blue-600:hover{--tw-bg-opacity: 1;background-color:rgb(37 99 235 / var(--tw-bg-opacity, 1))}.hover\:bg-blue-700:hover{--tw-bg-opacity: 1;background-color:rgb(29 78 216 / var(--tw-bg-opacity, 1))}.hover\:bg-gray-200:hover{--tw-bg-opacity: 1;background-color:rgb(229 231 235 / var(--tw-bg-opacity, 1))}.hover\:bg-gray-400:hover{--tw-bg-opacity: 1;background-color:rgb(156 163 175 / var(--tw-bg-opacity, 1))}.hover\:opacity-100:hover{opacity:1}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-2:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus\:ring-blue-400:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(96 165 250 / var(--tw-ring-opacity, 1))}.focus\:ring-blue-500:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(59 130 246 / var(--tw-ring-opacity, 1))}@media (min-width: 640px){.sm\:w-auto{width:auto}.sm\:flex-row{flex-direction:row}.sm\:gap-4{gap:1rem}.sm\:space-x-4>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(1rem * var(--tw-space-x-reverse));margin-left:calc(1rem * calc(1 - var(--tw-space-x-reverse)))}.sm\:space-y-0>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(0px * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(0px * var(--tw-space-y-reverse))}.sm\:p-8{padding:2rem}.sm\:px-6{padding-left:1.5rem;padding-right:1.5rem}}@media (min-width: 768px){.md\:max-w-\[1248px\]{max-width:1248px}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:p-10{padding:2.5rem}}@media (min-width: 1024px){.lg\:px-8{padding-left:2rem;padding-right:2rem}}@font-face{font-family:Paperlogy;src:url(https://fastly.jsdelivr.net/gh/projectnoonnu/2408-3@1.0/Paperlogy-8ExtraBold.woff2) format("woff2");font-weight:800;font-style:normal;font-display:swap}@font-face{font-family:Paperlogy;src:url(https://fastly.jsdelivr.net/gh/projectnoonnu/2408-3@1.0/Paperlogy-7Bold.woff2) format("woff2");font-weight:700;font-style:normal;font-display:swap}@font-face{font-family:Paperlogy;src:url(https://fastly.jsdelivr.net/gh/projectnoonnu/2408-3@1.0/Paperlogy-4Regular.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}.paperlogy-extra-bold{font-family:Paperlogy,sans-serif;font-weight:800}.paperlogy-bold{font-family:Paperlogy,sans-serif;font-weight:700}.paperlogy-regular{font-family:Paperlogy,sans-serif;font-weight:400}.paperlogy-light{font-family:Paperlogy,sans-serif;font-weight:300}.navbar{display:flex;justify-content:space-between;align-items:center;background-color:#fff;padding:12px 24px;border-bottom:1px solid #e5e7eb;position:relative}.navbar-left{display:flex;align-items:center}.navbar-center{position:absolute;left:50%;transform:translate(-50%);display:flex;gap:20px}.navbar-right{display:flex;align-items:center}.navbar-button{background:none;border:none;color:#374151;font-size:16px;cursor:pointer;padding:8px}.navbar-button:hover{color:#3d7a68}.navbar-left .navbar-button{font-size:24px;color:#3d7a68;font-weight:700}.navbar-logo{width:27px;height:24px;margin-right:8px}.navbar-title{font-size:20px;font-weight:700;color:#3d7a68}.profile-button{background:none;border:none;cursor:pointer}.profile-image{width:70px;height:70px;border-radius:50%}.auth-button{display:inline-flex;align-items:center;justify-content:center;min-height:36px;padding:8px 14px;border-radius:8px;font-size:14px;font-weight:600;border:1px solid transparent;cursor:pointer;transition:transform .12s ease,box-shadow .16s ease,background-color .16s ease,color .16s ease,border-color .16s ease;box-shadow:0 1px 2px #3741511f;-webkit-user-select:none;-moz-user-select:none;user-select:none}.auth-button:focus-visible{outline:2px solid #3D7A68;outline-offset:2px}.auth-button:active{transform:translateY(1px)}.auth-button.login{background-color:#3b8971;color:#fff;border-color:#3b8971}.auth-button.login:hover{background-color:#68ad98;box-shadow:0 2px 6px #3d7a684d;transform:translateY(-1px)}.auth-button.logout{background-color:#3b8971;color:#fff;border-color:#3b8971}.auth-button.logout:hover{background-color:#68ad98;color:#fff;box-shadow:0 2px 6px #37415140;transform:translateY(-1px)}.auth-button:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.navbar-right .auth-button+.auth-button{margin-left:10px}.navbar-right .auth-button{min-height:40px;padding:8px 16px}.column9{width:100%;background:#1f2937;padding:38px 80px 28px;box-sizing:border-box}.column10,.column11,.column13{flex:1;display:flex;flex-direction:column;align-items:flex-start;margin-right:24px;min-width:200px}.column10{padding-bottom:40px}.column11{padding-bottom:20px}.column13{padding-bottom:40px}.column12{display:flex;flex-direction:column;gap:10px;align-items:flex-start;margin-bottom:0}.row-view13{display:flex;align-items:center;gap:12px}.row-view12{display:flex;flex-wrap:wrap;justify-content:center;margin:0 16px;gap:40px}.view3{text-align:center;padding-top:24px;border-top:1px solid #374151;margin:0 16px}.text20{color:#fff;font-size:18px;font-weight:600;margin-bottom:20px}.text21,.text23,.text24{color:#9ca3af;font-size:16px;line-height:1.6}.text21{margin-bottom:6px}.footer-button{background:none;border:none;color:#9ca3af;font-size:16px;cursor:pointer;padding:0;transition:color .2s ease}.footer-button:hover{color:#fff;text-decoration:underline}.image10,.image11,.image12{width:28px;height:28px;cursor:pointer;transition:transform .2s ease}.image10:hover,.image11:hover,.image12:hover{transform:scale(1.1)}.social-button{background:none;border:none;padding:0;cursor:pointer;display:flex;align-items:center}:root{--bg: #FAF9F5;--bg-muted: #F2F0E9;--surface: #FFFFFF;--ink: #1B1F1A;--ink-muted: #5F665F;--heading: #1C2B25;--accent: #2F5D50;--accent-2: #3D7A68;--line: #E6E3DA;--radius-sm: 10px;--radius: 12px;--shadow-1: 0 1px 2px rgba(0, 0, 0, .08);--shadow-2: 0 6px 20px rgba(0, 0, 0, .08);--ff-sans: ui-sans-serif, system-ui, "Noto Sans KR", -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, sans-serif}.page{background:linear-gradient(0deg,var(--bg),var(--bg)) padding-box;min-height:100vh;padding:28px 20px 48px;color:var(--ink);font-family:var(--ff-sans)}.icon-style{font-size:20px;color:var(--ink-muted)}.search-bar-BookLoan{display:flex;align-items:center;justify-content:center;gap:10px;margin:20px auto;width:100%;max-width:960px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:10px 12px;box-shadow:var(--shadow-1)}.search-input-BookLoan{flex:unset;width:400px;height:40px;border:1px solid var(--line);border-radius:10px;padding:0 12px;background:var(--bg);color:var(--ink);outline:none}.search-input:focus{background:#fff;border-color:var(--accent-2);box-shadow:0 0 0 4px #3d7a681f}.btn-BookLoan{height:40px;padding:0 14px;border-radius:10px;border:1px solid transparent;font-weight:600;letter-spacing:.01em;transition:transform .08s ease,box-shadow .2s ease,background .2s ease,color .2s ease;cursor:pointer;writing-mode:horizontal-tb;white-space:nowrap;text-align:center}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff;box-shadow:var(--shadow-1)}.btn-primary:hover{transform:translateY(-1px);box-shadow:var(--shadow-2)}.btn-primary:active{transform:translateY(0)}.btn-quiet{background:var(--bg-muted);color:var(--heading);border:1px solid var(--line)}.btn-quiet:hover{background:#eae7df}.link{background:transparent;border:none;color:var(--accent);font-weight:600;cursor:pointer;padding:6px 8px;border-radius:8px}.link:hover{background:#2f5d5014}.card{max-width:960px;margin:16px auto;background:var(--surface);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-1);overflow:hidden}.card-title{padding:14px 18px;border-bottom:1px solid var(--line);background:#fff;font-size:18px;font-weight:800;color:var(--heading)}.user-info{display:grid;grid-template-columns:88px 1fr;gap:16px;padding:18px;align-items:center}.avatar{width:88px;height:88px;-o-object-fit:cover;object-fit:cover;border-radius:14px;border:1px solid var(--line);background:var(--bg-muted)}.user-info-text{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:minmax(32px,auto);row-gap:10px;-moz-column-gap:50px;column-gap:50px}.user-info-text .field{display:flex;align-items:center;gap:8px;min-height:32px;white-space:nowrap}.user-info-text .label{flex:0 0 90px;color:var(--ink-muted);text-align:left;font-weight:500}.user-info-text .value{flex:1 1 auto;color:var(--ink);font-weight:600;min-width:0}@media (max-width: 900px){.user-info-text{grid-template-columns:repeat(2,1fr)}}@media (max-width: 640px){.user-info{grid-template-columns:72px 1fr}.user-info-text{grid-template-columns:1fr}.user-info-text .label{flex-basis:84px}}.badge-user{display:inline-flex;align-items:center;justify-content:center;height:26px;padding:0 10px;border-radius:999px;font-size:13px;font-weight:700;border:1px solid transparent}.badge-user-blue{background:#e6f0ff;color:#2563eb;border-color:#cfe1ff}.badge-user-green{background:#e8f5ef;color:#147a5a;border-color:#c8ebdd}.badge-amber{background:#fff4e0;color:#b86f00;border-color:#ffe4b8}.badge-red{background:#ffe7e7;color:#b42318;border-color:#ffcfcf}.badge-gray{background:#f1f2f4;color:#3a3f44;border-color:#e2e5e9}.book-detail{display:grid;grid-template-columns:140px 1fr;gap:16px;padding:18px}@media (max-width: 640px){.book-detail{grid-template-columns:1fr}}.book-cover{width:140px;height:200px;border-radius:12px;-o-object-fit:cover;object-fit:cover;border:1px solid var(--line);background:var(--bg-muted)}.book-meta{display:grid;gap:10px}.book-buttons{display:flex;gap:10px;margin-top:8px}.table-wrap{overflow:auto;padding:10px 12px 16px}.loan-status-table{width:100%;border-collapse:collapse;border-spacing:0;min-width:680px;background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden}.loan-status-table thead th{background:var(--bg-muted);color:var(--heading);font-weight:700;font-size:14px;padding:12px;border-bottom:1px solid var(--line);text-align:center;vertical-align:middle}.loan-status-table tbody td{padding:12px;border-bottom:1px solid var(--line);color:var(--ink);font-size:14px;text-align:center;vertical-align:middle}.loan-status-table tbody tr:hover{background:#faf7ef}.cell-title{font-weight:600}.empty{padding:18px;color:var(--ink-muted)}.alert{max-width:960px;margin:0 auto 12px;border:1px solid #ffd19b;background:#fff6e7;color:#7a4d00;border-radius:12px;padding:10px 12px}.skeleton{border-radius:12px;background:linear-gradient(90deg,#eee,#f6f6f6,#eee);background-size:300% 100%;animation:shine 1.3s infinite linear;border:1px solid var(--line);margin:18px}.user-skeleton{height:116px}.book-skeleton,.table-skeleton{height:220px}@keyframes shine{0%{background-position:0% 0}to{background-position:-300% 0}}.page{background-color:#f3f4f6;padding:20px;font-family:Noto Sans KR,sans-serif}.search-bar{display:flex;align-items:center;gap:8px;margin:16px 0;background-color:#fff;padding:8px 12px;border-radius:6px;box-shadow:0 1px 3px #0000001a}.search-input{flex:1;height:40px;padding:0 12px;background-color:#f3f4f6;border:1px solid #d1d5db;border-radius:8px;font-size:14px;color:#111827}.search-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 1px #2563eb}.search-button{height:40px;padding:0 16px;background-color:#2563eb;color:#fff;border:none;border-radius:8px;cursor:pointer}.search-button:hover{background-color:#1e40af}.card{background-color:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 10px #0000000f;margin-bottom:20px}.card-title{font-size:20px;font-weight:700;margin-bottom:20px;color:#111827;border-bottom:1px solid #e5e7eb;padding-bottom:8px}.user-info{display:flex;align-items:center}.user-info img{width:96px;height:96px;border-radius:50%;-o-object-fit:cover;object-fit:cover;margin-left:20px;margin-right:60px;box-shadow:0 2px 4px #0000001a}.user-info-text{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:minmax(32px,auto);row-gap:10px;-moz-column-gap:50px;column-gap:50px;align-items:center}.user-info-text span{font-size:16px;color:#374151}.label{font-weight:600;color:#6b7280;margin-right:6px;font-size:20px}.book-detail{display:flex;gap:32px;align-items:flex-start;flex-wrap:wrap}.book-detail img{width:200px;height:280px;-o-object-fit:cover;object-fit:cover;border-radius:8px;box-shadow:0 2px 6px #00000014}.book-meta{flex:1;display:flex;flex-direction:column;gap:16px;font-size:20px;line-height:1.8}.book-meta .value{font-weight:500;color:#111827;font-size:20px}.book-status{color:#059669;font-weight:600}.book-buttons{display:flex;gap:12px;margin-top:8px;justify-content:flex-end}.loan-button,.return-button{display:flex;align-items:center;gap:8px;padding:10px 16px;font-size:14px;border-radius:6px;border:none;cursor:pointer;transition:background-color .3s ease}.loan-button{background-color:#2563eb;color:#fff}.loan-button:hover{background-color:#1e40af}.return-button{background-color:#10b981;color:#fff}.return-button:hover{background-color:#059669}.loan-status-table{width:100%;border-collapse:collapse;font-size:15px;color:#374151}.loan-status-table th,.loan-status-table td{padding:12px;border-bottom:1px solid #e5e7eb;text-align:center;vertical-align:middle}.loan-status-table th{background-color:#f9fafb;font-weight:600}.status{color:#059669;font-weight:500}.extend{color:#2563eb;cursor:pointer;font-weight:500}.extend:hover{text-decoration:underline}.register-page-wrapper{display:flex;justify-content:center;align-items:center;min-height:50vh;padding:80px 16px}.register-div{background-color:#fff;width:672px;height:863px;position:relative;border:1px solid #d1d5db;border-radius:12px;box-shadow:0 8px 24px #0000000f}.register-div .register-h{position:absolute;top:32px;left:32px;width:608px;height:32px}.register-div .register-title{color:#1f2937;font-size:35px;font-family:Noto Sans KR,sans-serif;position:absolute;top:-2px}.register-div .register-form{position:absolute;top:88px;left:32px;width:608px;height:727px}.register-section-header{border-bottom:1px solid #e5e7eb;font-size:18px;font-weight:400;color:#374151;padding-bottom:8px;margin-bottom:12px;margin-top:30px}.register-input-group{display:flex;flex-wrap:wrap;gap:24px 16px;margin-bottom:20px}.register-input-wrapper{width:292px;display:flex;flex-direction:column}.register-label{font-size:14px;color:#374151;margin-bottom:4px}.register-input{height:42px;padding:0 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px}.register-address-row{display:flex;gap:16px;align-items:center}.register-address-zipcode{width:203px;height:42px;border:1px solid #d1d5db;border-radius:6px;padding:0 12px;font-size:14px}.register-address-button{background-color:#f3f4f6;border-radius:6px;padding:10px 16px;font-size:14px;cursor:pointer;border:none}.register-address-button:hover{background-color:#d1d5db}.register-address-full{margin-top:12px;width:100%;height:42px;border:1px solid #d1d5db;border-radius:6px;padding:0 12px;font-size:14px}.register-checkbox-group{margin-top:20px}.register-checkbox-item{display:flex;align-items:flex-start;gap:12px;margin-bottom:12px}.register-checkbox-description{font-size:14px;color:#374151;line-height:1.5}.register-checkbox-subtext{font-size:12px;color:#6b7280;margin-top:2px}.register-button-wrapper{text-align:center;margin-top:20px}.register-submit-button{background-color:#3d7a68;color:#fff;border:none;border-radius:6px;padding:12px 32px;font-size:16px;cursor:pointer;transition:background-color .3s ease;margin-top:30px}.register-submit-button:hover{background-color:#8eb7aa}.member-list-container{background:#fff;border:1px solid #e7e3d8;border-radius:12px;box-shadow:0 6px 16px #0000000f;overflow:hidden}.member-table{width:100%;border-collapse:separate;border-spacing:0;table-layout:fixed;font-size:14px;color:#1b1f1a;text-align:center}.member-table-header th{background:#f4f1e8;color:#38423b;font-weight:700;text-align:center;padding:12px 14px;border-bottom:1px solid #e6e3da}.member-table tbody td{padding:12px 14px;border-bottom:1px solid #efede6;vertical-align:middle;background:#fff;text-align:center}.member-table tbody tr:nth-child(2n) td{background:#faf9f5}.member-table tbody tr:hover td{background:#f3f1eb}.member-table td,.member-table th{overflow:hidden;white-space:nowrap;text-overflow:ellipsis;text-align:center}.member-table col.col-id{width:70px!important}.member-table col.col-name{width:120px!important}.member-table col.col-contact{width:200px!important}.member-table col.col-grade,.member-table col.col-status{width:120px!important}.member-table col.col-joined{width:130px!important}.member-table col.col-actions{width:40px!important}.member-table th:nth-child(1),.member-table td:nth-child(1){width:70px!important}.member-table th:nth-child(2),.member-table td:nth-child(2){width:120px!important}.member-table th:nth-child(3),.member-table td:nth-child(3){width:200px!important}.member-table th:nth-child(4),.member-table td:nth-child(4){width:120px!important}.member-table th:nth-child(5),.member-table td:nth-child(5){width:120px!important}.member-table th:nth-child(6),.member-table td:nth-child(6){width:130px!important}.member-table th:nth-child(7),.member-table td:nth-child(7){width:40px!important}.member-table tbody tr td:nth-child(4)[data-badge]:before,.member-table tbody tr td:nth-child(5)[data-badge]:before{content:attr(data-badge);display:inline-block;padding:2px 8px;border-radius:999px;font-size:12px;line-height:1.6;background:#eef3ee;color:#2f5d50;border:1px solid #d9e4df}.member-table tbody tr td:nth-child(5)[data-badge=NORMAL]:before{background:#eef2ff;color:#3843a5;border-color:#d9ddff}.member-table tbody td:empty:before{content:none}.member-table-footer{display:flex;justify-content:flex-end;align-items:center;gap:8px;padding:10px 14px;background:#faf9f5;color:#5f665f;font-size:13px}.page-container{padding:56px 24px 40px;background:var(--bg);min-height:100vh;color:var(--ink);font-family:var(--ff-sans);max-width:1120px;margin:0 auto}.page-title{font-size:36px;font-weight:800;color:var(--heading);margin-bottom:8px;letter-spacing:-.02em;line-height:1.2}.page-sub{margin-bottom:18px;font-size:14px;color:var(--ink-muted)}.mem-header{display:grid;grid-template-columns:1fr auto;gap:12px 16px;margin-bottom:14px;align-items:center}@media (max-width: 800px){.mem-header{grid-template-columns:1fr}}.mem-search-group{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center}@media (max-width: 800px){.mem-search-group{grid-template-columns:1fr}}.mem-searchbox{display:flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:999px;background:#fff;padding:10px 14px;box-shadow:var(--shadow-1);transition:border-color .12s ease,box-shadow .12s ease,transform .12s ease}.mem-searchbox:focus-within{border-color:var(--accent);box-shadow:0 2px 12px #2f5d5026;transform:translateY(-1px)}.mem-searchbox-input{flex:1;font-size:14px;color:var(--ink);border:none;outline:none;background:transparent}.mem-filters{display:flex;gap:10px;align-items:center}.mem-select{border:1px solid var(--line);border-radius:var(--radius-sm);background:#fff;color:var(--ink);padding:10px 12px;font-size:14px;box-shadow:var(--shadow-1);transition:border-color .12s ease,box-shadow .12s ease;min-width:140px}.mem-select:focus,.mem-select:focus-visible{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #2f5d5026}@media (max-width: 600px){.mem-filters{flex-direction:column;align-items:stretch}.mem-select{min-width:unset;width:100%}}.btn-new{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1px solid var(--line);border-radius:12px;padding:10px 14px;font-size:14px;font-weight:700;cursor:pointer;transition:background-color .14s ease,color .14s ease,border-color .14s ease,transform .12s ease,box-shadow .12s ease}.btn-new:hover{transform:translateY(-1px);box-shadow:var(--shadow-1)}.btn-new:active{transform:translateY(0)}.btn-new:focus-visible{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #2f5d5026}.btn-accent{background:var(--accent);color:#fff;border-color:var(--accent-2)}.btn-accent:hover{background:var(--accent-2);color:#fff}.mem-card{border:1px solid var(--line);border-radius:16px;background:var(--surface);box-shadow:var(--shadow-2);overflow:hidden;text-align:center}.mem-card table{width:100%;border-collapse:separate;border-spacing:0;color:var(--ink)}.mem-card thead th{position:sticky;top:0;z-index:1;background:var(--bg-muted);color:var(--heading);font-weight:700;text-align:center;padding:12px 14px;border-bottom:1px solid var(--line)}.mem-card tbody td{text-align:center;padding:12px 14px;border-bottom:1px solid var(--line)}.mem-card tbody tr:nth-child(2n) td{background:#e6e3da59}.mem-card tbody tr:hover td{background:#8eb7aa40}.mem-empty,.mem-loading{display:flex;align-items:center;justify-content:center;height:200px;text-align:center;color:var(--ink-muted);font-size:14px}.mem-footerbar{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:16px;flex-wrap:wrap}.mem-muted{color:var(--ink-muted);font-size:14px}.new-pagination{display:flex;gap:8px;justify-content:center}.new-pagination button{min-width:38px;height:36px;padding:0 10px;border:1px solid var(--line);border-radius:999px;background:var(--bg-muted);font-size:13px;font-weight:700;cursor:pointer;color:var(--ink);transition:background-color .14s ease,color .14s ease,border-color .14s ease,transform .12s ease,box-shadow .12s ease}.new-pagination button:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-1)}.new-pagination button:focus-visible{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #2f5d5026}.new-pagination button.active{background:var(--accent);color:#fff;border-color:var(--accent-2);box-shadow:0 4px 14px #2f5d5038}.new-pagination button:disabled{background:var(--bg-muted);color:var(--ink-muted);cursor:not-allowed;opacity:.8}@media (prefers-reduced-motion: reduce){.mem-searchbox,.btn-new,.new-pagination button{transition:none}}.min-h-screen.bg-gray-50{background:var(--bg)!important;color:var(--ink);font-family:var(--ff-sans)}.flex-1.px-4.py-10{padding:56px 24px 40px!important}.max-w-5xl.mx-auto.bg-white.shadow-lg.rounded-lg{background:var(--surface)!important;border:1px solid var(--line);box-shadow:var(--shadow-2);border-radius:16px!important}.max-w-5xl.mx-auto.bg-white.shadow-lg.rounded-lg>h1{font-size:32px!important;line-height:1.25;font-weight:800!important;color:var(--heading);margin-bottom:6px!important;letter-spacing:-.01em}.max-w-5xl.mx-auto.bg-white.shadow-lg.rounded-lg>p{color:var(--ink-muted)!important}.text-xl.font-semibold.mb-4{color:var(--heading)!important}label.block.mb-1.font-medium.text-sm{color:var(--ink)}input[type=text],input[type=url],textarea{width:100%;background:var(--surface);color:var(--ink);border:1px solid var(--line);border-radius:var(--radius-sm);padding:10px 12px;box-shadow:var(--shadow-1);transition:border-color .12s ease,box-shadow .12s ease,transform .12s ease}textarea{resize:none}input[type=text]:focus,input[type=url]:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #2f5d5026}.intro{padding-bottom:20px}.grid.grid-cols-1.md\:grid-cols-2.gap-6{gap:16px!important}.list-disc.list-inside.text-gray-700{color:var(--ink)!important}.list-disc.list-inside.text-gray-700 li{margin:4px 0}button[type=submit].bg-blue-600{background:var(--accent)!important;border:1px solid var(--accent-2);color:#fff!important;border-radius:12px!important;padding:10px 18px!important;font-weight:700!important;transition:background-color .14s ease,transform .12s ease,box-shadow .12s ease,border-color .14s ease}button[type=submit].bg-blue-600:hover{background:var(--accent-2)!important;transform:translateY(-1px);box-shadow:var(--shadow-1)}button[type=submit].bg-blue-600:focus-visible{outline:none;box-shadow:0 0 0 3px #2f5d5026}form.space-y-10>section{padding-top:4px;padding-bottom:4px;border-top:1px solid transparent}form.space-y-10>section+section{margin-top:14px}.max-w-5xl.mx-auto.bg-white.shadow-lg.rounded-lg.p-6,.max-w-5xl.mx-auto.bg-white.shadow-lg.rounded-lg.md\:p-10{padding:24px!important}@media (min-width: 768px){.max-w-5xl.mx-auto.bg-white.shadow-lg.rounded-lg{padding:28px 32px!important}}@media (prefers-reduced-motion: reduce){input[type=text],input[type=url],textarea,button[type=submit].bg-blue-600{transition:none}}form button{background:var(--accent);color:#fff;border:1px solid var(--accent-2);padding:10px 20px;font-size:15px;font-weight:600;border-radius:12px;cursor:pointer;transition:background-color .14s ease,transform .12s ease,box-shadow .12s ease}form button:hover{background:var(--accent-2);transform:translateY(-1px);box-shadow:var(--shadow-1)}form button:active{transform:translateY(0);box-shadow:none}.form-actions{display:flex;justify-content:flex-end}:root{--bg: #FAF9F5;--bg-muted: #F2F0E9;--surface: #FFFFFF;--ink: #1B1F1A;--ink-muted: #5F665F;--heading: #1C2B25;--accent: #2F5D50;--accent-2: #3D7A68;--line: #E6E3DA;--shadow-1: 0 1px 2px rgba(0, 0, 0, .07);--shadow-2: 0 6px 24px rgba(0, 0, 0, .06);--radius-xs: 8px;--radius-sm: 10px;--radius: 12px;--ff-sans: ui-sans-serif, system-ui, "Noto Sans KR", -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, sans-serif;--ff-serif: ui-serif, Georgia, "Noto Serif KR", Cambria, "Times New Roman", serif}.page-container{padding:32px 24px;background-color:var(--bg);min-height:100vh;font-family:var(--ff-sans);color:var(--ink);max-width:1120px;margin:0 auto}.page-title{font-size:35px;line-height:1.2;font-weight:800;margin-top:20px;margin-bottom:20px;color:var(--heading);letter-spacing:-.02em}.page-title:after{content:"";display:block;height:2px;width:64px;margin-top:12px;background:var(--accent);border-radius:999px}.filter-bar{display:grid;grid-template-columns:1fr;gap:500px;margin-bottom:20px}@media (min-width: 640px){.filter-bar{grid-template-columns:220px 1fr;align-items:center}}.status-select{border:1px solid var(--line);border-radius:var(--radius-sm);padding:10px 12px;background:var(--surface);font-size:14px;color:var(--ink);box-shadow:var(--shadow-1);transition:border-color .12s ease,box-shadow .12s ease}.status-select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #2f5d5026}.search-box{display:flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:999px;padding:8px 12px;background:var(--surface);box-shadow:var(--shadow-1);max-width:360px;width:100%;transition:border-color .12s ease,box-shadow .12s ease,transform .12s ease}.search-box:focus-within{border-color:var(--accent);box-shadow:0 2px 12px #2f5d5026;transform:translateY(-1px)}.search-input{flex:1;font-size:14px;border:none;outline:none;color:var(--ink);background:transparent}.search-icon{width:18px;height:18px;opacity:.85}.loading,.error{text-align:center;padding:40px 0;font-size:14px;color:var(--ink)}.error{color:var(--accent-2)}.table-container{overflow:hidden;margin-bottom:28px;border:1px solid var(--line);border-radius:16px;background:linear-gradient(180deg,var(--surface) 0%,#ffffff 100%);box-shadow:var(--shadow-2)}.book-table{width:100%;border-collapse:separate;border-spacing:0;color:var(--ink)}.book-table th,.book-table td{padding:12px 14px;text-align:center;font-size:14px;border-bottom:1px solid var(--line)}.book-table thead th{background:var(--bg-muted);color:var(--heading);font-weight:700;position:sticky;top:0;z-index:1}.book-table tbody tr:nth-child(2n) td{background:#e6e3da59}.table-row{cursor:pointer;transition:background-color .14s ease,transform .14s ease,box-shadow .14s ease}.table-row:hover td{background-color:var(--bg-muted)}.table-row:focus td{background-color:var(--bg-muted);outline:none}.table-row:hover{transform:translateY(-1px)}.no-data{text-align:center;padding:28px;color:var(--ink-muted);background:var(--surface)}.badge{display:inline-block;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:700;color:#fff;letter-spacing:.02em;box-shadow:var(--shadow-1)}.badge-green{background-color:var(--accent)}.badge-red{background-color:var(--accent-2)}.badge-gray{background-color:var(--ink-muted)}.pagination{display:flex;justify-content:center;gap:8px;margin-top:12px;flex-wrap:wrap}.pagination button{min-width:40px;padding:8px 12px;border:1px solid var(--line);border-radius:999px;background:var(--bg-muted);font-size:13px;font-weight:600;cursor:pointer;color:var(--ink);transition:background-color .14s ease,color .14s ease,border-color .14s ease,transform .12s ease,box-shadow .12s ease}.pagination button:hover:not(:disabled):not(.active){background:var(--surface);transform:translateY(-1px);box-shadow:var(--shadow-1)}.pagination button.active{background:var(--accent);color:#fff;border-color:var(--accent-2);box-shadow:0 4px 14px #2f5d5038}.pagination button:disabled{background:var(--bg-muted);color:var(--ink-muted);cursor:not-allowed;opacity:.75}.book-item{width:100%;height:340px;background:#fff;border-radius:8px;box-shadow:0 2px 6px #0000001a;padding:16px;position:relative;display:flex;flex-direction:column;box-sizing:border-box}.book-image{width:100%;height:200px;-o-object-fit:cover;object-fit:cover;margin-bottom:16px;display:block;border-radius:4px}.book-title{font-size:1.125rem;font-weight:500;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.book-author{font-size:.875rem;color:#4b5563;margin-bottom:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.book-status{display:flex;align-items:center;justify-content:space-between;font-size:.875rem;margin-top:auto}.book-status.available{color:#2f5d50}.book-status.unavailable{color:#5f665f}.book-button{padding:4px 12px;border-radius:4px;font-size:.875rem;background-color:#3d7a68;color:#fff;border:none;cursor:pointer}.book-button:hover{background-color:#2f5d50}:root{--book-card-min-h: 340px}.booklist-container{margin-top:2.5rem;margin-bottom:2.5rem;padding-left:1rem;padding-right:1rem;max-width:1280px;margin-left:auto;margin-right:auto}.loading-text{text-align:center;margin-top:200px;margin-bottom:200px}.book-grid{display:grid;gap:1.5rem;grid-template-columns:repeat(1,1fr);align-items:stretch;grid-auto-rows:1fr}@media (min-width: 640px){.book-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 768px){.book-grid{grid-template-columns:repeat(4,1fr)}}.card-cell{display:flex;min-height:var(--book-card-min-h)}.card-cell>*{flex:1 1 auto;width:100%}.pagination{display:flex;justify-content:center;margin-top:2rem;gap:.5rem}.page-btn{padding:.25rem .75rem;border-radius:.25rem;background-color:#e5e7eb;color:#374151;cursor:pointer;border:none}.page-btn.active{background-color:#3b82f6;color:#fff}.page-shell{min-height:100vh;background:var(--bg);color:var(--ink);font-family:var(--ff-sans)}.page-main{padding:56px 24px 40px;max-width:1120px;margin:0 auto}.page-title{font-size:36px;font-weight:800;color:var(--heading);letter-spacing:-.02em;line-height:1.2;margin:0 0 8px}@media (min-width: 960px){.page-title{font-size:40px}}.page-title:after{content:"";display:block;width:64px;height:2px;margin-top:12px;background:var(--accent);border-radius:999px}.page-sub{margin:6px 0 0;font-size:14px;color:var(--ink-muted)}.bs-hero{margin-bottom:18px}.bs-searchwrap{max-width:1100px;margin:0 auto 18px;padding:0 4px}.bs-list-section{margin-top:6px}.bs-list-card{border:1px solid var(--line);border-radius:16px;background:var(--surface);box-shadow:var(--shadow-2);overflow:hidden}.bs-list-body{padding:16px 18px}.bs-list-card table{width:100%;border-collapse:separate;border-spacing:0;color:var(--ink);table-layout:auto;word-break:keep-all;overflow-wrap:anywhere}.bs-list-card thead th{position:sticky;top:0;z-index:2;background:var(--bg-muted);color:var(--heading);font-weight:700;text-align:center;padding:12px 14px;border-bottom:1px solid var(--line);vertical-align:middle;box-shadow:0 1px #0000000a}.bs-list-card tbody td{text-align:center;padding:12px 14px;border-bottom:1px solid var(--line);vertical-align:middle}.bs-list-card tbody tr:last-child td{border-bottom:none}.bs-list-card tbody tr:nth-child(2n) td{background:#e6e3da59}.bs-list-card tbody tr:hover td{background:var(--bg-muted)}.click-row{cursor:pointer}.bs-grid{display:grid;gap:16px;padding:16px}@media (min-width: 640px){.bs-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 960px){.bs-grid{grid-template-columns:repeat(3,1fr)}}.bs-empty,.bs-loading{display:flex;justify-content:center;align-items:center;min-height:360px;text-align:center;font-size:15px;color:var(--ink-muted)}.truncate-1{display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.truncate-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media (prefers-reduced-motion: reduce){.bs-list-card,.bs-list-card thead th,.bs-list-card tbody tr:hover td{transition:none}}:root{--bg: #f9fafb;--surface: #ffffff;--ink: #1f2937;--ink-muted: #6b7280;--good: #059669;--bad: #dc2626;--line: #e5e7eb;--radius: 12px;--shadow: 0 6px 16px rgba(0, 0, 0, .06);--bd-type-scale: 1}.bd-page{min-height:100vh;background:var(--bg);display:flex;flex-direction:column;--bd-type-scale: 1.15}.bd-loading{display:flex;align-items:center;justify-content:center}.bd-loading-text{color:var(--ink-muted);font-size:calc(1.125rem * var(--bd-type-scale))}.bd-main{width:100%;max-width:72rem;margin:2.5rem auto 0;background:var(--surface);box-shadow:var(--shadow);border-radius:var(--radius);padding:2rem;display:flex;gap:2.5rem;margin-bottom:50px;align-items:flex-start}.bd-left{width:33.333%;min-width:240px}.bd-image{width:100%;height:auto;-o-object-fit:cover;object-fit:cover;border-radius:8px;box-shadow:0 1px 2px #00000014;border:1px solid var(--line);background:#fff}.bd-right{width:66.666%;display:flex;flex-direction:column;--bd-gap: 1.25rem;gap:var(--bd-gap);padding-block:var(--bd-gap);align-self:center}.bd-right.equal-edges{--bd-gap: 1.25rem;gap:var(--bd-gap);padding:0}.bd-right.equal-edges:before,.bd-right.equal-edges:after{content:"";display:block;height:var(--bd-gap)}.bd-field{display:flex;flex-direction:column;gap:.25rem;justify-content:center}.bd-field>p{margin:0}.bd-label{font-size:calc(.875rem * var(--bd-type-scale));color:var(--ink-muted);line-height:1.2}.bd-value{font-size:calc(1rem * var(--bd-type-scale));color:var(--ink)}.bd-value-lg{font-size:calc(1.125rem * var(--bd-type-scale));font-weight:600}.bd-status{font-size:calc(1rem * var(--bd-type-scale));font-weight:600}.bd-good{color:var(--good)}.bd-bad{color:var(--bad)}@media (max-width: 1024px){.bd-main{gap:1.5rem}}@media (max-width: 768px){.bd-main{flex-direction:column;padding:1.25rem;align-items:stretch}.bd-left,.bd-right{width:100%}.bd-right{align-self:auto}}.min-screen{min-height:100vh;display:flex;flex-direction:column}.page-body{flex:1}.stats-grid-1{display:grid;grid-template-columns:1fr;gap:24px;padding:24px 32px 0}@media (min-width: 640px){.stats-grid-1{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1024px){.stats-grid-1{grid-template-columns:repeat(4,1fr)}}.stats-card{display:flex;align-items:center;gap:14px;padding:20px;border:1px solid var(--line);border-radius:16px;background:radial-gradient(120% 140% at 0% 0%,rgba(0,0,0,.02),transparent 60%),var(--surface);box-shadow:var(--shadow-1);transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease,background-color .18s ease}.stats-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-2);border-color:#ddd8c9}.stats-icon{width:20px;height:20px;color:var(--surface);background:linear-gradient(135deg,var(--accent-2),var(--accent));border-radius:999px;padding:10px;box-shadow:0 4px 12px #00000014}.stats-label{font-size:13px;color:var(--ink-muted);letter-spacing:.01em}.stats-value{font-size:22px;font-weight:800;color:var(--heading)}.main-grid{display:grid;grid-template-columns:1fr;gap:24px;padding:16px 32px 40px}@media (min-width: 1280px){.main-grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr) 920px}}.panel-card{background:var(--surface);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-1);padding:22px 20px;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease,background-color .18s ease}.panel-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-2);border-color:#ddd8c9}.panel-title{color:var(--heading);font-weight:800;letter-spacing:.01em;font-size:20px;position:relative;margin-bottom:12px;padding-bottom:6px}.panel-title:after{content:"";position:absolute;left:0;bottom:-2px;width:44px;height:3px;border-radius:999px;background:linear-gradient(90deg,var(--accent-2),var(--accent));opacity:.9}.panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.panel-row{display:flex;align-items:center;justify-content:space-between;font-size:14px;margin-top:50px;padding-top:6px}.panel-row2{display:flex;align-items:center;justify-content:space-between;font-size:14px;margin-top:10px;padding-top:6px}.panel-accent{display:inline-flex;align-items:center;justify-content:center;min-width:30px;height:22px;padding:0 10px;border-radius:999px;background:linear-gradient(135deg,var(--accent-2),var(--accent));color:#fff;font-weight:700;letter-spacing:.01em;box-shadow:0 2px 8px #00000014}.btn-list-item{width:100%;display:flex;justify-content:space-between;align-items:center;padding:11px 14px;border:1px solid var(--line);border-radius:12px;font-size:14px;background:linear-gradient(0deg,#00000003,#00000003),var(--surface);cursor:pointer;transition:background .16s ease,box-shadow .18s ease,transform .08s ease,border-color .16s ease}.btn-list-item+.btn-list-item{margin-top:8px}.btn-list-item:hover{background:linear-gradient(0deg,#00000005,#00000005),var(--bg-muted);border-color:#e0ddd3;box-shadow:var(--shadow-1);transform:translateY(-1px)}.btn-list-item:active{transform:translateY(0);box-shadow:none}.btn-list-item:focus-visible{outline:2px solid var(--accent-2);outline-offset:2px}.refresh-btn{display:inline-flex;align-items:center;gap:6px;font-size:14px;color:var(--ink);background:var(--surface);border:1px solid var(--line);border-radius:10px;cursor:pointer;padding:6px 10px;box-shadow:var(--shadow-1);transition:transform .08s ease,box-shadow .16s ease,background-color .16s ease,color .12s ease}.refresh-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-2);color:var(--heading)}.refresh-btn:active{transform:translateY(0);box-shadow:var(--shadow-1)}.refresh-btn.is-loading svg{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.discard-list{overflow-y:auto;max-height:450px;padding-right:6px;display:flex;flex-direction:column;gap:12px}.discard-item{background:linear-gradient(0deg,#00000003,#00000003),var(--bg);border:1px solid var(--line);border-radius:8px;padding:10px 12px;transition:background-color .16s ease,border-color .16s ease,box-shadow .18s ease,transform .08s ease}.discard-item:hover{background-color:var(--bg-muted);border-color:#ddd7c8;box-shadow:var(--shadow-1);transform:translateY(-1px)}.discard-item__row{display:flex;align-items:center;gap:8px}.discard-item__icon{width:18px;height:18px;color:var(--accent-2);filter:drop-shadow(0 2px 6px rgba(0,0,0,.08))}.discard-item__title{font-size:15px;color:var(--heading);line-height:1.4;word-break:break-word}.input{width:100%;border:1px solid var(--line);border-radius:12px;background:var(--bg);color:var(--ink);padding:10px 12px;font-size:14px;outline:none;transition:border-color .14s ease,box-shadow .2s ease,background-color .14s ease}.input:hover{background:#fff}.input:focus{background:#fff;border-color:var(--accent-2);box-shadow:0 0 0 2px #3d7a681f,0 0 0 5px #3d7a681a}.muted-text{font-size:14px;color:var(--ink-muted)}.error-text,.danger-text{font-size:14px;color:#d94848;margin-top:200px}.link{color:inherit;text-decoration:underline;text-underline-offset:2px}.link:hover{color:var(--accent-2)}.panel-card:focus-within,.stats-card:focus-within,.btn-list-item:focus-visible,.refresh-btn:focus-visible,.input:focus-visible,.discard-item:focus-within{outline:2px solid var(--accent-2);outline-offset:2px}.icon-books{background:linear-gradient(135deg,#00428e,#357abd)}.icon-users{background:linear-gradient(135deg,#006522,#2f8f4e)}.icon-loans{background:linear-gradient(135deg,#b67000,#d48806)}.icon-overdue{background:linear-gradient(135deg,#920027,#c0392b)}.stats-card:hover .stats-icon{box-shadow:0 6px 16px #0000001f;transform:translateZ(0)}@media (prefers-reduced-motion: reduce){.stats-card,.panel-card,.btn-list-item,.refresh-btn,.discard-item{transition:none!important;transform:none!important;box-shadow:none!important}.refresh-btn.is-loading svg{animation:none!important}}.mm-header{display:grid;grid-template-columns:1fr auto;gap:12px 16px;margin-bottom:14px;align-items:center}@media (max-width: 800px){.mm-header{grid-template-columns:1fr}}.mm-search-group{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center}@media (max-width: 800px){.mm-search-group{grid-template-columns:1fr}}.mm-searchbox{display:flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:999px;background:#fff;padding:10px 14px;box-shadow:var(--shadow-1);transition:border-color .12s ease,box-shadow .12s ease,transform .12s ease}.mm-searchbox:focus-within{border-color:var(--accent);box-shadow:0 2px 12px #2f5d5026;transform:translateY(-1px)}.mm-searchbox-input{flex:1;font-size:14px;color:var(--ink);border:none;outline:none;background:transparent}.mm-filters{display:flex;gap:10px;align-items:center}.mm-select{border:1px solid var(--line);border-radius:var(--radius-sm);background:#fff;color:var(--ink);padding:10px 12px;font-size:14px;box-shadow:var(--shadow-1);transition:border-color .12s ease,box-shadow .12s ease;min-width:100px}.mm-select:focus,.mm-select:focus-visible{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #2f5d5026}.mm-card{border:1px solid var(--line);border-radius:16px;background:var(--surface);box-shadow:var(--shadow-2);overflow:hidden;text-align:center;justify-content:center}.mm-card table,.mm-card .member-table{width:100%;table-layout:fixed;border-collapse:separate;border-spacing:0;color:var(--ink)}.mm-card table th,.mm-card table td,.mm-card .member-table th,.mm-card .member-table td{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mm-card thead th{position:sticky;top:0;z-index:1;background:var(--bg-muted);color:var(--heading);font-weight:700;text-align:center;padding:12px 14px;border-bottom:1px solid var(--line)}.mm-card tbody td{text-align:center;padding:12px 14px;border-bottom:1px solid var(--line)}.mm-card tbody tr:nth-child(2n) td{background:#e6e3da59}.mm-card tbody tr:hover td{background:#8eb7aa}.mm-empty,.mm-loading{display:flex;align-items:center;justify-content:center;height:200px;text-align:center;color:var(--ink-muted);font-size:14px}.mm-footerbar{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:16px;flex-wrap:wrap}.mm-muted{color:var(--ink-muted);font-size:14px}.pagination{display:flex;gap:8px;justify-content:center}.pagination button{min-width:38px;height:36px;padding:0 10px;border:1px solid var(--line);border-radius:999px;background:var(--bg-muted);font-size:13px;font-weight:700;cursor:pointer;color:var(--ink);transition:background-color .14s ease,color .14s ease,border-color .14s ease,transform .12s ease,box-shadow .12s ease}.pagination button.active,.pagination button[aria-current=page]{background:var(--accent);color:#fff;border-color:var(--accent-2);box-shadow:0 4px 14px #2f5d5038}.pagination button:disabled{background:var(--bg-muted);color:var(--ink-muted);cursor:not-allowed;opacity:.8}@media (prefers-reduced-motion: reduce){.mm-searchbox,.btn,.pagination button{transition:none}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:34px;padding:0 12px;border-radius:10px;border:1px solid var(--line);background:var(--surface);color:var(--ink);font-size:14px;cursor:pointer;box-shadow:var(--shadow-1);transition:background-color .16s ease,border-color .16s ease,box-shadow .18s ease,transform .08s ease}.btn:hover{background:#68ad98;border-color:#68ad98;transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn-accent{background:linear-gradient(135deg,var(--accent-2),var(--accent));color:#fff;border-color:transparent}.btn-accent:hover{box-shadow:0 6px 16px #0000001f}.mm-card table thead th:nth-child(1),.mm-card table tbody td:nth-child(1),.mm-card .member-table thead th:nth-child(1),.mm-card .member-table tbody td:nth-child(1){width:80px!important}.mm-card table thead th:nth-child(2),.mm-card table tbody td:nth-child(2),.mm-card .member-table thead th:nth-child(2),.mm-card .member-table tbody td:nth-child(2){width:100px!important}.mm-card table thead th:nth-child(3),.mm-card table tbody td:nth-child(3),.mm-card .member-table thead th:nth-child(3),.mm-card .member-table tbody td:nth-child(3){width:260px!important}.mm-card table thead th:nth-child(4),.mm-card table tbody td:nth-child(4),.mm-card .member-table thead th:nth-child(4),.mm-card .member-table tbody td:nth-child(4){width:120px!important}.mm-card table thead th:nth-child(5),.mm-card table tbody td:nth-child(5),.mm-card .member-table thead th:nth-child(5),.mm-card .member-table tbody td:nth-child(5){width:100px!important}.mm-card table thead th:nth-child(6),.mm-card table tbody td:nth-child(6),.mm-card .member-table thead th:nth-child(6),.mm-card .member-table tbody td:nth-child(6){width:120px!important}.mm-card table thead th:nth-child(7),.mm-card table tbody td:nth-child(7),.mm-card .member-table thead th:nth-child(7),.mm-card .member-table tbody td:nth-child(7){width:80px!important}.book-card-1{width:200px;height:100%;display:flex;flex-direction:column;padding:14px 16px;border-radius:12px;border:1px solid var(--line);background:#fff;box-shadow:var(--shadow-1);cursor:pointer;transition:background .15s ease,filter .2s ease;text-align:left;overflow:hidden}.book-card-1.is-available{color:#1f2937;border-color:#63e6be}.book-card-1.is-available:hover{background:#e6fcf5}.book-card-1.is-unavailable{color:#6b7280;background:#f8f9fa;border-color:#ced4da}.book-card-1.is-unavailable:hover{background:#f1f3f5}.book-title{font-weight:600;font-size:1rem;line-height:1.4;margin:0 0 6px;word-break:break-word;white-space:normal}.book-author,.book-callno{font-size:.9rem;color:#555;margin:4px 0;line-height:1.35;word-break:break-word;white-space:normal}.book-status{margin-top:auto;padding-top:8px;text-align:right;font-weight:500;font-size:.9rem;line-height:1.35}.status-ok{color:#16a34a}.status-bad{color:#ef4444}.book-card-1:focus-visible{outline:2px solid var(--accent-2);outline-offset:2px}.chat-session-list{width:25%;background:linear-gradient(to bottom,#fff,#f8f9fa);border-radius:16px;padding:20px;box-shadow:0 4px 6px #0000001a;border:1px solid #e5e7eb}.chat-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.chat-header-title{font-family:Paperlogy-Bold,sans-serif;font-size:1.125rem;color:#fff}.new-session-btn{display:flex;align-items:center;gap:6px;border:1px solid #d1d5db;border-radius:8px;padding:4px 12px;font-size:.875rem;color:#374151;background:#fff;transition:all .2s}.new-session-btn:hover{background:#f1f3f5;border-color:#9ca3af}.new-session-icon{width:12px;height:12px}.new-session-text{font-family:Paperlogy-Regular,sans-serif}.session-list{display:flex;flex-direction:column;gap:4px}.session-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;border-radius:8px;cursor:pointer;transition:all .2s;color:#374151}.session-item:hover{background:#99d8c4}.session-item.selected{background:#48a689;color:#fff;font-weight:600;box-shadow:inset 0 2px 4px #0000000d}.session-title{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.session-input{border:1px solid #d1d5db;border-radius:6px;padding:4px 8px;font-size:.875rem;width:100%;outline:none}.session-input:focus{border-color:#9775fa;box-shadow:0 0 0 2px #9775fa66}.action-buttons{display:flex;gap:4px;opacity:0;transition:opacity .2s}.session-item:hover .action-buttons{opacity:1}.action-btn{padding:4px;border-radius:6px;background:transparent;cursor:pointer}.action-btn:hover{background:#e5e7eb}.icon-edit{font-size:18px;color:#374151}.icon-delete{font-size:18px;color:#ef4444}:root{--bg: #FAF9F5;--bg-muted: #F2F0E9;--surface: #FFFFFF;--ink: #1B1F1A;--ink-muted: #5F665F;--heading: #1C2B25;--accent: #2F5D50;--accent-2: #3D7A68;--line: #E6E3DA;--shadow-1: 0 1px 2px rgba(0, 0, 0, .07);--radius-sm: 10px;--radius: 12px;--ff-sans: ui-sans-serif, system-ui, "Noto Sans KR", -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, sans-serif;--ff-serif: ui-serif, Georgia, "Noto Serif KR", Cambria, "Times New Roman", serif;--bookcard-w: 200px}*{box-sizing:border-box}.self-end{align-self:flex-end}.margin-right-12{margin-right:12px}.margin-right-8{margin-right:8px}.chatbot-page{min-height:100vh;display:flex;flex-direction:column;background:var(--bg);color:var(--ink);font-family:var(--ff-sans)}.page-inner{flex:1;width:100%;max-width:1120px;margin:0 auto;padding:24px;display:flex;border-radius:var(--radius);overflow:hidden}.spacer-8{width:32px;flex:0 0 32px}.chat-main{flex:1;display:flex;flex-direction:column;height:80vh;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-1);background:var(--bg-muted)}.chat-panel{background:var(--bg-muted)}.chat-header{display:flex;align-items:center;gap:12px;padding:18px 20px;background:var(--accent);color:var(--surface);border-top-left-radius:var(--radius);border-top-right-radius:var(--radius);box-shadow:inset 0 1px 2px #00000014}.chat-title{margin:0 0 4px;font-size:18px;font-weight:700;color:var(--surface)}.chat-title-highlight{color:#eaf2ee}.chat-subtitle{margin:0;font-size:13px;opacity:.9;color:var(--surface)}.avatar{display:inline-block;-o-object-fit:cover;object-fit:cover}.avatar--lg{width:48px;height:48px;border-radius:999px}.avatar--sm{width:24px;height:24px;border-radius:999px}.messages{flex:1;overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column;gap:16px;scrollbar-gutter:stable;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.messages-bottom-spacer{flex-shrink:0}.message-row{display:flex;width:100%}.message-row--user{justify-content:flex-end}.message-row--ai{justify-content:flex-start}.message{display:flex;flex-direction:column;max-width:75%;border-radius:var(--radius-sm);overflow:hidden;align-items:flex-start}.message--user{align-items:flex-end}.message--ai{align-items:flex-start}.message-bubble{padding:12px 14px;border-radius:var(--radius-sm);font-size:14px;line-height:1.55;word-break:break-word;white-space:pre-wrap;box-shadow:var(--shadow-1);background:#fff}.ai-bubble{background:var(--surface);border:1px solid var(--line);color:var(--ink)}.user-bubble{background:#fff;border:1px solid var(--line);color:var(--heading)}.message-time{margin-top:6px;font-size:12px;color:var(--ink-muted)}.message-time--right{align-self:flex-end}.message-time--left{align-self:flex-start}.typing-row{display:flex;align-items:center;gap:8px}.typing-dots{display:flex;gap:6px;padding:10px 12px;border-radius:var(--radius-sm);box-shadow:var(--shadow-1);background:var(--surface);border:1px solid var(--line)}.dot{width:8px;height:8px;background:var(--ink-muted);border-radius:999px;animation:bounce .9s infinite ease-in-out}.typing-dots .dot:nth-child(2){animation-delay:.1s}.typing-dots .dot:nth-child(3){animation-delay:.2s}@keyframes bounce{0%,80%,to{transform:translateY(0);opacity:.7}40%{transform:translateY(-6px);opacity:1}}.card{height:1000;margin-top:16px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);padding:16px;box-shadow:var(--shadow-1)}.card-grid{display:grid;grid-template-columns:repeat(3,var(--bookcard-w));justify-content:center;gap:16px;align-items:stretch}.card-grid>.grid-item-stretch{display:flex;width:var(--bookcard-w)}.card-grid>.grid-item-stretch>*{display:flex;flex-direction:column;width:100%;height:100%}.row-right{display:flex;justify-content:flex-end;margin-top:16px}.search-result-title{font-weight:600;margin:0 0 12px;color:var(--heading)}.primary-btn{background:var(--accent-2);color:var(--surface);padding:8px 16px;border-radius:var(--radius-sm);border:0;box-shadow:var(--shadow-1);cursor:pointer;transition:filter .2s ease,transform .02s ease}.primary-btn:hover{filter:brightness(.95)}.primary-btn:active{transform:translateY(1px)}.help-chips{background:#fff;padding:12px 8px;display:flex;flex-wrap:wrap;gap:8px;color:var(--heading);border-top:1px solid var(--line)}.help-chip{padding:6px 12px;background:#faf9f5;color:var(--ink);border-radius:var(--radius-sm);border:1px solid var(--line);cursor:pointer;transition:background .15s ease,filter .2s ease;text-align:left;font-size:14px}.help-chip:hover{filter:brightness(.97)}.input-area{background:#fff;padding:12px 16px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:8px;border-bottom-left-radius:var(--radius);border-bottom-right-radius:var(--radius)}.input-row{position:relative;display:flex;align-items:center}.chat-input{width:100%;height:48px;padding:0 48px 0 16px;border:1px solid var(--line);border-radius:999px;background:var(--bg-muted);color:var(--ink);outline:none}.chat-input::-moz-placeholder{color:var(--ink-muted)}.chat-input::placeholder{color:var(--ink-muted)}.chat-input:focus{border-color:var(--accent-2);box-shadow:0 0 0 3px #3d7a6826}.chat-send-btn{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--accent-2);background:transparent;border:0;padding:4px;cursor:pointer;transition:color .2s ease,transform .02s ease;display:inline-flex;align-items:center;justify-content:center;font-size:18px}.chat-send-btn:hover{color:var(--accent)}.chat-send-btn:active{transform:translateY(-51%)}.messages::-webkit-scrollbar{width:6px}.messages::-webkit-scrollbar-thumb{background:var(--ink-muted);border-radius:3px}.messages::-webkit-scrollbar-track{background:transparent}:root{--bg: #FAF9F5;--bg-muted: #F2F0E9;--surface: #FFFFFF;--ink: #1B1F1A;--ink-muted: #5F665F;--heading: #1C2B25;--accent: #2F5D50;--accent-2: #3D7A68;--line: #E6E3DA;--shadow-1: 0 1px 2px rgba(0, 0, 0, .07);--radius-sm: 10px;--radius: 12px;--ff-sans: ui-sans-serif, system-ui, "Noto Sans KR", -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, sans-serif;--ff-serif: ui-serif, Georgia, "Noto Serif KR", Cambria, "Times New Roman", serif}.be-root{min-height:100vh;background:var(--bg);color:var(--ink);font-family:var(--ff-sans);display:flex;flex-direction:column}.be-main{padding:56px 24px 40px;flex:1}.be-card{max-width:960px;margin:0 auto;background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:24px;box-shadow:var(--shadow-1)}@media (min-width:768px){.be-card{padding:28px 32px}}.be-title{font-size:32px;line-height:1.25;font-weight:800;color:var(--heading);margin-bottom:6px;letter-spacing:-.01em}.be-intro{color:var(--ink-muted);padding-bottom:20px}.be-form{display:flex;flex-direction:column;gap:24px}.be-grid{display:grid;grid-template-columns:1fr;gap:16px}@media (min-width:768px){.be-grid{grid-template-columns:repeat(2,1fr)}}.be-col-span-2{grid-column:span 1}@media (min-width:768px){.be-col-span-2{grid-column:span 2}}.be-field label.paperlogy-regular{color:var(--ink);display:block;margin-bottom:6px;font-size:14px}.be-field input[type=text],.be-field textarea{width:100%;background:var(--surface);color:var(--ink);border:1px solid var(--line);border-radius:var(--radius-sm);padding:10px 12px;box-shadow:var(--shadow-1);transition:border-color .12s ease,box-shadow .12s ease,transform .12s ease}.be-field textarea{min-height:120px;resize:vertical}.be-field input[type=text]:focus,.be-field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #2f5d5026}.be-image-section h2{color:var(--heading);font-weight:700;margin-bottom:8px}.be-preview{width:128px;height:160px;-o-object-fit:cover;object-fit:cover;border-radius:10px;border:1px solid var(--line);box-shadow:var(--shadow-1);margin-bottom:12px}.be-file-actions{display:flex;align-items:center;gap:12px;flex-wrap:nowrap}.be-file-actions input[type=file]{display:inline-block;width:auto;padding:6px 0;cursor:pointer}.be-file-actions button[type=submit]{margin-left:auto;background:var(--accent);color:#fff;border:1px solid var(--accent-2);padding:10px 20px;font-size:15px;font-weight:700;border-radius:12px;cursor:pointer;transition:background-color .14s ease,transform .12s ease,box-shadow .12s ease}.be-file-actions button[type=submit]:hover{background:var(--accent-2);transform:translateY(-1px);box-shadow:var(--shadow-1)}.be-file-actions button[type=submit]:disabled,.be-file-actions button[type=submit][aria-busy=true]{opacity:.65;cursor:not-allowed;transform:none;box-shadow:none}@media (prefers-reduced-motion: reduce){.be-field input[type=text],.be-field textarea,.be-file-actions button[type=submit]{transition:none}}:root{--bg: #FAF9F5;--bg-muted: #F2F0E9;--surface: #FFFFFF;--ink: #1B1F1A;--ink-muted: #5F665F;--heading: #1C2B25;--accent: #2F5D50;--accent-2: #3D7A68;--line: #E6E3DA;--shadow-1: 0 1px 2px rgba(0, 0, 0, .07);--shadow-2: 0 6px 16px rgba(0, 0, 0, .08);--radius-sm: 10px;--radius: 12px;--ff-sans: ui-sans-serif, system-ui, "Noto Sans KR", -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, sans-serif}.bookmanage-root{min-height:100vh;display:flex;flex-direction:column;background:var(--bg);color:var(--ink);font-family:var(--ff-sans)}.bookmanage-layout{display:flex;flex:1;max-width:1200px;margin:0 auto;width:100%}.bm-sidebar{width:240px;background:var(--surface);border-right:1px solid var(--line);padding:16px;display:flex;flex-direction:column;gap:10px}.bm-nav-btn{text-align:left;padding:10px 12px;border-radius:var(--radius-sm);background:transparent;border:1px solid transparent;cursor:pointer;color:var(--ink);transition:background .2s ease,color .2s ease,border-color .2s ease}.bm-nav-btn:hover{background:var(--bg-muted);border-color:var(--line)}.bm-nav-btn.active{background:#2f5d501a;color:var(--accent);font-weight:700;border-color:#2f5d5026}.bm-main{flex:1;padding:24px;display:flex;flex-direction:column;gap:16px}.bm-search{width:100%}.bm-input{width:100%;height:40px;padding:0 12px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);outline:none;transition:border-color .15s ease,box-shadow .15s ease}.bm-input:focus{border-color:var(--accent-2);box-shadow:0 0 0 3px #3d7a6826}.bm-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-1);padding:16px;overflow-x:auto}.bm-table{width:100%;border-collapse:collapse;font-size:14px}.bm-table thead{background:var(--bg-muted);color:var(--ink-muted)}.bm-table th,.bm-table td{padding:10px 8px;border-top:1px solid var(--line)}.bm-table thead th{border-top:none;font-weight:700}.bm-row{cursor:pointer;transition:background .15s ease}.bm-row:hover{background:#00000009}.bm-ellipsis{max-width:240px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bm-badge{display:inline-block;padding:4px 8px;font-size:12px;border-radius:999px;border:1px solid transparent}.bm-badge.ok{background:#e8f5e9;color:#1b5e20;border-color:#c8e6c9}.bm-badge.bad{background:#ffebee;color:#c62828;border-color:#ffcdd2}.bm-actions{display:flex;gap:6px}.bm-icon-btn{border:1px solid var(--line);background:var(--surface);padding:6px;border-radius:8px;cursor:pointer;transition:transform .1s ease,box-shadow .2s ease,background .2s ease}.bm-icon-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-2)}.bm-icon-btn.danger:hover{background:#ffe9e9}.bm-empty{text-align:center;padding:28px 0;color:var(--ink-muted)}.bm-pagination{margin-top:14px;display:flex;justify-content:center;gap:6px}.page-btn{padding:6px 10px;border-radius:8px;border:1px solid var(--line);background:var(--surface);cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease}.page-btn:hover:not(:disabled){background:var(--bg-muted)}.page-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.page-btn:disabled{opacity:.5;cursor:not-allowed}.bm-detail-card{margin-top:16px;display:grid;grid-template-columns:128px 1fr;gap:20px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-1);padding:20px}.bm-cover{width:128px;height:192px;border-radius:8px;overflow:hidden;border:1px solid var(--line);background:var(--bg-muted)}.bm-cover img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.bm-detail-body{display:flex;flex-direction:column;gap:12px}.bm-detail-head{display:flex;justify-content:space-between;align-items:center;gap:12px}.bm-title{font-size:20px;font-weight:800;color:var(--heading)}.bm-head-actions{display:flex;gap:8px}.btn-outline{padding:6px 10px;border:1px solid var(--line);border-radius:8px;background:var(--surface);cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease,transform .1s ease}.btn-outline:hover{transform:translateY(-1px);box-shadow:var(--shadow-2)}.btn-outline.blue{color:#0b5394;border-color:#bfd7ea;background:#f4f9ff}.btn-outline.blue:hover{background:#e6f2ff}.btn-outline.red{color:#c62828;border-color:#ffcdd2;background:#fff5f5}.btn-outline.red:hover{background:#ffe9e9}.bm-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px 24px;font-size:14px}.bm-key{font-weight:700;color:var(--heading)}.bm-desc{margin-top:4px;font-size:14px;line-height:1.6;color:var(--ink)}@media (max-width: 960px){.bookmanage-layout{padding:0 12px}.bm-sidebar{width:200px}}@media (max-width: 720px){.bookmanage-layout{flex-direction:column}.bm-sidebar{width:100%;flex-direction:row;gap:8px;padding:12px;border-right:none;border-bottom:1px solid var(--line)}.bm-detail-card{grid-template-columns:1fr}.bm-cover{width:160px;height:220px}}.bm-table th,.bm-table td{text-align:center!important;vertical-align:middle}.bm-actions{justify-content:center}.bm-table td .bm-badge{display:inline-block;margin:0 auto}.book-add-page{min-height:100vh;display:flex;flex-direction:column;background:var(--bg);color:var(--ink);font-family:var(--ff-sans)}.book-add-main{flex:1;padding:24px clamp(16px,5vw,48px) 48px}.form-card{width:min(100%,64rem);margin:0 auto;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-1)}@media (min-width: 768px){.form-card{padding:40px}}.page-title{font-size:32px;margin-bottom:8px;color:var(--heading)}.page-subtitle{color:var(--ink-muted);margin-bottom:24px}.form-root{display:flex;flex-direction:column;gap:40px}.section-title{font-size:20px;font-weight:800;color:var(--heading);margin-bottom:16px}.form-grid{display:grid;grid-template-columns:1fr;gap:24px}@media (min-width: 768px){.form-grid{grid-template-columns:repeat(2,1fr)}}.field-label{display:block;margin-bottom:6px;font-size:.9rem;font-weight:600;color:var(--ink-muted)}.field-input,.field-textarea{width:100%;border:1px solid var(--line);border-radius:var(--radius);padding:10px 12px;outline:none;background:#fff;font-size:14px;color:var(--ink);box-shadow:var(--shadow-1);transition:border-color .15s ease,box-shadow .15s ease,background .15s ease}.field-input::-moz-placeholder,.field-textarea::-moz-placeholder{color:#9aa39a}.field-input::placeholder,.field-textarea::placeholder{color:#9aa39a}.field-input:focus-visible,.field-textarea:focus-visible{outline:3px solid rgba(47,93,80,.35);outline-offset:2px;border-color:var(--accent-2)}.field-textarea{min-height:8rem;resize:vertical}.image-upload{margin-top:16px}.image-upload .field-label{margin-bottom:8px}.image-upload input[type=file]{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);padding:8px 10px;font-size:13px;color:var(--ink);box-shadow:var(--shadow-1);transition:border-color .15s ease,box-shadow .15s ease,background .15s ease}.image-upload input[type=file]:focus-visible{outline:3px solid rgba(47,93,80,.35);outline-offset:2px;border-color:var(--accent-2)}.image-preview{margin-top:8px;width:128px;height:192px;-o-object-fit:cover;object-fit:cover;border-radius:8px;border:1px solid var(--line);background:var(--bg-muted);box-shadow:var(--shadow-1)}.actions{display:flex;justify-content:flex-end}.submit-btn{background:var(--accent);color:#fff;padding:10px 20px;border:1px solid var(--accent);border-radius:var(--radius);font-weight:700;cursor:pointer;box-shadow:var(--shadow-1);transition:transform .15s ease,background .15s ease,box-shadow .15s ease,border-color .15s ease}.submit-btn:hover:not(:disabled){background:var(--accent-2);border-color:var(--accent-2);transform:translateY(-1px);box-shadow:var(--shadow-2)}.submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}:root{--bg: #FAF9F5;--bg-muted: #F2F0E9;--surface: #FFFFFF;--ink: #1B1F1A;--ink-muted: #5F665F;--heading: #1C2B25;--accent: #2F5D50;--accent-2: #3D7A68;--line: #E6E3DA;--shadow-1: 0 1px 2px rgba(0, 0, 0, .07);--shadow-2: 0 6px 16px rgba(0, 0, 0, .06);--radius: 12px;--radius-lg: 16px;--ff-sans: ui-sans-serif, system-ui, "Noto Sans KR", -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, sans-serif}.min-screen{min-height:100vh;display:flex;flex-direction:column;background:var(--bg);color:var(--ink);font-family:var(--ff-sans)}.page-body{flex:1;width:100%;padding:24px clamp(16px,5vw,48px) 48px}.fixed-width{width:min(100%,768px);margin:0 auto}.scan-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-1);margin-bottom:24px}.video-wrap{position:relative;width:100%;height:540px;background:#0b0b0b;border-top-left-radius:var(--radius-lg);border-top-right-radius:var(--radius-lg);overflow:hidden}.video-el{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.overlay-msg{position:absolute;left:50%;bottom:12px;transform:translate(-50%);background:#ffffffd9;border-radius:999px;padding:8px 16px;font-size:.875rem;text-align:center;color:var(--ink);box-shadow:var(--shadow-1)}.fullscreen-btn{position:absolute;top:12px;right:12px;background:#0000008c;color:#fff;border:0;border-radius:10px;padding:6px 10px;font-size:.875rem;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.fullscreen-btn:active{transform:scale(.97)}.scan-actions{padding:16px;display:flex;justify-content:center}.pill-btn{display:inline-flex;align-items:center;gap:8px;border-radius:999px;padding:12px 20px;color:#fff;border:1px solid transparent;box-shadow:var(--shadow-1);transition:transform .15s ease,box-shadow .15s ease,background .15s ease,border-color .15s ease}.pill-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-2)}.pill-primary{background:#3b8971;border-color:#3b8971}.pill-primary:hover{background:#68ad98;border-color:#68ad98}.pill-danger{background:#dc2626;border-color:#dc2626}.pill-danger:hover{background:#b91c1c;border-color:#b91c1c}.pill-icon{width:20px;height:20px;filter:brightness(0) saturate(100%) invert(100%)}.result-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-1);padding:24px;max-height:24rem;overflow-y:auto}.result-head{display:flex;align-items:center;justify-content:space-between}.result-title{position:relative;font-size:1.5rem;font-weight:800;color:#1f2937;padding-left:12px;margin:8px 0 24px}.title-mark{position:absolute;left:0;top:50%;width:6px;height:24px;transform:translateY(-50%);background:#3d7a68;border-radius:999px}.btn{display:inline-flex;align-items:center;gap:8px;border-radius:10px;padding:8px 12px;font-size:.875rem;font-weight:700;border:1px solid var(--line);background:var(--surface);color:var(--ink);box-shadow:var(--shadow-1);cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,background .15s ease,border-color .15s ease}.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-2);background:var(--bg-muted);border-color:#ddd7c8}.btn .btn-icon{width:16px;height:16px}.btn.danger{background:#dc2626;border-color:#dc2626;color:#fff}.btn.danger:hover{background:#b91c1c;border-color:#b91c1c}.stats-wrap{border-bottom:1px solid var(--line);padding-bottom:16px;margin-bottom:16px}.stats-grid{display:grid;grid-template-columns:1fr;gap:16px}@media (min-width: 640px){.stats-grid{grid-template-columns:repeat(3,1fr)}}.stat-card{display:flex;align-items:center;gap:12px;border:1px solid var(--line);border-radius:12px;padding:16px;transition:box-shadow .15s ease}.stat-card:hover{box-shadow:var(--shadow-2)}.icon-box{padding:8px;border-radius:10px;display:grid;place-items:center}.icon{width:20px;height:20px}.bg-blue{background:#eff6ff;color:#2563eb}.bg-amber{background:#fffbeb;color:#b45309}.bg-emerald{background:#ecfdf5;color:#047857}.stat-text{min-width:0}.stat-sub{font-size:12px;color:#6b7280}.stat-val{font-size:1.125rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.progress-val{font-weight:700}.progress{margin-top:8px;width:100%;height:8px;background:#e5e7eb;border-radius:999px;overflow:hidden}.progress-bar{height:100%;background:#10b981;border-radius:999px}.tags-head{display:flex;align-items:center;gap:8px}.tags-title{position:relative;font-size:1.25rem;font-weight:800;color:#1f2937;padding-left:12px;margin:8px 0 24px}.tags-count{margin-left:auto;font-size:.875rem;color:#6b7280}.tags-wrap{background:#fafafa;border-radius:12px;padding:12px;text-align:center}.tags{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.tag{display:inline-block;background:#68ad98;color:#fff;padding:6px 12px;border-radius:999px;font-size:.875rem}.tags-empty{font-size:.875rem;color:#6b7280}:root{--bg: #FAF9F5;--bg-muted: #F2F0E9;--surface: #FFFFFF;--ink: #1B1F1A;--ink-muted: #5F665F;--heading: #1C2B25;--accent: #2F5D50;--line: #E6E3DA;--shadow-1: 0 1px 2px rgba(0, 0, 0, .07);--radius-sm: 10px}.rbp-page{min-height:100vh;background:var(--bg);color:var(--ink);display:flex;flex-direction:column}.rbp-main{width:min(1120px,92%);margin:0 auto;padding:40px 0 60px}.rbp-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:20px}.rbp-title{font-size:clamp(30px,3vw,40px);font-weight:800;color:var(--heading);margin:0 0 0 10px}.rbp-title:after{content:"";display:block;width:150px;height:2px;margin-top:12px;background:var(--accent);border-radius:999px}.rbp-reload-btn{border:none;background:#2f5d50;color:#fff;border-radius:10px;padding:8px 14px;font-size:14px;cursor:pointer;box-shadow:var(--shadow-1);transition:background-color .18s ease}.rbp-reload-btn:hover{background:#3d7a68}.rbp-status,.rbp-error{font-size:14px;color:var(--ink-muted);margin-bottom:16px}.rbp-error{color:#b3261e}.rbp-grid{display:grid;gap:24px;grid-template-columns:repeat(5,minmax(0,1fr))}@media (max-width: 1280px){.rbp-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}@media (max-width: 1024px){.rbp-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (max-width: 768px){.rbp-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 480px){.rbp-grid{grid-template-columns:repeat(1,minmax(0,1fr))}}.rbp-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);box-shadow:var(--shadow-1);padding:12px;min-height:330px;display:flex;flex-direction:column;align-items:center;gap:20px;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.rbp-card:hover{transform:translateY(-2px);box-shadow:0 8px 20px #00000014}.rbp-card-media{aspect-ratio:4 / 5;width:100%;overflow:hidden;border-radius:8px;background:#eeece5;display:grid;place-items:center}.rbp-card-media img{width:100%;height:100%;-o-object-fit:contain;object-fit:contain;display:block}.rbp-card-title{height:60px;display:grid;place-items:center;text-align:center;padding:0 8px;margin:0}.rbp-card-title-text{font-size:15px;line-height:1.4;color:var(--heading);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;word-break:keep-all;white-space:normal}@media (prefers-reduced-motion: reduce){.rbp-card{transition:none;transform:none;box-shadow:none}}.rbp-card--top1{border:3px solid transparent;-o-border-image:linear-gradient(90deg,#d4af37,#ffe08a) 1;border-image:linear-gradient(90deg,#d4af37,#ffe08a) 1;border-radius:var(--radius-sm)}.rbp-card--top2{border:3px solid transparent;-o-border-image:linear-gradient(90deg,#9ea7b8,#d7dbe6) 1;border-image:linear-gradient(90deg,#9ea7b8,#d7dbe6) 1;border-radius:var(--radius-sm)}.rbp-card--top3{border:3px solid transparent;-o-border-image:linear-gradient(90deg,#c08a5c,#e4c3a0) 1;border-image:linear-gradient(90deg,#c08a5c,#e4c3a0) 1;border-radius:var(--radius-sm)}
