@import"https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700&family=Inter:wght@300;400;500;600&display=swap";*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #0d0f14;--bg-secondary: #161923;--bg-card: rgba(22, 25, 35, .7);--border-glow: rgba(168, 130, 82, .35);--accent: #c9a84c;--accent-hover: #e0be5a;--accent-glow: rgba(201, 168, 76, .25);--text-primary: #eae4d5;--text-secondary: #a69e8e;--text-muted: #6b6358;--error: #d94f4f;--success: #4fd97a;--font-display: "Cinzel", serif;--font-body: "Inter", system-ui, sans-serif;--radius: 12px;--transition: .3s cubic-bezier(.4, 0, .2, 1)}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-image:radial-gradient(ellipse at 20% 0%,rgba(201,168,76,.06) 0%,transparent 60%),radial-gradient(ellipse at 80% 100%,rgba(120,80,40,.05) 0%,transparent 60%)}#root{display:flex;justify-content:center;min-height:100vh;padding:1.25rem 1rem}.app{width:100%;max-width:920px;margin:0 auto;display:flex;flex-direction:column;gap:1.25rem;min-height:100vh}.app.dashboard-mode{max-width:100%;background:var(--bg-main)}.app-header-main{text-align:center;padding:1rem 0 .5rem;display:flex;flex-direction:column;gap:.25rem}.header-top{display:flex;justify-content:space-between;align-items:center;padding:0 1rem}.user-status{flex:1;text-align:left;font-size:.8rem;color:var(--text-secondary)}.app-logo{flex:2;font-family:var(--font-display);font-weight:700;font-size:1.6rem;letter-spacing:.12em;background:linear-gradient(135deg,var(--accent) 0%,#f0dca0 50%,var(--accent) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;text-transform:uppercase;display:flex;align-items:center;justify-content:center;gap:.75rem}.header-logo-img{height:38px;width:auto;filter:drop-shadow(0 0 10px rgba(201,168,76,.4))}.header-back-btn{background:#ffffff14;border:1px solid rgba(255,255,255,.15);color:#fff}.header-back-btn:hover{background:#ffffff26;border-color:var(--accent)}.header-spacer{flex:1}.app-tagline{color:var(--text-muted);font-size:.75rem;letter-spacing:.05em;text-transform:uppercase}.mobile-overlay{display:none}@media(max-width:900px){.mobile-overlay.active{display:block;position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:90;animation:fadeIn .3s ease-out}}.card{background:var(--bg-card);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border-glow);border-radius:var(--radius);padding:2rem;box-shadow:0 4px 30px #00000059;transition:border-color var(--transition)}.card:hover{border-color:#a882528c}.form-group{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.25rem}.form-row{display:flex;gap:1rem}.form-group label{font-family:var(--font-display);font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--accent)}textarea,select,.text-input{width:100%;background:var(--bg-secondary);border:1px solid rgba(168,130,82,.2);border-radius:8px;color:var(--text-primary);font-family:var(--font-body);font-size:.95rem;padding:.85rem 1rem;transition:border-color var(--transition),box-shadow var(--transition);outline:none;resize:vertical}textarea{min-height:100px}textarea:focus,select:focus,.text-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}textarea::placeholder,.text-input::placeholder{color:var(--text-muted);font-style:italic}select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='7' viewBox='0 0 12 7'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23a69e8e' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-family:var(--font-display);font-weight:600;font-size:.85rem;letter-spacing:.06em;text-transform:uppercase;padding:.8rem 1.8rem;border:none;border-radius:8px;cursor:pointer;transition:all var(--transition)}.btn-sm{padding:6px 14px;font-size:.75rem}.btn-primary{background:linear-gradient(135deg,var(--accent) 0%,#b08930 100%);color:#0d0f14;box-shadow:0 4px 15px var(--accent-glow)}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,var(--accent-hover) 0%,var(--accent) 100%);box-shadow:0 6px 24px #c9a84c66;transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:transparent;color:var(--accent);border:1px solid var(--accent)}.btn-secondary:hover{background:#c9a84c1a;box-shadow:0 4px 15px var(--accent-glow);transform:translateY(-1px)}.spinner-wrapper{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:3rem 0}.spinner{width:48px;height:48px;border:3px solid rgba(168,130,82,.2);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.spinner-wrapper p{color:var(--text-secondary);font-size:.9rem;animation:pulse 1.8s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.6}50%{opacity:1}}.dashboard-content{display:flex;gap:0;min-height:650px;border:1px solid var(--border-glow);border-radius:var(--radius);overflow:hidden;background:var(--bg-card)}.dashboard-main{flex:1;display:flex;flex-direction:column;gap:10px;padding:12px}.map-controls-bar{display:flex;align-items:center;justify-content:space-between}.toggle-group{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--text-secondary)}.switch{position:relative;display:inline-block;width:38px;height:20px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:var(--bg-secondary);transition:.3s;border:1px solid rgba(168,130,82,.3)}.slider:before{position:absolute;content:"";height:13px;width:13px;left:3px;bottom:3px;background-color:var(--text-muted);transition:.3s}input:checked+.slider{background-color:var(--accent);border-color:var(--accent)}input:checked+.slider:before{transform:translate(17px);background-color:#0d0f14}.slider.round{border-radius:20px}.slider.round:before{border-radius:50%}.download-bar{display:flex}.download-bar a{text-decoration:none}.error-message{background:#d94f4f1f;border:1px solid rgba(217,79,79,.35);border-radius:8px;padding:1rem 1.25rem;color:#f0a0a0;font-size:.9rem;text-align:center;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}.app-footer{text-align:center;padding:.75rem 0 .5rem;color:var(--text-muted);font-size:.72rem}@media(max-width:1024px){.app{padding:0 1rem}}@media(max-width:900px){.dashboard-content{flex-direction:column;min-height:auto}.form-row{flex-direction:column;gap:0}.dashboard-main{padding:8px}}@media(max-width:600px){.app-header h1{font-size:1.4rem}.card{padding:1.25rem}.btn{width:100%;padding:.9rem 1.5rem;font-size:.9rem}.form-group{margin-bottom:1rem}}.interactive-map-wrapper{display:flex;flex-direction:column;gap:10px;width:100%}.interactive-map-container{width:100%;height:60vh;min-height:400px;max-height:800px;overflow:hidden;background:#1a1a1a;border-radius:8px;position:relative;cursor:crosshair;border:1px solid #444;touch-action:none}.interactive-map-container.dragging{cursor:grabbing}.map-layer{position:absolute;top:0;left:0;cursor:pointer;-webkit-user-select:none;user-select:none}.map-base{display:block;max-width:none}.grid-overlay{position:absolute;inset:0;pointer-events:none}.map-marker{position:absolute;z-index:10;cursor:pointer;transition:transform .1s ease}.marker-pin{font-size:24px;filter:drop-shadow(0 2px 2px rgba(0,0,0,.5))}.controls{display:flex;gap:10px;align-items:center}.zoom-indicator{font-size:.9rem;color:#888;margin-left:auto}.help-text{font-size:.8rem;color:#666;text-align:center;margin:0}.btn-sm{padding:4px 8px;font-size:.8rem}.building-marker{position:absolute;z-index:10;cursor:grab;transition:transform .1s ease;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.building-marker:hover{z-index:20}.building-marker.dragging{cursor:grabbing;z-index:30}.building-icon{font-size:20px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.8));transition:transform .2s}.building-marker:hover .building-icon{transform:scale(1.3)}.building-tooltip{position:absolute;bottom:120%;left:50%;transform:translate(-50%);background:#141414f2;border:1px solid rgba(255,215,0,.4);padding:8px 12px;border-radius:6px;color:#fff;font-size:.85rem;white-space:nowrap;opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s;pointer-events:none;display:flex;flex-direction:column;gap:4px;box-shadow:0 4px 12px #00000080}.building-marker:hover .building-tooltip{opacity:1;visibility:visible}.building-tooltip strong{color:gold;font-size:.95rem}.building-tooltip span{color:#aaa}.sidebar{width:380px;min-width:380px;height:100%;background:var(--bg-card);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-left:1px solid var(--border-glow);display:flex;flex-direction:column;overflow:hidden;animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.sidebar-header{display:flex;justify-content:space-between;align-items:flex-start;padding:1.25rem 1.25rem 1rem;border-bottom:1px solid var(--border-glow)}.sidebar-title{font-family:var(--font-display);font-size:1.2rem;color:var(--text-primary);margin-bottom:2px}.sidebar-subtitle{font-size:.85rem;color:var(--text-secondary)}.sidebar-meta{font-size:.8rem;color:var(--text-muted);margin-top:4px}.close-btn{background:none;border:none;color:var(--text-muted);font-size:1.2rem;cursor:pointer;padding:4px;transition:color var(--transition)}.close-btn:hover{color:var(--text-primary)}.sidebar-tabs{display:flex;border-bottom:1px solid var(--border-glow);padding:0 1.25rem}.sidebar-tabs button{background:none;border:none;font-family:var(--font-display);font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);padding:.75rem 0;margin-right:1.5rem;cursor:pointer;border-bottom:2px solid transparent;transition:all var(--transition)}.sidebar-tabs button.active{color:var(--accent);border-bottom-color:var(--accent)}.sidebar-tabs button:hover:not(.active){color:var(--text-secondary)}.sidebar-content{flex:1;overflow-y:auto;padding:1rem 1.25rem}.detail-section{margin-bottom:1.25rem}.detail-section h3{font-family:var(--font-display);font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);margin-bottom:.5rem;border-bottom:1px solid rgba(168,130,82,.15);padding-bottom:4px}.detail-section p{font-size:.88rem;line-height:1.6;color:var(--text-secondary)}.empty-state{font-style:italic;color:var(--text-muted)!important}.ability-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.ability-score{display:flex;align-items:center;gap:8px;font-size:.85rem;padding:4px 8px;background:#0003;border-radius:6px}.ability-name{font-family:var(--font-display);font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);width:30px}.ability-value{font-weight:600;color:var(--text-primary)}.ability-mod{color:var(--accent);font-size:.8rem}.location-link{cursor:pointer;color:var(--accent)!important;transition:opacity var(--transition)}.location-link:hover{opacity:.8}.occupant-list{display:flex;flex-direction:column;gap:4px}.occupant-card{display:flex;align-items:center;gap:10px;padding:8px 10px;background:#00000026;border-radius:8px;cursor:pointer;transition:background var(--transition)}.occupant-card:hover{background:#a882521a}.occupant-icon{font-size:1.2rem}.occupant-info{display:flex;flex-direction:column;flex:1}.occupant-name{font-size:.88rem;font-weight:500;color:var(--text-primary)}.occupant-job{font-size:.75rem;color:var(--text-muted)}.occupant-status{font-size:1rem}.notes-input{width:100%;min-height:150px;background:#0003;border:1px solid rgba(168,130,82,.15);border-radius:8px;color:var(--text-primary);font-family:var(--font-body);font-size:.88rem;padding:10px;resize:vertical;outline:none;transition:border-color var(--transition)}.notes-input:focus{border-color:var(--accent)}.room-section{border-left:2px solid rgba(168,130,82,.15);padding-left:10px}.sidebar-actions{display:flex;gap:4px;padding:8px 1.25rem;border-bottom:1px solid rgba(168,130,82,.1)}.action-btn{background:#a8825214;border:1px solid rgba(168,130,82,.15);border-radius:6px;color:var(--text-secondary);font-family:var(--font-body);font-size:.75rem;padding:5px 10px;cursor:pointer;transition:all var(--transition)}.action-btn:hover{background:#a8825226;border-color:var(--accent);color:var(--accent)}.edit-input{background:var(--bg-secondary);border:1px solid var(--accent);border-radius:6px;color:var(--text-primary);font-family:var(--font-body);padding:4px 8px;outline:none;font-size:.88rem}.title-edit{font-family:var(--font-display);font-size:1.1rem;width:100%;margin-bottom:4px}.inline-edit{width:120px;margin-left:4px;font-size:.82rem}@media(max-width:900px){.sidebar{position:fixed;top:0;right:0;bottom:0;z-index:100;box-shadow:-4px 0 20px #00000080}}@media(max-width:500px){.sidebar{width:100%;min-width:100%}.sidebar-header{padding:1.5rem 1rem 1rem}.sidebar-tabs button{margin-right:1rem;font-size:.7rem}.sidebar-content{padding:1rem}.action-btn{padding:8px 12px;font-size:.8rem}}.reroll-icon-btn{background:none;border:none;cursor:pointer;font-size:1.1rem;opacity:.5;transition:opacity var(--transition),transform .2s;padding:0;line-height:1}.reroll-icon-btn:hover{opacity:1;transform:scale(1.1) rotate(15deg)}.relation-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.relation-item{background:#0003;border:1px solid rgba(168,130,82,.15);border-radius:8px;padding:10px;cursor:pointer;transition:all var(--transition)}.relation-item:hover{background:#a882521a;border-color:var(--accent)}.relation-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.relation-name{font-size:.9rem;font-weight:500;color:var(--text-primary)}.relation-type{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.relation-trust-container{display:flex;align-items:center;gap:8px}.trust-bar-bg{flex:1;height:4px;background:#ffffff1a;border-radius:2px;overflow:hidden}.trust-bar-fill{height:100%;border-radius:2px}.trust-label{font-size:.75rem;color:var(--text-secondary);min-width:40px;text-align:right}.toolbar{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;background:#0006;border:1px solid var(--border-glow);border-radius:10px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.toolbar-left{display:flex;align-items:center;gap:15px}.toolbar-back-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:8px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;font-size:1.2rem}.toolbar-back-btn:hover{background:#fff3;border-color:var(--primary);transform:translate(-2px)}.toolbar-info{display:flex;flex-direction:column}.toolbar-settlement-name{font-family:var(--font-display);font-size:1.1rem;color:var(--accent);letter-spacing:.04em}.toolbar-size{font-size:.75rem;color:var(--text-muted);text-transform:capitalize}.toolbar-actions{display:flex;gap:4px}.toolbar-btn{display:flex;align-items:center;gap:6px;background:transparent;border:1px solid transparent;color:var(--text-secondary);font-family:var(--font-body);font-size:.8rem;padding:6px 14px;border-radius:8px;cursor:pointer;transition:all var(--transition)}.toolbar-btn:hover:not(:disabled){background:#a882521a;border-color:#a8825233;color:var(--text-primary)}.toolbar-btn.active{background:#a8825226;border-color:var(--accent);color:var(--accent)}.toolbar-btn:disabled{opacity:.35;cursor:not-allowed}.toolbar-icon{font-size:1rem}.toolbar-label{font-weight:500}.toolbar-count{background:#a8825226;color:var(--accent);font-size:.7rem;font-weight:600;padding:1px 6px;border-radius:10px}@media(max-width:700px){.toolbar{flex-direction:column;gap:10px;padding:10px}.toolbar-left{width:100%;justify-content:center}.toolbar-actions{width:100%;justify-content:center;flex-wrap:wrap;gap:6px}.toolbar-btn{padding:10px 14px;font-size:.85rem;flex:1;min-width:80px;justify-content:center}.toolbar-label{display:none}}.time-system{display:flex;flex-direction:column;gap:8px;padding:10px 16px;border:1px solid var(--border-glow);border-radius:10px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:background .5s ease}.time-dawn{background:linear-gradient(135deg,#ff8c321f,#0000004d)}.time-day{background:linear-gradient(135deg,#ffdc6414,#0000004d)}.time-evening{background:linear-gradient(135deg,#ff64321a,#00000059)}.time-dusk{background:linear-gradient(135deg,#6432961a,#00000059)}.time-night{background:linear-gradient(135deg,#14143c4d,#0006)}.time-main-row{display:flex;align-items:center;justify-content:space-between;gap:1rem}.time-display{display:flex;align-items:center;gap:10px}.time-icon{font-size:1.6rem}.time-info{display:flex;flex-direction:column}.time-clock{font-family:var(--font-display);font-size:1.1rem;font-weight:600;color:var(--text-primary);letter-spacing:.03em}.time-day{font-size:.75rem;color:var(--text-muted)}.time-controls{display:flex;gap:4px;flex-wrap:wrap;justify-content:flex-end}.time-btn{background:#a882521a;border:1px solid rgba(168,130,82,.2);color:var(--accent);font-family:var(--font-body);font-size:.72rem;font-weight:500;padding:5px 10px;border-radius:6px;cursor:pointer;transition:all var(--transition);display:flex;align-items:center;gap:4px}.time-btn:hover,.time-btn.active{background:#a8825233;border-color:var(--accent)}.log-badge{background:var(--accent);color:#0d0f14;font-size:.6rem;font-weight:700;padding:0 4px;border-radius:8px;min-width:14px;text-align:center}.time-picker{display:grid;grid-template-columns:repeat(8,1fr);gap:3px;padding:8px 0;border-top:1px solid rgba(168,130,82,.1)}.hour-btn{background:#0003;border:1px solid transparent;border-radius:4px;color:var(--text-secondary);font-size:.68rem;padding:4px;cursor:pointer;transition:all var(--transition)}.hour-btn:hover{background:#a8825226;color:var(--text-primary)}.hour-btn.current{background:var(--accent);color:#0d0f14;font-weight:600}.event-log{max-height:200px;overflow-y:auto;padding:8px 0;border-top:1px solid rgba(168,130,82,.1);display:flex;flex-direction:column;gap:4px}.log-empty{font-size:.8rem;color:var(--text-muted);font-style:italic;text-align:center;padding:12px}.log-entry{display:flex;gap:10px;font-size:.78rem;padding:3px 0}.log-time{color:var(--text-muted);min-width:65px;font-family:monospace;font-size:.72rem}.log-text{color:var(--text-secondary)}.people-list-overlay{position:fixed;inset:0;background:#0009;z-index:200;display:flex;align-items:center;justify-content:center;animation:fadeInOverlay .2s ease-out}@keyframes fadeInOverlay{0%{opacity:0}to{opacity:1}}.people-list-panel{background:var(--bg-secondary);border:1px solid var(--border-glow);border-radius:var(--radius);width:90%;max-width:700px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 8px 40px #00000080;animation:scaleIn .25s ease-out}@keyframes scaleIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-glow)}.panel-header h2{font-family:var(--font-display);font-size:1.1rem;color:var(--accent)}.people-grid{overflow-y:auto;padding:1rem 1.5rem;display:flex;flex-direction:column;gap:6px}.person-card{display:flex;align-items:center;gap:12px;padding:10px 14px;background:#0003;border:1px solid transparent;border-radius:8px;cursor:pointer;transition:all var(--transition)}.person-card:hover{background:#a8825214;border-color:#a8825233}.person-avatar{font-size:1.5rem;width:36px;text-align:center}.person-details{display:flex;flex-direction:column;flex:1}.person-name{font-weight:500;color:var(--text-primary);font-size:.9rem}.person-job{font-size:.78rem;color:var(--text-secondary)}.person-location{font-size:.72rem;color:var(--text-muted);margin-top:2px}.person-status-dot{font-size:.9rem}.building-list-overlay{position:fixed;inset:0;background:#0009;z-index:200;display:flex;align-items:center;justify-content:center;animation:fadeInOverlay .2s ease-out}.building-list-panel{background:var(--bg-secondary);border:1px solid var(--border-glow);border-radius:var(--radius);width:90%;max-width:700px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 8px 40px #00000080;animation:scaleIn .25s ease-out}.building-grid{overflow-y:auto;padding:1rem 1.5rem;display:grid;grid-template-columns:1fr 1fr;gap:8px}.building-card{display:flex;align-items:center;gap:12px;padding:12px 14px;background:#0003;border:1px solid transparent;border-radius:8px;cursor:pointer;transition:all var(--transition)}.building-card:hover{background:#a8825214;border-color:#a8825233}.building-icon-large{font-size:1.8rem;width:40px;text-align:center}.building-details{display:flex;flex-direction:column;flex:1}.building-name{font-weight:500;color:var(--text-primary);font-size:.9rem}.building-type{font-size:.75rem;color:var(--text-secondary)}.building-occupants{font-size:.72rem;color:var(--text-muted);margin-top:2px}.building-status{font-size:.7rem}@media(max-width:600px){.building-grid{grid-template-columns:1fr}}.creator-overlay{position:fixed;inset:0;background:#000000b3;z-index:300;display:flex;align-items:center;justify-content:center;animation:fadeInOverlay .2s ease-out}.creator-modal{background:#1e1f2a;border:1px solid var(--border-glow);border-radius:var(--radius);width:92%;max-width:820px;max-height:88vh;display:flex;flex-direction:column;box-shadow:0 12px 60px #0009;animation:scaleIn .25s ease-out}.creator-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-glow)}.creator-header h2{font-family:var(--font-display);font-size:1.2rem;color:var(--text-primary);letter-spacing:.04em}.creator-tabs{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:4px;padding:10px 1.5rem;border-bottom:1px solid rgba(168,130,82,.15)}.creator-tab{display:flex;align-items:center;justify-content:center;text-align:center;gap:6px;background:#00000026;border:1px solid transparent;border-radius:8px;padding:10px 8px;cursor:pointer;transition:all var(--transition);color:var(--text-secondary)}.creator-tab:hover{background:#a8825214;border-color:#a8825226}.creator-tab.active{background:#a882521f;border-color:var(--accent);color:var(--accent)}.tab-icon{font-size:1.1rem}.tab-label{font-family:var(--font-display);font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;font-weight:600}.creator-content{flex:1;overflow-y:auto;padding:1.5rem}.tab-content{display:flex;flex-direction:column;gap:1.25rem;animation:fadeIn .2s ease-out}.field{display:flex;flex-direction:column;gap:6px}.field label,.section-label{font-family:var(--font-display);font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--accent)}.field input[type=text],.field input[type=number],.field select{width:100%;background:var(--bg-secondary);border:1px solid rgba(168,130,82,.2);border-radius:8px;color:var(--text-primary);font-family:var(--font-body);font-size:.9rem;padding:.7rem .9rem;outline:none;transition:border-color var(--transition)}.field input:focus,.field select:focus{border-color:var(--accent)}.field input[type=range]{-webkit-appearance:none;width:100%;height:6px;background:var(--bg-secondary);border-radius:3px;outline:none}.field input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--accent);cursor:pointer}.field-row{display:flex;gap:1rem}.field-row>.field{flex:1}.range-labels{display:flex;justify-content:space-between;font-size:.7rem;color:var(--text-muted)}.field-hint{font-size:.78rem;color:var(--text-muted);font-style:italic}.pill-grid{display:flex;flex-wrap:wrap;gap:6px}.pill{background:#0003;border:1px solid rgba(168,130,82,.15);border-radius:20px;padding:6px 14px;font-size:.8rem;font-family:var(--font-body);color:var(--text-secondary);cursor:pointer;transition:all var(--transition)}.pill:hover{border-color:#a882524d;color:var(--text-primary)}.pill.active{background:#a8825226;border-color:var(--accent);color:var(--accent)}.race-list{display:flex;flex-direction:column;gap:6px}.race-row{display:flex;align-items:center;gap:10px;padding:4px 0}.race-name{width:90px;font-size:.85rem;color:var(--text-primary)}.race-input{width:60px!important;text-align:center;padding:4px 6px!important;font-size:.85rem!important}.race-pct{font-size:.8rem;color:var(--text-muted)}.race-bar-bg{flex:1;height:6px;background:#0000004d;border-radius:3px;overflow:hidden}.race-bar{height:100%;background:var(--accent);border-radius:3px;transition:width .3s ease}.remove-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.9rem;padding:2px 6px}.remove-btn:hover{color:var(--error)}.add-race-row{display:flex;gap:8px;margin-top:8px}.add-race-input{flex:1;background:var(--bg-secondary);border:1px solid rgba(168,130,82,.15);border-radius:8px;color:var(--text-primary);font-family:var(--font-body);font-size:.85rem;padding:6px 10px;outline:none}.section-label .valid{color:var(--success)}.section-label .invalid{color:var(--error)}.creator-footer{display:flex;justify-content:flex-end;gap:10px;padding:1rem 1.5rem;border-top:1px solid var(--border-glow)}@media(max-width:600px){.creator-modal{max-height:95vh;width:96%}.creator-tabs{grid-template-columns:repeat(3,1fr);padding:8px 1rem}.tab-label{display:none}.tab-icon{font-size:1.4rem}.creator-content{padding:1rem}.field-row{flex-direction:column;gap:1rem}.creator-footer{padding:1rem;flex-direction:column}.creator-footer .btn{width:100%}}.premium-badge-overlay{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:16px;border-radius:10px;background:#0009;border:1px solid rgba(212,175,55,.3);text-align:center}.premium-badge-overlay.compact{flex-direction:row;padding:8px 14px;gap:10px}.premium-badge-overlay .lock-icon{font-size:1.6rem}.premium-badge-overlay.compact .lock-icon{font-size:1.1rem}.premium-badge-overlay .lock-label{color:#d4af37;font-size:.85rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.premium-badge-overlay .unlock-btn{font-size:.75rem;padding:6px 14px;background:linear-gradient(135deg,#d4af37,#b8860b);color:#1a1a2e;border:none;border-radius:6px;font-weight:700;cursor:pointer;text-decoration:none;transition:transform .2s,box-shadow .2s}.premium-badge-overlay .unlock-btn:hover{transform:scale(1.05);box-shadow:0 0 12px #d4af3780}.export-overlay{position:fixed;inset:0;background:#0009;z-index:200;display:flex;align-items:center;justify-content:center;animation:fadeInOverlay .2s ease-out}.export-panel{background:var(--bg-secondary);border:1px solid var(--border-glow);border-radius:var(--radius);width:95%;max-width:560px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 8px 40px #00000080;animation:scaleIn .25s ease-out}.export-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;padding:1rem;overflow-y:auto;flex:1}@media(max-width:480px){.export-grid{grid-template-columns:1fr}}.export-card{display:flex;flex-direction:column;align-items:center;gap:4px;padding:20px 14px;background:#0003;border:1px solid rgba(168,130,82,.12);border-radius:10px;cursor:pointer;transition:all var(--transition);text-align:center}.export-card:hover{background:#a8825214;border-color:var(--accent);transform:translateY(-2px)}.export-card.vtt{border-color:#648cc833}.export-card.vtt:hover{border-color:#6b8ec9}.export-icon{font-size:2rem;margin-bottom:4px}.export-label{font-family:var(--font-display);font-size:.8rem;font-weight:600;color:var(--text-primary);text-transform:uppercase;letter-spacing:.04em}.export-desc{font-size:.72rem;color:var(--text-muted)}.export-card.locked{position:relative;cursor:default;opacity:.9;background:#14141480;border-color:#d4af3726;overflow:hidden}.export-card.locked:hover{transform:none;background:#14141499;border-color:#d4af374d}.list-panel{position:absolute;top:60px;right:280px;width:320px;background:#1e1e24;border:1px solid #444;border-radius:8px;box-shadow:0 8px 32px #00000080;z-index:100;display:flex;flex-direction:column;max-height:calc(100vh - 80px)}.list-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid #333;background:#25252b;border-radius:8px 8px 0 0}.list-header h2{margin:0;font-size:1.1rem;color:#e0e0e0}.close-btn{background:none;border:none;color:#aaa;font-size:1.2rem;cursor:pointer;transition:color .2s}.close-btn:hover{color:#fff}.list-content{padding:12px;overflow-y:auto;display:flex;flex-direction:column;gap:12px}.empty-state{text-align:center;color:#aaa;font-style:italic;padding:20px}.list-item{background:#2a2a32;border:1px solid #3a3a44;border-radius:6px;padding:12px}.item-main{display:flex;flex-direction:column;gap:4px}.item-title{font-weight:600;color:gold;display:flex;align-items:center;gap:8px}.icon{font-size:1.2rem}.item-subtitle{font-size:.85rem;color:#888}.shop-panel{position:fixed;inset:0;background:#0a0a14eb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:200;display:flex;flex-direction:column;animation:fadeInPanel .3s ease-out}@keyframes fadeInPanel{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.shop-panel-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 2rem;border-bottom:1px solid var(--border-glow)}.shop-panel-header h2{font-family:var(--font-display);font-size:1.4rem;color:var(--text-primary)}.shop-panel-body{display:flex;flex:1;overflow:hidden}.shop-list{width:320px;min-width:280px;border-right:1px solid var(--border-glow);overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:6px}.shop-card{display:flex;align-items:center;gap:12px;padding:12px 14px;background:#00000040;border:1px solid transparent;border-radius:10px;cursor:pointer;transition:all var(--transition)}.shop-card:hover{background:#a8825214;border-color:#a8825233}.shop-card.active{background:#a882521f;border-color:var(--accent)}.shop-icon{font-size:1.6rem}.shop-info{display:flex;flex-direction:column;flex:1}.shop-name{font-weight:500;color:var(--text-primary);font-size:.92rem}.shop-type{font-size:.75rem;color:var(--text-muted)}.shop-status{font-size:.9rem}.shop-inventory{flex:1;overflow-y:auto;padding:1.5rem 2rem}.shop-inventory h3{font-family:var(--font-display);font-size:1.2rem;color:var(--text-primary);margin-bottom:4px}.shop-inventory-subtitle{font-size:.85rem;color:var(--text-muted);margin-bottom:1rem}.empty-inventory{display:flex;align-items:center;justify-content:center}.inventory-table{width:100%;border-collapse:separate;border-spacing:0 4px}.inventory-table thead th{font-family:var(--font-display);font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);text-align:left;padding:8px 12px;border-bottom:1px solid rgba(168,130,82,.15)}.inventory-table tbody tr{background:#0003;transition:background var(--transition)}.inventory-table tbody tr:hover{background:#a8825214}.inventory-table td{padding:10px 12px;font-size:.88rem;color:var(--text-secondary);vertical-align:middle}.inventory-table td:first-child{border-radius:8px 0 0 8px}.inventory-table td:last-child{border-radius:0 8px 8px 0}.item-name{display:block;font-weight:500;color:var(--text-primary);font-size:.9rem}.item-rarity{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em}.price-cell{white-space:nowrap;font-weight:600;color:var(--accent)!important}.gold-icon{font-size:.85rem}.stock-badge{display:inline-block;padding:2px 10px;border-radius:12px;font-size:.8rem;font-weight:600}.stock-badge.low{background:#ef444426;color:#ef4444}.stock-badge.normal{background:#f59e0b26;color:#f59e0b}.stock-badge.high{background:#10b98126;color:#10b981}.econ-tag{font-size:.78rem;white-space:nowrap}.supply-low{color:#ef4444}.supply-normal{color:var(--text-secondary)}.supply-high{color:#10b981}.demand-low{color:#60a5fa}.demand-normal{color:var(--text-secondary)}.demand-high{color:#f97316}@media(max-width:800px){.shop-panel-body{flex-direction:column}.shop-list{width:100%;min-width:unset;max-height:200px;border-right:none;border-bottom:1px solid var(--border-glow)}}.settings-panel{z-index:300}.settings-section{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-glow)}.settings-section h3{font-family:var(--font-display);font-size:1.1rem;color:var(--accent);margin-bottom:1.25rem;letter-spacing:.05em}.setting-item{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.setting-item label{font-size:.9rem;color:var(--text-secondary)}.setting-item input[type=number]{width:60px;padding:4px 8px;background:#0000004d;border:1px solid var(--border-glow);border-radius:4px;color:#fff}.setting-item select{padding:6px 10px;background:#0000004d;border:1px solid var(--border-glow);border-radius:4px;color:#fff}.panel-footer{padding:1.5rem 2rem;border-top:1px solid var(--border-glow);display:flex;justify-content:flex-end}.auth-container{position:fixed;top:0;left:0;width:100vw;height:100vh;display:flex;justify-content:center;align-items:center;z-index:9999;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);font-family:Cinzel,Noto Sans JP,sans-serif}.auth-card{background:var(--bg-panel);border:1px solid var(--border-color);border-radius:12px;padding:3rem;width:100%;max-width:400px;box-shadow:0 20px 50px #00000080;text-align:center;position:relative;animation:authPopIn .3s ease-out forwards}@keyframes authPopIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.auth-close{position:absolute;top:15px;right:15px;background:none;border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;transition:color .2s}.auth-close:hover{color:#fff}.auth-card h2{font-family:var(--font-display);color:var(--accent);margin-bottom:.2rem;font-size:1.8rem}.auth-subtitle{color:var(--text-muted);font-size:.85rem;margin-bottom:2rem}.auth-form{display:flex;flex-direction:column;gap:1rem}.auth-input{width:100%;padding:.8rem;background:#0003;border:1px solid rgba(168,130,82,.3);border-radius:8px;color:var(--text-primary);font-family:var(--font-body);font-size:.95rem;transition:all .2s ease}.auth-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #a8825233}.auth-submit{width:100%;margin-top:.5rem;padding:.8rem;font-size:1rem}.auth-message{padding:.8rem;border-radius:8px;margin-bottom:1rem;font-size:.85rem}.auth-message.error{background:#dc35451a;color:#ff6b6b;border:1px solid rgba(220,53,69,.3)}.auth-message.success{background:#28a7451a;color:#51cf66;border:1px solid rgba(40,167,69,.3)}.auth-toggle{margin-top:1.5rem}.btn-link{background:none;border:none;color:var(--text-muted);font-size:.85rem;cursor:pointer;text-decoration:underline;transition:color .2s}.btn-link:hover{color:var(--accent)}.landing-container{display:flex;flex-direction:column;min-height:100vh;width:100vw;background-color:var(--bg-main);color:var(--text-primary);overflow-x:hidden;font-family:Cinzel,Noto Sans JP,sans-serif;scroll-behavior:smooth}.landing-nav{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 4rem;background:#121212cc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:fixed;top:0;width:100%;z-index:1000;border-bottom:1px solid rgba(255,255,255,.1);box-sizing:border-box}.nav-brand{font-size:1.5rem;font-weight:700;letter-spacing:1px;display:flex;align-items:center;gap:.75rem}.nav-logo{height:32px;width:auto;filter:drop-shadow(0 0 8px rgba(139,92,246,.3))}.nav-links{display:flex;gap:2rem;align-items:center}.nav-links a{color:var(--text-secondary);text-decoration:none;font-size:1rem;transition:color .2s ease}.nav-links a:hover{color:var(--primary-accent)}.nav-user-info{display:flex;align-items:center;gap:15px;background:#ffffff0d;padding:6px 16px;border-radius:50px;border:1px solid rgba(255,255,255,.1)}.user-email{font-size:.85rem;color:var(--text-secondary);font-family:system-ui,sans-serif}.hero-section{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:6rem 2rem 4rem;text-align:center;background-size:cover;background-position:center;background-repeat:no-repeat;position:relative;overflow:hidden}.hero-overlay{position:absolute;inset:0;background:radial-gradient(circle at center,#8b5cf61a,#0a0a0fcc,#0a0a0f);z-index:1}.hero-content{position:relative;z-index:2;max-width:1000px;animation:heroFadeUp 1s cubic-bezier(.16,1,.3,1) forwards}@keyframes heroFadeUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.hero-badge{display:inline-block;padding:.5rem 1.25rem;background:#8b5cf626;border:1px solid rgba(139,92,246,.3);border-radius:100px;color:#a78bfa;font-size:.85rem;font-weight:600;margin-bottom:2rem;letter-spacing:.05em;text-transform:uppercase;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.hero-title{font-size:clamp(2.5rem,6vw,5rem);line-height:1.05;margin-bottom:1.5rem;font-weight:800;letter-spacing:-.02em;font-family:Cinzel,serif}.hero-title-main{color:#fff;text-shadow:0 0 40px rgba(139,92,246,.3)}.hero-title-highlight{font-size:clamp(2rem,5vw,4.5rem);background:linear-gradient(135deg,#a78bfa,#f472b6);-webkit-background-clip:text;background-clip:text;color:transparent;font-weight:900;margin-top:-.5rem}.hero-subtitle{font-size:1.25rem;color:#ffffffb3;margin:2.5rem auto 3.5rem;line-height:1.7;max-width:750px;font-family:inherit;font-weight:400}.hero-actions{display:flex;gap:1.5rem;justify-content:center;flex-wrap:wrap;margin-bottom:4rem}.hero-btn-main{padding:1.25rem 3rem;font-size:1.1rem;border-radius:12px;position:relative;overflow:hidden;background:linear-gradient(135deg,#8b5cf6,#ec4899);color:#fff!important;border:none!important;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 10px 40px -10px #8b5cf680;display:flex;flex-direction:column;align-items:center}.hero-btn-main:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 20px 60px -15px #8b5cf6b3}.hero-btn-secondary{padding:1.25rem 3rem;font-size:1.1rem;border-radius:12px;background:#ffffff08!important;border:1px solid rgba(255,255,255,.1)!important;color:#fff!important;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:all .3s ease;display:flex;flex-direction:column;align-items:center}.hero-btn-secondary:hover{background:#ffffff14!important;border-color:#ffffff4d!important;transform:translateY(-2px)}.hero-btn-main small,.hero-btn-secondary small{font-size:.7rem;opacity:.8;margin-top:4px;text-transform:uppercase;letter-spacing:.05em}.hero-trust{opacity:.6;font-size:.9rem;display:flex;flex-direction:column;gap:.5rem;letter-spacing:.1em;text-transform:uppercase}.trust-icons{color:#fdbb2d;font-size:1.2rem}.section-title{text-align:center;font-size:2.5rem;margin-bottom:3rem;position:relative;display:block;width:fit-content;margin-left:auto;margin-right:auto}.section-title:after{content:"";position:absolute;bottom:-10px;left:50%;transform:translate(-50%);width:60px;height:3px;background:var(--primary-accent);border-radius:2px}.saved-worlds-section{padding:4rem 2rem 6rem;background:linear-gradient(to bottom,#121212,#0d0d0d);border-top:1px solid rgba(255,255,255,.05)}.section-header{text-align:center;margin-bottom:3rem;display:flex;flex-direction:column;align-items:center}.section-subtitle{color:var(--text-secondary);font-size:1rem;margin-top:.5rem}.saved-worlds-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;max-width:1200px;margin:0 auto}.save-card{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:1.5rem;display:flex;flex-direction:column;gap:1rem;transition:all .2s ease}.save-card:hover{background:#ffffff0d;border-color:var(--primary-accent);transform:translateY(-3px);box-shadow:0 8px 24px #0003}.save-card-icon{font-size:2rem}.save-card-info h3{font-family:Cinzel,serif;font-size:1.2rem;margin-bottom:.25rem}.save-card-info p{font-size:.8rem;color:var(--text-muted)}.no-saves-cta{grid-column:1 / -1;border:2px dashed rgba(255,255,255,.1);border-radius:16px;padding:4rem;text-align:center;cursor:pointer;transition:all .2s ease;background:#ffffff03}.no-saves-cta:hover{background:#ffffff08;border-color:var(--primary-accent)}.cta-plus{font-size:3rem;font-weight:200;color:var(--primary-accent);margin-bottom:1rem}.features-section{padding:6rem 2rem;background:var(--bg-main);max-width:1200px;margin:0 auto}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}.feature-card{background:var(--bg-panel);border:1px solid var(--border-color);border-radius:12px;padding:2rem;transition:transform .3s ease,border-color .3s ease;font-family:system-ui,-apple-system,sans-serif}.feature-card:hover{transform:translateY(-5px);border-color:#a78bfa80;box-shadow:0 10px 30px #0003}.feature-icon{font-size:2.5rem;margin-bottom:1rem}.feature-card h3{font-size:1.3rem;margin-bottom:1rem;font-family:Cinzel,serif}.feature-card p{color:var(--text-secondary);line-height:1.6;font-size:.95rem}.pricing-section{padding:6rem 2rem;background:#0d0d0d}.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;max-width:1200px;margin:0 auto}.pricing-card{background:var(--bg-panel);border:1px solid var(--border-color);border-radius:12px;padding:2.5rem 2rem;display:flex;flex-direction:column;position:relative;font-family:system-ui,-apple-system,sans-serif}.highlighted-pricing{border:2px solid var(--primary-accent);transform:scale(1.02);box-shadow:0 0 30px #8b5cf626}.premium-card{background:linear-gradient(145deg,#1f1b2e,#151221);border:1px solid rgba(244,114,182,.4)}.pricing-header{text-align:center;margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid var(--border-color)}.pricing-header h3{font-family:Cinzel,serif;font-size:1.5rem;margin-bottom:.5rem}.pricing-header .price{font-size:3rem;font-weight:800;margin:.5rem 0}.pricing-header .price small{font-size:1rem;color:var(--text-secondary);font-weight:400}.pricing-header p{color:var(--text-secondary)}.premium-badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);background:linear-gradient(90deg,#f472b6,#a78bfa);color:#fff;padding:4px 12px;border-radius:20px;font-size:.8rem;font-weight:700;letter-spacing:1px}.pricing-features{list-style:none;padding:0;margin:0 0 2rem;flex-grow:1}.pricing-features li{margin-bottom:1rem;color:var(--text-secondary);display:flex;align-items:flex-start;gap:10px}.pricing-features li strong{color:var(--text-primary)}.btn-premium{background:linear-gradient(90deg,#f472b6,#a78bfa);color:#fff;border:none;padding:10px 20px;border-radius:6px;font-size:1rem;cursor:pointer;width:100%;transition:opacity .2s}.btn-premium:hover{opacity:.9}.pricing-card .btn{width:100%}.landing-footer{text-align:center;padding:2rem;background:#000;color:#666;font-size:.9rem;font-family:system-ui,-apple-system,sans-serif}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.hero-content h1{font-size:2.2rem}.landing-nav{padding:1rem}.nav-links{display:none}.highlighted-pricing{transform:none}}
