:root{--color-bg: #1a1f2e;--color-panel: #252b3d;--color-panel-raised: #2e3550;--color-panel-rgb: 37, 43, 61;--color-grass: #4a7c59;--color-accent: #f4a259;--color-accent-soft: #f4a25933;--color-teal: #7ec8c9;--color-text: #f0ebe1;--color-text-dim: #b7b2a5;--color-border: #3a4160;--font-display: "Press Start 2P", "DungGeunMo", monospace;--font-body: "JetBrains Mono", "Pretendard", "Noto Sans KR", monospace, sans-serif;--radius-md: 10px;--radius-lg: 16px;--topbar-height: 58px}[data-theme=dark]{--color-bg: #1a1f2e;--color-panel: #252b3d;--color-panel-raised: #2e3550;--color-panel-rgb: 37, 43, 61;--color-accent: #f4a259;--color-accent-soft: #f4a25933;--color-teal: #7ec8c9;--color-text: #f0ebe1;--color-text-dim: #b7b2a5;--color-border: #3a4160}[data-theme=light]{--color-bg: #f6f1e6;--color-panel: #fffdf8;--color-panel-raised: #ece4d3;--color-panel-rgb: 255, 253, 248;--color-accent: #f4a259;--color-accent-soft: #f4a25933;--color-teal: #4fa8a9;--color-text: #1a1f2e;--color-text-dim: #5b5f72;--color-border: #cfc9bd}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--color-bg);color:var(--color-text);font-family:var(--font-body);overflow:hidden;transition:background-color .25s ease,color .25s ease}body:has(.admin-page){overflow:auto}button{font-family:inherit;cursor:pointer}a{color:var(--color-teal);text-decoration:none}a:hover{text-decoration:underline}::selection{background:var(--color-accent);color:var(--color-bg)}.admin-page{min-height:100vh;padding:32px;background:var(--color-bg);color:var(--color-text)}.admin-hero{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;max-width:1180px;margin:0 auto 24px}.admin-kicker{margin:0 0 10px;color:var(--color-teal);font-weight:700;text-transform:uppercase}.admin-hero h1{margin:0 0 12px;font-family:var(--font-display);font-size:22px;line-height:1.5;color:var(--color-accent)}.admin-hero p{max-width:760px;margin:0;color:var(--color-text-dim);line-height:1.7}.admin-home-link,.admin-auth-panel button{border:2px solid var(--color-border);border-radius:8px;background:var(--color-panel-raised);color:var(--color-text);padding:12px 14px;font-weight:700}.admin-auth-panel{display:flex;gap:12px;max-width:1180px;margin:0 auto 18px}.admin-auth-panel input{flex:1;min-width:0;border:2px solid var(--color-border);border-radius:8px;background:var(--color-panel);color:var(--color-text);padding:12px 14px;font-family:inherit}.admin-error{max-width:1180px;margin:0 auto 18px;color:#ff9b9b}.admin-metrics,.admin-grid{max-width:1180px;margin:0 auto}.admin-metrics{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:18px}.admin-metric,.admin-panel{border:2px solid var(--color-border);border-radius:8px;background:var(--color-panel)}.admin-metric{padding:18px}.admin-metric span{display:block;margin-bottom:10px;color:var(--color-text-dim);font-size:13px}.admin-metric strong{font-size:28px;color:var(--color-accent)}.admin-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.admin-panel{padding:18px;min-width:0}.admin-panel-wide{grid-column:1 / -1}.admin-panel h2{margin:0 0 14px;font-size:18px}.admin-list{display:grid;gap:12px;max-height:520px;overflow:auto}.admin-list-item{border:1px solid var(--color-border);border-radius:8px;padding:12px;background:rgba(var(--color-panel-rgb),.55)}.admin-list-heading,.admin-event-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:center}.admin-list-heading span,.admin-list-item p,.admin-event-row{color:var(--color-text-dim);font-size:13px}.admin-list-item p{margin:8px 0 0;line-height:1.5;word-break:break-word}.admin-event-table{overflow:auto}.admin-event-row{grid-template-columns:1.5fr 1fr .6fr .8fr;padding:10px 0;border-bottom:1px solid var(--color-border)}.admin-event-row-head{color:var(--color-text);font-weight:700}@media (max-width: 820px){.admin-page{padding:20px}.admin-hero,.admin-auth-panel{flex-direction:column}.admin-auth-panel button{width:100%}.admin-metrics,.admin-grid{grid-template-columns:1fr}.admin-panel-wide{grid-column:auto}.admin-event-row{grid-template-columns:1fr .8fr .5fr}.admin-event-row span:last-child{display:none}}.intro-screen{position:relative;height:100%;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 30% 20%,#2a3550 0%,var(--color-bg) 60%);padding:24px}.intro-grid-bg{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(124,200,201,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(124,200,201,.06) 1px,transparent 1px);background-size:32px 32px;pointer-events:none}.intro-card{position:relative;z-index:1;background:var(--color-panel);border:3px solid var(--color-border);border-radius:var(--radius-lg);padding:40px 36px;max-width:760px;width:100%;text-align:left;box-shadow:0 0 0 6px #f4a25914,0 20px 60px #00000080}.intro-badge{display:inline-block;font-family:var(--font-display);font-size:9px;letter-spacing:2px;color:var(--color-bg);background:var(--color-accent);padding:6px 10px;border-radius:4px;margin-bottom:18px}.intro-title{font-family:var(--font-display);font-size:24px;margin:0 0 12px;line-height:1.5;color:var(--color-text)}.intro-name{margin:0 0 8px;color:var(--color-text-dim);font-weight:700}.intro-role{font-size:14px;color:var(--color-teal);margin:0 0 14px;font-weight:600}.intro-tagline{font-size:13px;color:var(--color-text-dim);line-height:1.7;margin:0 0 28px}.intro-keywords{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 20px}.intro-keywords span{border:1px solid var(--color-border);border-radius:6px;background:var(--color-panel-raised);color:var(--color-teal);padding:7px 9px;font-size:12px;font-weight:700}.intro-proof-grid{display:grid;grid-template-columns:130px minmax(0,1fr);gap:8px 12px;margin:0 0 24px;padding:14px;border:1px solid var(--color-border);border-radius:8px;background:rgba(var(--color-panel-rgb),.58);font-size:12px;line-height:1.5}.intro-proof-grid strong{color:var(--color-accent)}.intro-proof-grid span{color:var(--color-text-dim)}.btn-primary{font-family:var(--font-display);font-size:12px;background:var(--color-accent);color:var(--color-bg);border:none;padding:16px 22px;border-radius:var(--radius-md);width:100%;box-shadow:0 4px #c4863f;transition:transform .08s ease}.btn-primary:active{transform:translateY(4px);box-shadow:0 0 #c4863f}.intro-skip{font-size:12px;color:var(--color-text-dim);margin:16px 0 0}.intro-controls{display:flex;flex-wrap:wrap;gap:4px;margin-top:24px;padding-top:18px;border-top:1px dashed var(--color-border);font-size:11px;color:var(--color-text-dim)}@media (max-width: 640px){.intro-screen{align-items:flex-start;overflow:auto}.intro-card{padding:28px 22px}.intro-title{font-size:19px}.intro-proof-grid{grid-template-columns:1fr}}.app-shell{position:relative;height:100%;display:flex;flex-direction:column}.top-bar{position:relative;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 20px;background:rgba(var(--color-panel-rgb),.78);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-bottom:2px solid var(--color-border);z-index:60}.top-bar-name{font-family:var(--font-display);font-size:12px;color:var(--color-accent);white-space:nowrap;flex-shrink:0}.top-bar-nav{display:flex;gap:4px;overflow-x:auto;scrollbar-width:none;min-width:0}.top-bar-nav::-webkit-scrollbar{display:none}.top-bar-link{display:flex;align-items:center;gap:6px;background:transparent;border:1px solid transparent;color:var(--color-text-dim);font-size:12px;padding:8px 10px;border-radius:6px;transition:transform .1s steps(2,jump-end),background .15s,color .15s,border-color .15s}.top-bar-link:hover{background:var(--color-panel-raised);color:var(--color-text);transform:translateY(-2px)}.top-bar-link.active{color:var(--color-text);background:color-mix(in srgb,var(--zone-color) 22%,transparent);border-color:var(--zone-color);box-shadow:0 0 0 1px color-mix(in srgb,var(--zone-color) 40%,transparent)}.top-bar-link-icon{font-size:13px;line-height:1}.top-bar-name{cursor:pointer;transition:transform .15s ease,color .15s ease;-webkit-user-select:none;user-select:none}.top-bar-name:hover{transform:scale(1.05);color:#ff9f43}.top-bar-name:active{transform:scale(.98)}.top-bar-name:focus{outline:2px solid #ff9f43;outline-offset:4px}@media (max-width: 768px){.top-bar-name{padding:4px 8px}.app-shell{height:100dvh}.top-bar{padding:8px 12px;padding-top:calc(8px + env(safe-area-inset-top))}.footer-hint{display:none}}@media (max-width: 480px){.top-bar{padding:10px 12px}.top-bar-nav-desktop .top-bar-link{padding:6px 8px;font-size:0}.top-bar-nav-desktop .top-bar-link-icon{font-size:16px}}.hamburger-btn{display:none;align-items:center;justify-content:center;width:38px;height:38px;background:var(--color-panel-raised);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text);font-size:18px;flex-shrink:0;transition:transform .1s steps(2,jump-end),background .15s,border-color .15s}.hamburger-btn:hover{background:var(--color-accent-soft);border-color:var(--color-accent);transform:translateY(-2px)}.theme-toggle-btn{display:flex;align-items:center;gap:6px;background:var(--color-panel-raised);border:1px solid var(--color-border);color:var(--color-text);font-family:var(--font-display);font-size:10px;padding:9px 10px;border-radius:6px;flex-shrink:0;transition:transform .08s ease,background .15s,border-color .15s}.theme-toggle-btn:hover{background:var(--color-accent-soft);border-color:var(--color-accent);transform:translateY(-2px)}.theme-toggle-btn:active{transform:scale(.92)}.theme-toggle-icon{font-size:14px;line-height:1}[data-theme=dark] .theme-toggle-icon{animation:themeMoonGlow 2.4s ease-in-out infinite}@keyframes themeMoonGlow{0%,to{filter:drop-shadow(0 0 0 transparent)}50%{filter:drop-shadow(0 0 6px var(--color-teal))}}@media (max-width: 480px){.theme-toggle-btn{padding:8px;gap:0}.theme-toggle-label{display:none}}.mobile-menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0c148c;border:none;padding:0;z-index:9;animation:fadeIn .15s ease}.mobile-menu-panel{position:absolute;top:100%;right:12px;left:12px;z-index:11;background:var(--color-panel);border:2px solid var(--color-border);border-top:3px solid var(--color-accent);border-radius:var(--radius-md);padding:14px;display:flex;flex-direction:column;gap:14px;box-shadow:0 16px 40px #00000073;animation:modalRise .18s ease}.mobile-menu-nav{display:flex;flex-direction:column;gap:6px}.mobile-menu-link{width:100%;font-size:14px;padding:12px 14px;justify-content:flex-start}.mobile-menu-downloads{display:flex;flex-direction:column;gap:10px;padding-top:10px;border-top:1px dashed var(--color-border)}.top-bar-downloads{display:flex;gap:6px;flex-shrink:0}.download-btn{display:flex;align-items:center;gap:6px;background:var(--color-panel-raised);border:1px solid var(--color-border);color:var(--color-text);font-size:12px;padding:8px 10px;border-radius:6px;transition:transform .1s steps(2,jump-end),background .15s,border-color .15s}.download-btn:hover{background:var(--color-accent-soft);border-color:var(--color-accent);transform:translateY(-2px)}.download-btn.is-pressed{transform:scale(.92);background:var(--color-accent);color:var(--color-bg)}.download-btn-icon{font-size:14px;line-height:1}.download-btn-pdf{font-size:11px;opacity:.7}.download-btn-large{width:100%;justify-content:center;padding:14px 18px;font-size:13px;border-radius:var(--radius-md)}.download-btn-large .download-btn-icon{font-size:18px}@media (max-width: 480px){.top-bar-downloads-desktop .download-btn{padding:6px 8px;font-size:0;gap:0}.top-bar-downloads-desktop .download-btn-icon{font-size:16px}.top-bar-downloads-desktop .download-btn-pdf{display:none}}.game-stage{position:relative;flex:1;min-height:0}.quick-nav{position:absolute;right:18px;bottom:84px;z-index:8;width:min(320px,calc(100% - 36px));background:rgba(var(--color-panel-rgb),.9);border:2px solid var(--color-border);border-radius:8px;padding:14px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 12px 34px #00000052}.quick-nav-title{font-family:var(--font-display);font-size:11px;color:var(--color-accent);margin-bottom:10px}.quick-nav-list{display:grid;gap:6px}.quick-nav-item{display:grid;grid-template-columns:10px minmax(0,1fr);align-items:center;gap:8px;width:100%;border:1px solid transparent;border-radius:6px;background:transparent;color:var(--color-text);padding:8px;font-size:12px;text-align:left}.quick-nav-item:hover{background:var(--color-panel-raised);border-color:var(--color-border)}.quick-nav-dot{width:8px;height:8px;border-radius:2px;background:var(--quick-color)}@media (max-width: 768px){.quick-nav{display:none}}.game-stage canvas{display:block;width:100%;height:100%}.zone-hint{position:absolute;bottom:calc(20px + env(safe-area-inset-bottom));left:50%;transform:translate(-50%);background:var(--color-panel);border:2px solid var(--color-accent);border-radius:var(--radius-md);padding:10px 16px;display:flex;align-items:center;gap:8px;font-size:13px;animation:bob 1.2s ease-in-out infinite;z-index:5;pointer-events:none}.zone-hint-icon{font-size:16px}.zone-hint-key{font-size:10px;color:var(--color-bg);background:var(--color-accent);padding:3px 7px;border-radius:4px;margin-left:6px}@keyframes bob{0%,to{transform:translate(-50%)}50%{transform:translate(-50%,-6px)}}.zone-enter-hint{border-color:var(--zone-color, var(--color-accent));pointer-events:auto;cursor:pointer;font-family:inherit;color:var(--color-text)}.zone-enter-hint .zone-hint-key{background:var(--zone-color, var(--color-accent));color:var(--color-bg)}.zone-enter-hint:hover{background:var(--color-panel-raised)}.mailbox-hint{border-color:#4a78a0;pointer-events:auto;cursor:pointer;font-family:inherit;color:var(--color-text)}.mailbox-hint .zone-hint-key{background:#4a78a0}.mailbox-hint:hover{background:var(--color-panel-raised)}.ai-npc-hint{border-color:#7ec8c9;pointer-events:auto;cursor:pointer;font-family:inherit;color:var(--color-text)}.ai-npc-hint .zone-hint-key{background:#7ec8c9;color:var(--color-bg)}.ai-npc-hint:hover{background:var(--color-panel-raised)}.footer-hint{text-align:center;font-size:11px;color:var(--color-text-dim);padding:8px;background:rgba(var(--color-panel-rgb),.78);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-top:1px solid var(--color-border)}.joystick-base{position:absolute;bottom:calc(70px + env(safe-area-inset-bottom));left:calc(30px + env(safe-area-inset-left));width:96px;height:96px;border-radius:50%;background:rgba(var(--color-panel-rgb),.7);border:2px solid var(--color-border);z-index:6;touch-action:none}.joystick-knob{position:absolute;top:50%;left:50%;width:44px;height:44px;margin:-22px 0 0 -22px;border-radius:50%;background:var(--color-accent);box-shadow:0 2px 8px #0006}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0c14b3;display:flex;align-items:center;justify-content:center;z-index:50;padding:20px;animation:fadeIn .18s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalRise{0%{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-panel{position:relative;background:var(--color-panel);border:3px solid var(--color-border);border-top:5px solid var(--zone-color, var(--color-accent));border-radius:var(--radius-lg);max-width:920px;width:100%;max-height:84vh;overflow-y:auto;animation:modalRise .22s ease;padding:32px;box-shadow:0 0 0 6px #f4a2590f,0 30px 80px #00000080}.modal-close{position:absolute;top:16px;right:16px;background:var(--color-panel-raised);border:none;color:var(--color-text);width:32px;height:32px;border-radius:8px;font-size:18px;line-height:1}.modal-close:hover{background:var(--color-accent);color:var(--color-bg)}.modal-top-button{position:sticky;bottom:0;float:right;z-index:2;margin:18px 0 0 12px;border:2px solid var(--zone-color, var(--color-accent));border-radius:8px;background:var(--color-panel-raised);color:var(--color-text);font-family:var(--font-display);font-size:10px;padding:10px 12px;box-shadow:0 8px 22px #00000059}.modal-top-button:hover{background:var(--zone-color, var(--color-accent));color:var(--color-bg)}.modal-eyebrow{font-size:12px;color:var(--color-accent);font-weight:700;letter-spacing:1px;margin-bottom:8px}.modal-title{font-family:var(--font-display);font-size:18px;margin:0 0 16px;line-height:1.6}.modal-meta{font-size:12px;color:var(--color-text-dim);margin:0 0 20px}.modal-paragraph{font-size:14px;line-height:1.8;color:var(--color-text);margin:0 0 14px}.skills-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}@media (max-width: 520px){.skills-grid{grid-template-columns:1fr}}.skill-card{background:var(--color-panel-raised);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:16px}.skill-card-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px}.skill-name{font-weight:700;font-size:14px}.skill-category{font-size:10px;color:var(--color-teal);text-transform:uppercase}.skill-level{display:flex;gap:4px;margin-bottom:10px}.skill-pip{width:14px;height:6px;border-radius:2px;background:var(--color-border)}.skill-pip.on{background:var(--color-accent)}.skill-desc{font-size:12px;line-height:1.6;color:var(--color-text-dim);margin:0}.timeline{display:flex;flex-direction:column;gap:24px;position:relative;padding-left:20px;border-left:2px dashed var(--color-border)}.timeline-item{position:relative}.timeline-marker{position:absolute;left:-27px;top:4px;width:12px;height:12px;border-radius:50%;background:var(--color-accent);box-shadow:0 0 0 4px var(--color-panel)}.timeline-year{font-size:11px;color:var(--color-teal);font-weight:700;margin-bottom:4px}.timeline-company{font-size:15px;margin:0 0 2px}.timeline-role{font-size:12px;color:var(--color-text-dim);margin-bottom:8px}.timeline-summary{font-size:13px;line-height:1.7;margin:0 0 10px}.timeline-highlights{margin:0;padding-left:18px;font-size:12px;color:var(--color-text-dim);line-height:1.8}.project-achievements{list-style:none;margin:0 0 10px;padding:0;display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--color-text-dim)}.project-achievements li{padding-left:16px;position:relative}.project-achievements li:before{content:"✓";position:absolute;left:0;color:var(--color-accent)}.projects-grid{display:flex;flex-direction:column;gap:14px}.project-card{background:var(--color-panel-raised);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:18px}.project-name{font-size:15px;margin:0 0 8px}.project-desc{font-size:13px;line-height:1.7;color:var(--color-text-dim);margin:0 0 12px}.project-tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}.project-tag{font-size:10px;background:var(--color-accent-soft);color:var(--color-accent);padding:4px 8px;border-radius:4px}.project-link{font-size:12px;font-weight:600}.project-detail-grid{gap:18px}.project-detail-card{padding:22px}.project-detail-sections{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.project-detail-section{border:1px solid var(--color-border);border-radius:8px;background:rgba(var(--color-panel-rgb),.45);padding:12px}.project-detail-section h3,.project-detail-section h4{margin:0 0 8px;font-size:12px;color:var(--color-accent)}.project-detail-section p{margin:0;color:var(--color-text-dim);font-size:12px;line-height:1.7}.project-tags-compact{margin-bottom:0}.project-detail-list,.interview-list{margin:0;padding-left:18px;color:var(--color-text-dim);font-size:12px;line-height:1.8}.architecture-inline{display:grid;gap:4px;margin:14px 0;padding:12px;border-left:4px solid var(--zone-color, var(--color-accent));background:var(--color-panel);border-radius:6px;font-size:12px}.architecture-inline strong{color:var(--color-teal)}.architecture-inline span{color:var(--color-text-dim);line-height:1.6}.interview-section{margin-top:12px}.interview-list li{margin-bottom:4px}.architecture-flow{display:grid;gap:8px;margin:20px 0}.architecture-step{display:grid;gap:8px;justify-items:center}.architecture-node{width:100%;border:2px solid var(--color-border);border-radius:8px;background:var(--color-panel-raised);padding:14px}.architecture-node-label{display:inline-block;margin-bottom:6px;color:var(--color-accent);font-size:11px;font-weight:700;text-transform:uppercase}.architecture-node strong{display:block;margin-bottom:6px;color:var(--color-text);font-size:14px}.architecture-node p{margin:0;color:var(--color-text-dim);font-size:12px;line-height:1.7}.architecture-arrow{color:var(--color-teal);font-family:var(--font-display);font-size:16px}@media (max-width: 700px){.project-detail-sections{grid-template-columns:1fr}.modal-panel{padding:24px 18px}}.contact-email{display:block;font-size:16px;font-weight:700;color:var(--color-accent);margin:4px 0;transition:transform .1s steps(2,jump-end),color .15s}.contact-email:hover{color:var(--color-teal);transform:translate(3px)}.contact-email:last-of-type{margin-bottom:20px}.contact-links{display:flex;gap:12px}.contact-link{font-size:13px;background:var(--color-panel-raised);padding:10px 16px;border-radius:var(--radius-md);border:1px solid var(--color-border);transition:transform .1s steps(2,jump-end),background .15s,border-color .15s,color .15s}.contact-link:hover{background:var(--color-accent-soft);border-color:var(--color-accent);color:var(--color-text);transform:translateY(-2px)}.mailbox-modal-actions{display:flex;flex-direction:column;gap:12px;margin-top:8px}@media (max-width: 768px){.top-bar-nav-desktop,.top-bar-downloads-desktop{display:none}.hamburger-btn{display:flex}}@media (prefers-reduced-motion: reduce){.zone-hint{animation:none}}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.chat-widget-button{position:fixed;right:calc(20px + env(safe-area-inset-right));bottom:calc(20px + env(safe-area-inset-bottom));z-index:70;font-family:var(--font-display);font-size:12px;background:var(--color-accent);color:var(--color-bg);border:none;padding:14px 18px;border-radius:var(--radius-md);box-shadow:0 4px #c4863f,0 12px 30px #0006;transition:transform .08s ease}.chat-widget-button:hover{transform:translateY(-2px)}.chat-widget-button:active{transform:translateY(2px);box-shadow:0 0 #c4863f}.chat-modal-overlay{z-index:70}.chat-modal-panel{display:flex;flex-direction:column;max-width:420px;max-height:84vh;overflow-y:auto;padding:24px 20px 20px;border-top:5px solid var(--color-teal)}.chat-modal-header{display:flex;align-items:center;gap:8px;margin:0 0 14px;padding-right:28px}.chat-modal-title{font-family:var(--font-display);font-size:14px;color:var(--color-teal)}.contact-form{display:flex;flex-direction:column;gap:14px}.contact-form-intro{margin:0 0 4px;font-size:12.5px;line-height:1.8;color:var(--color-text-dim);border:1px dashed var(--color-border);border-radius:var(--radius-md);padding:12px 14px;background:var(--color-panel-raised)}.contact-field{display:flex;flex-direction:column;gap:6px}.contact-field-label{font-family:var(--font-display);font-size:11px;color:var(--color-text)}.contact-input{width:100%;font-family:var(--font-body);font-size:13px;background:var(--color-panel-raised);border:1px solid var(--color-border);color:var(--color-text);padding:10px 12px;border-radius:var(--radius-md);resize:none}.contact-input:focus{border-color:var(--color-accent)}.contact-textarea{min-height:110px;line-height:1.6}.contact-form-error{margin:0;font-size:12px;color:#e57373}.contact-form-success{margin:0;font-size:12px;color:#6fcf73}.contact-send-btn{align-self:flex-end;font-family:var(--font-display);font-size:12px;background:var(--color-accent);color:var(--color-bg);border:none;padding:12px 22px;border-radius:var(--radius-md);box-shadow:0 3px #c4863f}.contact-send-btn:active{transform:translateY(3px);box-shadow:0 0 #c4863f}.contact-send-btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 480px){.chat-modal-panel{width:100vw;height:100dvh;max-width:none;max-height:none;border-radius:0;border-top-width:5px}}.npc-chat-modal-overlay{z-index:70}.npc-chat-modal-panel{display:flex;flex-direction:column;max-width:460px;max-height:84vh;padding:24px 20px 20px;border-top:5px solid #7ec8c9}.npc-chat-modal-header{display:flex;align-items:center;gap:8px;margin:0 0 14px;padding-right:28px}.npc-chat-modal-title{font-family:var(--font-display);font-size:13px;color:#7ec8c9}.npc-chat-messages{display:flex;flex-direction:column;gap:10px;overflow-y:auto;min-height:180px;max-height:42vh;padding-right:2px;margin-bottom:12px}.npc-chat-bubble{font-size:13px;line-height:1.6;padding:10px 14px;border-radius:var(--radius-md);white-space:pre-line;max-width:88%}.npc-chat-bubble-model{align-self:flex-start;background:var(--color-panel-raised);border:1px solid var(--color-border);color:var(--color-text)}.npc-chat-bubble-user{align-self:flex-end;background:var(--color-accent);color:var(--color-bg)}.npc-chat-bubble-loading{display:flex;gap:4px;align-items:center;padding:12px 14px}.npc-chat-dot{width:6px;height:6px;border-radius:50%;background:var(--color-text-dim);animation:npcChatDotPulse 1s ease-in-out infinite}.npc-chat-dot:nth-child(2){animation-delay:.15s}.npc-chat-dot:nth-child(3){animation-delay:.3s}@keyframes npcChatDotPulse{0%,to{opacity:.3;transform:translateY(0)}50%{opacity:1;transform:translateY(-3px)}}.npc-chat-error{margin:0 0 10px;font-size:12px;color:#e57373}.npc-chat-suggestions{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.npc-chat-suggestion-btn{font-family:var(--font-body);font-size:11.5px;line-height:1.4;background:var(--color-panel-raised);border:1px solid var(--color-border);color:var(--color-text-dim);padding:6px 10px;border-radius:var(--radius-md)}.npc-chat-suggestion-btn:hover{border-color:#7ec8c9;color:var(--color-text)}.npc-chat-suggestion-btn:disabled{opacity:.5;cursor:not-allowed}.npc-chat-input-row{display:flex;gap:8px}.npc-chat-input{flex:1;min-width:0;font-family:var(--font-body);font-size:13px;background:var(--color-panel-raised);border:1px solid var(--color-border);color:var(--color-text);padding:10px 12px;border-radius:var(--radius-md)}.npc-chat-input:focus{border-color:#7ec8c9}.npc-chat-send-btn{font-family:var(--font-display);font-size:12px;background:#7ec8c9;color:var(--color-bg);border:none;padding:0 18px;border-radius:var(--radius-md);box-shadow:0 3px #5fa3a4}.npc-chat-send-btn:active{transform:translateY(3px);box-shadow:0 0 #5fa3a4}.npc-chat-send-btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 480px){.npc-chat-modal-panel{width:100vw;height:100dvh;max-width:none;max-height:none;border-radius:0;border-top-width:5px}.npc-chat-messages{max-height:none;flex:1}}.online-visitors-badge{position:fixed;top:calc(var(--topbar-height) + 12px);right:16px;z-index:65;background:var(--color-panel);border:2px solid var(--color-border);border-radius:var(--radius-md);padding:8px 12px;font-family:var(--font-display);font-size:10px;color:var(--color-text);display:flex;flex-direction:column;gap:6px;pointer-events:none;box-shadow:0 2px 8px #00000040}.online-visitors-row{display:flex;align-items:center;gap:6px;white-space:nowrap}.online-visitors-total{color:var(--color-text-dim)}.online-status-dot{width:8px;height:8px;border-radius:50%;background:var(--color-text-dim);flex-shrink:0}.online-status-dot-connected{background:#4caf50;animation:onlineDotPulse 1.6s ease-in-out infinite}.online-status-dot-connecting{background:var(--color-accent);animation:onlineDotPulse .9s ease-in-out infinite}.online-status-dot-disconnected{background:#e25c5c}@keyframes onlineDotPulse{0%,to{opacity:1;box-shadow:0 0 #4caf5066}50%{opacity:.6;box-shadow:0 0 0 4px #4caf5000}}@media (max-width: 768px){.online-visitors-badge{top:calc(var(--topbar-height) + 16px)}}@media (max-width: 480px){.online-visitors-badge{right:8px;padding:6px 9px;font-size:9px}}
