@import "https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@500;600;700&family=Manrope:wght@400;500;600;700;800&family=Noto+Serif+JP:wght@400;500;600;700&display=swap";
:root{--bg-deep:#1a120d;--bg-mid:#2c1c13;--bg-warm:#4b3327;--wood-light:#ad7e5924;--wood-dark:#3d27193d;--paper:#f5ecde;--paper-strong:#fffaf3f0;--paper-soft:#f5ecded1;--ink:#2c1e16;--ink-soft:#6d594d;--text-primary:#f5ecde;--text-secondary:#f5ecdeb8;--text-muted:#f5ecde8c;--border-subtle:#f5ecde1f;--accent-warm:#c79c56;--line:#68472d29;--line-strong:#76513347;--gold:#c79c56;--gold-soft:#c79c562e;--gold-strong:#9a6a2a;--green:#6f8573;--green-soft:#6f85732e;--rose:#8d5b5b;--rose-soft:#8d5b5b2e;--shadow-xl:0 34px 90px #120b0747;--shadow-lg:0 16px 40px #180f0a29;--shadow-md:0 10px 24px #20140c1f;--shadow-sm:0 6px 16px #20140c14;--radius-xl:32px;--radius-lg:24px;--radius-md:18px;--radius-sm:14px;--font-display:"Cormorant Garamond", "Noto Serif JP", "Yu Mincho", serif;--font-body:"Manrope", "Hiragino Sans", "Yu Gothic UI", sans-serif;--font-serif:"Noto Serif JP", "Cormorant Garamond", "Yu Mincho", serif}*,:before,:after{box-sizing:border-box}html{scroll-behavior:smooth;min-height:100%}body{min-height:100vh;color:var(--ink);font-family:var(--font-body);-webkit-font-smoothing:antialiased;background:radial-gradient(circle at 0 0,#fcddb01a,#0000 24%),radial-gradient(circle at 100% 0,#fff5e614,#0000 16%),linear-gradient(#2b1c13b8,#17100be6),linear-gradient(125deg,#72503b 0%,#4b3327 30%,#322117 62%,#1a120d 100%);margin:0;overflow-x:hidden}body:before,body:after{content:"";pointer-events:none;position:fixed;inset:0}body:before{opacity:.8;mix-blend-mode:soft-light;background:repeating-linear-gradient(90deg,#8b62421f 0 10px,#4f332326 10px 22px,#b5876014 22px 34px,#3d271929 34px 46px),repeating-linear-gradient(0deg,#fff1da04 0 2px,#482d1c0d 2px 6px,#1b120c05 6px 10px)}body:after{background:radial-gradient(circle at 50% 0,#ffe8c814,#0000 38%),radial-gradient(circle at 50% 100%,#110a0733,#0000 34%)}a{color:inherit}button,input,textarea{font:inherit}img{max-width:100%;display:block}.page-shell{z-index:1;min-height:100vh;padding:32px 24px 44px;position:relative}.page-frame{width:min(1080px,100%);margin:0 auto}.topbar{justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:clamp(28px,5vw,44px);display:flex}.brand-block{max-width:680px}.topbar-actions{flex-wrap:wrap;justify-content:flex-end;align-items:flex-start;gap:12px;display:flex}.eyebrow{color:#fff0dcd1;letter-spacing:.14em;text-transform:uppercase;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#2117114d;border:1px solid #fff4e224;border-radius:999px;align-items:center;min-height:34px;padding:0 14px;font-size:.74rem;font-weight:700;display:inline-flex}.page-title{color:#fff4e8;font-family:var(--font-display);letter-spacing:.02em;text-wrap:balance;text-shadow:0 6px 18px #140c082e;margin:10px 0;font-size:clamp(3.2rem,7vw,5.2rem);font-weight:600;line-height:.94}.page-title-main{display:inline}.page-title-gacha{color:#0000;background:linear-gradient(120deg,#ff4b4b 0%,#ff9f43 14%,#ffe66d 28%,#4cd964 42%,#36cfff 58%,#6c63ff 76%,#ff66d8 92%,#ff4b4b 100%) 0 0/240% 240%;text-shadow:0 0 12px #ff5da47a,0 0 22px #49d0ff6b,0 0 34px #ffe26352,0 10px 22px #140c0847;filter:saturate(1.18)brightness(1.05);-webkit-background-clip:text;background-clip:text;animation:3.8s linear infinite gacha-rainbow-shift;display:inline-block;position:relative}.page-title-gacha:before,.page-title-gacha:after{content:attr(data-text);pointer-events:none;opacity:.72;mix-blend-mode:screen;position:absolute;inset:0}.page-title-gacha:before{color:#48e3ffc7;animation:2.4s steps(2,end) infinite gacha-glitch-cyan;transform:translate(-.038em,.022em)}.page-title-gacha:after{color:#ff4ebcd1;animation:2.9s steps(2,end) infinite gacha-glitch-pink;transform:translate(.04em,-.024em)}@keyframes gacha-rainbow-shift{0%{background-position:0%}to{background-position:200%}}@keyframes gacha-glitch-cyan{0%,to{opacity:.72;transform:translate(-.038em,.022em)}18%{opacity:.92;transform:translate(-.052em,.012em)}19%{transform:translate(-.016em,-.018em)}56%{opacity:.84;transform:translate(-.046em,.03em)}57%{transform:translate(-.014em,-.012em)}}@keyframes gacha-glitch-pink{0%,to{opacity:.72;transform:translate(.04em,-.024em)}24%{opacity:.9;transform:translate(.056em,-.036em)}25%{transform:translate(.018em,.014em)}68%{opacity:.82;transform:translate(.05em,-.014em)}69%{transform:translate(.014em,.024em)}}.page-lead{color:#fff1dfd6;max-width:620px;margin:0;font-size:1rem;line-height:1.8}.auth-link-button,.auth-logout-link{border-radius:999px;justify-content:center;align-items:center;min-height:42px;padding:0 16px;font-size:.82rem;font-weight:800;text-decoration:none;display:inline-flex}.auth-link-button{color:#fff5e7;background:#1e150f57;border:1px solid #ffeccd2e;box-shadow:0 10px 24px #140c0829}.auth-link-button:hover,.auth-link-button:focus-visible{background:#291c1480;outline:none}.auth-user-block{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;display:flex}.auth-user-chip{background:linear-gradient(#121212fa 0%,#050505fa 100%);border:1px solid #ffffff1f;border-radius:999px;align-items:center;gap:10px;min-height:42px;padding:6px 12px 6px 8px;display:inline-flex;box-shadow:inset 0 1px #ffffff14,0 14px 28px #0000003d}.auth-user-avatar,.auth-user-avatar-fallback{border-radius:999px;flex:none;width:30px;height:30px}.auth-user-avatar{object-fit:cover}.auth-user-avatar-fallback{color:#fff;background:#ffffff1f;place-items:center;font-size:.84rem;font-weight:800;display:grid}.auth-user-copy{gap:2px;display:grid}.auth-user-label{color:#ffffffbd;letter-spacing:.08em;text-transform:uppercase;font-size:.68rem;font-weight:700}.auth-user-name{color:#fff;font-size:.82rem;font-weight:800}.auth-history-button{color:#433126;cursor:pointer;background:#fffcf7f5;border:1px solid #fff1df1f;border-radius:14px;justify-content:center;align-items:center;gap:8px;min-height:42px;padding:0 16px;font-size:.82rem;font-weight:800;transition:transform .16s,box-shadow .16s,border-color .16s,background-color .16s;display:inline-flex;box-shadow:inset 0 1px #fffc,0 10px 24px #140c0829}.auth-history-button:hover,.auth-history-button:focus-visible{background:#fffffffa;border-color:#c79c564d;outline:none;transform:translateY(-1px);box-shadow:inset 0 1px #ffffffdb,0 14px 28px #140c0833}.auth-history-icon{flex:none;width:16px;height:16px}.history-modal-backdrop{z-index:1100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:radial-gradient(circle at top,#fcddb01f,#0000 28%),#140c08b8;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.history-modal-frame{width:min(960px,100%);max-height:min(88vh,980px);box-shadow:var(--shadow-xl);background:linear-gradient(#fffcf7fa,#f4ebddf5);border:1px solid #7a573924;border-radius:32px;padding:28px;overflow:auto}.history-modal-head{justify-content:space-between;align-items:center;gap:16px;display:flex}.history-modal-back,.history-modal-close{cursor:pointer;border:0}.history-modal-back{color:#453225c7;background:0 0;align-items:center;gap:8px;padding:0;font-size:.92rem;font-weight:700;transition:color .16s,transform .16s;display:inline-flex}.history-modal-back:hover,.history-modal-back:focus-visible{color:var(--ink);outline:none;transform:translate(-1px)}.history-modal-close{color:#453225b3;width:38px;height:38px;box-shadow:var(--shadow-sm);background:#fff9f0e6;border-radius:999px;justify-content:center;align-items:center;display:inline-flex}.history-modal-close:hover,.history-modal-close:focus-visible{color:var(--ink);outline:none;transform:translateY(-1px)}.history-modal-title{color:var(--ink);font-family:var(--font-display);margin:18px 0 0;font-size:clamp(2.2rem,5vw,3.3rem);font-weight:700;line-height:.95}.history-modal-state{color:var(--ink-soft);background:#fffbf4d6;border:1px solid #7a57391a;border-radius:20px;margin-top:22px;padding:18px 20px;font-size:.94rem;line-height:1.7}.history-card-list{gap:18px;margin-top:22px;display:grid}.history-card{box-shadow:var(--shadow-md);background:#ffffffc7;border:1px solid #7a57391f;border-radius:28px;gap:18px;padding:24px;transition:transform .18s,box-shadow .18s,border-color .18s;display:grid}.history-card:hover{box-shadow:var(--shadow-lg);border-color:#9a6a2a33;transform:translateY(-2px)scale(1.01)}.history-card-head{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.history-card-status{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.history-status-badge{letter-spacing:.04em;border-radius:999px;align-items:center;min-height:30px;padding:0 12px;font-size:.76rem;font-weight:800;display:inline-flex}.history-status-badge.is-matched{color:#4f6b54;background:#6f857324}.history-status-badge.is-waiting{color:#8a5b20;background:#c79c5629}.history-status-time{color:#6d594db8;font-size:.82rem;font-weight:700}.history-delete-button{color:#6d594d7a;cursor:default;background:0 0;border:0;padding:0;font-size:1rem}.history-delete-button:disabled{opacity:1}.history-section{gap:10px;display:grid}.history-section-head{align-items:center;gap:10px;display:flex}.history-section-icon{color:#fff;border-radius:999px;flex:none;justify-content:center;align-items:center;width:28px;height:28px;display:inline-flex}.history-section-icon.history-received{background:linear-gradient(135deg,#6bb88c,#3f8d69)}.history-section-icon.history-submitted{background:linear-gradient(135deg,#6d76d8,#6b42b8)}.history-section-icon-svg{width:14px;height:14px}.history-section-title{color:var(--ink);margin:0;font-size:.92rem;font-weight:800}.history-section-panel{border:1px solid #0000;border-radius:22px;gap:14px;padding:16px;display:grid}.history-section-panel.history-received{background:#6f857314;border-color:#6f857324}.history-section-panel.history-submitted{background:#6d76d814;border-color:#6d76d824}.history-book-list{gap:10px;display:grid}.history-book-item{background:#ffffffbd;border:1px solid #7a573914;border-radius:18px;grid-template-columns:52px minmax(0,1fr);align-items:start;gap:12px;padding:12px;text-decoration:none;transition:transform .16s,border-color .16s,background-color .16s;display:grid}.history-book-item:hover,.history-book-item:focus-visible{background:#ffffffe6;border-color:#9a6a2a29;outline:none;transform:translateY(-1px)}.history-book-thumb,.history-book-thumb-fallback{border-radius:12px;width:52px;height:72px}.history-book-thumb{object-fit:cover;box-shadow:0 10px 18px #20140c1f}.history-book-thumb-fallback{color:#fff9eff5;letter-spacing:.08em;background:linear-gradient(145deg,#d8b681,#8b6036 70%,#5d3b20);place-items:center;font-size:.6rem;font-weight:800;display:grid}.history-book-copy{gap:3px;min-width:0;display:grid}.history-book-title{color:var(--ink);margin:0;font-size:.9rem;font-weight:800;line-height:1.45}.history-book-author{color:var(--ink-soft);margin:0;font-size:.78rem;line-height:1.4}.history-book-url{color:#4f6b54;word-break:break-all;font-size:.76rem;line-height:1.55;text-decoration:underline}.history-submitted .history-book-url{color:#5848a4}.history-book-comment,.history-message{color:#47362be0;margin:0;font-size:.8rem;line-height:1.55}.history-card-footer{justify-content:center;display:flex}.history-detail-link{color:#6d594dad;font-size:.8rem;font-weight:700;text-decoration:none;transition:color .16s}.history-detail-link:hover,.history-detail-link:focus-visible{color:var(--ink);outline:none}.auth-logout-link{color:#fff4e2eb;cursor:pointer;appearance:none;background:#1e150f3d;border:1px solid #ffeccd1f}.auth-primary-link{white-space:nowrap;color:#fff;background:linear-gradient(#121212fa 0%,#050505fa 100%);justify-content:center;align-items:center;gap:0;text-decoration:none;display:inline-flex;box-shadow:inset 0 1px #ffffff1a,0 20px 36px #00000047}.auth-primary-link-label{align-items:center;display:inline-flex}.login-required-panel{max-width:760px;margin-inline:auto}.language-switcher{box-shadow:var(--shadow-sm);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#1c120d6b;border:1px solid #fff2e11f;border-radius:999px;flex-wrap:wrap;justify-content:flex-end;gap:6px;padding:7px;display:flex}.lang-chip{color:#fff1dfbd;cursor:pointer;background:0 0;border:0;border-radius:999px;padding:10px 14px;font-size:.78rem;font-weight:700;transition:transform .16s,background-color .16s,color .16s,box-shadow .16s}.lang-chip:hover,.lang-chip:focus-visible{color:#fff8f0f5;background:#fff5e714;outline:none;transform:translateY(-1px)}.lang-chip.is-active{color:#2d1c12;background:linear-gradient(135deg,#f6d7a8fa,#c99b5afa);box-shadow:inset 0 1px #ffffff70}.home-form-stage,.result-layout{gap:18px;display:grid}.home-form-stage{justify-items:center}.home-form-stage>.paper-panel{width:min(860px,100%)}.paper-panel{isolation:isolate;border-radius:var(--radius-xl);background:linear-gradient(180deg, #fff8eaf7, #f4e8cef2), var(--paper);border:1px solid #9a6a2a3d;padding:clamp(28px,3vw,40px);position:relative;overflow:hidden;box-shadow:0 0 0 1px #ffeac452,0 24px 56px #20140c33,0 10px 24px #c79c5614}.paper-panel:before{content:"";z-index:0;pointer-events:none;background:linear-gradient(135deg,#ffffffc7,#0000 34%),radial-gradient(circle at 100% 0,#e2bb6e33,#0000 26%),radial-gradient(circle at 0 0,#fff3d63d,#0000 20%),repeating-linear-gradient(0deg,#7d583b05 0 2px,#ffffff06 2px 5px);position:absolute;inset:0}.paper-panel:after{content:"";z-index:0;pointer-events:none;background:linear-gradient(90deg,#0000,#c79c56f0,#0000);border-radius:999px;height:3px;position:absolute;top:0;left:18px;right:18px;box-shadow:0 6px 18px #c79c562e}.paper-panel>*{z-index:1;position:relative}.empty-panel{max-width:640px}.panel-title{z-index:1;color:var(--ink);font-family:var(--font-display);letter-spacing:.02em;margin:0;font-size:clamp(2rem,4vw,2.8rem);font-weight:600;line-height:.96;position:relative}.panel-text{z-index:1;color:var(--ink-soft);margin:12px 0 0;font-size:.98rem;line-height:1.75;position:relative}.form-grid{z-index:1;gap:22px;margin-top:28px;display:grid;position:relative}.field-block{gap:10px;display:grid}.field-head{justify-content:space-between;align-items:center;gap:14px;display:flex}.field-head-actions{flex-wrap:wrap;align-items:center;gap:8px;display:inline-flex}.field-label{color:var(--gold-strong);letter-spacing:.16em;text-transform:uppercase;font-size:.78rem;font-weight:800}.field-link-icon,.field-help-trigger{border:1px solid var(--line);width:30px;height:30px;color:var(--ink-soft);box-shadow:var(--shadow-sm);background:#fffbf5d6;border-radius:999px;justify-content:center;align-items:center;transition:transform .16s,color .16s,border-color .16s,background-color .16s;display:inline-flex}.field-link-icon{text-decoration:none}.field-link-icon:hover,.field-link-icon:focus-visible,.field-help-trigger:hover,.field-help-trigger:focus-visible{color:var(--gold-strong);background:#fff8eefa;border-color:#9b6b3057;outline:none;transform:translateY(-1px)}.field-link-icon-mark{font-size:.8rem;line-height:1}.field-help-trigger{cursor:pointer;font-size:.8rem;font-weight:800}.helper-text{color:#665246b8;font-size:.76rem;font-weight:700}.book-stack{gap:12px;display:grid}.book-stack-actions{justify-content:flex-end;margin-top:4px;display:flex}.book-clear-button{min-height:38px;padding:0 14px;font-size:.78rem}.book-field{grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:12px;animation:.46s both rise-in;display:grid}.book-field-error{color:#b14646;word-break:break-all;grid-column:2/-1;margin-top:-4px;font-size:.82rem;font-weight:700;line-height:1.5}.book-candidate-panel{background:#fffbf2cc;border:1px solid #a081472e;border-radius:16px;grid-column:2/-1;gap:10px;margin-top:-2px;padding:12px 14px;display:grid}.book-candidate-panel-title{color:#7b5c2d;font-size:.82rem;font-weight:700;line-height:1.5}.book-candidate-list{gap:10px;display:grid}.book-candidate-card{text-align:left;cursor:pointer;background:#ffffffd1;border:1px solid #a0814729;border-radius:14px;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:12px;width:100%;padding:10px 12px;transition:transform .16s,border-color .16s,box-shadow .16s,background-color .16s;display:grid}.book-candidate-card:hover,.book-candidate-card:focus-visible{background:#fffffff0;border-color:#a081474d;outline:none;transform:translateY(-1px);box-shadow:0 10px 20px #140c0814}.book-candidate-card.is-selected{background:linear-gradient(#fff4d6f2,#f7eac6f2);border-color:#a0814757}.book-candidate-media{align-items:center;display:flex}.book-candidate-image{object-fit:cover;border-radius:10px;width:52px;height:72px;box-shadow:0 10px 18px #20140c1f}.book-candidate-image-placeholder{color:#563a1eb8;letter-spacing:.1em;background:linear-gradient(#f8edd5eb,#eadcbdeb);place-items:center;font-size:.62rem;font-weight:800;display:grid}.book-candidate-copy{gap:3px;min-width:0;display:grid}.book-candidate-title{color:var(--ink);font-size:.93rem;line-height:1.45}.book-candidate-author,.book-candidate-source{color:var(--ink-soft);font-size:.77rem;line-height:1.4}.book-field:nth-child(2){animation-delay:60ms}.book-field:nth-child(3){animation-delay:.12s}@keyframes rise-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.book-index{color:#fff8ef;letter-spacing:.12em;text-transform:uppercase;min-width:48px;height:42px;box-shadow:inset 0 1px 0 #ffffff47, var(--shadow-sm);border:1px solid #ffffff2e;border-radius:14px;justify-content:center;align-items:center;padding:0 10px;font-size:.72rem;font-weight:800;display:inline-flex;position:relative;overflow:hidden}.book-index:after{content:"";pointer-events:none;background:linear-gradient(135deg,#ffffff57,#0000 34% 70%);position:absolute;inset:0}.book-index-ur{background:linear-gradient(135deg,#ffde9c,#d79336 58%,#9e5d1d)}.book-index-sr{background:linear-gradient(135deg,#d0c4ff,#7f7ae0 58%,#4d3f8d)}.book-index-r{background:linear-gradient(135deg,#bfe2d4,#6f9c86 56%,#496b5a)}.book-index-plain{color:#fff9f0;border:1px solid #ffffff2e;min-width:44px;padding:0;box-shadow:inset 0 1px #ffffff3d,0 8px 18px #20140c1f}.book-index-plain-1{background:linear-gradient(135deg,#d6aa67,#9f6b2b)}.book-index-plain-2{background:linear-gradient(135deg,#8d9ed1,#5f739f)}.book-index-plain-3{background:linear-gradient(135deg,#8bb39b,#5c856a)}.text-input{border:1px solid var(--line);border-radius:var(--radius-sm);width:100%;color:var(--ink);background:#fffcf7d6;padding:15px 18px;font-size:.96rem;transition:border-color .16s,box-shadow .16s,transform .16s,background-color .16s;box-shadow:inset 0 1px #fffc}.text-input::placeholder{color:#7965588f}.text-input:hover,.text-input:focus{background:#fffdf9fa;border-color:#9a6a2a70;outline:none;transform:translateY(-1px);box-shadow:0 0 0 4px #c79c561f,inset 0 1px #ffffffe6}.book-comment-trigger{color:#fffdf8;cursor:pointer;background:linear-gradient(#34251bfa,#1c130dfa);border:1px solid #7a573929;border-radius:999px;width:50px;height:50px;padding:0;transition:transform .16s,background-color .16s,border-color .16s,box-shadow .16s;position:relative}.book-comment-trigger:hover,.book-comment-trigger:focus-visible{background:linear-gradient(#251a13fa,#140d0afa);border-color:#7a573942;outline:none;transform:translateY(-1px);box-shadow:0 12px 22px #140c0824}.book-comment-trigger.has-comment{background:linear-gradient(#171717fa,#080808fa);border-color:#ffe2a357;box-shadow:inset 0 1px #ffffff14,0 12px 22px #140c0829}.book-comment-trigger.has-comment:after{content:"";background:#f0c46d;border-radius:999px;width:8px;height:8px;position:absolute;top:8px;right:8px;box-shadow:0 0 0 2px #140e0ae0}.book-comment-trigger-icon{justify-content:center;align-items:center;width:100%;height:100%;display:inline-flex}.book-comment-trigger-svg{width:22px;height:22px}.x-section{border-radius:var(--radius-md);background:linear-gradient(#fff9f0b8,#faf4ea9e);border:1px solid #7a57391f;padding:18px}.x-section.auth-account-panel{background:#ebebebf2!important;border:1px solid #0000001f!important}.x-section-title{color:var(--ink);font-size:1.82rem;font-weight:800;line-height:1;text-decoration:none}.x-section-link{transition:color .16s,transform .16s}.x-section-link:hover,.x-section-link:focus-visible{color:var(--gold-strong);outline:none;transform:translateY(-1px)}.x-section-grid{grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:16px;display:grid}.connected-account-card{color:#fff;background:#000;border:1px solid #ffffff1a;border-radius:18px;justify-content:space-between;align-items:center;gap:16px;padding:16px 18px;display:flex}.connected-account-main{align-items:center;gap:16px;min-width:0;display:flex}.connected-account-avatar,.connected-account-avatar-fallback{border-radius:999px;flex:none;width:58px;height:58px}.connected-account-avatar{object-fit:cover;border:1px solid #fff3}.connected-account-avatar-fallback{color:#fff4e4;background:linear-gradient(145deg,#8c6540,#5d3b20);place-items:center;font-size:1rem;font-weight:800;display:grid}.connected-account-copy{gap:4px;display:grid}.connected-account-label{color:#fff9;letter-spacing:.08em;text-transform:uppercase;font-size:.74rem;font-weight:700}.connected-account-handle{color:#fff;font-size:1rem}.connected-account-name{color:#ffffffb3;font-size:.86rem}.connected-account-logout-form{flex:none}.connected-account-logout-button{white-space:nowrap;min-height:40px;padding:0 16px}.x-icon-field{justify-items:end}.x-icon-field .field-head{justify-content:flex-end}.username-input-wrap{position:relative}.username-prefix{color:#6d594dc7;pointer-events:none;font-weight:800;position:absolute;top:50%;left:16px;transform:translateY(-50%)}.username-input{padding-left:36px}.x-icon-upload-field{border:1px solid var(--line);width:104px;height:104px;box-shadow:var(--shadow-md);cursor:pointer;background:linear-gradient(#ffffff24,#ffffff05),linear-gradient(#43352b,#2d221b);border-radius:28px;justify-content:center;align-items:center;transition:transform .16s,border-color .16s,box-shadow .16s;display:inline-flex;position:relative;overflow:hidden}.x-icon-upload-field:hover,.x-icon-upload-field:focus-within{box-shadow:0 0 0 4px #c79c561f, var(--shadow-md);border-color:#9a6a2a57;transform:translateY(-1px)}.file-input{opacity:0;cursor:pointer;position:absolute;inset:0}.x-icon-preview,.x-icon-placeholder{width:100%;height:100%}.x-icon-preview{object-fit:cover}.x-icon-placeholder{background:radial-gradient(circle,#ffffff14,#0000 58%),linear-gradient(#ffffff05,#fff0);justify-content:center;align-items:center;display:flex}.x-icon-symbol{background:linear-gradient(#424953,#252d36);border-radius:999px;justify-content:center;align-items:center;width:48px;height:48px;display:inline-flex;position:relative;box-shadow:inset 0 1px #ffffff14,0 12px 24px #00000047}.x-icon-symbol-camera{border:1.8px solid #f6f8faf5;border-radius:4px;justify-content:center;align-items:center;width:18px;height:13px;display:inline-flex;position:absolute}.x-icon-symbol-camera:before{content:"";border:1.8px solid #f6f8faf5;border-bottom:0;border-radius:3px 3px 0 0;width:7px;height:4px;position:absolute;top:-4px;left:2px}.x-icon-symbol-lens{border:1.8px solid #f6f8faf5;border-radius:999px;width:6px;height:6px}.x-icon-symbol-spark{background:#f6f8faf5;border-radius:1px;position:absolute;transform:rotate(45deg)}.x-icon-symbol-spark:before,.x-icon-symbol-spark:after{content:"";background:#f6f8faf5;border-radius:1px;position:absolute;inset:0}.x-icon-symbol-spark:before{transform:rotate(90deg)}.x-icon-symbol-spark-large{width:6px;height:6px;top:11px;right:11px}.x-icon-symbol-spark-small{width:3px;height:3px;top:17px;right:7px}.message-footer{justify-content:flex-end;display:flex}.field-inline-actions{justify-content:flex-end;margin-top:2px;display:flex}.inline-clear-button{min-height:38px;padding:0 14px;font-size:.78rem}.counter{color:#665246c2;letter-spacing:.08em;font-size:.76rem;font-weight:800}.error-banner{border-radius:var(--radius-sm);color:#7e4a4a;background:#8d5b5b14;border:1px solid #8d5b5b29;padding:14px 16px;font-size:.92rem;line-height:1.6}.exchange-anonymous-row{text-align:center;justify-content:center;align-items:center;padding-top:6px;display:flex}.exchange-anonymous-label{color:var(--ink);cursor:pointer;justify-content:center;align-items:center;gap:12px;font-size:1.1rem;font-weight:700;display:inline-flex}.exchange-anonymous-checkbox{accent-color:#a26b2e;cursor:pointer;width:22px;height:22px}.submit-row{justify-content:center;padding-top:16px;display:flex}.primary-button,.secondary-button{cursor:pointer;border:0;transition:transform .16s,box-shadow .16s,background-color .16s,border-color .16s,color .16s,opacity .16s}.primary-button{color:#fff9f0;letter-spacing:.22em;text-transform:uppercase;background:linear-gradient(135deg,#d6aa67,#9f6b2b);border-radius:999px;min-width:260px;min-height:56px;padding:0 28px;font-size:.9rem;font-weight:800;box-shadow:inset 0 1px #fff6,0 20px 40px #66421e3d}.primary-button:hover,.primary-button:focus-visible{outline:none;transform:translateY(-2px);box-shadow:inset 0 1px #ffffff70,0 26px 46px #66421e47}.primary-button:disabled{opacity:.68;cursor:wait;transform:none}.primary-button.auth-primary-link{color:#fff;background:linear-gradient(#121212fa 0%,#050505fa 100%);box-shadow:inset 0 1px #ffffff1a,0 20px 36px #00000047}.primary-button.auth-primary-link:hover,.primary-button.auth-primary-link:focus-visible{background:linear-gradient(#1c1c1cfa 0%,#0a0a0afa 100%);box-shadow:inset 0 1px #ffffff24,0 26px 46px #00000057}.secondary-button,.share-link,.book-share-button{border:1px solid var(--line);min-height:44px;color:var(--ink);box-shadow:var(--shadow-sm);background:#fffaf3e0;border-radius:999px;justify-content:center;align-items:center;padding:0 16px;font-size:.86rem;font-weight:700;text-decoration:none;display:inline-flex}.secondary-button:hover,.secondary-button:focus-visible,.share-link:hover,.share-link:focus-visible,.book-share-button:hover,.book-share-button:focus-visible{background:#fffdf9fa;border-color:#9a6a2a4d;outline:none;transform:translateY(-1px)}.share-link-x{color:#fff;background:linear-gradient(#121212fa 0%,#050505fa 100%);border-color:#ffffff1f;box-shadow:inset 0 1px #ffffff1a,0 20px 36px #0000003d}.share-link-x:hover,.share-link-x:focus-visible{background:linear-gradient(#1c1c1cfa 0%,#0a0a0afa 100%);border-color:#ffffff24;box-shadow:inset 0 1px #ffffff24,0 24px 40px #0000004d}.share-actions{flex-wrap:wrap;align-items:center;gap:10px;display:inline-flex}.share-link-icon{width:44px;min-width:44px;padding:0}.share-link-icon-svg{width:20px;height:20px}.usage-modal-backdrop{z-index:1000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#140c0880;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.usage-modal{width:min(760px,100%);max-height:min(84vh,860px);box-shadow:var(--shadow-xl);background:linear-gradient(#fffcf7fa,#f4ebddf5);border:1px solid #7a573929;border-radius:28px;padding:24px;overflow:auto}.comment-modal{width:min(560px,100%)}.usage-modal-head{justify-content:space-between;align-items:center;gap:16px;margin-bottom:14px;display:flex}.usage-modal-title{color:var(--ink);font-family:var(--font-display);margin:0;font-size:clamp(1.7rem,3vw,2.1rem);font-weight:600}.usage-modal-close{border:1px solid var(--line);width:38px;height:38px;color:var(--ink-soft);cursor:pointer;box-shadow:var(--shadow-sm);background:#fff9f0e6;border-radius:999px;justify-content:center;align-items:center;display:inline-flex}.usage-modal-close:hover,.usage-modal-close:focus-visible{color:var(--ink);outline:none;transform:translateY(-1px)}.usage-modal-lead{color:var(--ink-soft);margin:0 0 18px;font-size:.95rem;line-height:1.75}.comment-modal-label{margin-bottom:8px}.comment-textarea{resize:vertical;min-height:140px}.comment-modal-actions{justify-content:flex-end;gap:12px}.comment-save-button{min-width:132px}.usage-steps{gap:14px;display:grid}.usage-step-card{background:#fff9f0bd;border:1px solid #7a57391a;border-radius:20px;grid-template-columns:minmax(220px,250px) minmax(0,1fr);align-items:center;gap:16px;padding:16px;display:grid}.usage-step-copy{gap:8px;display:grid}.usage-step-title{color:var(--ink);letter-spacing:.02em;margin:0;font-size:1rem;font-weight:800}.usage-step-body{color:var(--ink-soft);margin:0;font-size:.92rem;line-height:1.7}.usage-visual{min-height:150px;box-shadow:var(--shadow-md);background:linear-gradient(#30231a,#1f1711);border:1px solid #7a57391f;border-radius:18px;overflow:hidden}.usage-visual-step-1{min-height:unset;aspect-ratio:388/190}.usage-visual-step-2{min-height:150px}.usage-visual-step-3{min-height:unset;aspect-ratio:1207/349}.usage-step-image{object-fit:cover;object-position:top center;width:100%;height:100%}.status-box{border-radius:var(--radius-md);background:#fffaf2bd;border:1px solid #7a57391a;margin-top:18px;padding:18px 20px}.status-copy{gap:6px;display:grid}.status-line{color:var(--ink);letter-spacing:.04em;align-items:center;gap:10px;font-size:.96rem;font-weight:800;display:inline-flex}.status-dot{border-radius:999px;width:10px;height:10px}.status-dot.is-waiting{background:var(--gold);animation:1.8s infinite pulse;box-shadow:0 0 #c79c565c}.status-dot.is-ready{background:var(--green);box-shadow:0 0 14px #6f85734d}@keyframes pulse{0%{box-shadow:0 0 #c79c5652}70%{box-shadow:0 0 0 14px #c79c5600}to{box-shadow:0 0 #c79c5600}}.share-row{flex-wrap:wrap;gap:10px;margin:18px 0 22px;display:flex}.result-grid{grid-template-columns:repeat(2,minmax(0,1fr));align-items:stretch;gap:18px;display:grid}.result-layout{gap:18px;display:grid}.shelf-card{border-radius:var(--radius-lg);height:100%;box-shadow:var(--shadow-lg);background:linear-gradient(#fffcf7cc,#f8efe1c2);border:1px solid #7a57391f;flex-direction:column;gap:16px;padding:22px;display:flex}.shelf-card-head{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.shelf-card-profile{align-items:center;gap:12px;min-width:0;display:flex}.shelf-card-profile-link{text-decoration:none;transition:transform .16s}.shelf-card-profile-link:hover,.shelf-card-profile-link:focus-visible{outline:none;transform:translateY(-1px)}.shelf-card-profile-link:hover .profile-handle,.shelf-card-profile-link:focus-visible .profile-handle,.shelf-card-profile-link:hover .shelf-card-title,.shelf-card-profile-link:focus-visible .shelf-card-title{color:var(--gold-strong)}.profile-icon,.profile-fallback{border-radius:999px;flex:none;width:48px;height:48px}.profile-icon{object-fit:cover;box-shadow:var(--shadow-sm);border:1px solid #7a57392e}.profile-fallback{color:#fffaf2;background:linear-gradient(135deg,#b08a51,#805427);place-items:center;font-size:.95rem;font-weight:800;display:grid}.shelf-card-profile-copy{gap:4px;min-width:0;display:grid}.shelf-card-title{color:var(--ink);font-family:var(--font-display);letter-spacing:.01em;white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:1.45rem;font-weight:600;line-height:1;overflow:hidden}.profile-handle{color:var(--ink-soft);font-size:.82rem;font-weight:700}.profile-handle-placeholder{visibility:hidden}.shelf-card-badge{color:var(--gold-strong);letter-spacing:.12em;text-transform:uppercase;background:#c79c561f;border:1px solid #c79c5629;border-radius:999px;align-self:flex-start;padding:8px 12px;font-size:.7rem;font-weight:800}.book-links{gap:18px;display:grid}.book-link{gap:8px;display:grid}.book-link-main{color:inherit;text-decoration:none;display:block}.book-link-media{border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);background:#fffcf7db;border:1px solid #7a57391a;grid-template-columns:auto 58px minmax(0,1fr);align-items:center;gap:14px;padding:14px;transition:transform .16s,border-color .16s,box-shadow .16s,background-color .16s;display:grid}.book-link-main:hover .book-link-media,.book-link-main:focus-visible .book-link-media{box-shadow:var(--shadow-md);background:#fffdf9fa;border-color:#9a6a2a3d;outline:none;transform:translateY(-1px)}.book-rarity{letter-spacing:.1em;border-radius:12px;min-width:44px;height:36px;font-size:.66rem}.book-thumbnail,.book-thumbnail-placeholder{border-radius:10px;width:58px;height:82px}.book-thumbnail{object-fit:cover;box-shadow:0 10px 20px #180f0a29}.book-thumbnail-placeholder{color:#fff9eff0;background:linear-gradient(145deg,#d8b681,#8b6036 70%,#5d3b20);place-items:center;font-size:1.35rem;display:grid;box-shadow:0 10px 20px #180f0a24}.book-link-copy{min-width:0}.book-link-top{flex-direction:column;display:flex}.book-link-title{color:var(--ink);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.95rem;font-weight:800;line-height:1.55;display:-webkit-box;overflow:hidden}.book-link-author{color:var(--ink-soft);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:.8rem;font-weight:600;line-height:1.4;display:block;overflow:hidden}.book-link-comment{color:#47362be6;-webkit-line-clamp:3;-webkit-box-orient:vertical;margin-top:8px;font-size:.78rem;line-height:1.5;display:-webkit-box;overflow:hidden}.book-link-actions{justify-content:flex-end;display:flex}.book-share-button{min-height:38px;padding:0 14px;font-size:.78rem}.detail-list{flex-wrap:wrap;gap:8px;display:flex}.tag-badge{color:#536657;background:#6f85731f;border:1px solid #6f857329;border-radius:999px;justify-content:center;align-items:center;min-height:32px;padding:0 12px;font-size:.75rem;font-weight:700;display:inline-flex}.shelf-card-message{color:var(--ink-soft);font-family:var(--font-serif);border-top:1px solid #7a57391f;margin:0;padding-top:14px;font-size:.9rem;line-height:1.85}.shelf-card-footer-action{justify-content:flex-end;margin-top:auto;padding-top:4px;display:flex}.back-link{color:#fff4e2eb;align-items:center;gap:8px;width:fit-content;font-size:.88rem;font-weight:700;text-decoration:none;display:inline-flex}.back-link:hover,.back-link:focus-visible{color:#fff9f0;outline:none}.back-link-block{border-top:1px solid #7a573914;justify-content:center;margin-top:clamp(24px,5vw,40px);padding-top:24px;display:flex}.back-link-paper{width:fit-content;color:var(--ink-soft);align-items:center;gap:8px;font-size:.9rem;font-weight:700;text-decoration:none;transition:color .16s;display:inline-flex}.back-link-paper:hover,.back-link-paper:focus-visible{color:var(--ink);outline:none}.turnstile-shell{background:linear-gradient(#fffbf4db,#f1e7d8e6),#ffffff6b;border:1px solid #805e3f24;border-radius:18px;padding:14px;box-shadow:inset 0 1px #ffffffb3}.turnstile-widget{min-height:66px}.turnstile-unavailable{color:var(--ink-soft);font-size:.88rem;line-height:1.6}.rating-panel{background:linear-gradient(#fffaf3e6,#f3e9dbeb),#fff6;border:1px solid #78533429;border-radius:24px;margin-top:28px;padding:22px;box-shadow:inset 0 1px #ffffffb8}.rating-panel-head{gap:6px;display:grid}.rating-panel-title{color:var(--ink);margin:0;font-size:1.02rem;font-weight:800}.rating-panel-body{color:var(--ink-soft);margin:0;font-size:.9rem;line-height:1.7}.rating-options{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:18px;display:grid}.rating-option{min-height:52px;color:var(--ink);text-align:center;cursor:pointer;background:#fffcf6f0;border:1px solid #73523629;border-radius:18px;padding:12px 14px;font-size:.84rem;font-weight:700;transition:transform .18s,box-shadow .18s,border-color .18s}.rating-option:hover,.rating-option:focus-visible{border-color:#976b4047;outline:none;transform:translateY(-1px);box-shadow:0 10px 20px #20140c14}.rating-option.is-selected{background:linear-gradient(#fff6e6fa,#f5e7d0eb);border-color:#976b405c;box-shadow:0 12px 28px #6d48251f}.rating-option:disabled{cursor:default}.rating-reason-block{gap:8px;margin-top:16px;display:grid}.rating-reason-select{min-height:48px}.rating-actions{justify-content:flex-end;margin-top:18px;display:flex}.rating-success{color:#5b7049;margin-top:18px;font-size:.92rem;font-weight:700}@media (max-width:960px){.topbar{flex-direction:column;align-items:stretch}.language-switcher{justify-content:flex-start}.result-grid,.usage-step-card,.rating-options{grid-template-columns:1fr}}@media (max-width:720px){.page-shell{padding:20px 14px 32px}.page-title{font-size:clamp(2.7rem,12vw,3.8rem)}.page-lead{font-size:.94rem}.paper-panel{border-radius:26px;padding:24px 18px}.field-head{align-items:flex-start}.book-field{grid-template-columns:auto minmax(0,1fr) auto;gap:10px}.book-candidate-card{grid-template-columns:auto minmax(0,1fr)}.book-index{width:fit-content;min-width:44px;height:38px}.book-link-media{grid-template-columns:auto 52px minmax(0,1fr);gap:12px}.x-section-grid{grid-template-columns:1fr}.x-icon-field{justify-items:start}.x-icon-field .field-head{justify-content:space-between}.book-thumbnail,.book-thumbnail-placeholder{width:52px;height:74px}.primary-button{width:100%;min-width:0}.share-row{flex-direction:column;align-items:stretch}.secondary-button,.share-link{width:100%}.usage-modal{padding:18px}.connected-account-card,.connected-account-main{align-items:flex-start}}@media (max-width:520px){.page-title{font-size:2.4rem}.panel-title{font-size:1.8rem}.shelf-card{padding:18px}.shelf-card-head{flex-direction:column;align-items:stretch}.book-link-media{grid-template-columns:auto 1fr}.book-rarity{grid-row:span 2;align-self:center}.usage-browser-page{grid-template-columns:60px minmax(0,1fr)}.connected-account-card{flex-direction:column;align-items:stretch}.connected-account-logout-form,.connected-account-logout-button{width:100%}}.legal-panel,.legal-sections{gap:28px;display:grid}.legal-section{gap:14px;display:grid}.legal-section-title{margin:0}.legal-copy{gap:10px;display:grid}.legal-paragraph{margin:0}.legal-links{flex-wrap:wrap;align-items:center;gap:14px 18px;display:flex}.site-footer{z-index:1;border-top:1px solid var(--line);text-align:center;margin-top:64px;padding:32px 24px 24px;position:relative}.site-footer-nav{flex-wrap:wrap;justify-content:center;gap:10px 22px;margin-bottom:14px;display:flex}.site-footer-nav a{color:var(--paper-soft);font-size:.82rem;font-weight:500;text-decoration:none;transition:color .18s}.site-footer-nav a:hover{color:var(--gold)}.site-footer-copy{color:var(--ink-soft);letter-spacing:.04em;margin:0;font-size:.72rem}.breadcrumb{margin:12px 0 8px}.breadcrumb-list{flex-wrap:wrap;align-items:center;gap:0;margin:0;padding:0;font-size:.82rem;list-style:none;display:flex}.breadcrumb-item{align-items:center;display:flex}.breadcrumb-separator{color:var(--text-muted);margin:0 8px;font-size:.75rem}.breadcrumb-link{color:var(--accent-warm);text-decoration:none}.breadcrumb-link:hover{text-decoration:underline}.breadcrumb-current{color:var(--text-secondary)}.hero-section{margin:32px 0 24px}.hero-title{font-family:var(--font-display);color:var(--text-primary);margin:0 0 12px;font-size:1.35rem;font-weight:700;line-height:1.4}.hero-body{color:var(--text-secondary);margin:0 0 28px;font-size:.92rem;line-height:1.7}.hero-features{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:28px;display:grid}.hero-feature-card{background:var(--bg-mid);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:16px}.hero-feature-title{color:var(--accent-warm);margin:0 0 6px;font-size:.95rem;font-weight:700}.hero-feature-body{color:var(--text-secondary);margin:0;font-size:.85rem;line-height:1.6}.hero-steps{flex-direction:column;gap:12px;margin:0;padding:0;list-style:none;display:flex}.hero-step{color:var(--text-secondary);align-items:flex-start;gap:12px;font-size:.9rem;line-height:1.6;display:flex}.hero-step-number{background:var(--accent-warm);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:.8rem;font-weight:700;display:flex}.hero-step-text{padding-top:3px}.gallery-preview-section{background:var(--bg-mid);border:1px solid var(--border-subtle);border-radius:var(--radius-md);margin:36px 0 28px;padding:24px}.gallery-preview-heading{font-family:var(--font-display);color:var(--text-primary);margin:0 0 16px;font-size:1.1rem;font-weight:700}.gallery-preview-grid{grid-template-columns:repeat(auto-fill,minmax(128px,1fr));gap:8px;margin-bottom:12px;display:grid}.gallery-preview-item{flex-direction:column;gap:6px;display:flex}.gallery-preview-card{background:var(--bg-deep);border:1px solid var(--border-subtle);border-radius:12px;flex-direction:column;gap:12px;padding:20px;text-decoration:none;transition:border-color .2s;display:flex}.gallery-preview-card:hover{border-color:var(--accent-warm)}.gallery-preview-theme{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:.92rem;font-weight:600;overflow:hidden}.gallery-preview-books{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;font-size:.78rem;line-height:1.5;overflow:hidden}.gallery-preview-date{color:var(--text-muted);font-size:.72rem}.gallery-preview-intro{color:var(--text-secondary);margin:-8px 0 16px;font-size:.86rem;line-height:1.6}.gallery-preview-card-header{justify-content:flex-end;align-items:center;min-height:18px;display:flex}.gallery-preview-featured{flex-direction:column;gap:6px;margin-top:8px;display:flex}.gallery-preview-cover,.gallery-preview-cover-placeholder{aspect-ratio:3/4.2;border-radius:8px;width:100%;overflow:hidden}.gallery-preview-cover{object-fit:cover;box-shadow:0 8px 14px #140c0829}.gallery-preview-cover-placeholder{color:#fff9eff0;letter-spacing:.12em;background:linear-gradient(145deg,#d8b681,#8b6036 70%,#5d3b20);place-items:center;font-size:.58rem;font-weight:800;display:grid}.gallery-preview-book-title{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:.72rem;font-weight:600;overflow:hidden}.gallery-preview-book-author{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;font-size:.62rem;line-height:1.35;overflow:hidden}.gallery-preview-comment-box{background:var(--paper-soft);border:1px solid #68472d29;border-radius:8px;min-height:52px;padding:8px 9px;box-shadow:0 6px 12px #140c0814}.gallery-preview-comment{color:var(--ink-soft);-webkit-line-clamp:3;-webkit-box-orient:vertical;font-size:.58rem;line-height:1.35;display:-webkit-box;overflow:hidden}.gallery-preview-badge{letter-spacing:.03em;color:#fff8ea;background:var(--gold-strong,#9a6a2a);white-space:nowrap;border-radius:999px;align-items:center;padding:2px 8px;font-size:.7rem;font-weight:700;display:inline-flex}.gallery-preview-quote{border-left:2px solid var(--accent-warm);background:#f5ecde0a;border-radius:4px;margin:4px 0 2px;padding:10px 12px}.gallery-preview-quote-text{color:var(--text-primary);-webkit-line-clamp:3;-webkit-box-orient:vertical;margin:0 0 4px;font-size:.84rem;font-style:italic;line-height:1.55;display:-webkit-box;overflow:hidden}.gallery-preview-quote-cite{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;font-size:.72rem;font-style:normal;display:block;overflow:hidden}.gallery-preview-books-list{flex-direction:column;gap:2px;margin:4px 0 0;padding:0;list-style:none;display:flex}.gallery-preview-book{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;padding-left:12px;font-size:.78rem;line-height:1.45;position:relative;overflow:hidden}.gallery-preview-book:before{content:"·";color:var(--text-muted);position:absolute;left:2px}.gallery-preview-book--highlight{color:var(--text-primary);font-weight:500}.gallery-preview-book--highlight:before{content:"★";color:var(--accent-warm);font-size:.68rem;left:0}.gallery-preview-card--tier-s{border-color:#c79c5673}.gallery-preview-card--tier-a{border-color:#c79c5647}.gallery-preview-card--tier-b{border-color:#f5ecde2e}.comment-modal-hint{color:var(--ink-soft);border-left:2px solid var(--gold);background:#c79c5614;border-radius:4px;margin:0 0 12px;padding:8px 12px;font-size:.82rem;line-height:1.55}.comment-threshold-met{color:var(--green);margin-left:12px;font-size:.78rem;font-weight:600}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px;display:grid}.gallery-card{border-radius:var(--radius-md);background:var(--paper-soft);color:var(--ink);box-shadow:var(--shadow-sm);flex-direction:column;gap:12px;padding:20px;text-decoration:none;transition:box-shadow .18s,transform .18s;display:flex}.gallery-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.gallery-card-theme{font-family:var(--font-serif);color:var(--gold-strong);margin:0;font-size:1rem;font-weight:600}.gallery-card-books{gap:12px;display:flex}.gallery-card-book{flex-direction:column;flex:1;align-items:center;gap:4px;min-width:0;display:flex}.gallery-card-cover{object-fit:cover;width:64px;height:90px;box-shadow:var(--shadow-sm);border-radius:4px}.gallery-card-cover-placeholder{background:var(--line);border-radius:4px;width:64px;height:90px}.gallery-card-book-title{text-align:center;-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.72rem;font-weight:600;line-height:1.3;display:-webkit-box;overflow:hidden}.gallery-card-book-author{color:var(--ink-soft);text-align:center;text-overflow:ellipsis;white-space:nowrap;max-width:100%;font-size:.66rem;overflow:hidden}.gallery-card-date{color:var(--ink-soft);font-size:.7rem}.gallery-pagination{justify-content:center;align-items:center;gap:18px;margin-top:32px;display:flex}.gallery-pagination-link{color:var(--gold);font-size:.88rem;font-weight:600;text-decoration:none}.gallery-pagination-link:hover{text-decoration:underline}.gallery-pagination-info{color:var(--paper-soft);font-size:.82rem}.gallery-detail-layout{flex-direction:column;gap:32px;display:flex}.gallery-detail-section{border-radius:var(--radius-md);background:var(--paper-soft);color:var(--ink);padding:24px}.gallery-detail-label{font-family:var(--font-display);color:var(--gold-strong);margin:0 0 10px;font-size:1.2rem;font-weight:600}.gallery-detail-theme{font-family:var(--font-serif);margin:0 0 12px;font-size:1rem;font-weight:600}.gallery-detail-books{flex-direction:column;gap:16px;display:flex}.gallery-detail-book{gap:14px;display:flex}.gallery-detail-cover{object-fit:cover;width:72px;height:100px;box-shadow:var(--shadow-sm);border-radius:4px;flex-shrink:0}.gallery-detail-cover-placeholder{background:var(--line);border-radius:4px;flex-shrink:0;width:72px;height:100px}.gallery-detail-book-info{flex-direction:column;gap:2px;min-width:0;display:flex}.gallery-detail-book-title{color:var(--ink);font-size:.9rem;font-weight:600;text-decoration:none}.gallery-detail-book-title:hover{color:var(--gold-strong);text-decoration:underline}.gallery-detail-book-author{color:var(--ink-soft);font-size:.78rem}.gallery-detail-book-comment{color:var(--ink-soft);margin:4px 0 0;font-size:.78rem;font-style:italic}.gallery-detail-message{color:var(--ink);margin:14px 0 0;font-size:.88rem;line-height:1.6}.contact-form-wrapper{margin:20px 0}.contact-form-iframe{border-radius:var(--radius-sm);border:none;width:100%;min-height:600px}.contact-fallback{padding:20px 0}.contact-builtin-form{flex-direction:column;gap:20px;margin:24px 0;display:flex}.contact-field{flex-direction:column;gap:6px;display:flex}.contact-label{color:var(--text-primary);align-items:center;gap:8px;font-size:.9rem;font-weight:600;display:flex}.contact-required{color:var(--accent-warm);background:#ff6b351f;border-radius:4px;padding:1px 6px;font-size:.72rem;font-weight:500}.contact-input,.contact-textarea{width:100%;color:var(--text-primary);background:var(--bg-mid);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:10px 14px;font-family:inherit;font-size:.95rem;transition:border-color .2s}.contact-input:focus,.contact-textarea:focus{border-color:var(--accent-warm);outline:none}.contact-input:disabled,.contact-textarea:disabled{opacity:.6;cursor:not-allowed}.contact-textarea{resize:vertical;min-height:120px}.contact-submit-btn{color:#fff;background:var(--accent-warm);border-radius:var(--radius-sm);cursor:pointer;border:none;align-self:flex-start;padding:10px 32px;font-size:.95rem;font-weight:600;transition:opacity .2s}.contact-submit-btn:hover:not(:disabled){opacity:.85}.contact-submit-btn:disabled{opacity:.5;cursor:not-allowed}.contact-error{color:#ff6b6b;margin:0;font-size:.88rem}.contact-success{border-radius:var(--radius-sm);background:#4cd96414;border:1px solid #4cd96440;margin:24px 0;padding:24px}.contact-success-title{color:#4cd964;margin:0 0 8px;font-size:1.1rem;font-weight:700}.contact-success-body{color:var(--text-secondary);margin:0;font-size:.92rem;line-height:1.6}.not-found-section{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:50vh;padding:80px 20px;display:flex}.not-found-code{font-family:var(--font-display);color:var(--accent-warm);opacity:.7;margin:0;font-size:6rem;font-weight:700;line-height:1}.not-found-title{color:var(--text-primary);margin:16px 0 8px;font-size:1.4rem;font-weight:600}.not-found-body,.not-found-body-ja{color:var(--text-secondary);margin:4px 0;font-size:.95rem;line-height:1.6}.not-found-actions{margin-top:32px}.not-found-home-link{color:#fff;background:var(--accent-warm);border-radius:var(--radius-sm);padding:10px 28px;font-size:.95rem;font-weight:600;text-decoration:none;transition:opacity .2s;display:inline-block}.not-found-home-link:hover{opacity:.85}.cookie-consent-banner{z-index:9999;background:var(--bg-deep);border-top:1px solid var(--line-strong);flex-wrap:wrap;justify-content:center;align-items:center;gap:16px;padding:16px 24px;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 24px #0000004d}.cookie-consent-text{color:var(--paper-soft);max-width:600px;margin:0;font-size:.82rem;line-height:1.5}.cookie-consent-link{color:var(--gold);text-decoration:underline}.cookie-consent-actions{flex-shrink:0;gap:10px;display:flex}.cookie-consent-accept{background:var(--gold);color:var(--bg-deep);cursor:pointer;border:none;border-radius:999px;padding:8px 20px;font-size:.8rem;font-weight:700;transition:background .18s}.cookie-consent-accept:hover{background:var(--gold-strong)}.cookie-consent-decline{border:1px solid var(--line-strong);color:var(--paper-soft);cursor:pointer;background:0 0;border-radius:999px;padding:8px 20px;font-size:.8rem;font-weight:600;transition:border-color .18s}.cookie-consent-decline:hover{border-color:var(--paper-soft)}.report-block{justify-content:flex-end;margin-top:12px;display:flex}.report-trigger{border:1px solid var(--line);color:var(--ink-soft);border-radius:var(--radius-sm);cursor:pointer;background:0 0;padding:5px 14px;font-size:.78rem;transition:border-color .18s,color .18s}.report-trigger:hover{border-color:var(--rose);color:var(--rose)}.report-panel{background:var(--paper-strong);border:1px solid var(--line);border-radius:var(--radius-md);flex-direction:column;gap:10px;max-width:360px;margin-left:auto;padding:16px 20px;display:flex}.report-title{color:var(--ink);margin:0;font-size:.88rem;font-weight:600}.report-select{border:1px solid var(--line-strong);border-radius:var(--radius-sm);background:var(--paper);width:100%;color:var(--ink);cursor:pointer;padding:8px 10px;font-size:.82rem}.report-actions{justify-content:flex-end;gap:8px;display:flex}.report-cancel{border:1px solid var(--line);color:var(--ink-soft);cursor:pointer;background:0 0;border-radius:999px;padding:6px 14px;font-size:.78rem;transition:border-color .18s}.report-cancel:hover{border-color:var(--ink-soft)}.report-submit{background:var(--rose);color:#fff;cursor:pointer;border:none;border-radius:999px;padding:6px 16px;font-size:.78rem;font-weight:600;transition:opacity .18s}.report-submit:disabled{opacity:.45;cursor:not-allowed}.report-submit:not(:disabled):hover{opacity:.85}.report-feedback{text-align:right;margin:0;font-size:.82rem}.report-success{color:var(--green)}.report-already{color:var(--ink-soft)}.report-error{color:var(--rose)}.home-guide-link{text-align:center;max-width:720px;margin:1.25rem auto .25rem;padding:0 1rem}.home-guide-link-anchor{color:var(--paper);opacity:.78;letter-spacing:.01em;border-bottom:1px dashed #f5ecde59;padding:.5rem .85rem;font-size:.92rem;font-weight:500;text-decoration:none;transition:opacity .15s,border-color .15s,color .15s;display:inline-block}.home-guide-link-anchor:hover,.home-guide-link-anchor:focus-visible{opacity:1;border-bottom-color:var(--gold);color:var(--paper-strong);outline:none}.guide-section{max-width:960px;margin:2.75rem auto 0;padding:0 1rem}.guide-section-heading{font-family:var(--font-display);color:var(--paper);letter-spacing:.01em;margin:0 0 1.1rem;font-size:clamp(1.4rem,2.4vw,1.9rem);font-weight:600}.guide-examples-empty{color:var(--paper-soft);margin:.5rem 0 0;font-size:.98rem}.hero-section--guide{margin-top:1.5rem}.guide-cta{text-align:center;background:var(--paper-strong);border:1px solid var(--line);border-radius:var(--radius-lg);max-width:720px;box-shadow:var(--shadow-md);margin:3rem auto 2rem;padding:2rem 1.5rem}.guide-cta-heading{font-family:var(--font-display);color:var(--ink);margin:0 0 .6rem;font-size:clamp(1.3rem,2.4vw,1.75rem);font-weight:600}.guide-cta-body{color:var(--ink-soft);max-width:520px;margin:0 auto 1.4rem;font-size:1rem;line-height:1.7}.guide-cta-button{background:var(--gold-strong);color:#fff8ea;letter-spacing:.02em;box-shadow:var(--shadow-sm);border-radius:999px;padding:.85rem 1.75rem;font-size:1rem;font-weight:600;text-decoration:none;transition:transform .15s,background .15s,box-shadow .15s;display:inline-block}.guide-cta-button:hover,.guide-cta-button:focus-visible{background:var(--gold);box-shadow:var(--shadow-md);outline:none;transform:translateY(-1px)}.gallery-empty-actions{flex-wrap:wrap;justify-content:center;gap:1rem;margin-top:1.25rem;display:flex}.gallery-detail-cta{margin-top:2.5rem}.gallery-detail-cta-actions{flex-wrap:wrap;justify-content:center;align-items:center;gap:1rem;display:flex}
