:root{--minimap-size: 140px;--panel-offset: 1rem;--bottom-offset: 4.5rem;--pad-size: 108px}@media(max-width:768px){:root{--minimap-size: 100px;--panel-offset: .5rem;--bottom-offset: 1rem;--pad-size: 90px}}.minimap-container{position:fixed;bottom:var(--bottom-offset);left:var(--panel-offset);width:var(--minimap-size);height:var(--minimap-size);border-radius:10px;overflow:hidden;background:#1a1510eb;border:2px solid #8b7355;box-shadow:inset 0 0 12px #00000080;z-index:100}.story-scrolls-panel{position:fixed;bottom:calc(var(--bottom-offset) + var(--minimap-size) + 6px);left:var(--panel-offset);z-index:150;width:220px;box-sizing:border-box;transition:bottom .2s ease}.story-scrolls-panel.ui-hidden{bottom:var(--bottom-offset)}.quest-log{box-sizing:border-box;background:#e8dcc4!important;border:1px solid #8b7355!important;border-radius:8px!important;box-shadow:0 2px 12px #00000040!important;color:#2d2118!important;font-family:system-ui,-apple-system,sans-serif!important;overflow:hidden;max-height:44px;transition:max-height .35s ease,box-shadow .3s ease}.quest-log.expanded{max-height:380px;box-shadow:0 4px 20px #00000059!important}.quest-log-header{height:44px;display:flex;align-items:center;justify-content:space-between;padding:0 12px;cursor:pointer;background:#8b735526;border-bottom:1px solid rgba(139,115,85,.2);-webkit-user-select:none;user-select:none}.quest-log-title{display:flex;align-items:center;gap:6px;font-weight:600;font-size:.9rem;color:#2d2118!important}.quest-log-subtitle{font-weight:500;font-size:.75rem;color:#6b5a42!important}.quest-log-stats{font-size:.8rem;font-weight:600;color:#5c4a32!important;display:flex;align-items:center;gap:6px}.quest-log-content{padding:12px;overflow-y:auto;max-height:320px;background:#e8dcc4!important}.section-label{font-size:.7rem;text-transform:uppercase;color:#6b5a42!important;margin-bottom:8px;font-weight:600;letter-spacing:.5px}.region-progress-list{margin-bottom:14px}.region-progress-item{margin-bottom:10px}.region-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:3px;gap:8px}.region-name{font-size:.8rem;font-weight:500;color:#2d2118!important;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.progress-bar-bg{height:4px;background:#8b735533;border-radius:2px;overflow:hidden}.progress-bar-fill{height:100%;background:#8b7355;border-radius:2px;transition:width .4s ease-out}.region-count{font-size:.75rem;font-weight:600;color:#5c4a32!important;flex-shrink:0}.region-remaining{color:#8b7355!important;font-weight:500}.scrolls-list-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px}.scroll-item-btn{background:#8b735526;border:1px solid rgba(101,67,33,.3);border-radius:6px;padding:8px 10px;display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;transition:all .2s;color:#2d2118!important;font-weight:500;min-width:70px}.scroll-item-btn:hover{background:#8b735540;border-color:#7a6345}.scroll-icon{font-size:1.1rem}.scroll-title-short{font-size:.7rem;text-align:center;max-width:80px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.final-quest-box{background:#7fb06926;padding:1rem;border-radius:6px;text-align:center;margin-bottom:1rem}.final-story-btn{margin-top:10px;padding:8px 16px;background:#8b7355;color:#fff;border:none;border-radius:4px;cursor:pointer;font-family:inherit;font-weight:700}.final-story-modal.portfolio-modal{max-width:520px}.final-story-content{max-height:40vh;overflow-y:auto;margin-bottom:.5rem;padding-right:4px;scrollbar-width:thin;scrollbar-color:rgba(139,115,85,.5) transparent}.final-story-content::-webkit-scrollbar{width:6px}.final-story-content::-webkit-scrollbar-thumb{background:#8b735580;border-radius:3px}.final-story-dialogue{font-size:1rem;line-height:1.75;color:#e8dcc4;white-space:pre-wrap;word-wrap:break-word;font-family:Georgia,Times New Roman,serif}.final-story-actions{margin-top:1.25rem;padding-top:1rem;border-top:1px solid rgba(139,115,85,.25)}.share-completion-block{margin-top:1.25rem;padding:1.25rem;background:#00000040;border-radius:10px;border:1px solid rgba(139,115,85,.2)}.share-completion-title{font-size:.95rem;font-weight:600;color:#e8dcc4;margin:0 0 .5rem;letter-spacing:.02em}.share-completion-desc{font-size:.85rem;color:#a89878;margin:0 0 1rem;line-height:1.5}.share-completion-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1rem}.share-social-row{margin-bottom:1rem}.share-social-label{display:block;font-size:.8rem;color:#a89878;margin-bottom:.5rem;letter-spacing:.02em}.share-social-buttons{display:flex;flex-wrap:wrap;gap:.6rem}.share-social-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1rem;font-size:.9rem;font-weight:500;color:#c9b896;background:#8b735533;border:1px solid rgba(139,115,85,.4);border-radius:8px;cursor:pointer;transition:all .2s}.share-social-btn .share-social-icon{flex-shrink:0;width:1.25rem;height:1.25rem;color:inherit}.share-social-btn:hover{background:#8b735559;border-color:#8b735599;color:#e8dcc4}.share-social-btn-instagram{border-color:#8b735559}.share-paste-hint{margin:.75rem 0 0;padding:.6rem .75rem;font-size:.8rem;color:#c9b896;background:#8b735526;border-radius:6px;border:1px solid rgba(139,115,85,.25);line-height:1.4;animation:shareHintFade .3s ease-out}@keyframes shareHintFade{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.share-completion-btn{padding:.55rem 1.1rem;font-size:.9rem;min-width:140px}.share-completion-btn.secondary{background:transparent;border:1px solid rgba(139,115,85,.5);color:#c9b896}.share-completion-btn.secondary:hover{background:#8b735526}.share-qr-block{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem;background:#00000026;border-radius:8px;width:fit-content;margin:0 auto}.share-qr-img{display:block;border-radius:6px;background:#fff;padding:6px;box-sizing:border-box}.share-qr-label{font-size:.75rem;color:#a89878;letter-spacing:.02em}.scroll-modal.portfolio-modal{background:linear-gradient(180deg,#f0e2c4,#e5d4a8)!important;border-color:#8b7355!important;color:#4a3728!important}.scroll-modal .portfolio-modal-title,.scroll-modal .portfolio-modal-subtitle{color:#5d4037!important}.scroll-modal .scroll-content{background:#f4e4bc80;padding:1.25rem;border-radius:2px;border:1px solid rgba(139,115,85,.3);font-family:Georgia,serif!important;font-style:italic;color:#3d2e22!important;line-height:1.8;white-space:pre-wrap;word-wrap:break-word;overflow-wrap:break-word;max-width:100%;min-width:0;overflow-x:hidden}.scroll-modal .story-modal-button{background:#8b7355;color:#f5e6c8}@media(max-width:768px){.final-story-content{max-height:35vh}.share-completion-block{padding:1rem}.share-completion-actions{flex-direction:column}.share-completion-btn{width:100%;min-width:0}.share-social-buttons{gap:.5rem}.share-social-btn{padding:.5rem .85rem;font-size:.85rem}.share-social-btn .share-social-icon{width:1.1rem;height:1.1rem}}@media(max-width:768px){.story-scrolls-panel{width:200px}.quest-log-header{padding:0 10px;height:40px}.quest-log-content{padding:10px}.quest-log-title{font-size:.85rem}.quest-log-stats,.region-name{font-size:.75rem}.region-count{font-size:.7rem}.scroll-item-btn{min-width:60px;padding:6px 8px}.scroll-title-short{font-size:.65rem;max-width:65px}}.camera-controls-container{position:fixed;bottom:var(--bottom-offset);right:var(--panel-offset);display:flex;flex-direction:column;align-items:flex-end;gap:8px;z-index:100;transition:all .3s cubic-bezier(.4,0,.2,1)}.camera-controls-container.ui-hidden{bottom:var(--bottom-offset)}.camera-buttons-row{display:flex;flex-direction:row;gap:6px;align-self:flex-end;justify-content:flex-end}.camera-btn{width:36px;height:36px;border-radius:8px;border:1px solid #8b7355;background:#0009;color:#c9b896;cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center;font-weight:600;transition:all .2s;padding:0;margin:0;line-height:1}.camera-btn:hover{background:#8b735566;border-color:#c9b896}@media(max-width:768px){.camera-buttons-row{flex-wrap:wrap;max-width:130px}}.camera-angle-pad{width:var(--pad-size)!important;height:var(--pad-size)!important;position:relative;background:#1a1510e6!important;border:1px solid #8b7355!important;border-radius:12px!important}.indicator-legend-btn{position:fixed;bottom:calc(var(--bottom-offset) + 34px);left:calc(var(--panel-offset) + var(--minimap-size) + 6px);width:28px;height:28px;border-radius:6px;border:1px solid #8b7355;background:#1a1510e6;color:#c9b896;cursor:pointer;font-size:.9rem;font-weight:600;display:flex;align-items:center;justify-content:center;z-index:100;transition:all .2s}@media(max-width:768px){.indicator-legend-btn{bottom:calc(var(--bottom-offset) + var(--minimap-size) - 28px);left:calc(var(--panel-offset) + var(--minimap-size) + 4px)}}.notification-container{position:fixed;top:10%;left:50%;transform:translate(-50%);z-index:900;pointer-events:none;display:flex;flex-direction:column;align-items:center;gap:.5rem;width:90%}@media(max-width:768px){.notification-item{font-size:.9rem!important;padding:.35rem .75rem!important}}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{width:100%;height:100%;overflow:hidden;background:#1a1510;touch-action:none;overscroll-behavior:none}body{font-family:system-ui,-apple-system,sans-serif;-webkit-font-smoothing:antialiased;cursor:grab;position:fixed}canvas{display:block;touch-action:none}.camera-angle-pad,.camera-angle-pad *{-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.portal-popover-anchor{position:fixed;bottom:8rem;left:50%;transform:translate(-50%);z-index:200;pointer-events:none}.portal-popover{background:linear-gradient(180deg,#1e1c19,#14120f);border:1.5px solid #00d4ff;border-radius:14px;padding:.85rem 1.25rem;min-width:180px;text-align:center;box-shadow:0 8px 32px #0009,0 0 20px #00d4ff26;pointer-events:auto;-webkit-user-select:none;user-select:none;opacity:0;transform:translateY(12px) scale(.92);transition:opacity .25s ease-out,transform .25s ease-out}.portal-popover.portal-popover-visible{opacity:1;transform:translateY(0) scale(1)}.portal-popover-icon{font-size:1.15rem;margin-bottom:.2rem;color:#00d4ff;text-shadow:0 0 8px rgba(0,212,255,.4)}.portal-popover-text{color:#c9d6e0;font-size:.85rem;line-height:1.4;margin:0 0 .65rem}.portal-popover-text strong{color:#00d4ff;font-weight:600}.portal-popover-actions{display:flex;gap:.5rem;justify-content:center}.portal-popover-btn{padding:.35rem 1rem;border-radius:7px;font-size:.82rem;font-weight:600;cursor:pointer;transition:background .15s,transform .1s;border:none}.portal-popover-btn:active{transform:scale(.95)}.portal-popover-confirm{background:linear-gradient(180deg,#00b8d4,#0097a7);color:#fff}.portal-popover-confirm:hover{background:linear-gradient(180deg,#00d4ff,#00b8d4)}.portal-popover-cancel{background:#ffffff14;color:#8a9aa8;border:1px solid rgba(255,255,255,.12)}.portal-popover-cancel:hover{background:#ffffff26;color:#c9d6e0}.settings-overlay{position:fixed;inset:0;background:#000000b3;display:flex;justify-content:center;align-items:flex-start;overflow-y:auto;z-index:3000;padding:2rem 1rem;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);-webkit-overflow-scrolling:touch}.settings-modal{background:linear-gradient(180deg,#2d2a26,#1a1816);border:2px solid #8b7355;border-radius:12px;max-width:420px;width:100%;padding:2.5rem 2rem;position:relative;box-shadow:0 20px 60px #000c;margin-bottom:2rem}@media(max-width:768px){.settings-modal{padding:2rem 1.25rem}}.settings-close{position:absolute;top:1rem;right:1rem;background:none;border:none;color:#c9b896;font-size:1.75rem;cursor:pointer;line-height:1;padding:0 .25rem;transition:color .2s}.settings-close:hover{color:#fff}.settings-title{color:#e8dcc4;font-size:1.5rem;margin-bottom:.25rem;font-family:Georgia,serif}.settings-subtitle{color:#a89878;font-size:.9rem;margin-bottom:1.25rem}.settings-section{margin-bottom:1.25rem}.settings-section:last-of-type{margin-bottom:0}.settings-checkbox{display:flex;align-items:center;gap:.75rem;cursor:pointer;-webkit-user-select:none;user-select:none}.settings-checkbox input{position:absolute;opacity:0;width:0;height:0}.settings-checkmark{width:22px;height:22px;min-width:22px;border:2px solid #8b7355;border-radius:6px;background:#0006;display:flex;align-items:center;justify-content:center;transition:background .2s,border-color .2s}.settings-checkbox input:checked+.settings-checkmark{background:#8b735580;border-color:#c9a55c}.settings-checkmark:after{content:"✓";color:#e8dcc4;font-size:14px;font-weight:700;line-height:1;opacity:0;transition:opacity .15s ease}.settings-checkbox input:checked+.settings-checkmark:after{opacity:1}.settings-label{color:#c9b896;font-size:.95rem}.settings-hint{color:#a89878;font-size:.8rem;margin:.4rem 0 0 2rem;line-height:1.4}.settings-slider-label{display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem}.settings-volume-value{color:#c9a55c;font-size:.9rem;font-weight:600}.settings-slider{width:100%;height:6px;border-radius:3px;background:#0006;accent-color:#8b7355;cursor:pointer}.settings-slider::-webkit-slider-thumb{width:18px;height:18px;border-radius:50%;background:#c9a55c;cursor:pointer;border:2px solid #8b7355}.settings-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#c9a55c;cursor:pointer;border:2px solid #8b7355}.settings-divider{height:1px;background:#8b73554d;margin:1.25rem 0}.settings-tutorial-btn{width:100%;padding:.6rem 1rem;border-radius:8px;border:1px solid #8b7355;background:#8b735526;color:#c9b896;font-size:.95rem;cursor:pointer;transition:background .2s;margin-bottom:.5rem}.settings-tutorial-btn:hover{background:#8b73554d}.settings-restart-btn{width:100%;padding:.6rem 1rem;border-radius:8px;border:1px solid #8b7355;background:#8b735526;color:#c9b896;font-size:.95rem;cursor:pointer;transition:background .2s,border-color .2s,color .2s}.settings-restart-btn:hover{background:#8b73554d}.settings-restart-btn.confirm{border-color:#e53935;background:#e5393526;color:#ff6b6b}.settings-restart-btn.confirm:hover{background:#e539354d}.settings-version{margin-top:1.5rem;padding-top:1rem;border-top:1px solid rgba(139,115,85,.2);font-size:.75rem;color:#6b5a42;text-align:center}.profile-overlay{position:fixed;inset:0;background:#000c;display:flex;justify-content:center;align-items:center;z-index:4000;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:1rem;box-sizing:border-box;overflow-y:auto;-webkit-overflow-scrolling:touch}.profile-modal{background:linear-gradient(180deg,#2d2a26,#1a1816);border:2px solid #8b7355;border-radius:16px;max-width:650px;width:100%;max-height:85vh;display:flex;flex-direction:column;position:relative;box-shadow:0 30px 80px #000000e6;animation:modalScaleUp .3s cubic-bezier(.34,1.56,.64,1);overflow:hidden;margin:auto}@keyframes modalScaleUp{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.profile-close{position:absolute;top:1.25rem;right:1.25rem;background:none;border:none;color:#c9b896;font-size:2rem;cursor:pointer;z-index:10;line-height:1}.profile-header{padding:2.5rem 2.5rem 1.5rem;display:flex;align-items:center;gap:1.5rem;background:#8b73551a;border-bottom:1px solid rgba(139,115,85,.2);flex-shrink:0}.profile-avatar{width:64px;height:64px;background:#8b7355;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:2.5rem;box-shadow:0 4px 12px #0000004d}.profile-name{color:#e8dcc4;font-size:1.75rem;margin:0;font-family:Georgia,serif}.profile-title{color:#a89878;margin:.25rem 0 0;font-size:1rem}.profile-tabs{display:flex;background:#0003;padding:0 1rem;border-bottom:1px solid rgba(139,115,85,.2);flex-shrink:0;align-items:stretch}.profile-tab{display:flex;align-items:center;padding:1rem 1.5rem;background:none;border:none;color:#a89878;cursor:pointer;font-weight:600;font-size:.95rem;position:relative;transition:color .2s;flex-shrink:0}.profile-tab.active{color:#c9a55c}.profile-tab.active:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:#c9a55c}.profile-content{flex:1;overflow-y:auto;padding:2rem 2.5rem;scrollbar-width:thin;scrollbar-color:#8b7355 transparent}.profile-text{color:#c9b896;line-height:1.6;font-size:1.05rem;margin-bottom:2rem}.profile-highlight{background:#8b735526;padding:1.25rem;border-radius:8px;border-left:4px solid #c9a55c;margin-top:1rem}.profile-highlight h4{color:#c9a55c;margin:0 0 .5rem;font-size:1.1rem;font-family:Georgia,serif}.profile-highlight p{color:#c9b896;margin:0;line-height:1.5}.profile-projects-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}.profile-project-card{background:#1a151080;border:1px solid rgba(139,115,85,.3);padding:1.5rem;border-radius:12px;transition:transform .2s}.profile-project-card:hover{transform:translateY(-4px);background:#8b73551a}.profile-project-card h5{color:#c9a55c;font-size:1.2rem;margin:0 0 .75rem}.project-tech-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin:1rem 0}.tech-tag{background:#8b735533;color:#a89878;padding:.2rem .6rem;border-radius:4px;font-size:.8rem;border:1px solid rgba(139,115,85,.3)}.teleport-btn{background:none;border:1px solid #8b7355;color:#c9b896;padding:.4rem .8rem;border-radius:6px;cursor:pointer;font-size:.85rem;transition:all .2s}.teleport-btn:hover{background:#8b7355;color:#fff}.skills-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.skill-group{background:#0003;padding:1rem;border-radius:8px;border:1px solid rgba(139,115,85,.2)}.skill-group h6{color:#c9a55c;margin:0 0 .5rem;font-size:1rem}.skill-group p{color:#a89878;margin:0;font-size:.9rem}.contact-links{display:flex;flex-direction:column;gap:1rem;margin:1.5rem 0}.contact-item{display:flex;align-items:center;justify-content:space-between;gap:1rem;background:#8b73550d;padding:.75rem 1rem;border-radius:10px;border:1px solid rgba(139,115,85,.1);transition:background .2s}.contact-item:hover{background:#8b73551a}.contact-item>span:first-child{display:flex;align-items:center;gap:.75rem;flex:1;min-width:0}.contact-item .link-text{color:#c9b896;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-action-btn{background:#8b735526;border:1px solid rgba(139,115,85,.4);color:#a89878;padding:.3rem .8rem;border-radius:6px;font-size:.8rem;cursor:pointer;margin-left:auto;transition:all .2s;display:inline-block;white-space:nowrap;flex-shrink:0}.profile-action-btn:hover{background:#8b73554d;border-color:#c9a55c;color:#c9a55c;transform:translateY(-1px)}.cv-download-btn{width:100%;padding:1rem;background:linear-gradient(180deg,#8b7355,#6e5a42);border:none;border-radius:8px;color:#fff;font-weight:700;font-size:1.1rem;margin-top:1rem;cursor:pointer;transition:filter .2s}.cv-download-btn:hover{filter:brightness(1.2)}.fade-in{animation:fadeIn .4s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.profile-overlay{padding:env(safe-area-inset-top,.5rem) .75rem env(safe-area-inset-bottom,.5rem);align-items:flex-start;min-height:100vh;min-height:100dvh}.profile-modal{max-height:min(90vh,calc(100dvh - 1.5rem));max-height:min(90vh,calc(100svh - 1.5rem));margin:.75rem auto;flex-shrink:0}.profile-header{padding:1.25rem 1rem;flex-direction:column;text-align:center;gap:.75rem}.profile-tabs{overflow-x:auto;white-space:nowrap;justify-content:flex-start;-webkit-overflow-scrolling:touch;scrollbar-width:none;min-height:48px}.profile-tabs::-webkit-scrollbar{display:none}.profile-tab{padding:.75rem 1rem;font-size:.85rem}.profile-content{padding:1.25rem;min-height:0;flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.skills-grid{grid-template-columns:1fr;gap:.75rem}.contact-item{padding:.75rem;min-width:0;flex-wrap:wrap}.contact-item .link-text{font-size:.8rem;word-break:break-all;white-space:normal}.profile-action-btn{padding:.3rem .6rem;font-size:.75rem;margin-left:0;width:100%;justify-content:center;display:flex}.profile-name{font-size:1.4rem}.profile-title{font-size:.9rem}}.tutorial-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1100;padding:1rem;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:tutorialFadeIn .35s ease-out}@keyframes tutorialFadeIn{0%{opacity:0}to{opacity:1}}.tutorial-card{background:linear-gradient(180deg,#2d2a26,#1a1816);border:2px solid #8b7355;border-radius:16px;max-width:420px;width:100%;padding:2rem 2rem 1.5rem;position:relative;box-shadow:0 24px 64px #0009,0 0 40px #8b735526;text-align:center;animation:tutorialSlideIn .35s ease-out}@keyframes tutorialSlideIn{0%{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.tutorial-card-exit{animation:tutorialSlideOut .25s ease-in forwards}@keyframes tutorialSlideOut{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-10px) scale(.98)}}.tutorial-skip{position:absolute;top:.75rem;right:1rem;background:none;border:none;color:#a89878;font-size:.85rem;cursor:pointer;transition:color .2s;padding:.25rem .5rem}.tutorial-skip:hover{color:#e8dcc4}.tutorial-progress{height:3px;background:#8b735533;border-radius:2px;margin-bottom:1.25rem;overflow:hidden}.tutorial-progress-bar{height:100%;background:linear-gradient(90deg,#c9a55c,#e8b840);border-radius:2px;transition:width .35s ease}.tutorial-step-indicator{display:flex;justify-content:center;gap:8px;margin-bottom:1.25rem}.tutorial-dot{width:8px;height:8px;border-radius:50%;background:#8b73554d;transition:background .3s,transform .3s}.tutorial-dot.active{background:#e8b840;transform:scale(1.3)}.tutorial-dot.done{background:#8b7355}.tutorial-icon{font-size:3rem;margin-bottom:.75rem;filter:drop-shadow(0 2px 8px rgba(0,0,0,.4))}.tutorial-title{color:#e8dcc4;font-size:1.5rem;font-family:Georgia,serif;margin-bottom:.5rem}.tutorial-desc{color:#c9b896;font-size:.95rem;line-height:1.6;margin-bottom:.75rem;min-height:3.2rem}.tutorial-portfolio-hint{color:#a89878;font-size:.85rem;line-height:1.5;margin:0 0 1.25rem;padding:.6rem .75rem;background:#8b735526;border-radius:8px;border:1px solid rgba(139,115,85,.25)}.tutorial-portfolio-hint strong{color:#c9a55c}.tutorial-actions{display:flex;justify-content:center;gap:.75rem;margin-bottom:1rem}.tutorial-btn{padding:.55rem 1.75rem;border-radius:8px;cursor:pointer;font-size:.95rem;transition:background .2s,transform .1s}.tutorial-btn:active{transform:scale(.97)}.tutorial-btn-next{background:linear-gradient(180deg,#8b7355,#6b5344);border:1px solid #a89878;color:#e8dcc4}.tutorial-btn-next:hover{background:linear-gradient(180deg,#9b8365,#7b6354)}.tutorial-btn-back{background:transparent;border:1px solid #8b7355;color:#a89878}.tutorial-btn-back:hover{background:#8b735526;color:#c9b896}.tutorial-hint{color:#6b5e4e;font-size:.75rem;margin:0}.portfolio-modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:2000;padding:1rem;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);overflow-y:auto;box-sizing:border-box}.portfolio-modal{background:linear-gradient(180deg,#2d2a26,#1a1816);border:2px solid #8b7355;border-radius:12px;max-width:500px;width:100%;min-width:0;max-height:85vh;overflow-y:auto;padding:2.5rem 2rem 2rem;position:relative;box-shadow:0 20px 60px #000c;scrollbar-width:thin;scrollbar-color:#8b7355 transparent;box-sizing:border-box}.portfolio-modal::-webkit-scrollbar{width:6px}.portfolio-modal::-webkit-scrollbar-thumb{background-color:#8b7355;border-radius:10px}.portfolio-modal-close{position:absolute;top:1rem;right:1.25rem;background:none;border:none;color:#c9b896;font-size:2rem;cursor:pointer;line-height:1;padding:0;transition:all .2s;z-index:10}.portfolio-modal-close:hover{color:#fff;transform:scale(1.1)}.portfolio-modal-title{color:#e8dcc4;font-size:1.85rem;margin-bottom:.25rem;font-family:Georgia,serif;letter-spacing:-.5px}.portfolio-modal-subtitle{color:#a89878;font-size:.9rem;margin-bottom:1.5rem;text-transform:uppercase;letter-spacing:1px}@media(max-width:768px){.portfolio-modal-overlay{padding:2rem .75rem;align-items:flex-start}.portfolio-modal{padding:1.75rem 1.25rem 1.25rem;max-height:calc(100dvh - 2rem);min-height:0;border-radius:12px;width:100%;max-width:min(500px,calc(100vw - 1.5rem));box-sizing:border-box;margin:auto 0}.portfolio-content-row{flex-wrap:wrap;gap:.5rem}.portfolio-content-row .row-actions{flex-basis:100%;margin-top:.25rem}.portfolio-modal-title{font-size:1.4rem;margin-bottom:.2rem}.portfolio-modal-subtitle{font-size:.75rem;margin-bottom:1rem}.portfolio-modal-content{font-size:.85rem;line-height:1.5}.story-modal .story-dialogue{font-size:.9rem;line-height:1.6;white-space:pre-wrap;word-break:break-word}.portfolio-modal-close{font-size:1.5rem;top:.5rem;right:.75rem}.story-modal-actions{margin-top:1.25rem;flex-direction:column;gap:.75rem}.story-modal-button{width:100%;padding:.7rem 1rem;font-size:.9rem}.hints-button{bottom:calc(var(--bottom-offset) + var(--minimap-size) - 28px - 34px)!important;left:calc(var(--panel-offset) + var(--minimap-size) + 4px)!important;width:28px!important;height:28px!important;border-radius:6px!important}}.portfolio-modal-content{color:#c9b896;font-size:.95rem;line-height:1.7;overflow-wrap:break-word;word-break:break-word;min-width:0}.portfolio-projects{min-width:0;list-style:none;padding:0;margin:0}.portfolio-project{min-width:0}.portfolio-text-content{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem}.portfolio-content-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;background:#8b735514;padding:.75rem 1rem;border-radius:8px;border:1px solid rgba(139,115,85,.15);transition:all .2s}.portfolio-content-row:hover{background:#8b73551f;border-color:#8b73554d}.row-main{flex:1;min-width:0;overflow-wrap:break-word;word-break:break-word}.row-label{color:#c9a55c;font-weight:600}.row-value{color:#c9b896}.modal-action-btn{background:#8b735533;border:1px solid rgba(139,115,85,.4);color:#a89878;padding:.35rem .75rem;border-radius:6px;font-size:.8rem;font-weight:600;cursor:pointer;white-space:nowrap;text-decoration:none;transition:all .2s}.modal-action-btn:hover{background:#8b735559;border-color:#c9a55c;color:#e8dcc4;transform:translateY(-1px)}.portfolio-project h3{color:#e8dcc4;font-size:1.2rem;margin-bottom:.5rem}.portfolio-project p{margin-bottom:1rem;color:#b8a888}.portfolio-project-tech{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.tech-tag{background:#8b735540;padding:.25rem .65rem;border-radius:4px;font-size:.75rem;color:#e8dcc4;border:1px solid rgba(139,115,85,.3)}.portfolio-project-link{display:inline-flex;align-items:center;color:#c9a55c;text-decoration:none;font-size:.9rem;font-weight:600;transition:color .2s}.portfolio-project-link:hover{color:#e8c57c}.story-modal .story-dialogue{font-size:1.05rem;line-height:1.7;color:#e8dcc4;white-space:pre-wrap;word-wrap:break-word;overflow-wrap:break-word;max-width:100%;min-width:0;overflow-x:hidden}.story-modal-actions{margin-top:2rem;display:flex;justify-content:flex-end;gap:1rem}.story-modal-button{background:linear-gradient(180deg,#8b7355,#6b5344);border:1px solid #a89878;color:#e8dcc4;padding:.65rem 1.75rem;border-radius:10px;cursor:pointer;font-size:1rem;font-weight:600;transition:all .2s;box-shadow:0 4px 12px #0000004d}.story-modal-button.secondary{background:transparent;border-color:#8b735580;color:#a89878}.story-modal-button:hover{background:linear-gradient(180deg,#9b8365,#7b6354);transform:translateY(-2px);box-shadow:0 6px 16px #0006}.story-modal-button:active{transform:translateY(0)}.intro-modal .portfolio-modal-content{font-size:1.1rem}.intro-modal .portfolio-text{font-family:inherit;font-size:inherit;line-height:1.65;color:#c9b896;white-space:pre-wrap;word-wrap:break-word;margin:0 0 1rem;padding:0;background:none;border:none;max-width:100%}.intro-dont-show{display:flex;align-items:center;gap:.75rem;margin-top:1.5rem;color:#c9b896;font-size:.95rem;cursor:pointer;-webkit-user-select:none;user-select:none}.intro-dont-show input{width:1.15rem;height:1.15rem;accent-color:#8b7355}.hints-button{position:fixed;bottom:calc(var(--bottom-offset) + 34px + 34px);left:calc(var(--panel-offset) + var(--minimap-size) + 6px);width:28px;height:28px;border-radius:6px;background:#1a1510e6;border:1px solid #8b7355;color:#c9b896;font-size:1rem;font-weight:700;cursor:pointer;z-index:90;display:flex;align-items:center;justify-content:center;transition:all .2s;box-shadow:0 4px 12px #00000080}.hints-button:hover{background:#2d2a26;border-color:#c9b896;transform:scale(1.1)}.hints-content section{margin-bottom:1.75rem}.hints-content h3{color:#e8dcc4;font-size:1.1rem;margin-bottom:.5rem;border-left:3px solid #8b7355;padding-left:.75rem}.hints-content p{color:#c9b896;font-size:.95rem;line-height:1.7;margin:0;white-space:pre-wrap}.scroll-pickup-badge{display:inline-block;background:linear-gradient(135deg,#8b7355 10%,#4a3c2a);border:1px solid #a89878;color:#fff8e8;padding:.4rem 1.25rem;border-radius:999px;font-size:.85rem;font-weight:700;margin-bottom:1rem;text-transform:uppercase;letter-spacing:.5px}.scroll-pickup-modal .portfolio-modal-content,.scroll-pickup-modal .portfolio-modal-content pre{white-space:pre-wrap;word-wrap:break-word;overflow-wrap:break-word;max-width:100%;min-width:0;overflow-x:hidden}.scroll-challenge-modal .scroll-challenge-content{margin-top:1.5rem}.scroll-challenge-prompt{color:#e8dcc4;font-size:1.1rem;margin-bottom:1.5rem}.scroll-challenge-rps{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.scroll-challenge-result,.scroll-challenge-outcome{color:#c9b896;margin-bottom:1rem;padding:.75rem;background:#0003;border-radius:8px}.scroll-challenge-math{display:flex;gap:1rem;align-items:center;margin-bottom:1rem}.scroll-challenge-input{background:#1a1816;border:1.5px solid #8b7355;color:#e8dcc4;padding:.75rem;border-radius:10px;font-size:1.1rem;width:7rem;text-align:center}.scroll-challenge-input:focus{outline:none;border-color:#c9b896;box-shadow:0 0 0 2px #8b73554d}.scroll-challenge-riddle{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.scroll-riddle-option{background:#8b73551a;border:1px solid rgba(139,115,85,.3);color:#c9b896;padding:1rem;border-radius:10px;cursor:pointer;text-align:left;transition:all .2s;font-size:.95rem}.scroll-riddle-option:hover{background:#8b735533;border-color:#8b735580}.scroll-riddle-option.selected{border-color:#a89878;background:#8b73554d}.scroll-riddle-option.correct{border-color:#4caf50;background:#4caf5033;color:#fff}.scroll-riddle-option.wrong{border-color:#e53935;background:#e5393533}.scroll-challenge-error{color:#ff5252;font-size:.95rem;margin-bottom:1rem;font-weight:600}.scroll-challenge-moved{color:#f0c674;font-size:1.1rem;margin-bottom:1.5rem;line-height:1.5;background:#f0c6741a;padding:1rem;border-radius:8px;border-left:4px solid #f0c674}.scroll-tooltip{position:fixed;transform:translate(-50%,calc(-100% - 12px));background:#1a1510f2;border:1.5px solid #8b7355;color:#e8dcc4;padding:.65rem 1.25rem;border-radius:10px;font-size:.9rem;z-index:150;pointer-events:none;max-width:280px;text-align:center;box-shadow:0 8px 24px #0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}@media(max-width:768px){.scroll-tooltip{max-width:200px;font-size:.8rem;padding:.5rem .75rem}}
