.content-container{display:flex;width:100%;padding:var(--spacing-lg) 0}.left-area{width:var(--sidebar-width);margin:0 var(--spacing-lg)}.middle-area{width:var(--central-width)}.right-area{width:var(--sidebar-width);margin:0 var(--spacing-lg)}html[data-view-mode=compact] .content-container{padding:var(--spacing-md)}html[data-view-mode=compact] .middle-area,html[data-view-mode=compact] .middle-area--solo{width:100%;max-width:100%}.news-feed{max-height:80vh;overflow-y:auto}.news-article{margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:1px dashed var(--color-border)}.news-article:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.news-article h3{color:var(--color-primary);margin-top:0;margin-bottom:var(--spacing-sm);font-size:var(--font-size-lg)}.news-date{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-md)}.news-article{cursor:pointer;transition:background-color .3s ease}.news-article:hover{background-color:color-mix(in srgb,var(--color-primary),transparent 90%)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl);background-color:color-mix(in srgb,var(--color-background),transparent 35%);z-index:var(--z-index-modal-backdrop)}.modal-content{width:min(900px,92vw);max-height:90vh;background-color:var(--color-secondary);border:1px solid var(--color-border);border-radius:var(--border-radius-md);box-shadow:var(--shadow-lg);z-index:var(--z-index-modal);display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);padding:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.modal-header h2{margin:0;font-size:var(--font-size-xl)}.close-button{background-color:transparent;color:var(--color-text-primary);border:1px solid var(--color-border);padding:var(--spacing-xs) var(--spacing-sm);margin-left:0}.close-button:hover{background-color:color-mix(in srgb,var(--color-primary),transparent 90%)}.modal-body{padding:var(--spacing-lg);overflow:auto}.modal-footer{display:flex;justify-content:flex-end;padding:var(--spacing-lg);border-top:1px solid var(--color-border)}.article-content{color:var(--color-text-primary)}.article-content p{margin:0 0 var(--spacing-md)}.article-content h1,.article-content h2,.article-content h3{color:var(--color-primary);margin:var(--spacing-lg) 0 var(--spacing-sm)}.article-content ul,.article-content ol{margin:0 0 var(--spacing-md);padding-left:var(--spacing-xl)}.article-content code{font-family:var(--font-family-mono);font-size:.95em;background-color:color-mix(in srgb,var(--color-background),transparent 70%);padding:0 var(--spacing-xs);border-radius:var(--border-radius-sm)}.article-content pre{margin:0 0 var(--spacing-md);padding:var(--spacing-md);overflow:auto;background-color:color-mix(in srgb,var(--color-background),transparent 70%);border:1px solid var(--color-border);border-radius:var(--border-radius-sm)}.article-content pre code{background-color:transparent;padding:0}.article-content blockquote{margin:0 0 var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);border-left:3px solid var(--color-border);color:var(--color-text-secondary)}.article-content a{color:var(--color-primary)}.murmurs-feed{max-height:50vh;overflow:hidden}.murmurs-feed.is-scrollable{overflow-y:auto}.murmur-item{padding:var(--spacing-sm);border-bottom:1px dashed var(--color-border)}.murmur-item:last-child{border-bottom:none}.murmur-item:hover{background-color:color-mix(in srgb,var(--color-primary),transparent 90%)}.murmur-meta{display:flex;gap:var(--spacing-sm);font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-xs)}.murmur-message{color:var(--color-text);word-break:break-word}.room-carousel{padding:var(--spacing-md)}.room-carousel__viewport{position:relative;width:100%;aspect-ratio:1 / 1;border:1px solid var(--color-border);border-radius:var(--border-radius-md);overflow:hidden;box-shadow:var(--shadow-md);background-color:var(--color-background-lighter)}.room-carousel__track{display:flex;width:100%;height:100%;transition:transform .65s cubic-bezier(.22,1,.36,1);will-change:transform}.room-carousel__slide{position:relative;flex:0 0 100%;height:100%;background-color:var(--color-secondary)}.room-carousel__image{width:100%;height:100%;object-fit:cover;display:block;position:absolute;z-index:1}.room-carousel__image-fallback{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg);color:var(--color-text-secondary);background-color:var(--color-secondary)}.room-carousel__overlay{position:absolute;left:0;right:0;bottom:0;padding:var(--spacing-sm) var(--spacing-md);background-color:color-mix(in srgb,var(--color-background),transparent 35%);border-top:1px solid var(--color-border);display:flex;align-items:baseline;justify-content:space-between;flex-direction:column;gap:var(--spacing-md)}.room-carousel__name{color:var(--color-text-primary);font-size:var(--font-size-md);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.room-carousel__hint{color:var(--color-text-secondary);font-size:var(--font-size-xs)}.room-carousel__placeholder{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.main-content-area{display:flex;flex-direction:column;align-items:center;width:100%;height:calc(100% - var(--header-height))}html[data-view-mode=compact] .main-content-area{height:100%}.language-switcher{display:flex;align-items:center}.language-select{background-color:var(--color-secondary);color:var(--color-text-primary);border:1px solid var(--color-border);border-radius:var(--border-radius-sm);padding:var(--spacing-sm);font-family:var(--font-family-primary);font-size:var(--font-size-sm)}.language-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px color-mix(in srgb,var(--color-primary),transparent 50%)}.language-switcher--list{width:100%}.language-switcher-list{display:flex;flex-direction:column;gap:6px}.language-option-button{width:100%;text-align:left;padding:8px 10px;border-radius:10px;border:1px solid transparent;background:color-mix(in srgb,var(--color-secondary) 70%,transparent);color:var(--color-text-primary);font-family:var(--font-family-primary);font-size:var(--font-size-sm)}.language-option-button:hover{background:color-mix(in srgb,var(--color-secondary) 55%,transparent)}.language-option-button.is-active{border-color:color-mix(in srgb,var(--color-primary) 70%,transparent);background:color-mix(in srgb,var(--color-primary) 14%,var(--color-secondary))}.theme-switcher{display:flex;align-items:center;gap:var(--spacing-sm)}.theme-switcher label{font-weight:700;color:var(--color-text-primary)}.theme-select{background-color:var(--color-secondary);color:var(--color-text-primary);border:1px solid var(--color-border);border-radius:var(--border-radius-sm);padding:var(--spacing-sm);font-family:var(--font-family-primary);font-size:var(--font-size-sm)}.theme-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px color-mix(in srgb,var(--color-primary),transparent 50%)}.theme-switcher--list{width:100%}.theme-switcher-list{display:flex;flex-direction:column;gap:6px}.theme-option-button{width:100%;text-align:left;padding:8px 10px;border-radius:10px;border:1px solid transparent;background:color-mix(in srgb,var(--color-secondary) 70%,transparent);color:var(--color-text-primary);font-family:var(--font-family-primary);font-size:var(--font-size-sm)}.theme-option-button:hover{background:color-mix(in srgb,var(--color-secondary) 55%,transparent)}.theme-option-button.is-active{border-color:color-mix(in srgb,var(--color-primary) 70%,transparent);background:color-mix(in srgb,var(--color-primary) 14%,var(--color-secondary))}.top-nav-bar{background-color:var(--color-secondary);display:flex;flex-direction:row;height:var(--header-height);box-shadow:0 2px 8px #00000059;z-index:10}.top-nav-bar--overlay{position:fixed;top:0;left:0;right:0;transform:translateY(-110%);transition:transform .18s ease;z-index:50}.top-nav-bar--overlay.is-open{transform:translateY(0)}.top-nav-launcher{position:fixed;top:-12px;left:50%;transform:translate(-50%);width:40px;height:40px;border-radius:10px;padding:0;margin:0;background:transparent;color:var(--color-text-primary);display:inline-flex;align-items:center;justify-content:center;z-index:60;cursor:ns-resize}.top-nav-launcher:hover:after{opacity:.9}.top-nav-launcher:hover{background-color:transparent}.brand-container{display:flex;align-items:center}.nav-links{flex-grow:1;display:flex;align-items:center;justify-content:center}@media(max-width:1024px){.all-links{display:none}}@media(max-width:1024px){.all-links.is-open{display:flex;position:absolute;left:0;right:0;top:var(--header-height);justify-content:center;background:var(--color-secondary);border-bottom:1px solid var(--color-border);padding:var(--spacing-md);box-shadow:0 6px 18px #00000059;z-index:11}}.menu-toggle{display:none}@media(max-width:1024px){.menu-toggle{display:block;background:none;border:none;font-size:var(--font-size-lg);color:var(--color-text-primary);cursor:pointer;padding:var(--spacing-sm) var(--spacing-md)}}.user-actions{display:flex;align-items:center;padding:0 var(--spacing-xl)}.compact-actions{display:flex;align-items:center;gap:8px}.icon-button{width:38px;height:38px;padding:0;margin:0;border-radius:10px;border:1px solid var(--color-border);background:color-mix(in srgb,var(--color-secondary) 80%,transparent);color:var(--color-text-primary);display:inline-flex;align-items:center;justify-content:center}.icon-button:hover{background:color-mix(in srgb,var(--color-secondary) 60%,transparent)}.compact-action{position:relative}.compact-popover{position:absolute;top:calc(100% + 6px);left:0;right:auto;min-width:180px;max-width:calc(100vw - 16px);padding:10px;border-radius:10px;border:1px solid var(--color-border);background:var(--color-secondary);box-shadow:0 10px 26px #00000059;z-index:70}html[data-view-mode=compact] .user-actions{padding:0 var(--spacing-md)}.nav-links ul{list-style:none;padding:0;margin:0;display:flex;gap:var(--spacing-xl)}.nav-links a{color:var(--color-text-primary);text-decoration:none;font-weight:700;transition:color .3s ease}.nav-links a:hover{color:var(--color-primary)}@media(max-width:1024px){.brand-name{display:none}}.welcome-banner{display:flex;flex-direction:column;margin:var(--spacing-md);color:var(--color-primary)}.creatures-container{width:100%;max-width:980px;padding:0 var(--spacing-md)}.creature-list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:var(--spacing-md)}.creature-item{border:1px solid var(--color-border);border-radius:var(--border-radius-md);padding:var(--spacing-md);background:var(--color-secondary);display:flex;flex-direction:column;gap:var(--spacing-sm)}.creature-item__name{margin:0}.creature-item__meta{margin:0;opacity:.9}.creature-item__play{margin-left:0}.actions-container{width:100%;max-width:980px;padding:var(--spacing-md);display:flex;justify-content:flex-end}html[data-view-mode=compact] .welcome-banner{margin:var(--spacing-sm)}html[data-view-mode=compact] .creature-list--compact{grid-template-columns:1fr;gap:10px}html[data-view-mode=compact] .creature-item--compact{flex-direction:row;align-items:center;justify-content:space-between;padding:10px}html[data-view-mode=compact] .creature-item__main{display:flex;flex-direction:column;gap:2px;min-width:0}html[data-view-mode=compact] .creature-item__name{font-size:var(--font-size-md);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}html[data-view-mode=compact] .creature-item__meta{font-size:var(--font-size-xs);opacity:.85}html[data-view-mode=compact] .creature-item__play--compact{padding:8px 12px;margin-left:0}.inline-alert{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm, .5rem);border-radius:var(--border-radius-md, 6px);padding:var(--spacing-sm, .5rem) var(--spacing-md, .75rem);border:1px solid var(--color-border);font-size:var(--font-size-sm, .95rem);background:var(--color-secondary);color:var(--color-text-primary)}.inline-alert__content{display:flex;flex-direction:column;gap:var(--spacing-xs, .25rem)}.inline-alert__title{font-weight:600}.inline-alert__message{line-height:1.4}.inline-alert__actions{display:flex;align-items:center;gap:var(--spacing-sm, .5rem)}.inline-alert__cta{border:1px solid currentColor;background:transparent;color:inherit;padding:var(--spacing-xs, .25rem) var(--spacing-sm, .5rem);border-radius:var(--border-radius-sm, 4px);cursor:pointer;font-size:var(--font-size-xs, .85rem)}.inline-alert__cta--solid{background:var(--color-background);color:var(--color-text-primary)}.inline-alert__dismiss{background:transparent;border:none;font-size:var(--font-size-md, 1rem);cursor:pointer;color:inherit}.inline-alert--info{color:var(--color-info);border-color:var(--color-info);background:var(--color-background-lighter)}.inline-alert--success{color:var(--color-success);border-color:var(--color-success);background:var(--color-background-lighter)}.inline-alert--warning{color:var(--color-warning);border-color:var(--color-warning);background:var(--color-background-lighter)}.inline-alert--error{color:var(--color-error);border-color:var(--color-error);background:var(--color-background-lighter)}.register-form{display:flex;flex-direction:column;gap:var(--spacing-md);background-color:var(--color-secondary);border:1px solid var(--color-border);padding:var(--spacing-lg);border-radius:var(--border-radius-md)}.register-form button{margin-top:var(--spacing-lg)}.login-form{display:flex;flex-direction:column;gap:var(--spacing-md);background-color:var(--color-secondary);border:1px solid var(--color-border);padding:var(--spacing-lg);border-radius:var(--border-radius-md)}.login-form button{margin-top:var(--spacing-lg)}.create-character-form{display:flex;flex-direction:column;gap:var(--spacing-md);background-color:var(--color-secondary);border:1px solid var(--color-border);padding:var(--spacing-lg);border-radius:var(--border-radius-md)}.create-character-form button{margin-top:var(--spacing-lg)}.game-session-alert{margin-bottom:1rem}.session-top-bar{display:flex;justify-content:space-between;align-items:center;background-color:var(--color-secondary);border-bottom:1px solid var(--color-border);color:var(--color-text-primary);font-size:var(--font-size-sm);height:var(--header-height);min-height:var(--header-height);width:calc(100% - (2 * var(--spacing-md)));z-index:1;padding:0 var(--spacing-md)}.session-top-bar-left{align-items:center;display:flex;gap:var(--spacing-sm);position:relative}.creature-effects{display:flex;align-items:center;gap:6px;flex-wrap:wrap}html[data-view-mode=compact] .creature-effects--floating{position:absolute;left:0;top:calc(100% + 6px);z-index:1150;max-width:min(92vw,520px);padding:6px 8px;border-radius:12px;background:color-mix(in srgb,var(--color-secondary) 88%,transparent);border:1px solid color-mix(in srgb,var(--color-border) 70%,transparent);box-shadow:0 10px 22px #00000047}.creature-effect-chip{display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;background:color-mix(in srgb,var(--color-accent-bg) 16%,transparent);border:1px solid color-mix(in srgb,var(--color-accent-bg) 35%,var(--color-border) 65%);color:var(--color-text-primary);font-size:12px;line-height:1.4}.session-top-bar-middle{display:flex;flex-grow:1;align-items:center;justify-content:center}.session-top-bar-compact-time{font-weight:600;letter-spacing:.2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.session-top-bar-right{display:flex;align-items:center;justify-content:flex-end;gap:12px}.quit-button--ghost{background:transparent;color:var(--color-danger-bg);border:1px solid var(--color-danger-bg)}.quit-button--icon{width:40px;height:36px;padding:0;margin-left:0;display:inline-flex;align-items:center;justify-content:center;border-radius:10px}.quit-indicator{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border:1px solid var(--color-danger-bg);border-radius:8px;background:color-mix(in srgb,var(--color-danger-bg) 12%,transparent);color:var(--color-danger-text);box-shadow:0 0 0 1px color-mix(in srgb,var(--color-danger-bg) 20%,transparent)}.quit-indicator__pulse{width:12px;height:12px;border-radius:50%;background:var(--color-danger-bg);box-shadow:0 0 color-mix(in srgb,var(--color-danger-bg) 60%,transparent);animation:quitPulse 1.6s infinite;will-change:transform}.quit-indicator__label{font-weight:600;letter-spacing:.2px}@keyframes quitPulse{0%{transform:translateZ(0) scale(.9);box-shadow:0 0 color-mix(in srgb,var(--color-danger-bg) 60%,transparent)}70%{transform:translateZ(0) scale(1.1);box-shadow:0 0 0 10px color-mix(in srgb,var(--color-danger-bg) 0%,transparent)}to{transform:translateZ(0) scale(1);box-shadow:0 0 color-mix(in srgb,var(--color-danger-bg) 0%,transparent)}}.interactive{color:var(--color-primary);white-space:nowrap;border-radius:var(--border-radius-sm);padding:2px 6px;margin:0 2px;cursor:pointer;display:inline-block;font-weight:700;text-shadow:var(--interactive-text-shadow);transition:all .2s ease;-webkit-user-select:text;user-select:text}.interactive:hover{filter:brightness(1.3);text-shadow:var(--interactive-text-shadow);transform:translateZ(0) scale(1.05);will-change:transform}.interactive[data-type=item]{background-color:var(--color-interactive-item);border:1px solid var(--color-interactive-item-border)}.interactive[data-type=creature]{background-color:var(--color-interactive-creature);border:1px solid var(--color-interactive-creature-border)}.interactive[data-type=resourceGenerator]{background-color:var(--color-interactive-resource);border:1px solid var(--color-interactive-resource-border)}.interactive[data-type=room]{background-color:var(--color-interactive-room);border:1px solid var(--color-interactive-room-border)}.interactive[data-type=portal]{background-color:var(--color-interactive-portal);border:1px solid var(--color-interactive-portal-border)}.interactive[data-type=skill]{background-color:var(--color-interactive-skill);border:1px solid var(--color-interactive-skill-border)}.interactive[data-type=exit]{background-color:var(--color-interactive-exit);border:1px solid var(--color-interactive-exit-border)}.interactive[data-type=scenery]{background-color:var(--color-interactive-scenery);border:1px solid var(--color-interactive-scenery-border)}.interactive[data-type=bodyPart]{background-color:var(--color-interactive-body);border:1px solid var(--color-interactive-body-border)}.interactive[data-type=lore]{background-color:var(--color-interactive-lore);border:1px solid var(--color-interactive-lore-border)}.interactive[data-type=recipe]{background-color:var(--color-interactive-recipe);border:1px solid var(--color-interactive-recipe-border)}.interactive[data-type=creatureProperty],.interactive[data-type=area]{background-color:var(--color-interactive-other);border:1px solid var(--color-interactive-other-border)}.interactive[data-type=door]{background-color:var(--color-interactive-door);border:1px solid var(--color-interactive-door-border)}.interactive[data-type=roomEffect],.interactive[data-type=creatureEffect]{background-color:var(--color-interactive-effectTemplate);border:1px solid var(--color-interactive-effectTemplate-border)}.interactive[data-type=weatherTemplate]{background-color:var(--color-interactive-weatherTemplate);border:1px solid var(--color-interactive-weatherTemplate-border)}.interactive[data-type=other]{background-color:var(--color-interactive-other);border:1px solid var(--color-interactive-other-border)}.typewriter-piece{display:inline-block;opacity:0;animation:interactiveTextFade .25s ease forwards}.typewriter-char{white-space:pre}.typewriter-element{display:inline-flex}@keyframes interactiveTextFade{0%{opacity:0;transform:translate3d(0,.2rem,0)}to{opacity:1;transform:translateZ(0)}}.context-menu{position:fixed;min-width:220px;max-width:280px;background-color:var(--color-background);border:1px solid var(--color-border);border-radius:var(--border-radius-md, 6px);box-shadow:var(--shadow-md, 0 3px 8px rgba(0, 0, 0, .2));z-index:var(--z-index-dropdown, 1000);padding:var(--spacing-xs, 4px);color:var(--color-text-primary);font-size:var(--font-size-sm, .875rem);font-family:var(--font-family-primary, "Segoe UI", sans-serif)}.context-menu__content{display:flex;flex-direction:column;gap:var(--spacing-xs, 4px)}.context-menu__scroll-button{border:none;background:transparent;color:var(--color-text-secondary);height:24px;display:flex;align-items:center;justify-content:center;cursor:default;border-radius:var(--border-radius-sm, 4px);transition:background-color .2s ease,color .2s ease;-webkit-user-select:none;user-select:none}.context-menu__scroll-button[data-active=true]{cursor:pointer}.context-menu__scroll-button[data-active=true]:hover{background-color:var(--color-secondary);color:var(--color-primary)}.context-menu__items{max-height:200px;overflow-y:auto;overscroll-behavior:contain}.context-menu__list{list-style:none;margin:0;padding:0}.context-menu__item{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;border-radius:var(--border-radius-sm, 4px);cursor:pointer;gap:var(--spacing-sm, 8px);color:inherit}.context-menu__item:hover,.context-menu__item[aria-expanded=true]{background-color:var(--color-secondary)}.context-menu__item[aria-disabled=true]{opacity:.5;cursor:not-allowed}.context-menu__item-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.context-menu__item-shortcut{font-size:.75em;color:var(--color-text-secondary)}.context-menu__submenu-indicator{font-size:.8em;color:var(--color-text-secondary)}.context-menu__spinner-container,.context-menu__empty{padding:var(--spacing-lg, 16px);display:flex;justify-content:center;align-items:center;gap:var(--spacing-sm, 8px);color:var(--color-text-secondary)}.context-menu__spinner{width:18px;height:18px;border-radius:50%;border:2px solid var(--color-border);border-top-color:var(--color-primary);animation:context-menu-spin .8s linear infinite;will-change:transform}@keyframes context-menu-spin{0%{transform:translateZ(0) rotate(0)}to{transform:translateZ(0) rotate(360deg)}}:root{--session-mid-section-height: 470px;--left-section-width: 400px}.session-mid-section{display:flex;justify-content:space-between;align-items:center;color:var(--color-text-primary);font-size:var(--font-size-md);height:var(--session-mid-section-height);min-height:var(--session-mid-section-height);width:100%;z-index:1;background-color:var(--color-background-lighter)}.left-section{width:calc(var(--left-section-width) - (4 * var(--spacing-md)));min-width:calc(var(--left-section-width) - (4 * var(--spacing-md)));display:flex;flex-direction:column;align-items:center;height:calc(100% - 4 * var(--spacing-md));border:1px solid var(--color-border);border-radius:var(--border-radius-md);margin:var(--spacing-md);padding:var(--spacing-md);background-color:var(--color-secondary);box-shadow:var(--shadow-md)}.room-image{width:350px;height:350px;border:1px solid var(--color-border);border-radius:var(--border-radius-sm)}.room-name{display:flex;align-items:center;justify-content:center}.room-weather{width:100%;display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);margin:var(--spacing-sm) 0}.weather-label{font-weight:var(--font-weight-semibold);color:var(--color-text-secondary)}.weather-chips{display:flex;gap:var(--spacing-xs);flex-wrap:wrap;justify-content:flex-end}.weather-chip{display:inline-flex;align-items:center;padding:0;margin:0;font-size:var(--font-size-xs)}.weather-chip--calm{background:var(--color-success-muted);color:var(--color-text-primary)}.middle-section{display:flex;flex-direction:column;align-items:flex-start;height:calc(100% - (2 * var(--spacing-md)) - (2 * var(--spacing-md)));border:1px solid var(--color-border);border-radius:var(--border-radius-md);margin:var(--spacing-md) 0;flex-grow:1;padding:var(--spacing-md);background-color:var(--color-secondary);box-shadow:var(--shadow-md)}.room-description{min-height:120px;border-bottom:1px solid var(--color-border)}.world-navigation{width:250px;min-width:250px;display:flex;flex-direction:column;align-items:center;justify-content:center;height:calc(100% - 2 * var(--spacing-md));margin:var(--spacing-md)}.world-navigation .interactive{width:40px;height:40px;padding:0;margin:0;border:none;background:transparent;align-items:center;justify-content:center;display:flex;color:inherit;border-radius:20px}.minimap{position:relative;left:0;top:0;width:230px;height:230px}.session-bottom-section{display:flex;flex-direction:column;background-color:var(--color-background-lighter);color:var(--color-text-primary);font-size:var(--font-size-md);width:100%;flex-grow:1;min-height:0;overflow:hidden}.session-bottom-section__active-progress{padding:0 var(--spacing-md);border-bottom:1px solid transparent;background-color:var(--color-background, var(--color-background-lighter));box-shadow:0 2px 6px #0000;position:relative;z-index:2;max-height:0;opacity:0;transform:translate3d(0,-.5rem,0);transition:max-height .22s ease,opacity .18s ease,transform .22s ease,padding .22s ease,border-color .22s ease,box-shadow .22s ease;overflow:hidden;pointer-events:none}html[data-view-mode=compact] .session-bottom-section__active-progress{position:fixed;left:0;right:0;bottom:calc(var(--rd-communication-dock-height, 0px));z-index:1050;border-bottom:none;border-top:1px solid transparent;padding-bottom:calc(var(--spacing-md) + env(safe-area-inset-bottom,0px));transform:translate3d(0,.5rem,0)}.session-bottom-section__active-progress--visible{padding:var(--spacing-md);border-bottom:1px solid var(--color-border, rgba(255, 255, 255, .08));box-shadow:0 2px 6px #0000004d;max-height:140px;opacity:1;transform:translateZ(0);pointer-events:auto}html[data-view-mode=compact] .session-bottom-section__active-progress--visible{border-bottom:none;border-top:1px solid var(--color-border, rgba(255, 255, 255, .12));box-shadow:0 -8px 18px #00000047}.log-messages{flex:1;overflow-y:auto;padding:var(--spacing-md);padding-bottom:calc(var(--spacing-md) + var(--rd-communication-dock-height, 0px) + var(--rd-active-progress-height, 0px));display:block;font-size:var(--font-size-md);-webkit-user-select:text;user-select:text}.log-messages__quick-actions{position:sticky;top:0;z-index:6;height:0;padding:0;pointer-events:none}.log-messages__quick-actions .quick-actions-toolbar{position:absolute;top:0;right:0;pointer-events:auto}.log-messages__inner{display:block}.log-message{line-height:1.4;white-space:pre-wrap;color:var(--color-text-secondary);padding-bottom:var(--spacing-xs)}.log-message__content{display:block;position:relative}.log-message__simplify-overlay{position:absolute;top:0;right:0;bottom:0;left:0;opacity:1;transform:translateZ(0);will-change:opacity,transform;pointer-events:none;animation:logSimplifyFadeOut .18s ease forwards}@keyframes logSimplifyFadeOut{0%{opacity:1;transform:translateZ(0)}to{opacity:0;transform:translate3d(0,-2px,0)}}@media(prefers-reduced-motion:reduce){.log-message__simplify-overlay{animation:none;opacity:0}}.log-message__layer{grid-area:1 / 1 / 2 / 2;transition:opacity .2s ease,transform .22s ease;opacity:0;transform:translate3d(0,6px,0);will-change:opacity,transform}.log-message__layer.is-active{opacity:1;pointer-events:auto}.log-message__layer.is-inactive{opacity:0;pointer-events:none}.log-message--general{color:var(--color-text-primary)}.log-message--markdown{color:var(--color-text-primary);white-space:normal}.log-message__markdown{white-space:normal}.log-message__markdown--plain{white-space:pre-wrap}.log-message__markdown :where(h1,h2,h3,h4,h5,h6){margin:.25rem 0}.log-message__markdown :where(p){margin:.25rem 0}.log-message__markdown :where(ul,ol){margin:.25rem 0;padding-left:1.25rem}.log-message__markdown :where(li){margin:.125rem 0}.log-message__markdown :where(pre){margin:.25rem 0;padding:.25rem .5rem;overflow-x:auto}.log-message__markdown :where(blockquote){margin:.25rem 0;padding-left:.5rem}.log-message__markdown :where(hr){margin:.5rem 0}.log-message--other-action{color:var(--color-text-secondary)}.log-message--combat,.log-message--error{color:var(--color-error)}.log-message--movement,.log-message--info,.log-message--time{color:var(--color-info)}.log-message--communication{color:var(--color-text-secondary)}.communication-quote,.communication-quote--say,.communication-quote--say-to{color:var(--color-accent)}.communication-quote--tell{color:var(--color-primary)}.communication-quote--whisper,.communication-quote--whisper-to{color:var(--color-info)}.communication-quote--yell{color:var(--color-warning)}.communication-quote--murmur{color:var(--color-text-secondary)}.log-message--warning{color:var(--color-warning)}.log-message--own-action{color:var(--color-log-own-action, var(--color-warning))}.log-message--progress{color:var(--color-success)}.log-message--quest{color:var(--color-accent)}.log-message--system{color:var(--color-primary)}.log-message--weather{color:var(--color-weather, var(--color-info))}.log-message--creature-effect{color:var(--color-creature-effect, var(--color-success))}.progress-bar{display:flex;flex-direction:column;gap:4px;width:100%;max-width:400px;color:var(--color-text-primary, var(--color-text-secondary, inherit))}.progress-bar__label{font-weight:600;font-size:.85rem;position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;margin:0;display:flex;align-items:center;justify-content:center;pointer-events:none;text-align:center;color:var(--color-text-primary, var(--color-text-secondary, inherit));text-shadow:var(--interactive-text-shadow, none)}.progress-bar__track{width:100%;height:20px;border-radius:var(--border-radius-progress-bar, 999px);background:color-mix(in srgb,var(--color-secondary, var(--color-background, currentColor)) 60%,var(--color-background, transparent));border:1px solid var(--color-border, currentColor);box-shadow:inset 0 0 4px color-mix(in srgb,var(--color-border, currentColor) 50%,transparent);position:relative;overflow:hidden}.progress-bar__fill{height:100%;border-radius:var(--border-radius-progress-bar, 999px);background:linear-gradient(90deg,color-mix(in srgb,var(--color-success, var(--color-primary, currentColor)) 85%,transparent),color-mix(in srgb,var(--color-accent, var(--color-primary, currentColor)) 80%,transparent));width:100%;transform-origin:left center;transform:scaleX(0);will-change:transform;transition:transform .1s linear;position:relative;z-index:1;box-shadow:0 0 6px color-mix(in srgb,var(--color-accent, currentColor) 50%,transparent)}.quick-actions-toolbar{display:flex;flex-direction:column;gap:10px;border-radius:14px;z-index:1;background:color-mix(in srgb,var(--color-secondary) 35%,transparent);border:1px solid color-mix(in srgb,var(--color-border) 60%,transparent);box-shadow:0 10px 28px #00000040;transition:background .14s ease,border-color .14s ease}.quick-actions-toolbar:hover{background:color-mix(in srgb,var(--color-secondary) 72%,transparent);border-color:color-mix(in srgb,var(--color-border) 95%,transparent)}.quick-actions-toolbar__button{width:42px;height:42px;border-radius:12px;background:color-mix(in srgb,var(--color-secondary) 12%,transparent);color:var(--color-text-primary);display:inline-flex;align-items:center;justify-content:center;padding:0;margin:0;opacity:.82;transition:opacity .14s ease,background .14s ease,border-color .14s ease}.quick-actions-toolbar__button:hover,.quick-actions-toolbar__button:active,.quick-actions-toolbar__button:focus-visible{opacity:1;background:color-mix(in srgb,var(--color-secondary) 78%,transparent);border-color:color-mix(in srgb,var(--color-border) 90%,transparent);outline:none}.quick-actions-toolbar__button:disabled{opacity:.35;cursor:not-allowed}.quantity-selector-dialog{position:fixed;bottom:var(--spacing-xl, 24px);right:var(--spacing-xl, 24px);width:min(360px,calc(100% - 2 * var(--spacing-xl, 24px)));background:var(--color-background, #101014);color:var(--color-text-primary, #f3f3f3);border:1px solid var(--color-border, rgba(255, 255, 255, .12));border-radius:var(--border-radius-lg, 8px);box-shadow:var(--shadow-lg, 0 8px 24px rgba(0, 0, 0, .35));padding:var(--spacing-lg, 16px);z-index:var(--z-index-quantity-modal, 5000);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);will-change:transform}.quantity-selector-dialog__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-md, 12px);margin-bottom:var(--spacing-lg, 16px);cursor:grab;-webkit-user-select:none;user-select:none}.quantity-selector-dialog__header-actions{display:flex;align-items:center;gap:var(--spacing-sm, 8px)}.quantity-selector-dialog__title{font-size:var(--font-size-lg, 1.125rem);font-weight:600;margin:0}.quantity-selector-dialog__subtitle{font-size:var(--font-size-sm, .875rem);color:var(--color-text-secondary, #a0a0a0);margin:0}.quantity-selector-dialog__max{font-size:var(--font-size-sm, .875rem);color:var(--color-text-secondary, #a0a0a0);white-space:nowrap}.quantity-selector-dialog__close{border:none;background:transparent;color:var(--color-text-primary, #f3f3f3);font-size:var(--font-size-lg, 1.125rem);cursor:pointer;line-height:1;padding:var(--spacing-xxs, 2px)}.quantity-selector-dialog__controls{display:flex;align-items:center;gap:var(--spacing-sm, 8px);margin-bottom:var(--spacing-md, 12px)}.quantity-selector-dialog__adjust{border:1px solid var(--color-border, rgba(255, 255, 255, .18));background:var(--color-secondary, rgba(255, 255, 255, .08));color:var(--color-text-primary, #f3f3f3);padding:var(--spacing-sm, 8px);border-radius:var(--border-radius-sm, 4px);font-weight:600;min-width:52px;cursor:pointer;transition:background .2s ease,color .2s ease}.quantity-selector-dialog__adjust:disabled{opacity:.5;cursor:not-allowed}.quantity-selector-dialog__slider{flex:1}.quantity-selector-dialog__slider input[type=range]{width:100%;accent-color:var(--color-primary, #4f46e5)}.quantity-selector-dialog__input{display:flex;flex-direction:column;gap:var(--spacing-xs, 4px);font-size:var(--font-size-sm, .875rem);margin-bottom:var(--spacing-lg, 16px)}.quantity-selector-dialog__input input{border:1px solid var(--color-border, rgba(255, 255, 255, .18));background:var(--color-background-lighter, rgba(255, 255, 255, .05));color:var(--color-text-primary, #f3f3f3);padding:var(--spacing-sm, 8px);border-radius:var(--border-radius-sm, 4px);font-size:var(--font-size-md, 1rem)}.quantity-selector-dialog__actions{display:flex;gap:var(--spacing-md, 12px);justify-content:flex-end}.quantity-selector-dialog__button{border-radius:var(--border-radius-md, 6px);padding:var(--spacing-sm, 8px) var(--spacing-lg, 16px);font-weight:600;border:1px solid transparent;cursor:pointer;transition:background .2s ease,color .2s ease,border .2s ease}.quantity-selector-dialog__button--secondary{background:transparent;border-color:var(--color-border, rgba(255, 255, 255, .18));color:var(--color-text-primary, #f3f3f3)}.quantity-selector-dialog__button--primary{background:var(--color-primary, #4f46e5);color:#fff}.quantity-selector-dialog__button:disabled{opacity:.6;cursor:not-allowed}@media(max-width:600px){.quantity-selector-dialog{left:var(--spacing-lg, 16px);right:var(--spacing-lg, 16px);width:auto}}.shop-dialog{position:fixed;bottom:var(--spacing-xl, 24px);right:var(--spacing-xl, 24px);width:min(640px,calc(100% - 2 * var(--spacing-xl, 24px)));background:var(--color-background, #101014);color:var(--color-text-primary, #f3f3f3);border:1px solid var(--color-border, rgba(255, 255, 255, .12));border-radius:var(--border-radius-lg, 8px);box-shadow:var(--shadow-lg, 0 8px 24px rgba(0, 0, 0, .35));padding:var(--spacing-lg, 16px);z-index:var(--z-index-popover, 1060);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);will-change:transform}.shop-dialog__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-md, 12px);cursor:grab;-webkit-user-select:none;user-select:none}.shop-dialog__header:active{cursor:grabbing}.shop-dialog__title{font-size:var(--font-size-lg, 1.125rem);font-weight:600;margin:0}.shop-dialog__subtitle{margin:0;font-size:var(--font-size-sm, .875rem);color:var(--color-text-secondary, #a0a0a0)}.shop-dialog__close{border:none;background:transparent;color:var(--color-text-primary, #f3f3f3);font-size:var(--font-size-xl, 1.25rem);cursor:pointer;line-height:1;padding:var(--spacing-xs, 4px)}.shop-dialog__table{margin-top:var(--spacing-lg, 16px);border:1px solid var(--color-border, rgba(255, 255, 255, .12));border-radius:var(--border-radius-md, 6px);background:var(--color-background-lighter, rgba(255, 255, 255, .03));overflow:hidden}.shop-dialog__table-wrapper{max-height:320px;overflow-y:auto}.shop-dialog__table table{width:100%;border-collapse:separate;border-spacing:0}.shop-dialog__table th,.shop-dialog__table td{padding:var(--spacing-sm, 8px) var(--spacing-md, 12px);text-align:left;font-size:var(--font-size-sm, .875rem)}.shop-dialog__table thead th{position:sticky;top:0;background:var(--color-secondary, rgba(255, 255, 255, .08));border-bottom:1px solid var(--color-border, rgba(255, 255, 255, .12));z-index:1}.shop-dialog__table tbody td{border-bottom:1px solid var(--color-border, rgba(255, 255, 255, .08))}.shop-dialog__table tbody tr:last-child td{border-bottom:none}.shop-dialog__table tbody tr{transition:background .2s ease}.shop-dialog__table tbody tr:hover{background:#ffffff0f}.shop-dialog__table tbody tr:nth-child(2n){background:#ffffff05}.shop-dialog__cell--name{font-weight:600;max-width:250px;min-width:250px;overflow:hidden}.shop-dialog__cell--price{overflow:hidden}.shop-dialog__cell--available{max-width:70px;min-width:70px;overflow:hidden}.shop-dialog__cell--buy{max-width:140px;min-width:140px;overflow:hidden}.shop-dialog__quantity{display:flex;align-items:center;gap:var(--spacing-xs, 4px)}.shop-dialog__quantity input{width:64px;border:1px solid var(--color-border, rgba(255, 255, 255, .18));background:var(--color-background, #101014);color:var(--color-text-primary, #f3f3f3);padding:var(--spacing-xs, 4px);border-radius:var(--border-radius-sm, 4px);text-align:center}.shop-dialog__quantity-button{border:1px solid var(--color-border, rgba(255, 255, 255, .18));background:var(--color-secondary, rgba(255, 255, 255, .08));color:var(--color-text-primary, #f3f3f3);width:28px;height:28px;border-radius:var(--border-radius-sm, 4px);cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;margin-left:0}.shop-dialog__quantity-button:disabled{opacity:.5;cursor:not-allowed}.shop-dialog__empty-row td{text-align:center;padding:var(--spacing-lg, 16px);color:var(--color-text-secondary, #a0a0a0)}.shop-dialog__table-footer{display:flex;flex-direction:column;gap:var(--spacing-sm, 8px);padding:var(--spacing-md, 12px);border-top:1px solid var(--color-border, rgba(255, 255, 255, .12));background:#00000040}.shop-dialog__table-footer p{margin:0;font-size:var(--font-size-sm, .875rem);color:var(--color-text-secondary, #a0a0a0)}.shop-dialog__funds{display:flex;flex-direction:column;gap:var(--spacing-xs, 4px);font-size:var(--font-size-sm, .875rem)}.shop-dialog__actions{margin-top:var(--spacing-lg, 16px);display:flex;justify-content:flex-end;gap:var(--spacing-md, 12px)}.shop-dialog__button{border-radius:var(--border-radius-md, 6px);padding:var(--spacing-sm, 8px) var(--spacing-lg, 16px);font-weight:600;border:1px solid transparent;cursor:pointer}.shop-dialog__button--secondary{background:transparent;border-color:var(--color-border, rgba(255, 255, 255, .18));color:var(--color-text-primary, #f3f3f3)}.shop-dialog__button--primary{background:var(--color-primary, #4f46e5);color:#fff}.shop-dialog__button:disabled{opacity:.6;cursor:not-allowed}@media(max-width:720px){.shop-dialog{left:var(--spacing-lg, 16px);right:var(--spacing-lg, 16px);width:auto}.shop-dialog__table-wrapper{max-height:240px}}.bank-dialog{position:fixed;bottom:var(--spacing-xl, 24px);right:var(--spacing-xl, 24px);width:min(520px,calc(100% - 2 * var(--spacing-xl, 24px)));background:var(--color-background, #101014);color:var(--color-text-primary, #f3f3f3);border:1px solid var(--color-border, rgba(255, 255, 255, .12));border-radius:var(--border-radius-lg, 8px);box-shadow:var(--shadow-lg, 0 8px 24px rgba(0, 0, 0, .35));padding:var(--spacing-lg, 16px);z-index:var(--z-index-popover, 1060);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);will-change:transform}.bank-dialog__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-md, 12px);cursor:grab;-webkit-user-select:none;user-select:none}.bank-dialog__header:active{cursor:grabbing}.bank-dialog__title{font-size:var(--font-size-lg, 1.125rem);font-weight:600;margin:0}.bank-dialog__subtitle{margin:0;font-size:var(--font-size-sm, .875rem);color:var(--color-text-secondary, #a0a0a0)}.bank-dialog__close{border:none;background:transparent;color:var(--color-text-primary, #f3f3f3);font-size:var(--font-size-xl, 1.25rem);cursor:pointer;line-height:1;padding:var(--spacing-xs, 4px)}.bank-dialog__grid{margin-top:var(--spacing-lg, 16px);display:grid;grid-template-columns:1fr;gap:var(--spacing-md, 12px)}.bank-dialog__panel{border:1px solid var(--color-border, rgba(255, 255, 255, .12));border-radius:var(--border-radius-md, 6px);background:var(--color-background-lighter, rgba(255, 255, 255, .03));padding:var(--spacing-md, 12px)}.bank-dialog__panel--summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md, 12px)}.bank-dialog__stat{display:flex;flex-direction:column;gap:var(--spacing-xs, 4px)}.bank-dialog__label{margin:0;font-size:var(--font-size-sm, .875rem);color:var(--color-text-secondary, #a0a0a0)}.bank-dialog__value{margin:0;font-weight:700}.bank-dialog__muted{margin:0;color:var(--color-text-secondary, #a0a0a0);font-size:var(--font-size-sm, .875rem)}.bank-dialog__panel--inputs{display:flex;flex-direction:column;gap:var(--spacing-sm, 8px)}.bank-dialog__panel-header{display:flex;justify-content:space-between;align-items:baseline;gap:var(--spacing-sm, 8px)}.bank-dialog__rows{display:flex;flex-direction:column;gap:var(--spacing-sm, 8px)}.bank-dialog__row{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md, 12px)}.bank-dialog__row-label{min-width:72px;font-weight:600}.bank-dialog__quantity{display:flex;align-items:center;gap:var(--spacing-xs, 4px)}.bank-dialog__quantity input{width:88px;border:1px solid var(--color-border, rgba(255, 255, 255, .18));background:var(--color-background, #101014);color:var(--color-text-primary, #f3f3f3);padding:var(--spacing-xs, 4px);border-radius:var(--border-radius-sm, 4px);text-align:center}.bank-dialog__quantity-button{border:1px solid var(--color-border, rgba(255, 255, 255, .18));background:var(--color-secondary, rgba(255, 255, 255, .08));color:var(--color-text-primary, #f3f3f3);width:28px;height:28px;border-radius:var(--border-radius-sm, 4px);cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center}.bank-dialog__quantity-button:disabled{opacity:.5;cursor:not-allowed}.bank-dialog__panel--totals{display:flex;flex-direction:column;gap:var(--spacing-sm, 8px)}.bank-dialog__totals{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--spacing-md, 12px)}.bank-dialog__summary-row{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm, 8px);padding:var(--spacing-xs, 4px) 0;border-top:1px solid var(--color-border, rgba(255, 255, 255, .08))}.bank-dialog__actions{margin-top:var(--spacing-lg, 16px);display:flex;justify-content:flex-end;gap:var(--spacing-md, 12px)}.bank-dialog__button{border-radius:var(--border-radius-md, 6px);padding:var(--spacing-sm, 8px) var(--spacing-lg, 16px);font-weight:600;border:1px solid transparent;cursor:pointer}.bank-dialog__button--secondary{background:transparent;border-color:var(--color-border, rgba(255, 255, 255, .18));color:var(--color-text-primary, #f3f3f3)}.bank-dialog__button--primary{background:var(--color-primary, #4f46e5);color:#fff}.bank-dialog__button:disabled{opacity:.6;cursor:not-allowed}@media(max-width:720px){.bank-dialog{left:var(--spacing-lg, 16px);right:var(--spacing-lg, 16px);width:auto}}.communication-dialog{position:fixed;bottom:var(--spacing-xl, 24px);left:var(--spacing-xl, 24px);width:min(520px,calc(100% - 2 * var(--spacing-xl, 24px)));background:var(--color-background, #101014);color:var(--color-text-primary, #f3f3f3);border:1px solid var(--color-border, rgba(255, 255, 255, .12));border-radius:var(--border-radius-lg, 8px);box-shadow:var(--shadow-lg, 0 8px 24px rgba(0, 0, 0, .35));padding:var(--spacing-lg, 16px);z-index:var(--z-index-popover, 1060);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);will-change:transform}html[data-view-mode=compact] .communication-dialog.communication-dialog--docked{left:0;right:0;bottom:0;width:100%;max-width:100%;border-radius:14px 14px 0 0;padding-bottom:calc(var(--spacing-lg, 16px) + env(safe-area-inset-bottom,0px));max-height:min(46vh,360px);overflow:auto}html[data-view-mode=compact] .communication-dialog.communication-dialog--docked .communication-dialog__header{cursor:default}.communication-dialog__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-md, 12px);cursor:grab;-webkit-user-select:none;user-select:none}.communication-dialog__header:active{cursor:grabbing}.communication-dialog__heading{display:flex;flex-direction:column;gap:var(--spacing-xs, 4px)}.communication-dialog__title{font-size:var(--font-size-lg, 1.125rem);font-weight:600;margin:0}.communication-dialog__hint{margin:0;font-size:var(--font-size-sm, .875rem);color:var(--color-text-secondary, #a0a0a0)}.communication-dialog__close{border:none;background:transparent;color:var(--color-text-primary, #f3f3f3);font-size:var(--font-size-xl, 1.25rem);cursor:pointer;line-height:1;padding:var(--spacing-xs, 4px)}.communication-dialog__grid{margin-top:var(--spacing-lg, 16px);display:grid;grid-template-columns:1fr;gap:var(--spacing-md, 12px)}.communication-dialog__field{display:flex;flex-direction:column;gap:var(--spacing-xs, 4px)}.communication-dialog__label{font-size:var(--font-size-sm, .875rem);color:var(--color-text-secondary, #a0a0a0)}.communication-dialog__select,.communication-dialog__textarea{width:100%;border:1px solid var(--color-border, rgba(255, 255, 255, .12));background:var(--color-background-lighter, rgba(255, 255, 255, .03));color:var(--color-text-primary, #f3f3f3);border-radius:var(--border-radius-md, 6px);padding:var(--spacing-sm, 8px)}.communication-dialog__textarea{resize:vertical}.communication-dialog__validation{font-size:var(--font-size-sm, .875rem);color:var(--color-text-secondary, #a0a0a0)}.protected-route-status{margin:var(--spacing-xxl, 2rem) auto;max-width:min(640px,100%)}.runtime-debug-hud{position:fixed;right:12px;bottom:12px;z-index:9999;width:380px;background:#141418e6;color:#f2f2f2;border:1px solid rgba(255,255,255,.08);border-radius:8px;box-shadow:0 10px 30px #00000059;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:12px}.runtime-debug-hud__header{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-bottom:1px solid rgba(255,255,255,.08);font-weight:600}.runtime-debug-hud__actions{display:flex;gap:6px}.runtime-debug-hud__actions button{background:#ffffff1a;color:#f2f2f2;border:1px solid rgba(255,255,255,.12);border-radius:6px;padding:2px 6px;font-size:11px;cursor:pointer}.runtime-debug-hud__actions button:hover{background:#ffffff2e}.runtime-debug-hud__body{padding:8px 10px 10px;display:flex;flex-direction:column;gap:6px}.runtime-debug-hud__row{display:flex;justify-content:space-between;gap:8px}.runtime-debug-hud__muted{color:#fff9}.runtime-debug-hud.is-collapsed .runtime-debug-hud__body{display:none}:root{--color-background: #1a1a1a;--color-background-lighter: color-mix(in srgb, var(--color-background) 90%, white 1%);--color-text-primary: #e0e0e0;--color-text-secondary: #b0b0b0;--color-primary: #4CAF50;--color-primary-hover: #45a049;--color-secondary: #333;--color-border: #444;--color-accent: #8a4a8a;--color-accent-hover: #a05aa0;--color-success: #4CAF50;--color-warning: #f44336;--color-error: #f44336;--color-info: #2196F3;--color-weather: #1e3a8a;--color-log-own-action: #ff9800;--color-interactive-item: #8a8a4a;--color-interactive-creature: #4a4a8a;--color-interactive-resource: #4a8a4a;--color-interactive-room: #8a8a4a;--color-interactive-portal: #8a4a8a;--color-interactive-skill: #4a8a8a;--color-interactive-exit: #4c6a43;--color-interactive-scenery: #6a6a6a;--color-interactive-body: #8a6a4a;--color-interactive-lore: #4a6a8a;--color-interactive-recipe: #8a4a6a;--color-interactive-door: #6f3600;--color-interactive-effectTemplate: #780101;--color-interactive-weatherTemplate: #780101;--color-interactive-other: #6a6a6a;--color-interactive-item-border: #ffff6a;--color-interactive-creature-border: #6a6aff;--color-interactive-resource-border: #6aff6a;--color-interactive-room-border: #ffff6a;--color-interactive-portal-border: #ff6aff;--color-interactive-skill-border: #6affff;--color-interactive-exit-border: #8c8c8c;--color-interactive-scenery-border: #8c8c8c;--color-interactive-body-border: #ffb36a;--color-interactive-lore-border: #6aaaff;--color-interactive-recipe-border: #ff6aaa;--color-interactive-door-border: #3a1c00;--color-interactive-effectTemplate-border: #400000;--color-interactive-weatherTemplate-border: #400000;--color-interactive-other-border: #8c8c8c;--interactive-text-shadow: 1px 1px 1px #000;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 12px;--spacing-lg: 16px;--spacing-xl: 24px;--spacing-xxl: 32px;--border-radius-sm: 4px;--border-radius-md: 8px;--border-radius-lg: 12px;--border-radius-progress-bar: 999px;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-md: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-xxl: 1.5rem;--header-height: 60px;--sidebar-width: 20%;--central-width: 60%;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .2);--shadow-md: 0 4px 8px rgba(0, 0, 0, .2);--shadow-lg: 0 8px 16px rgba(0, 0, 0, .2);--font-family-primary: "Lato", -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;--font-family-mono: source-code-pro, Menlo, Monaco, Consolas, "Courier New", monospace;--z-index-dropdown: 100000;--z-index-sticky: 1020;--z-index-fixed: 1030;--z-index-modal-backdrop: 1040;--z-index-modal: 1050;--z-index-popover: 1060;--z-index-tooltip: 1070}body{margin:0;padding:0;font-family:var(--font-family-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--color-background);color:var(--color-text-primary);overflow:hidden;-webkit-user-select:none;user-select:none;height:100vh}#app{display:flex;flex-direction:column;height:100%}.page{display:flex;flex-direction:column;width:100%;height:100%;align-items:center;color:var(--color-primary)}input,select{padding:var(--spacing-sm);border:1px solid var(--color-border);border-radius:var(--border-radius-sm)}input:focus,select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px color-mix(in srgb,var(--color-primary),transparent 50%)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-top:var(--spacing-lg)}.form-actions{display:flex;flex-direction:column;align-items:flex-end;justify-content:flex-end}.error-message{color:var(--color-error);margin-bottom:var(--spacing-sm)}button{background-color:var(--color-primary);color:var(--color-secondary);border:none;padding:var(--spacing-sm) var(--spacing-lg);margin-left:var(--spacing-md);border-radius:var(--border-radius-sm);cursor:pointer;transition:background-color .3s ease;font-weight:700}button:hover{background-color:var(--color-primary-hover)}.content-block{background-color:var(--color-secondary);border:1px solid var(--color-border);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg);border-radius:var(--border-radius-md)}.content-block h2{color:var(--color-primary);margin-top:0;margin-bottom:var(--spacing-md);font-size:var(--font-size-xl)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-text-secondary);border-radius:4px}*{scrollbar-width:thin;scrollbar-color:var(--color-text-secondary) transparent}
