@import"https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/variable/pretendardvariable.css";:root{color-scheme:light;font-family:Pretendard Variable,Pretendard,-apple-system,BlinkMacSystemFont,system-ui,Apple SD Gothic Neo,Noto Sans KR,sans-serif;background:linear-gradient(180deg,#f6efe4,#ece0cc)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#app{width:100%;height:100%;margin:0}body{display:flex;justify-content:center;overflow:hidden;overscroll-behavior:none;touch-action:manipulation;color:#4d402f;background:radial-gradient(circle at 18% 18%,rgba(231,163,173,.2),transparent 22%),radial-gradient(circle at 82% 16%,rgba(155,197,231,.18),transparent 24%),radial-gradient(circle at 46% 84%,rgba(174,201,163,.2),transparent 28%),linear-gradient(180deg,#f5efe4,#ede2cf 54%,#e7d9c0)}#app{position:relative;width:100%;max-width:480px;min-height:100%;overflow:hidden}@media(min-width:768px){#app{border-radius:28px;box-shadow:0 26px 60px #85654a38,0 0 0 1px #fffcf4cc}}.librarian-king-app{position:relative;width:100%;height:100%;overflow:hidden}.game-root{position:absolute;inset:0;width:100%;height:100%}.game-root canvas{display:block;width:100%!important;height:100%!important}.hud-top{position:absolute;top:max(12px,env(safe-area-inset-top));left:0;width:100%;display:flex;align-items:stretch;gap:10px;padding-inline:12px;z-index:3;pointer-events:none;transition:opacity .18s ease,transform .18s ease}.hud-top--hidden{opacity:0;transform:translateY(-12px);pointer-events:none;visibility:hidden}.global-settings-button{position:absolute;top:max(13px,env(safe-area-inset-top));right:12px;z-index:6;width:40px;height:40px;border:none;border-radius:20px;background:#ffffffb8;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);color:#bf360c;display:grid;place-items:center;cursor:pointer;box-shadow:0 4px 12px #0000000f;transition:transform .18s ease,box-shadow .18s ease,color .18s ease}.global-settings-button:hover{transform:translateY(-1px);color:#e65100;box-shadow:0 6px 16px #0000001a}.global-settings-button svg{width:24px;height:24px;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:1.7}.audio-sheet,.sound-lab{position:absolute;inset:0;z-index:7}.sound-lab{z-index:8}.audio-sheet.audio-sheet--hidden,.sound-lab.sound-lab--hidden{display:none}.audio-sheet__backdrop,.sound-lab__backdrop{position:absolute;inset:0;background:#4d402f52;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.audio-sheet{display:grid;place-items:center}.audio-sheet__card{position:relative;width:min(calc(100% - 32px),320px);padding:22px 18px 18px;border-radius:28px;border:1px solid rgba(255,251,243,.94);background:linear-gradient(180deg,#fffcf5fc,#f4ead6f5),#fffaf2f5;box-shadow:0 22px 44px #73583e3d,inset 0 1px #fffffff0,inset 0 -2px #e1d2bab8}.audio-sheet__eyebrow,.sound-lab__eyebrow{font-size:11px;font-weight:800;letter-spacing:.16em;color:#b08363;text-transform:uppercase}.audio-sheet__title,.sound-lab__title{margin-top:8px;font-size:24px;font-weight:800;line-height:1.16;color:#4d402f}.audio-sheet__body,.sound-lab__subtitle{margin:8px 0 0;font-size:13px;font-weight:700;line-height:1.5;color:#7f6f58}.audio-control{display:block;margin-top:16px;padding:14px 14px 12px;border-radius:22px;background:linear-gradient(180deg,#fffcf6fa,#efe4ceeb),#fff9eff2;border:1px solid rgba(236,219,192,.94);box-shadow:inset 0 1px #fffffff0,inset 0 -2px #dfcbad80}.audio-control--panel{margin-top:0}.audio-control__label{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px;font-size:13px;font-weight:800;color:#5f4b37}.audio-control__label strong{font-size:15px}.audio-range{width:100%;margin:0;accent-color:#cb7f61;cursor:pointer}.audio-sheet__actions{display:flex;gap:10px;margin-top:18px}.audio-sheet__button,.sound-lab__footer-button,.sound-lab__close,.sound-lab__preview-button{border:0;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,filter .18s ease}.audio-sheet__button:hover,.sound-lab__footer-button:hover,.sound-lab__close:hover,.sound-lab__preview-button:hover{transform:translateY(-1px)}.audio-sheet__button{flex:1;height:48px;border-radius:999px;font-size:15px;font-weight:800}.audio-sheet__button--ghost,.sound-lab__footer-button--ghost{color:#6d5a44;background:linear-gradient(180deg,#fffcf5fa,#efe5d0f2),#fffaf2eb;box-shadow:inset 0 1px #fffffff5,inset 0 -2px #e1d2bac2}.audio-sheet__button--confirm,.sound-lab__footer-button--confirm{color:#fffdf7;background:linear-gradient(180deg,#e59dad,#cc7489);box-shadow:0 10px 18px #bd698238,inset 0 1px #ffe8ee99,inset 0 -3px #8c41553d}.sound-lab{overflow:hidden}.sound-lab__panel{position:relative;z-index:1;display:flex;flex-direction:column;gap:14px;width:100%;height:100%;padding:max(18px,env(safe-area-inset-top)) 14px calc(18px + env(safe-area-inset-bottom));overflow-y:auto;background:radial-gradient(circle at top left,rgba(255,241,215,.5),transparent 28%),radial-gradient(circle at top right,rgba(183,214,235,.28),transparent 26%),linear-gradient(180deg,#faf1e0fa,#e9dbbff5)}.sound-lab__header,.sound-lab__section,.sound-lab__footer{position:relative;border:1px solid rgba(255,251,243,.94);border-radius:28px;background:linear-gradient(180deg,#fffcf5f7,#f4ead6f2),#fffaf2f2;box-shadow:0 18px 34px #8364482e,inset 0 1px #fffffff0,inset 0 -2px #e1d2baad}.sound-lab__header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:18px 18px 16px}.sound-lab__close{flex:0 0 auto;min-width:66px;height:40px;padding:0 16px;border-radius:999px;font-size:13px;font-weight:800;color:#5e4937;background:#efe3c9eb;box-shadow:inset 0 1px #ffffffdb,inset 0 -2px #dbc6a5a3}.sound-lab__section{padding:16px}.sound-lab__section-title{font-size:14px;font-weight:800;letter-spacing:.08em;color:#8b6f52;text-transform:uppercase}.sound-lab__section-body,.sound-lab__sample-list{display:grid;gap:12px;margin-top:14px}.sound-lab__sample-row{display:grid;gap:10px;padding:14px;border-radius:22px;background:linear-gradient(180deg,#fffdf8f5,#efe4cdeb),#fffaf1f0;border:1px solid rgba(236,220,192,.94)}.sound-lab__sample-copy strong{display:block;font-size:15px;font-weight:800;color:#51402f}.sound-lab__sample-copy span{display:block;margin-top:4px;font-size:12px;font-weight:700;line-height:1.45;color:#7d6b56}.sound-lab__sample-values{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px;font-size:12px;font-weight:800;color:#8a6d4d}.sound-lab__preview-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:14px}.sound-lab__preview-button{display:grid;gap:4px;min-height:84px;padding:14px;border-radius:20px;text-align:left;background:linear-gradient(180deg,#fffcf6fa,#efe5d0f0),#fffaf2eb;color:#5c472f;box-shadow:0 10px 22px #936e5024,inset 0 1px #fffffff5,inset 0 -2px #e1d2babd}.sound-lab__preview-button strong{font-size:15px;font-weight:800}.sound-lab__preview-button span{font-size:12px;font-weight:700;line-height:1.4;color:#7f6f58}.sound-lab__footer{display:flex;gap:10px;padding:14px}.sound-lab__footer-button{flex:1;height:48px;border-radius:999px;font-size:15px;font-weight:800}.restart-dialog{position:absolute;inset:0;z-index:5;display:grid;place-items:center;pointer-events:auto}.restart-dialog--hidden{display:none}.restart-dialog__backdrop{position:absolute;inset:0;background:#4d402f47;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.restart-dialog__card{position:relative;width:min(calc(100% - 32px),308px);padding:22px 18px 18px;border-radius:28px;border:1px solid rgba(255,251,243,.94);background:linear-gradient(180deg,#fffcf5fa,#f4ead6f2),#fffaf2f5;box-shadow:0 18px 36px #73583e33,inset 0 1px #fffffff0,inset 0 -2px #e1d2bab8}.restart-dialog__title{font-size:22px;font-weight:800;line-height:1.2;color:#4d402f}.restart-dialog__body{margin:8px 0 0;font-size:13px;font-weight:700;line-height:1.45;color:#7f6f58}.restart-dialog__actions{display:flex;gap:10px;margin-top:18px}.restart-dialog__button{flex:1;height:46px;border-radius:999px;border:0;font-size:15px;font-weight:800;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,filter .18s ease}.restart-dialog__button:hover{transform:translateY(-1px)}.restart-dialog__button--ghost{color:#6d5a44;background:linear-gradient(180deg,#fffcf5fa,#efe5d0f2),#fffaf2eb;box-shadow:inset 0 1px #fffffff5,inset 0 -2px #e1d2bac2}.restart-dialog__button--confirm{color:#fffdf7;background:linear-gradient(180deg,#e59dad,#cc7489);box-shadow:0 10px 18px #bd698238,inset 0 1px #ffe8ee99,inset 0 -3px #8c41553d}.progress-pill{flex:1;min-width:0;padding:9px 14px 10px;border-radius:26px;border:1px solid rgba(255,183,77,.3);background:linear-gradient(180deg,#ffffffd9,#fff8e1cc);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:0 8px 20px #0000001a}.hud-actions{display:flex;flex-direction:column;gap:8px;pointer-events:auto;flex:0 0 auto}.hud-icon-button{width:44px;height:44px;border:1px solid rgba(255,183,77,.3);border-radius:16px;background:linear-gradient(180deg,#ffffffd9,#fff8e1cc);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);color:#e65100;display:grid;place-items:center;cursor:pointer;box-shadow:0 8px 20px #0000001a;transition:transform .18s ease,box-shadow .18s ease,color .18s ease}.hud-icon-button:hover{transform:translateY(-1px);color:#bf360c;box-shadow:0 12px 24px #00000026}.hud-icon-button svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:2.2}.progress-pill__eyebrow{margin-bottom:5px;font-size:10px;font-weight:800;letter-spacing:.16em;color:#ff8f00;text-transform:uppercase}.progress-pill__meta{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:3px;font-size:11px;font-weight:700;color:#795548}.progress-pill__meta span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:800;color:#3e2723}.progress-pill__meta strong{color:#e65100;font-size:12px}.progress-pill__subtitle{margin-bottom:7px;font-size:11px;font-weight:700;color:#8d6e63;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.progress-track{height:8px;border-radius:999px;background:#ffe0b280;overflow:hidden}.progress-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,#ff8a80,#ffb74d,#4dd0e1 68%,#b39ddb);box-shadow:0 0 16px #ff8a8059}.stage-preview{position:absolute;inset:0;display:flex;flex-direction:column;overflow:hidden;padding:12px 10px calc(14px + env(safe-area-inset-bottom));z-index:4;pointer-events:auto;background:radial-gradient(circle at 50% -10%,rgba(255,247,225,.9),rgba(242,228,199,.34) 34%,transparent 58%),linear-gradient(180deg,#efe4cb,#e6d2ae 45%,#d7b88d)}.stage-preview--hidden{display:none}.stage-preview__sky,.stage-preview__glow{position:absolute;pointer-events:none}.stage-preview__sky{inset:0 0 auto;height:220px;background:radial-gradient(circle at 16% 24%,rgba(171,205,188,.22),transparent 20%),radial-gradient(circle at 82% 16%,rgba(238,208,145,.24),transparent 20%),radial-gradient(circle at 50% 16%,rgba(255,250,235,.88),transparent 16%),linear-gradient(180deg,#795e45eb,#ba986f8f 52%,#f3e5c600)}.stage-preview__glow{width:144px;height:144px;border-radius:999px;filter:blur(8px);opacity:.5}.stage-preview__glow--left{left:-24px;bottom:210px;background:radial-gradient(circle,rgba(181,132,84,.74),transparent 70%)}.stage-preview__glow--right{right:-8px;top:248px;background:radial-gradient(circle,rgba(137,170,127,.72),transparent 68%)}.stage-preview:before{content:"";position:absolute;inset:176px 0 0;background:linear-gradient(180deg,#f5ead4fa,#e7d6b5e6),radial-gradient(circle at 14% 22%,rgba(255,244,214,.42),transparent 14%),radial-gradient(circle at 82% 34%,rgba(255,236,198,.4),transparent 16%),repeating-linear-gradient(-14deg,#bda07614 0 14px,#f0dfbf0a 14px 30px),repeating-linear-gradient(90deg,rgba(125,100,74,.05) 0,rgba(125,100,74,.05) 1px,transparent 1px,transparent 24px),repeating-linear-gradient(180deg,rgba(125,100,74,.05) 0,rgba(125,100,74,.05) 1px,transparent 1px,transparent 24px);box-shadow:inset 0 14px 24px #fff7e2b8,inset 0 -24px 32px #b08e6124}.stage-preview:after{content:"";position:absolute;inset:0;pointer-events:none;background:repeating-linear-gradient(180deg,#73543a38 0 18px,#ae815738 18px 38px,#5d443033 38px 56px) left 10px top 206px / 24px 312px no-repeat,repeating-linear-gradient(180deg,#73543a38 0 18px,#ae815738 18px 38px,#5d443033 38px 56px) right 10px top 232px / 24px 286px no-repeat,radial-gradient(circle at 8% 70%,rgba(156,105,61,.08),transparent 12%),radial-gradient(circle at 92% 63%,rgba(115,160,115,.1),transparent 14%),radial-gradient(circle at 14% 34%,rgba(255,255,255,.2),transparent 8%)}.stage-preview__header,.stage-preview__hero,.stage-preview__map-frame,.stage-preview__dock{position:relative;z-index:1}.stage-preview__header{display:flex;align-items:center;justify-content:space-between;gap:12px;min-height:44px}.stage-preview__brand{font-size:11px;font-weight:800;letter-spacing:.16em;color:#7c5f42;text-transform:uppercase}.stage-preview__eyebrow{display:inline-flex;align-items:center;height:30px;padding:0 12px;border-radius:999px;background:linear-gradient(180deg,#f6e9d0f5,#e3cea6f0);font-size:10px;font-weight:800;letter-spacing:.16em;color:#b08363;text-transform:uppercase}.stage-preview__hero{margin-top:18px;text-align:center}.stage-preview__title{margin:0;font-size:31px;line-height:1.12;color:#4d402f;text-wrap:balance}.stage-preview__subtitle{width:min(100%,296px);margin:10px auto 0;font-size:13px;font-weight:700;line-height:1.48;color:#8d765d;text-wrap:balance}.stage-preview__map-frame{position:relative;flex:1;min-height:406px;margin-top:12px;padding:10px 6px 0;border-radius:38px;background:linear-gradient(180deg,#fff8e885,#e8d8bb3d);border:1px solid rgba(233,217,187,.74);box-shadow:inset 0 1px #ffffff6b,inset 0 -2px #b4997029}.stage-preview__track{position:absolute;top:6px;bottom:8px;left:50%;width:14px;border-radius:999px;background:linear-gradient(180deg,#a17549fa,#684831fa);box-shadow:inset 0 2px #fff0d347,0 4px 10px #7251352e;transform:translate(-50%)}.stage-preview__track:before{content:"";position:absolute;inset:8px 4px;border-radius:inherit;background:repeating-linear-gradient(180deg,rgba(255,235,179,.6) 0,rgba(255,235,179,.6) 12px,transparent 14px,transparent 28px)}.stage-preview__route{position:relative;height:100%;display:flex;flex-direction:column-reverse;justify-content:space-between}.stage-preview__stop{position:relative;display:flex;width:100%}.stage-preview__stop:nth-child(odd){justify-content:flex-end}.stage-preview__stop:nth-child(2n){justify-content:flex-start}.stage-preview__stop:before{content:"";position:absolute;top:34px;width:72px;height:4px;border-radius:999px;background:#a0815e99}.stage-preview__stop:nth-child(odd):before{right:100%;margin-right:12px}.stage-preview__stop:nth-child(2n):before{left:100%;margin-left:12px}.stage-preview__stop-card{display:inline-flex;flex-direction:column;align-items:center;gap:8px;min-width:108px;max-width:118px;padding:10px 10px 11px;border-radius:26px;background:linear-gradient(180deg,#fffbf3f0,#f0e3cbeb);border:1px solid rgba(238,223,197,.96);box-shadow:0 10px 24px #8f6e4c29,inset 0 1px #ffffffe6,inset 0 -2px #ddc9a98a}.stage-preview__stop--done .stage-preview__stop-card{background:linear-gradient(180deg,#f1f9ecfa,#daecd6f0);border-color:#c2dfbbf5}.stage-preview__stop--current .stage-preview__stop-card{background:linear-gradient(180deg,#fff7e0fa,#f6e2b5f5);border-color:#efc872fa;box-shadow:0 16px 28px #b2843f33,inset 0 1px #fffffff0,inset 0 -2px #d5aa5c5c}.stage-preview__marker{position:relative;z-index:1;min-width:56px;padding:0 12px;height:48px;border-radius:999px;display:grid;place-items:center;border:3px solid rgba(172,140,98,.94);background:linear-gradient(180deg,#a7917bfa,#7e6c5bfa);color:#fff7ea;font-size:18px;font-weight:800;box-shadow:0 10px 22px #8363413d,inset 0 2px #fff8e447}.stage-preview__stop--done .stage-preview__marker{border-color:#80a37bf0;background:linear-gradient(180deg,#a3c999fa,#75a073fa)}.stage-preview__stop--current .stage-preview__marker{min-width:88px;height:72px;border-width:4px;border-color:#c2793ff5;background:linear-gradient(180deg,#d99c4ffa,#a06331fa);color:#fff9ef;font-size:27px;box-shadow:0 16px 32px #9b5e3042,0 0 0 8px #ffe9b8cc,inset 0 2px #fff6dd52}.stage-preview__stop-label{display:inline-flex;align-items:center;justify-content:center;min-width:54px;padding:4px 10px;border-radius:999px;background:#fff8e8e0;font-size:9px;font-weight:800;letter-spacing:.08em;color:#8b7358;text-transform:uppercase;box-shadow:0 3px 10px #916e4a1f}.stage-preview__stop--current .stage-preview__stop-label{color:#84532e;background:#fff0c7f5}.stage-preview__dock{position:relative;z-index:1;margin-top:auto;padding:16px 16px calc(16px + env(safe-area-inset-bottom));border-radius:28px 28px 18px 18px;background:linear-gradient(180deg,#fffcf6fa,#f1e5ccf5);border:1px solid rgba(255,255,255,.98);box-shadow:0 22px 44px #8a694d38,inset 0 1px #fffffff5,inset 0 -2px #e1d2baa8}.stage-preview__stage{display:inline-flex;align-items:center;min-height:30px;padding:0 12px;border-radius:999px;background:#efe3c9e0;font-size:11px;font-weight:800;letter-spacing:.08em;color:#8b6f52}.stage-preview__dock-label{margin-top:10px;font-size:10px;font-weight:800;letter-spacing:.12em;color:#b08363;text-transform:uppercase}.stage-preview__library{margin-top:6px;font-size:22px;font-weight:800;line-height:1.2;color:#584632;text-wrap:balance}.stage-preview__library-subtitle{margin-top:4px;font-size:13px;font-weight:700;color:#8d765d;text-wrap:balance}.stage-preview__travel{margin-top:10px;font-size:12px;font-weight:800;line-height:1.45;color:#7f6f58;text-wrap:balance}.stage-preview__button{width:100%;height:58px;margin-top:14px;border:0;border-radius:999px;background:linear-gradient(180deg,#9ee15f,#78c443);color:#fffdf7;font-size:22px;font-weight:800;letter-spacing:.03em;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,filter .18s ease;box-shadow:0 14px 24px #6e9c3f47,inset 0 2px #eeffdab8,inset 0 -4px #4f7a2757;text-shadow:0 2px 0 rgba(77,115,39,.42)}.stage-preview__button:hover{transform:translateY(-1px);filter:saturate(1.06);box-shadow:0 18px 28px #6e9c3f57,inset 0 2px #eeffdab8,inset 0 -4px #4f7a2757}.stage-preview__button:active{transform:translateY(0)}@media(max-width:380px){.stage-preview{padding:12px 8px calc(14px + env(safe-area-inset-bottom))}.stage-preview__title{font-size:28px}.stage-preview__map-frame{min-height:386px;padding-inline:2px}.stage-preview__library{font-size:20px}.stage-preview__stop-card{min-width:132px;max-width:150px;padding-inline:10px}.stage-preview__dock{padding-inline:14px}}
