:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#3d3527;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;overflow-x:hidden;position:relative;background:#fff}button{font-family:inherit;color:inherit;cursor:pointer}button:focus-visible{outline:2px solid rgba(255,207,158,.7);outline-offset:2px}.speech-bubble{position:absolute;left:50%;bottom:100%;transform:translate(-50%) translateY(-6px);background:#fffdf8;border:1.5px solid #2b2b2b;color:#2a2a3a;padding:6px 12px;border-radius:14px;font-size:12px;font-weight:500;white-space:nowrap;box-shadow:0 2px 6px #00000026;animation:bubble-pop .25s ease-out;z-index:20;pointer-events:none}.speech-bubble:before{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border-width:6px 6px 0 6px;border-style:solid;border-color:#2b2b2b transparent transparent transparent}.speech-bubble:after{content:"";position:absolute;top:calc(100% - 1.5px);left:50%;transform:translate(-50%);border-width:5px 5px 0 5px;border-style:solid;border-color:#fffdf8 transparent transparent transparent}.speech-bubble--fade{animation:bubble-fade .4s ease-in forwards}@keyframes bubble-pop{0%{opacity:0;transform:translate(-50%) translateY(2px) scale(.85)}to{opacity:1;transform:translate(-50%) translateY(-6px) scale(1)}}@keyframes bubble-fade{0%{opacity:1}to{opacity:0}}.character-figure{width:32px;height:48px;display:flex;align-items:flex-end;justify-content:center;transition:transform .15s ease-in-out}.character-figure--lying{width:56px;height:32px;align-items:center;animation:lie-down-settle .32s ease-out}.stickman{width:100%;height:100%;fill:none;stroke:#2b2b2b;stroke-width:3;stroke-linecap:round}.sm-head{fill:#ffcf9e;stroke-width:2.4}.sm-pillow{fill:#fffdf8;stroke:#c8bfa6;stroke-width:1.6}.sm-arm-left,.sm-arm-right,.sm-leg-left,.sm-leg-right{transition:transform .15s ease-in-out}.sm-arm-left,.sm-arm-right{transform-origin:16px 18px}.sm-leg-left,.sm-leg-right{transform-origin:16px 30px}.character-figure--walking .sm-leg-left{animation:stickman-leg-swing .4s ease-in-out infinite}.character-figure--walking .sm-leg-right{animation:stickman-leg-swing .4s ease-in-out infinite;animation-delay:-.2s}.character-figure--walking .sm-arm-right{animation:stickman-arm-swing .4s ease-in-out infinite}.character-figure--walking .sm-arm-left{animation:stickman-arm-swing .4s ease-in-out infinite;animation-delay:-.2s}@keyframes stickman-leg-swing{0%,to{transform:rotate(24deg)}50%{transform:rotate(-24deg)}}@keyframes stickman-arm-swing{0%,to{transform:rotate(-18deg)}50%{transform:rotate(18deg)}}@keyframes lie-down-settle{0%{transform:translateY(-8px) scale(.9);opacity:.5}60%{transform:translateY(1px) scale(1.03);opacity:1}to{transform:translateY(0) scale(1);opacity:1}}.nupbang-room{position:absolute;top:0;right:0;bottom:0;left:0;z-index:10;overflow:hidden;pointer-events:none}.room-floor{position:absolute;left:4%;right:4%;height:2px;background:#2b2b2b59}.bed-slot{position:absolute;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:2px}.bed-icon{width:56px;height:49px;fill:none;stroke:#2b2b2b;stroke-width:2.5}.bed-icon rect:nth-child(3){fill:#fffdf8}.bed-slot__number{font-size:11px;font-weight:700;color:#5b5446}.character{position:absolute;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;z-index:11;-webkit-user-select:none;user-select:none}.character--remote{transition:left .12s linear,top .2s ease-in-out}.character-nickname{margin-bottom:2px;font-size:10px;font-weight:600;color:#3d3527;white-space:nowrap;text-shadow:0 1px 2px rgba(255,255,255,.8)}.chat-box{display:flex;flex-direction:column;width:100%;height:100%;background:#fffdf8;overflow:hidden}.chat-box__header{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 10px;font-size:14px;font-weight:700;color:#3d3527;letter-spacing:.02em;border-bottom:1.5px solid #2b2b2b}.chat-box__close{border:none;background:transparent;color:#6b6457;font-size:16px;line-height:1;padding:4px}.chat-box__close:hover{color:#3d3527}.chat-box__log{flex:1;overflow-y:auto;padding:12px 16px;display:flex;flex-direction:column;gap:8px}.chat-box__log::-webkit-scrollbar{width:6px}.chat-box__log::-webkit-scrollbar-thumb{background:#2b2b2b2e;border-radius:3px}.chat-box__empty{margin:auto;font-size:12px;color:#b3a890}.chat-box__line{font-size:13px;line-height:1.5;color:#3d3527;word-break:break-word}.chat-box__nickname{font-weight:700}.chat-box__input-row{display:flex;gap:8px;padding:12px;border-top:1.5px solid #2b2b2b;background:#fdf8ef}.chat-box__input{flex:1;min-width:0;padding:9px 12px;border-radius:10px;border:1.5px solid #2b2b2b;background:#fffdf8;color:#3d3527;font-size:13px;outline:none;transition:border-color .2s ease-in-out}.chat-box__input::placeholder{color:#b3a890}.chat-box__input:focus{border-color:#c2793f}.chat-box__input:disabled{cursor:not-allowed}.chat-box__send{padding:9px 16px;border-radius:10px;border:1.5px solid #2b2b2b;background:#ffcf9e;color:#3d2a16;font-size:13px;font-weight:700;cursor:pointer;transition:background .2s ease-in-out}.chat-box__send:hover:not(:disabled){background:#ffc183}.chat-box__send:disabled{opacity:.4;cursor:not-allowed}.action-bar{position:fixed;left:50%;bottom:22px;transform:translate(-50%);z-index:50;display:flex;flex-wrap:wrap;justify-content:center;gap:10px;max-width:calc(100vw - 24px);padding:12px 16px;border-radius:20px;background:#fffdf8e0;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1.5px solid #2b2b2b;box-shadow:0 8px 24px #3c321e2e}@media (max-width: 480px){.action-bar{gap:8px;padding:10px;bottom:12px}.action-bar__btn{padding:8px 12px;font-size:12px}}.action-bar__btn{padding:10px 16px;border-radius:999px;border:1.5px solid #2b2b2b;background:#fffdf8;color:#3d3527;font-size:13px;font-weight:600;white-space:nowrap;cursor:pointer;transition:background .2s ease-in-out,transform .15s ease-in-out}.action-bar__btn:hover{background:#ffcf9e4d}.action-bar__btn:active{transform:scale(.96)}.action-bar__btn--active{background:#ffcf9e;color:#3d2a16}.enter-room{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;display:flex;align-items:center;justify-content:center;padding:24px 16px}.enter-room__card{display:flex;flex-direction:column;gap:10px;width:min(380px,100%);padding:32px 28px;border-radius:22px;background:#fffdf8;border:1.5px solid #2b2b2b;box-shadow:0 16px 40px #3c321e1f;animation:enter-room-rise .35s ease-out}@keyframes enter-room-rise{0%{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.enter-room__title{margin:0;font-size:22px;font-weight:700;color:#3d3527;text-align:center;letter-spacing:.02em}.enter-room__subtitle{margin:0 0 10px;font-size:12.5px;color:#8a7f68;text-align:center}.enter-room__label{font-size:12px;font-weight:600;color:#6b6457;margin-top:6px}.enter-room__input{padding:11px 13px;border-radius:10px;border:1.5px solid #2b2b2b;background:#fdf8ef;color:#3d3527;font-size:14px;outline:none;transition:border-color .2s ease-in-out,box-shadow .2s ease-in-out,background .2s ease-in-out}.enter-room__input::placeholder{color:#b3a890}.enter-room__input:focus{border-color:#c2793f;background:#fffdf8;box-shadow:0 0 0 3px #ffcf9e59}.enter-room__submit{margin-top:18px;padding:13px;border-radius:12px;border:1.5px solid #2b2b2b;background:#ffcf9e;color:#3d2a16;font-size:14.5px;font-weight:700;letter-spacing:.01em;transition:background .2s ease-in-out,transform .15s ease-in-out,box-shadow .2s ease-in-out}.enter-room__submit:hover:not(:disabled){background:#ffc183;transform:translateY(-1px);box-shadow:0 6px 18px #ffb4824d}.enter-room__submit:active:not(:disabled){transform:translateY(0)}.enter-room__submit:disabled{opacity:.4;cursor:not-allowed}@media (max-width: 420px){.enter-room__card{padding:24px 18px;border-radius:18px}}.drawing-canvas{position:absolute;top:0;right:0;bottom:0;left:0;z-index:5;width:100%;height:100%;pointer-events:none;touch-action:none}.drawing-canvas--active{pointer-events:auto;cursor:crosshair}.bed-request-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:90;display:flex;align-items:center;justify-content:center;background:#3d352740}.bed-request-modal{display:flex;flex-direction:column;gap:16px;width:min(320px,86vw);padding:24px;border-radius:16px;background:#fffdf8;border:1.5px solid #2b2b2b;box-shadow:0 16px 40px #3c321e40;text-align:center}.bed-request-modal__text{margin:0;font-size:15px;color:#3d3527;line-height:1.5}.bed-request-modal__actions{display:flex;gap:10px}.bed-request-modal__btn{flex:1;padding:10px;border-radius:10px;border:1.5px solid #2b2b2b;font-size:14px;font-weight:700;cursor:pointer}.bed-request-modal__btn--yes{background:#ffcf9e;color:#3d2a16}.bed-request-modal__btn--yes:hover{background:#ffc183}.bed-request-modal__btn--no{background:#fdf8ef;color:#3d3527}.bed-request-modal__btn--no:hover{background:#f0e9da}.toast-stack{position:fixed;top:20px;left:50%;transform:translate(-50%);z-index:80;display:flex;flex-direction:column;gap:8px;align-items:center;pointer-events:none}.toast{padding:9px 18px;border-radius:999px;background:#2b2b2bd9;color:#fffdf8;font-size:13px;font-weight:600;box-shadow:0 6px 18px #0003;animation:toast-pop .2s ease-out}@keyframes toast-pop{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.slide-bg{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;overflow:hidden;background:#fff}.slide-bg__photo{position:absolute;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(115deg,rgba(43,43,43,.05) 0px,rgba(43,43,43,.05) 1px,transparent 1px,transparent 16px),linear-gradient(150deg,#ece6d8,#ded6c2 55%,#e7e0d1);clip-path:polygon(0 0,40% 0,33% 100%,0 100%)}.slide-bg__stripe-dark{position:absolute;top:0;right:0;bottom:0;left:0;background:#2b2b2b;clip-path:polygon(40% 0,42% 0,35% 100%,33% 100%)}.slide-bg__stripe-blue{position:absolute;top:0;right:0;bottom:0;left:0;background:#1565c0;clip-path:polygon(42.5% 0,46% 0,39% 100%,35.5% 100%)}.slide-bg__corner{position:absolute;top:0;right:7%;width:1.1%;height:30%;background:#1565c0}.ppt-chrome{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;background:#cdd3d8;font-family:Malgun Gothic,Inter,system-ui,sans-serif;-webkit-user-select:none;user-select:none}.ppt-titlebar{flex-shrink:0;height:26px;display:flex;align-items:center;justify-content:center;position:relative;background:linear-gradient(180deg,#b53344,#9c1f30);color:#fff}.ppt-titlebar__text{font-size:12px}.ppt-titlebar__controls{position:absolute;right:6px;top:0;height:100%;display:flex;align-items:center;gap:14px;font-size:13px;color:#ffffffd9}.ppt-titlebar__btn{cursor:default}.ppt-titlebar__btn--close:hover{color:#ffb3b3}.ppt-ribbon{flex-shrink:0;background:#f3f3f3;border-bottom:1px solid #c2c2c2}.ppt-ribbon__tabs{display:flex;gap:2px;padding:3px 8px 0;font-size:12px;color:#444;border-bottom:1px solid #d8d8d8}.ppt-ribbon__tab{padding:4px 10px;border-radius:2px 2px 0 0}.ppt-ribbon__tab--active{background:#fff;color:#9c1f30;font-weight:600}.ppt-ribbon__groups{display:flex;gap:10px;padding:6px 10px;height:70px;overflow:hidden}.ppt-ribbon__group{display:flex;flex-direction:column;align-items:center;justify-content:space-between;padding:0 8px;border-right:1px solid #e0e0e0;min-width:54px}.ppt-ribbon__group:last-child{border-right:none}.ppt-ribbon__icons{display:flex;gap:5px;flex:1;align-items:center}.ppt-ribbon__icon{width:16px;height:16px;border-radius:3px;background:#d9dde0;border:1px solid #c4c9cd}.ppt-ribbon__group-label{font-size:9.5px;color:#666;white-space:nowrap}.ppt-body{flex:1;min-height:0;display:flex}.ppt-slide-panel{flex-shrink:0;width:168px;background:#c4cad0;border-right:1px solid #aab1b8;display:flex;flex-direction:column}.ppt-slide-panel__tabs{display:flex;gap:10px;padding:6px 10px;font-size:11px;color:#444;border-bottom:1px solid #aab1b8}.ppt-slide-panel__tab--active{font-weight:700;color:#222}.ppt-slide-panel__thumb{margin:10px;display:flex;align-items:flex-start;gap:6px}.ppt-slide-panel__thumb-number{font-size:11px;color:#444;padding-top:2px}.ppt-slide-panel__thumb-preview{flex:1;aspect-ratio:16 / 9;background:linear-gradient(150deg,#ece6d8,#ded6c2 55%,#e7e0d1);border:2px solid #f5b400;box-shadow:0 1px 3px #0000004d}.slide-stage-wrapper{flex:1;min-width:0;min-height:0;display:flex;align-items:center;justify-content:center;background:#9aa3aa;overflow:hidden;container-type:size}.slide-stage{position:relative;z-index:1;aspect-ratio:16 / 9;width:min(100cqw,177.78cqh);max-width:100cqw;max-height:100cqh;background:#fff;box-shadow:0 10px 50px #00000059;overflow:hidden}@media (max-width: 860px){.ppt-ribbon,.ppt-slide-panel{display:none}.ppt-titlebar{height:20px}.ppt-titlebar__text{font-size:10px}}.app-screen{position:relative;width:100%;height:100vh;overflow:hidden}.chat-drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:65;background:#3d35272e}.chat-drawer{position:fixed;top:0;right:0;height:100vh;width:min(340px,86vw);border-left:1.5px solid #2b2b2b;box-shadow:-8px 0 24px #3c321e2e;transform:translate(100%);transition:transform .25s ease-in-out;z-index:70}.chat-drawer--open{transform:translate(0)}
