@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial}}}@layer theme{:root,:host{--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--spacing:.25rem;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-noto-serif-jp), "Yu Mincho", "YuMincho", "Hiragino Mincho ProN", serif;--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}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;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.static{position:static}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.block{display:block}.flex{display:flex}.table{display:table}.h-full{height:100%}.min-h-full{min-height:100%}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.flex-wrap{flex-wrap:wrap}.border{border-style:var(--tw-border-style);border-width:1px}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}:root{--bg:#fff;--text:#0a0a0a;--gray-900:#1a1a1a;--gray-700:#404040;--gray-500:#737373;--gray-400:#a3a3a3;--gray-300:#d4d4d4;--gray-200:#e5e5e5;--gray-100:#f5f5f5;--gray-50:#fafafa;--header-h:56px;--tabs-h:44px;--footer-h:24px;--ease:cubic-bezier(.22, .61, .36, 1)}html,body{overscroll-behavior-y:none;height:100%}body{background:var(--bg);color:var(--text);font-family:var(--font-noto-serif-jp), "Yu Mincho", "YuMincho", "Hiragino Mincho ProN", serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-weight:400;line-height:1.75}:focus-visible{outline:2px solid var(--text);outline-offset:2px;border-radius:2px}button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,[role=button]:focus-visible,[role=tab]:focus-visible{outline:2px solid var(--text);outline-offset:2px}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}.app-wrapper{max-width:640px;margin:0 auto;position:relative}.app-header{max-width:640px;height:var(--header-h);background:var(--bg);border-bottom:1px solid var(--gray-200);z-index:10;justify-content:space-between;align-items:center;margin:0 auto;padding:0 24px;display:flex;position:fixed;top:0;left:0;right:0}.app-title{letter-spacing:.08em;color:var(--text);cursor:pointer;font-size:1.1rem;font-weight:500;text-decoration:none}.app-title:hover{color:var(--gray-700)}.header-right{align-items:center;gap:14px;display:flex}.header-icon-btn{width:28px;height:28px;color:var(--text);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:0;display:flex}.header-icon-btn:hover{color:var(--gray-700)}.page-indicator{color:var(--gray-500);letter-spacing:.15em;font-variant-numeric:tabular-nums;font-size:.72rem}.menu-btn{cursor:pointer;background:0 0;border:none;flex-direction:column;justify-content:space-between;width:28px;height:28px;padding:6px 4px;display:flex}.menu-btn span{background:var(--text);width:100%;height:1px;transition:all .3s var(--ease);display:block}.menu-overlay{background:var(--bg);z-index:20;opacity:0;pointer-events:none;max-width:640px;transition:opacity .35s var(--ease);flex-direction:column;justify-content:center;align-items:center;margin:0 auto;display:flex;position:fixed;inset:0}.menu-overlay.open{opacity:1;pointer-events:auto}.menu-close{color:var(--text);cursor:pointer;background:0 0;border:none;width:32px;height:32px;padding:0;font-family:inherit;font-size:1.6rem;font-weight:300;line-height:1;position:absolute;top:14px;right:22px}.menu-list{flex-direction:column;align-items:center;gap:22px;display:flex}.menu-divider{background:var(--gray-300);border:none;width:32px;height:1px;margin:2px 0}.menu-item{color:var(--gray-500);letter-spacing:.3em;transition:color .2s var(--ease);white-space:nowrap;cursor:pointer;background:0 0;border:none;padding:4px 20px;font-family:inherit;font-size:1.2rem;font-weight:400;text-decoration:none}.menu-item:hover{color:var(--text)}.menu-item.active{color:var(--text);font-weight:500}.menu-item:disabled{color:var(--gray-300);cursor:default}.menu-item:disabled:hover{color:var(--gray-300)}.genre-tabs{top:var(--header-h);max-width:640px;height:var(--tabs-h);background:var(--bg);border-bottom:1px solid var(--gray-200);-webkit-overflow-scrolling:touch;scrollbar-width:none;z-index:9;margin:0 auto;padding:0 18px;display:flex;position:fixed;left:0;right:0;overflow:auto hidden;-webkit-mask-image:linear-gradient(90deg,#0000 0,#000 20px calc(100% - 20px),#0000 100%);mask-image:linear-gradient(90deg,#0000 0,#000 20px calc(100% - 20px),#0000 100%)}.genre-tabs::-webkit-scrollbar{display:none}.genre-tab{height:100%;color:var(--gray-500);letter-spacing:.15em;cursor:pointer;white-space:nowrap;transition:color .2s var(--ease);background:0 0;border:none;flex:none;padding:0 18px;font-family:inherit;font-size:.82rem;position:relative}.genre-tab:hover{color:var(--gray-900)}.genre-tab.active{color:var(--text);font-weight:500}.genre-tab.active:after{content:"";background:var(--text);height:1px;position:absolute;bottom:-1px;left:12px;right:12px}.scroll-container{scroll-snap-type:y mandatory;height:100dvh;padding-top:calc(var(--header-h) + var(--tabs-h));padding-bottom:var(--footer-h);scroll-padding-top:calc(var(--header-h) + var(--tabs-h));scroll-padding-bottom:var(--footer-h);-webkit-overflow-scrolling:touch;overflow-y:scroll}.book-page{height:calc(100vh - var(--header-h) - var(--tabs-h) - var(--footer-h));height:calc(100dvh - var(--header-h) - var(--tabs-h) - var(--footer-h));scroll-snap-align:start;scroll-snap-stop:always;flex-direction:column;padding:12px 24px 20px;display:flex;position:relative;overflow:hidden}.header-note{color:var(--gray-500);letter-spacing:.1em;border:1px solid var(--gray-300);white-space:nowrap;border-radius:999px;padding:2px 8px;font-size:.6rem}.garden-empty-wrap{height:calc(100vh - var(--header-h) - var(--tabs-h) - var(--footer-h));height:calc(100dvh - var(--header-h) - var(--tabs-h) - var(--footer-h));justify-content:center;align-items:center;display:flex}.book-cover-hero{aspect-ratio:2/3;border:1px solid var(--gray-300);width:62vw;max-width:258px;box-shadow:3px 3px 0 var(--gray-100), 6px 6px 0 var(--gray-50);text-align:center;background:linear-gradient(135deg,#fafafa 0%,#ededed 100%);flex-direction:column;flex-shrink:0;justify-content:space-between;align-items:center;margin:0 auto 18px;padding:32px 20px 24px;display:flex;position:relative}.book-cover-hero .cover-frame{pointer-events:none;border:1px solid #00000021;position:absolute;inset:14px}.cover-var-1{background:linear-gradient(135deg,#fbf9f4 0%,#ebe5d7 100%)}.cover-var-2{background:linear-gradient(135deg,#f7f7f9 0%,#d8d6dc 100%)}.cover-var-3{background:linear-gradient(160deg,#f2efea 0%,#e0dad0 70%,#cbc4b8 100%)}.cover-var-4{background:linear-gradient(#fdfcf8 0%,#e4e0d3 100%)}.book-cover-hero.has-image{padding:0;overflow:hidden}.book-cover-hero.has-image .cover-frame{display:none}.book-cover-hero.has-image:after{content:"";opacity:0;height:55%;transition:opacity 1.2s var(--ease);pointer-events:none;z-index:1;background:linear-gradient(#fff0 0%,#ffffff40 55%,#ffffff8c 100%);position:absolute;bottom:0;left:0;right:0}.book-page.show-love .book-cover-hero.has-image:after{opacity:1}.cover-img{object-fit:cover;width:100%;height:100%;display:block}.cover-frame-inner{pointer-events:none;border:1px solid #00000012;position:absolute;inset:22px}.cover-rule{pointer-events:none;background:#0000001f;height:1px;position:absolute;top:50%;left:32%;right:32%}.cover-rule:before,.cover-rule:after{content:"";background:#00000014;height:1px;position:absolute;left:0;right:0}.cover-rule:before{top:-5px}.cover-rule:after{top:5px}.cover-meta{text-align:center;letter-spacing:.18em;color:var(--gray-600);pointer-events:none;font-size:.7rem;font-weight:400;position:absolute;top:32px;left:0;right:0}.book-info{text-align:center;flex-shrink:0;margin:0 -18px 12px}.book-title{letter-spacing:.02em;white-space:nowrap;text-overflow:ellipsis;max-width:100%;margin-bottom:1px;padding:0 6px;font-size:1.15rem;font-weight:500;line-height:1.45;overflow:hidden}.book-author-text{color:var(--gray-700);margin-bottom:0;font-size:.85rem}.love-comments{-webkit-backdrop-filter:blur(42px)saturate(1.6);opacity:0;max-height:30vh;transition:opacity 1.2s var(--ease), transform 1.2s var(--ease), max-height .55s cubic-bezier(.2, .8, .3, 1), padding .55s cubic-bezier(.2, .8, .3, 1);pointer-events:none;z-index:2;will-change:max-height, transform;background:#ffffff14;border-top:1px solid #ffffff4d;border-bottom:1px solid #ffffff26;flex-direction:column;padding:14px 0 18px;display:flex;position:absolute;bottom:88px;left:14px;right:14px;overflow:hidden;transform:translateY(16px);box-shadow:0 -8px 36px #0000000a}.love-comments.expanded{max-height:60vh;padding:20px 0 22px}.love-comments .comment-body,.love-comments .comment-handle{text-shadow:0 0 6px #ffffffe6,0 0 3px #fffc,0 0 1px #fff}.comments-scroll{scroll-snap-type:x mandatory;overscroll-behavior-x:contain;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-direction:row;display:flex;overflow:auto hidden}.comments-scroll::-webkit-scrollbar{display:none}.comments-scroll .love-comment{scroll-snap-align:center;box-sizing:border-box;border-bottom:none;flex:0 0 100%;padding:16px 22px 18px}.comments-dots{justify-content:center;gap:6px;padding:10px 0 2px;display:flex}.comments-dot{background:var(--gray-300);width:5px;height:5px;transition:background .2s var(--ease);border-radius:50%}.comments-dot.active{background:var(--text)}.book-page.show-love .love-comments{opacity:1;pointer-events:auto;transform:translateY(0)}.comments-label{color:var(--gray-500);letter-spacing:.3em;text-align:center;cursor:pointer;background:0 0;border:none;border-bottom:1px solid #0000000f;justify-content:center;align-items:center;gap:8px;width:100%;margin-bottom:0;padding:6px 22px 10px;font-family:inherit;font-size:.7rem;display:flex}.comments-label:hover{color:var(--gray-700)}.comments-toggle{color:var(--gray-400);font-size:.6rem}.love-comments .comments-scroll{transition:opacity .4s cubic-bezier(.2,.8,.3,1)}.love-comments.collapsed .comments-scroll{opacity:.7;cursor:pointer}.love-comments.expanded .comments-scroll{opacity:1}.love-comments.collapsed .love-comment{padding:8px 22px 6px}.love-comments.collapsed .love-comment .comment-header{margin-bottom:4px}.love-comments.collapsed .comment-body{-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.8rem;line-height:1.7;display:-webkit-box;overflow:hidden}.love-comment{border-bottom:1px solid var(--gray-100);padding:16px 0}.love-comment:last-child{border-bottom:none}.comment-header{justify-content:space-between;align-items:baseline;margin-bottom:8px;display:flex}.comment-handle{color:var(--gray-900);letter-spacing:.03em;font-size:.82rem;font-weight:500}.comment-date{color:var(--gray-500);letter-spacing:.05em;font-size:.66rem}.comment-body{color:var(--gray-900);font-size:.9rem;line-height:1.9}.more-comments{text-align:center;color:var(--gray-700);letter-spacing:.15em;cursor:pointer;background:0 0;border:none;border-top:1px solid #0000000d;width:100%;margin:8px 0 0;padding:12px 22px 4px;font-family:inherit;font-size:.78rem;text-decoration:none;display:block}.more-comments:hover{color:var(--text)}.action-row{flex-shrink:0;gap:10px;margin-top:auto;display:flex}.action-btn{background:var(--bg);border:1px solid var(--text);color:var(--text);cursor:pointer;transition:background .15s var(--ease), color .15s var(--ease), transform 80ms var(--ease);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;min-height:56px;padding:12px 8px;font-family:inherit;text-decoration:none;display:flex}.action-btn:active{transform:scale(.98)}.action-btn:hover{background:var(--gray-50)}.action-btn.primary{background:var(--text);color:var(--bg)}.action-btn.primary:hover{background:var(--gray-900)}.action-btn-main{letter-spacing:.14em;font-size:.95rem;font-weight:500;line-height:1.2}.action-btn-sub{letter-spacing:.1em;opacity:.65;font-size:.62rem;line-height:1.2}.action-btn-link{text-decoration:none}.book-page>.book-cover-hero{opacity:0;transition:opacity 1.1s var(--ease), transform 1.1s var(--ease);transform:translateY(32px)scale(.94)}.book-page.visible>.book-cover-hero{opacity:1;transition-delay:50ms;transform:translateY(0)scale(1)}.book-page>:not(.book-cover-hero):not(.love-comments){opacity:0;transition:opacity .8s var(--ease), transform .8s var(--ease);transform:translateY(20px)}.book-page.visible>:not(.book-cover-hero):not(.love-comments){opacity:1;transform:translateY(0)}.book-page.visible>.book-info{transition-delay:.28s}.book-page.visible>.action-row{transition-delay:.44s}@media (prefers-reduced-motion:reduce){.book-page>.book-cover-hero,.book-page>:not(.book-cover-hero){opacity:1;transition:none;transform:none}}.book-detail{background:var(--bg);z-index:30;-webkit-overflow-scrolling:touch;opacity:0;pointer-events:none;max-width:640px;transition:opacity .35s var(--ease);margin:0 auto;position:fixed;inset:0;overflow-y:auto}.book-detail.open{opacity:1;pointer-events:auto}.detail-close{background:var(--bg);color:var(--text);cursor:pointer;z-index:2;border:none;width:32px;height:32px;padding:0;font-family:inherit;font-size:1.6rem;font-weight:300;line-height:1;position:fixed;top:14px;right:22px}.detail-content{max-width:560px;margin:0 auto;padding:60px 26px}.detail-book-title{letter-spacing:.02em;margin-bottom:4px;font-size:1.35rem;font-weight:500;line-height:1.5}.detail-book-author{color:var(--gray-700);margin-bottom:32px;font-size:.9rem}.detail-comments-label{color:var(--gray-500);letter-spacing:.3em;text-align:center;border-top:1px solid var(--gray-200);border-bottom:1px solid var(--gray-200);margin-bottom:12px;padding:12px 0;font-size:.7rem}.detail-comments .love-comment{border-bottom:1px solid var(--gray-100);padding:20px 0}.detail-cover-wrap{justify-content:center;margin-bottom:24px;display:flex}.detail-cover{aspect-ratio:2/3;object-fit:cover;border:1px solid var(--gray-300);width:60vw;max-width:200px;box-shadow:4px 4px 0 var(--gray-100), 8px 8px 0 var(--gray-50);background:linear-gradient(135deg,#fafafa 0%,#ededed 100%)}.detail-cover-empty{text-align:center;color:var(--gray-700);letter-spacing:.05em;justify-content:center;align-items:center;padding:24px;font-size:1.1rem;font-weight:500;display:flex}.detail-genre{letter-spacing:.3em;color:var(--gray-500);text-align:center;margin-bottom:8px;font-size:.7rem}.detail-book-title{text-align:center;margin-bottom:4px}.detail-book-author{text-align:center;margin-bottom:28px}.detail-actions{gap:10px;margin-bottom:8px;display:flex}.detail-side-row{justify-content:center;align-items:center;gap:4px;padding:10px 0 24px;display:flex}.concept-modal{background:var(--bg);z-index:30;-webkit-overflow-scrolling:touch;opacity:0;pointer-events:none;max-width:640px;transition:opacity .4s var(--ease);margin:0 auto;position:fixed;inset:0;overflow-y:auto}.concept-modal.open{opacity:1;pointer-events:auto}.concept-close{background:var(--bg);color:var(--text);cursor:pointer;z-index:2;border:none;width:32px;height:32px;padding:0;font-family:inherit;font-size:1.6rem;font-weight:300;line-height:1;position:fixed;top:14px;right:22px}.concept-content{max-width:540px;margin:0 auto;padding:70px 28px 80px}.concept-title{letter-spacing:.15em;text-align:center;margin-bottom:24px;font-size:1.55rem;font-weight:500}.concept-lede{text-align:center;color:var(--gray-700);border-bottom:1px solid var(--gray-200);letter-spacing:.1em;margin-bottom:36px;padding:8px 0 28px;font-size:1rem;line-height:2.1}.concept-content h3{letter-spacing:.28em;text-align:center;color:var(--gray-900);margin:40px 0 18px;font-size:.95rem;font-weight:500}.concept-content p{color:var(--gray-900);margin-bottom:18px;font-size:.95rem;line-height:2.1}.concept-content ul{border-top:1px solid var(--gray-100);border-bottom:1px solid var(--gray-100);margin:16px 0 24px;padding:0;list-style:none}.concept-content li{text-align:center;letter-spacing:.1em;border-bottom:1px solid var(--gray-100);padding:10px 0;font-size:.95rem;line-height:2}.concept-content li:last-child{border-bottom:none}.concept-closing{text-align:center;letter-spacing:.15em;border-top:1px solid var(--gray-200);padding-top:28px;color:var(--gray-700)!important;margin-top:56px!important;font-size:.95rem!important}.concept-legal-links{color:var(--gray-500);letter-spacing:.1em;justify-content:center;gap:12px;margin-top:28px;font-size:.72rem;display:flex}.concept-legal-links a{color:var(--gray-500);border-bottom:1px solid var(--gray-200);padding-bottom:1px;text-decoration:none}.concept-legal-links a:hover{color:var(--text);border-bottom-color:var(--text)}.flow-page{flex-direction:column;max-width:640px;min-height:100dvh;margin:0 auto;padding:28px 28px 32px;display:flex}.flow-header{justify-content:space-between;align-items:center;min-height:32px;margin-bottom:40px;display:flex}.flow-back{color:var(--gray-700);cursor:pointer;background:0 0;border:none;padding:4px 8px;font-family:inherit;font-size:1.3rem;line-height:1}.flow-progress{color:var(--gray-500);letter-spacing:.2em;font-variant-numeric:tabular-nums;font-size:.7rem}.flow-body{flex-direction:column;flex:1;justify-content:center;display:flex}.flow-title{text-align:center;letter-spacing:.08em;margin-bottom:24px;font-size:1.5rem;font-weight:500;line-height:1.6}.flow-lede{color:var(--gray-700);text-align:center;letter-spacing:.08em;margin-bottom:36px;font-size:.95rem;line-height:2.1}.flow-field{margin-bottom:24px}.flow-label{color:var(--gray-500);letter-spacing:.25em;margin-bottom:10px;font-size:.72rem;display:block}.flow-input,.flow-textarea{background:var(--bg);border:none;border-bottom:1px solid var(--gray-300);width:100%;color:var(--text);letter-spacing:.03em;padding:10px 0;font-family:inherit;font-size:1rem;line-height:1.8}.flow-textarea{resize:vertical;min-height:96px;line-height:2}.flow-input:focus,.flow-textarea:focus{border-bottom-color:var(--text);outline:none}.scanner-overlay{z-index:40;background:#000;flex-direction:column;display:flex;position:fixed;inset:0}.scanner-close{color:#fff;cursor:pointer;z-index:2;background:#ffffff1a;border:1px solid #ffffff4d;border-radius:50%;width:40px;height:40px;padding:0;font-family:inherit;font-size:1.4rem;line-height:1;position:absolute;top:20px;right:24px}.scanner-body{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:24px;padding:24px;display:flex;position:relative}.scanner-video{aspect-ratio:4/3;object-fit:cover;background:#111;border:2px solid #ffffff26;width:100%;max-width:420px}.scanner-hint{color:#ffffffbf;letter-spacing:.1em;text-align:center;font-size:.85rem;line-height:1.8}.scanner-error{color:#ffb6b6;text-align:center;background:#ffffff14;max-width:320px;padding:12px 16px;font-size:.85rem;line-height:1.8}.scanner-manual{color:#fff;letter-spacing:.15em;cursor:pointer;background:0 0;border:1px solid #ffffff80;margin-top:18px;padding:12px 24px;font-family:inherit;font-size:.82rem;transition:background .2s,border-color .2s}.scanner-manual:hover{background:#ffffff1a;border-color:#fff}.book-search-notice{color:var(--gray-700);letter-spacing:.05em;background:var(--gray-100);border-left:2px solid var(--gray-500);margin-top:10px;padding:10px 14px;font-size:.8rem;line-height:1.7}.book-search-inline{align-items:center;display:flex;position:relative}.book-search-camera{cursor:pointer;color:var(--gray-500);background:0 0;border:none;padding:4px 6px;font-size:1.1rem;line-height:1;position:absolute;bottom:6px;right:0}.book-search-camera:hover{color:var(--text)}.book-search-inline .flow-input{padding-right:40px}.book-search{position:relative}.book-search-dropdown{background:var(--bg);border:1px solid var(--gray-200);-webkit-overflow-scrolling:touch;z-index:5;border-top:none;max-height:320px;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 8px 24px #0000000d}.book-search-empty{text-align:center;color:var(--gray-500);letter-spacing:.1em;padding:16px;font-size:.8rem}.book-search-item{border:none;border-bottom:1px solid var(--gray-100);text-align:left;cursor:pointer;width:100%;transition:background .12s var(--ease);background:0 0;align-items:flex-start;gap:12px;padding:12px 14px;font-family:inherit;display:flex}.book-search-item:hover{background:var(--gray-50)}.book-search-item:last-child{border-bottom:none}.book-search-cover{object-fit:cover;border:1px solid var(--gray-200);background:var(--gray-100);flex-shrink:0;width:38px;height:56px}.book-search-cover-empty{background:linear-gradient(135deg, var(--gray-100), var(--gray-200))}.book-search-meta{flex:1;min-width:0}.book-search-title{color:var(--text);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:4px;font-size:.9rem;line-height:1.5;display:-webkit-box;overflow:hidden}.book-search-author{color:var(--gray-500);letter-spacing:.03em;text-overflow:ellipsis;white-space:nowrap;font-size:.72rem;overflow:hidden}.flow-signals{flex-direction:column;gap:14px;padding:8px 0 0;display:flex}.flow-signal{cursor:pointer;letter-spacing:.05em;align-items:center;gap:12px;font-size:.95rem;display:flex}.flow-signal input[type=checkbox]{appearance:none;border:1px solid var(--gray-400);background:var(--bg);cursor:pointer;flex-shrink:0;width:18px;height:18px;position:relative}.flow-signal input[type=checkbox]:checked{background:var(--text);border-color:var(--text)}.flow-signal input[type=checkbox]:checked:after{content:"";border:solid var(--bg);border-width:0 1.5px 1.5px 0;width:5px;height:10px;position:absolute;top:1px;left:5px;transform:rotate(45deg)}.flow-handle-preview{text-align:center;color:var(--text);letter-spacing:.1em;border-top:1px solid var(--gray-200);border-bottom:1px solid var(--gray-200);margin:16px 0 24px;padding:24px 0;font-size:1.3rem}.flow-handle-preview-note{color:var(--gray-500);letter-spacing:.15em;margin-top:8px;font-size:.7rem;display:block}.flow-button-row{flex-direction:column;gap:12px;margin-top:32px;display:flex}.flow-btn{background:var(--text);width:100%;color:var(--bg);letter-spacing:.2em;cursor:pointer;transition:background .2s var(--ease);border:none;padding:16px;font-family:inherit;font-size:.95rem}.flow-btn:hover:not(:disabled){background:var(--gray-900)}.flow-btn:disabled{background:var(--gray-300);color:var(--gray-500);cursor:not-allowed}.flow-missing{text-align:center;color:var(--gray-500);letter-spacing:.12em;margin:0;font-size:.75rem;line-height:1.8}.flow-btn-ghost{background:var(--bg);color:var(--gray-700);border:1px solid var(--gray-300)}.flow-btn-ghost:hover:not(:disabled){background:var(--gray-50);color:var(--text)}.flow-link{text-align:center;color:var(--gray-500);cursor:pointer;letter-spacing:.1em;text-underline-offset:4px;background:0 0;border:none;padding:8px;font-family:inherit;font-size:.8rem;text-decoration:underline}.flow-link:hover{color:var(--text)}.my-loves-page{max-width:640px;min-height:100dvh;margin:0 auto;padding:24px 24px 80px}.my-loves-header{border-bottom:1px solid var(--gray-200);justify-content:space-between;align-items:center;margin-bottom:24px;padding:8px 0 24px;display:flex}.my-loves-title{letter-spacing:.18em;color:var(--text);margin:0;font-size:1.05rem;font-weight:500}.my-loves-add{color:var(--gray-500);padding:4px 8px;font-size:1.5rem;font-weight:300;line-height:1;text-decoration:none}.my-loves-add:hover{color:var(--text)}.my-loves-meta{text-align:right;color:var(--gray-500);letter-spacing:.2em;margin:0 0 16px;font-size:.7rem}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:18px;min-height:50vh;padding:72px 32px 96px;display:flex}.empty-state-rule{background:var(--gray-300);width:48px;height:1px;margin:0 auto 4px}.empty-state-head{color:var(--gray-900);letter-spacing:.08em;margin:0;font-size:1rem;font-weight:500;line-height:2}.empty-state-sub{color:var(--gray-500);letter-spacing:.08em;max-width:280px;margin:0;font-size:.82rem;line-height:2}.empty-state-cta{color:var(--text);letter-spacing:.2em;border:1px solid var(--gray-400);cursor:pointer;transition:background .2s var(--ease), color .2s var(--ease);background:#fff;margin-top:12px;padding:12px 28px;font-family:inherit;font-size:.82rem;text-decoration:none;display:inline-block}.empty-state-cta:hover{background:var(--text);color:#fff}.my-loves-loading{text-align:center;color:var(--gray-400);letter-spacing:.1em;padding:48px 24px;font-size:.82rem}.my-loves-list{margin:0;padding:0;list-style:none}.my-love-item{border-bottom:1px solid var(--gray-100);padding:22px 0 24px}.my-love-head{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:4px;display:flex}.my-love-title{letter-spacing:.02em;flex:1;margin:0;font-size:1.05rem;font-weight:500;line-height:1.5}.my-love-delete{color:var(--gray-300);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:0 4px;font-family:inherit;font-size:1.2rem;font-weight:300;line-height:1}.my-love-delete:hover{color:var(--gray-700)}.my-love-author{color:var(--gray-700);margin:0 0 12px;font-size:.82rem}.my-love-signals{flex-wrap:wrap;gap:6px;margin-bottom:12px;display:flex}.my-love-signal{border:1px solid var(--gray-300);color:var(--gray-700);letter-spacing:.08em;white-space:nowrap;padding:3px 9px;font-size:.66rem}.my-love-reason{color:var(--gray-900);margin:0 0 10px;font-size:.88rem;line-height:1.95}.my-love-date{color:var(--gray-500);letter-spacing:.1em;text-align:right;margin:0;font-size:.66rem}.notifications-meta{color:var(--gray-500);letter-spacing:.1em;text-align:center;border-bottom:1px solid var(--gray-100);margin:0 0 12px;padding:0 0 18px;font-size:.74rem}.notifications-list{margin:0;padding:0;list-style:none}.notification-item{border-bottom:1px solid var(--gray-100);gap:14px;padding:16px 0;display:flex}.notification-cover{object-fit:cover;border:1px solid var(--gray-200);background:var(--gray-100);flex-shrink:0;width:44px;height:66px}.notification-cover-empty{background:linear-gradient(135deg, var(--gray-100), var(--gray-200))}.notification-meta{flex:1;min-width:0}.notification-line{justify-content:space-between;align-items:baseline;gap:12px;margin:0 0 2px;display:flex}.notification-handle{color:var(--gray-900);letter-spacing:.02em;font-size:.78rem;font-weight:500}.notification-when{color:var(--gray-500);letter-spacing:.05em;white-space:nowrap;flex-shrink:0;font-size:.66rem}.notification-action{color:var(--gray-700);margin:0 0 6px;font-size:.82rem;line-height:1.7}.notification-book{color:var(--text);font-weight:500}.notification-snippet{color:var(--gray-700);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:.78rem;line-height:1.8;display:-webkit-box;overflow:hidden}.settings-section{border-bottom:1px solid var(--gray-100);padding:28px 0 32px}.settings-section-title{letter-spacing:.25em;color:var(--gray-700);margin:0 0 12px;font-size:.78rem;font-weight:500}.settings-section-note{color:var(--gray-500);margin:0 0 16px;font-size:.78rem;line-height:1.9}.settings-button-row{gap:12px;margin-top:16px;display:flex}.settings-btn{background:var(--text);color:var(--bg);letter-spacing:.15em;cursor:pointer;transition:background .15s var(--ease);border:none;flex:1;padding:12px 20px;font-family:inherit;font-size:.85rem}.settings-btn:hover:not(:disabled){background:var(--gray-900)}.settings-btn:disabled{background:var(--gray-300);cursor:not-allowed}.settings-btn-block{width:100%}.settings-btn-ghost{background:var(--bg);color:var(--gray-700);border:1px solid var(--gray-300);letter-spacing:.15em;cursor:pointer;flex:1;padding:12px 20px;font-family:inherit;font-size:.85rem}.settings-btn-ghost:hover{background:var(--gray-50);color:var(--text)}.settings-danger{border-bottom:none}.settings-btn-danger{background:var(--bg);width:100%;color:var(--gray-700);border:1px solid var(--gray-400);letter-spacing:.15em;cursor:pointer;transition:all .15s var(--ease);padding:12px 20px;font-family:inherit;font-size:.85rem}.settings-btn-danger:hover{background:var(--gray-50);color:var(--text);border-color:var(--text)}.settings-links{margin:0;padding:0;list-style:none}.settings-links li{border-bottom:1px solid var(--gray-100);padding:12px 0}.settings-links li:last-child{border-bottom:none}.settings-links a{color:var(--gray-700);letter-spacing:.05em;font-size:.88rem;text-decoration:none;display:block}.settings-links a:hover{color:var(--text)}.legal-page{max-width:640px;margin:0 auto;padding:40px 28px 80px}.legal-back{color:var(--gray-500);letter-spacing:.1em;margin-bottom:32px;font-size:.8rem;text-decoration:none;display:inline-block}.legal-back:hover{color:var(--text)}.legal-title{letter-spacing:.12em;text-align:center;margin-bottom:12px;font-size:1.5rem;font-weight:500}.legal-meta{color:var(--gray-500);text-align:center;letter-spacing:.15em;border-bottom:1px solid var(--gray-200);margin-bottom:32px;padding-bottom:32px;font-size:.72rem}.legal-page h2{letter-spacing:.15em;border-left:2px solid var(--gray-300);margin:40px 0 14px;padding-left:8px;font-size:1rem;font-weight:500}.legal-page p{color:var(--gray-900);margin-bottom:16px;font-size:.92rem;line-height:2}.legal-page ul{margin:12px 0 20px;padding:0;list-style:none}.legal-page li{color:var(--gray-900);padding:4px 0 4px 20px;font-size:.9rem;line-height:1.9;position:relative}.legal-page li:before{content:"—";color:var(--gray-400);position:absolute;left:0}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}
