:root{--bg-void:#080a10;--bg-base:#0c0e14;--bg-raised:#141726;--bg-surface:#1b1f2e;--bg-overlay:#161a28;--border-dim:#1f2338;--border-mid:#2f3550;--border-bright:#3b4679;--text-primary:#eef0ff;--text-secondary:#cfd4ff;--text-muted:#7b83b8;--accent-from:#5f6dff;--accent-mid:#8b25ff;--accent-to:#ab8cff;--accent-grad:linear-gradient(135deg, #5f6dff 0%, #8b25ff 50%, #ab8cff 100%);--warm-bg:#f5efe7;--warm-surface:#e8dbc4;--warm-border:#b39f86;--warm-text:#2f241b;--warm-muted:#6b5338;--warm-accent:#7c5a2d}.city-layout{box-sizing:border-box;background:linear-gradient(180deg, var(--bg-base), var(--bg-raised));flex-direction:column;align-items:center;gap:0;width:100vw;max-width:100vw;min-height:100vh;margin:0;font-family:DM Mono,Courier New,monospace;display:flex;position:relative}.building-manager{flex-direction:column;align-items:center;min-height:200px;margin-top:0;display:flex;position:relative}.building-center{justify-content:center;align-items:flex-start;width:100%;display:flex}.budget-header{z-index:10;width:100%;position:sticky;top:0;bottom:0}.add-transaction-btn{background:var(--accent-grad);width:70px;height:70px;color:var(--text-primary);border:1px solid var(--border-bright);cursor:pointer;z-index:1000;border-radius:50%;justify-content:center;align-items:center;font-size:36px;transition:transform .15s,box-shadow .15s;display:flex;position:fixed;bottom:24px;right:24px;box-shadow:0 12px 28px #000000a6,0 4px 12px #5f6dff40,inset 0 1px #ffffff26}.add-transaction-btn:hover{transform:scale(1.08)translateY(-2px);box-shadow:0 18px 36px #000000bf,0 6px 18px #5f6dff59,inset 0 1px #fff3}.slide-trigger-btn{background:linear-gradient(145deg, var(--bg-surface), var(--bg-overlay));color:var(--text-secondary);border:1px solid var(--border-mid);cursor:pointer;z-index:1000;letter-spacing:.03em;border-radius:8px;padding:10px 16px;font-family:inherit;transition:transform .12s,box-shadow .12s,filter .12s;position:fixed;bottom:24px;left:24px;box-shadow:0 6px 14px #00000080,inset 0 1px #ffffff0d}.slide-trigger-btn:hover{filter:brightness(1.1);transform:translateY(-1px);box-shadow:0 10px 20px #000000a6,inset 0 1px #ffffff0f}.transaction-overlay{z-index:2000;justify-content:center;width:100%;height:100%;display:flex;position:fixed;top:0;left:0}.transaction-overlay.popup{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#080a10b3;align-items:center}.transaction-overlay.popup .transaction-panel{border-radius:16px}.transaction-overlay.slide{align-items:flex-start}.transaction-panel{background:linear-gradient(#0c0e14,#1b1f2e);border:1px solid #2f3550;flex-direction:column;gap:10px;width:min(90vw,900px);padding:14px;transition:transform .25s;display:flex;position:relative;box-shadow:0 25px 50px #000000b3,inset 0 1px #ffffff0a}.transaction-panel.slide.open{transform:translateY(0)}.transaction-panel.slide.closing,.transaction-panel.closing{transform:translateY(-110%)}.transaction-overlay.slide .transaction-panel{border-bottom:1px solid #2f3550;border-radius:0;width:100%}.transaction-slide-header,.transaction-header-row,.transaction-title{color:#eef0ff}.transaction-slide-header{justify-content:space-between;font-weight:700;display:flex}.transaction-header-row{justify-content:space-between;align-items:center;padding-bottom:20px;padding-right:50px;display:flex}.transaction-title{letter-spacing:.03em;font-size:18px;font-weight:800}.transaction-row{gap:10px;display:flex}.transaction-row select,.transaction-row input{color:#cfd4ff;background:linear-gradient(#1b1f2e,#141726);border:1px solid #2f3550;border-radius:8px;flex:1;height:36px;padding:0 10px;font-family:inherit;transition:border-color .15s;box-shadow:inset 0 1px 2px #0006}.transaction-row select:focus,.transaction-row input:focus{border-color:#5f6dff;outline:none;box-shadow:0 0 0 2px #5f6dff33,inset 0 1px 2px #0006}.transaction-type-row{gap:10px;margin-top:4px;display:flex}.transaction-type-row button{color:#cfd4ff;background:linear-gradient(#1b1f2e,#141726);border:1px solid #2f3550;border-radius:8px;flex:1;height:36px;font-family:inherit;font-size:18px;transition:transform .12s,filter .12s;box-shadow:0 4px 10px #0006,inset 0 1px #ffffff0d}.transaction-type-row button:hover{filter:brightness(1.1)}.transaction-type-row button.active{color:#fff;background:linear-gradient(135deg,#5f6dff 0%,#8b25ff 50%,#ab8cff 100%);border:1px solid #3b4679;box-shadow:0 6px 14px #5f6dff59,inset 0 1px #ffffff1f}.transaction-type-row button.inactive{color:#cfd4ff;background:linear-gradient(#1b1f2e,#141726)}.transaction-submit{color:#fff;letter-spacing:.04em;cursor:pointer;background:linear-gradient(135deg,#5f6dff 0%,#8b25ff 50%,#ab8cff 100%);border:1px solid #3b4679;border-radius:8px;height:40px;font-family:inherit;font-weight:700;transition:transform .12s,box-shadow .12s;box-shadow:0 10px 20px #5f6dff59,inset 0 1px #ffffff1f}.transaction-submit:hover{transform:translateY(-1px);box-shadow:0 14px 28px #5f6dff73,inset 0 1px #ffffff26}.transaction-close{color:#fff;cursor:pointer;background:linear-gradient(135deg,#5f6dff 0%,#8b25ff 50%,#ab8cff 100%);border:1px solid #3b4679;border-radius:50%;width:36px;height:36px;font-size:20px;position:absolute;top:12px;right:12px;box-shadow:0 8px 16px #5f6dff59,inset 0 1px #ffffff26}.drag-handle.bottom{cursor:grab;background:#ffffff59;border-radius:2px;width:40px;height:4px;margin:6px auto 0}.building-select-wrapper{width:100%;display:inline-block;position:relative}select{color:#eef0ff;appearance:none;cursor:pointer;background:linear-gradient(#1b1f2e,#141726);border:1px solid #2f3550;border-radius:8px;width:100%;padding:0 32px 0 10px;box-shadow:inset 0 1px 2px #0006}select option{color:#eef0ff;background:#141726}select:focus{border-color:#5f6dff;outline:none;box-shadow:0 0 0 2px #5f6dff40}.building-select-wrapper:after{content:"";pointer-events:none;opacity:.75;border-top:6px solid #cfd4ff;border-left:5px solid #0000;border-right:5px solid #0000;width:0;height:0;position:absolute;top:50%;right:12px;transform:translateY(-50%)}select:hover{filter:brightness(1.08)}.menu-layer{pointer-events:none;z-index:0;width:140px;position:absolute;top:0;left:50%;transform:translate(-50%)}.dropdown-ellipse{z-index:0;transform-origin:top;background:linear-gradient(#141726,#0c0e14);border:1px solid #2f3550;border-radius:999px;width:85px;height:500px;transition:transform .28s,opacity .28s;position:absolute;top:18px;left:50%;transform:translate(-50%);box-shadow:0 18px 36px #000000a6,inset 0 2px 6px #ffffff0a}.profile-dropdown{z-index:2;transform-origin:top;flex-direction:column;align-items:center;gap:10px;width:140px;transition:transform .28s,opacity .28s;display:flex;position:absolute;top:95px;left:50%;transform:translate(-50%)}.dropdown-item{z-index:1;cursor:pointer;color:#eef0ff;background-image:linear-gradient(145deg,#1b1f2e,#0c0e14),linear-gradient(135deg,#5f6dff 0%,#8b25ff 50%,#ab8cff 100%);background-origin:border-box;background-clip:padding-box,border-box;border:1px solid #0000;border-radius:50%;justify-content:center;align-items:center;width:75px;height:75px;font-size:14px;font-weight:600;transition:transform .2s,box-shadow .2s;display:flex;position:relative;box-shadow:0 10px 20px #0000008c,inset 0 1px #ffffff0d}.dropdown-item:after{content:"";pointer-events:none;background:linear-gradient(#ffffff1a,#0000 60%);border-radius:50%;position:absolute;inset:0}.dropdown-item:hover{transform:translateY(-3px)scale(1.05);box-shadow:0 16px 30px #000000bf,inset 0 1px #ffffff0f}.menu-layer.open{pointer-events:auto}.menu-layer.open .dropdown-ellipse,.menu-layer.open .profile-dropdown{opacity:1;transform:translate(-50%)scaleY(1)}.menu-layer.open .dropdown-item{opacity:1;transform:translateY(0)}.menu-layer.closed{pointer-events:none}.menu-layer.closed .dropdown-ellipse,.menu-layer.closed .profile-dropdown{opacity:0;transform:translate(-50%)scaleY(.1)}.menu-layer.closed .dropdown-item{opacity:0;transform:translateY(-10px)}.budget-header{box-sizing:border-box;background:linear-gradient(#080a10,#0c0e14);border-bottom:1px solid #1f2338;width:100%;min-height:100px;padding:47.5px 10px}.header-row{align-items:center;gap:10px;display:flex}.budget-panel{flex:1;min-width:0}.budget-title{color:#eef0ff;letter-spacing:.04em;background:linear-gradient(145deg,#1b1f2e,#141726);border:1px solid #3b4679;border-radius:8px;margin-bottom:6px;padding:8px 12px;font-size:15px;font-weight:700;box-shadow:0 2px 6px #080a1080}.budget-values{background:#141726;border:1px solid #2f3550;border-radius:10px;width:100%;height:36px;display:flex;position:relative;overflow:visible}.budget-left{background:linear-gradient(135deg,#5f6dff 0%,#8b25ff 40%,#ab8cff 100%);border-radius:9px 0 0 9px;transition:width .5s cubic-bezier(.77,0,.18,1);position:relative;overflow:hidden;box-shadow:inset 0 1px #ffffff26}.budget-left:after{content:"";pointer-events:none;background:linear-gradient(#ffffff1f,#0000 60%);position:absolute;inset:0}.budget-right{background:linear-gradient(135deg,#1b1f2e 0%,#2f3550 100%);border-left:1px solid #3b4679;border-radius:0 9px 9px 0;transition:width .5s cubic-bezier(.77,0,.18,1);overflow:hidden}.budget-label-left{pointer-events:none;z-index:2;white-space:nowrap;color:#fff;text-shadow:0 1px 4px #000000b3,0 0 8px #00000080;letter-spacing:.03em;align-items:center;gap:5px;height:100%;padding-left:12px;font-size:14px;font-weight:800;display:flex;position:absolute;top:0;left:0}.budget-label-right{pointer-events:none;z-index:2;white-space:nowrap;color:#cfd4ff;text-shadow:0 1px 4px #000000b3,0 0 8px #00000080;letter-spacing:.03em;align-items:center;height:100%;padding-right:12px;font-size:14px;font-weight:700;display:flex;position:absolute;top:0;right:0}.budget-values:hover{filter:brightness(1.06)}.player-menu-wrapper{z-index:20;flex-shrink:0;width:85px;position:relative}.player-icon-button{cursor:pointer;z-index:21;background:0 0;border:none;padding:0;position:relative}.player-icon{color:#eef0ff;z-index:21;background:linear-gradient(145deg,#1b1f2e,#0c0e14);border:1px solid #2f3550;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:85px;height:85px;font-size:14px;font-weight:600;line-height:1.1;transition:transform .15s,box-shadow .15s;display:flex;position:relative;box-shadow:0 10px 20px #0000008c,inset 0 1px #ffffff0d}.player-icon:hover{transform:translateY(-3px)scale(1.05);box-shadow:0 16px 30px #000000bf,inset 0 1px #ffffff0f}.budget-period-row{box-sizing:border-box;grid-template-columns:minmax(0,1fr) 122px;gap:6px;width:100%;min-width:0;margin-top:6px;display:grid}.budget-period,.budget-days-left{color:#cfd4ff;text-align:center;box-sizing:border-box;white-space:nowrap;letter-spacing:0;background:linear-gradient(145deg,#1b1f2e,#141726);border:1px solid #2f3550;border-radius:8px;min-width:0;padding:4px 5px;font-size:12px;font-weight:600}.budget-period{text-overflow:ellipsis;cursor:pointer;overflow:hidden}.budget-period:hover{filter:brightness(1.12)}.budget-days-left{text-overflow:clip;overflow:visible}.budget-date-detail{background:linear-gradient(145deg,#1b1f2e,#141726);border:1px solid #2f3550;border-radius:8px;justify-content:space-between;align-items:center;margin-bottom:8px;padding:8px 12px;display:flex}.budget-date-label{color:#7b83b8;letter-spacing:.05em;text-transform:uppercase;font-size:11px;font-weight:600}.budget-date-value{color:#eef0ff;font-size:15px;font-weight:700}.budget-date-close{color:#eef0ff;cursor:pointer;letter-spacing:.04em;background:linear-gradient(135deg,#5f6dff,#8b25ff);border:none;border-radius:8px;width:100%;margin-top:6px;padding:10px 16px;font-weight:700;transition:transform .12s,box-shadow .12s;box-shadow:0 6px 14px #5f6dff59}.budget-date-close:hover{transform:translateY(-1px);box-shadow:0 10px 20px #5f6dff73}.budget-edit-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9999;background:#080a10bf;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.budget-edit-modal{color:#eef0ff;background:linear-gradient(#0c0e14,#1b1f2e);border:1px solid #2f3550;border-radius:16px;width:100%;max-width:400px;padding:20px;box-shadow:0 25px 50px #000000b3,inset 0 1px #ffffff0a}.budget-edit-title{letter-spacing:.03em;color:#eef0ff;margin:0 0 12px;font-size:20px;font-weight:800}@keyframes buildingFloat{0%{transform:translateY(0)}50%{transform:translateY(-14px)}to{transform:translateY(0)}}.building-float{animation:buildingFloat var(--float-duration,3s) ease-in-out var(--float-delay,0s) infinite}.building-box{color:#fff;cursor:pointer;background:#111;border-radius:8px;justify-content:center;align-items:center;width:200px;height:200px;margin:10px;font-size:1.1rem;display:flex;box-shadow:0 2px 8px #00000026}@keyframes playerBounce{0%{transform:translate(-50%,-100%)translateY(0)}50%{transform:translate(-50%,-100%)translateY(-6px)}to{transform:translate(-50%,-100%)translateY(0)}}.player-bounce{animation:.8s ease-in-out infinite playerBounce}.budget-setup-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9999;background:#080a10bf;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.budget-setup-modal{color:#eef0ff;background:linear-gradient(#0c0e14,#1b1f2e);border:1px solid #2f3550;border-radius:16px;width:100%;max-width:420px;max-height:90vh;padding:24px;font-family:DM Mono,Courier New,monospace;overflow-y:auto;box-shadow:0 25px 50px #000000b3,inset 0 1px #ffffff0a}.budget-setup-modal h2{color:#eef0ff;letter-spacing:.04em;margin:0 0 4px;font-size:22px;font-weight:800}.budget-setup-hint{color:#7b83b8;letter-spacing:.02em;margin:0 0 18px;font-size:13px}.budget-setup-row{justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.budget-setup-row>span:first-child{color:#cfd4ff;flex:1;font-size:14px;font-weight:600}.budget-setup-input-wrap{background:linear-gradient(145deg,#1b1f2e,#141726);border:1px solid #2f3550;border-radius:8px;align-items:center;width:130px;padding:4px 8px;transition:border-color .15s;display:inline-flex}.budget-setup-input-wrap:focus-within{border-color:#5f6dff;box-shadow:0 0 0 2px #5f6dff33}.budget-setup-input-wrap .dollar{color:#ab8cff;margin-right:4px;font-weight:700}.budget-setup-input-wrap input{text-align:right;color:#eef0ff;background:0 0;border:none;outline:none;width:100%;font-family:inherit;font-size:16px;font-weight:700}.budget-setup-dates{gap:12px;margin:18px 0 12px;display:flex}.budget-setup-dates label{color:#7b83b8;letter-spacing:.04em;text-transform:uppercase;flex-direction:column;flex:1;gap:4px;font-size:11px;font-weight:600;display:flex}.budget-setup-dates input{color:#eef0ff;background:linear-gradient(145deg,#1b1f2e,#141726);border:1px solid #2f3550;border-radius:8px;padding:6px 8px;font-family:inherit;font-size:14px;transition:border-color .15s}.budget-setup-dates input:focus{border-color:#5f6dff;outline:none;box-shadow:0 0 0 2px #5f6dff33}.budget-setup-total{text-align:center;color:#cfd4ff;background:#5f6dff14;border:1px solid #5f6dff40;border-radius:8px;margin:16px 0 8px;padding:12px;font-size:16px}.budget-setup-total strong{color:#ab8cff;font-size:20px;font-weight:800}.budget-setup-error{color:#ff9b8a;text-align:center;margin:8px 0;font-size:13px;font-weight:600}.budget-setup-submit{color:#fff;cursor:pointer;letter-spacing:.04em;background:linear-gradient(135deg,#5f6dff,#8b25ff);border:1px solid #3b4679;border-radius:10px;width:100%;margin-top:8px;padding:12px;font-family:inherit;font-size:16px;font-weight:700;transition:transform .12s,box-shadow .12s;box-shadow:0 10px 24px #5f6dff59,inset 0 1px #ffffff1f}.budget-setup-submit:disabled{opacity:.45;cursor:not-allowed}.budget-setup-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 14px 30px #5f6dff73,inset 0 1px #ffffff26}.account-page{background:linear-gradient(#0c0e14,#141726);justify-content:center;min-height:100vh;font-family:DM Mono,Courier New,monospace;display:flex}.account-screen{background:linear-gradient(#0c0e14,#141726);border-left:1px solid #1f2338;border-right:1px solid #1f2338;flex-direction:column;align-items:center;width:min(100vw,900px);min-height:100vh;display:flex}.account-header{color:#eef0ff;background:linear-gradient(#0c0e14,#141726);border-bottom:1px solid #2f3550;justify-content:center;align-items:center;width:100%;height:85px;margin-bottom:16px;display:flex;position:relative}.account-title{letter-spacing:.05em;color:#eef0ff;font-size:22px;font-weight:800}.close-button{color:#cfd4ff;cursor:pointer;background:linear-gradient(145deg,#1b1f2e,#141726);border:1px solid #2f3550;border-radius:50%;width:44px;height:44px;font-size:22px;font-weight:700;transition:transform .15s,filter .15s;position:absolute;top:18px;right:16px;box-shadow:0 6px 14px #00000080}.profile-row{justify-content:center;gap:20px;margin:40px;display:flex}.user-icon-button{cursor:pointer;background-image:linear-gradient(145deg,#1b1f2e,#0c0e14),linear-gradient(135deg,#5f6dff 0%,#8b25ff 50%,#ab8cff 100%);background-origin:border-box;background-clip:padding-box,border-box;border:1px solid #3b4679;border-radius:50%;justify-content:center;align-items:center;width:85px;height:85px;transition:transform .15s,box-shadow .15s;display:flex;overflow:hidden;box-shadow:0 8px 18px #00000080}.user-icon-button:hover{transform:translateY(-3px)scale(1.05);box-shadow:0 14px 26px #000000b3}.user-icon{object-fit:cover;width:100%;height:100%}.info-column{flex-direction:column;flex:1;gap:18px;display:flex}.info{color:#eef0ff;background:linear-gradient(145deg,#1b1f2e,#141726);border:1px solid #2f3550;border-radius:8px;max-width:220px;min-height:38px;margin:6px;padding:8px 12px;font-family:inherit;font-size:14px;transition:border-color .15s}.info:focus{border-color:#5f6dff;outline:none;box-shadow:0 0 0 2px #5f6dff33}.save{color:#fff;cursor:pointer;letter-spacing:.04em;background:linear-gradient(135deg,#5f6dff,#8b25ff);border:1px solid #3b4679;border-radius:8px;width:100%;height:36px;margin-bottom:22px;font-family:inherit;font-size:14px;font-weight:800;transition:transform .15s,box-shadow .15s;box-shadow:0 6px 14px #5f6dff4d}.save:hover{transform:translateY(-2px);box-shadow:0 10px 20px #5f6dff66}.save:active{transform:scale(.97)}.big{color:#cfd4ff;cursor:pointer;letter-spacing:.04em;background:linear-gradient(145deg,#1b1f2e,#141726);border:1px solid #2f3550;border-radius:10px;width:260px;height:48px;margin-bottom:26px;font-family:inherit;font-size:16px;font-weight:800;transition:transform .15s,filter .15s;box-shadow:0 8px 18px #0006}.big:hover{filter:brightness(1.1);transform:translateY(-2px)}.small{color:#cfd4ff;cursor:pointer;letter-spacing:.03em;background:linear-gradient(145deg,#1b1f2e,#141726);border:1px solid #2f3550;border-radius:6px;width:110px;height:26px;font-family:inherit;font-size:11px;font-weight:700}.account-info-display{flex-direction:column;justify-content:center;gap:6px;margin-left:10px;display:flex}.account-info-line{color:#eef0ff;font-size:20px;font-weight:700}.account-error{color:#ff9b8a;background:#a3341f40;border:1px solid #a3341f80;border-radius:8px;margin-bottom:16px;padding:10px 14px;font-size:14px;font-weight:700}.account-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#080a10b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.account-modal{background:linear-gradient(#0c0e14,#1b1f2e);border:1px solid #2f3550;border-radius:14px;flex-direction:column;align-items:center;gap:16px;width:min(90vw,460px);padding:28px 24px;display:flex;box-shadow:0 25px 50px #000000b3}.overlay-input{color:#eef0ff;background:linear-gradient(145deg,#1b1f2e,#141726);border:1px solid #2f3550;border-radius:8px;width:100%;max-width:360px;height:44px;padding:0 12px;font-family:inherit;font-size:15px;transition:border-color .15s}.overlay-input:focus{border-color:#5f6dff;outline:none;box-shadow:0 0 0 2px #5f6dff33}.modal-buttons{flex-direction:column;align-items:center;width:100%;max-width:360px;display:flex}.modal-btn{width:100%}.account-warning-text{text-align:center;color:#cfd4ff;width:100%;max-width:360px;font-size:16px;font-weight:700;line-height:1.4}.delete-confirm-btn{color:#ff9b8a;cursor:pointer;background:#a3341f40;border:1px solid #a3341f80;border-radius:8px;padding:10px 16px;font-family:inherit;font-weight:700}.delete-confirm-btn:hover{background:#a3341f66}.account-success{color:#ab8cff;background:#5f6dff1a;border:1px solid #5f6dff4d;border-radius:10px;margin:10px 0 14px;padding:10px 12px;font-size:14px;font-weight:600}.add-friends-page{background:linear-gradient(#080a10,#0c0e14);justify-content:center;align-items:stretch;min-height:100vh;font-family:DM Mono,Courier New,monospace;display:flex}.add-friends-screen{box-sizing:border-box;background:linear-gradient(#0c0e14,#141726);width:100vw;min-height:100vh}.add-friends-top{box-sizing:border-box;background:linear-gradient(#0c0e14,#141726);border-bottom:1px solid #2f3550;align-items:center;min-height:180px;padding:20px 16px;display:flex;position:relative}.add-friends-player-icon{color:#eef0ff;text-align:center;background-image:linear-gradient(145deg,#1b1f2e,#0c0e14),linear-gradient(135deg,#5f6dff 0%,#8b25ff 50%,#ab8cff 100%);background-origin:border-box;background-clip:padding-box,border-box;border:1px solid #0000;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:125px;height:125px;font-weight:700;line-height:1.1;display:flex;box-shadow:0 10px 24px #0000008c}.add-friends-user-text{color:#eef0ff;margin-left:28px;font-weight:700;line-height:1.1}.add-friends-username,.add-friends-userid{color:#eef0ff;font-size:32px}.add-friends-close-btn{color:#cfd4ff;cursor:pointer;background:linear-gradient(145deg,#1b1f2e,#141726);border:1px solid #2f3550;border-radius:50%;width:50px;height:50px;font-size:32px;font-weight:700;transition:filter .15s,transform .15s;position:absolute;top:18px;right:16px}.add-friends-close-btn:hover{filter:brightness(1.15);transform:translateY(-1px)}.add-friends-body{padding:12px 28px 80px 40px}.add-friends-search-input{box-sizing:border-box;color:#eef0ff;background:linear-gradient(145deg,#1b1f2e,#141726);border:1px solid #2f3550;border-radius:8px;outline:none;width:100%;height:42px;padding:0 12px;font-family:inherit;font-size:18px;transition:border-color .15s}.add-friends-search-input:focus{border-color:#5f6dff;box-shadow:0 0 0 2px #5f6dff33}.add-friends-results{flex-direction:column;gap:18px;margin-top:22px;display:flex}.add-friends-result-row{grid-template-columns:minmax(0,1fr) auto;align-items:center;column-gap:16px;width:100%;display:grid}.add-friends-result-name{color:#eef0ff;font-size:18px;font-weight:700}.add-friends-send-btn{color:#fff;cursor:pointer;letter-spacing:.04em;background:linear-gradient(135deg,#5f6dff,#8b25ff);border:1px solid #3b4679;border-radius:10px;padding:10px 16px;font-family:inherit;font-weight:700;transition:transform .12s,box-shadow .12s;box-shadow:0 4px 12px #5f6dff4d}.add-friends-send-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 16px #5f6dff66}.add-friends-send-btn:disabled{opacity:.45;cursor:default}.add-friends-empty{color:#7b83b8;font-size:18px;font-weight:700}.add-friends-section-title{letter-spacing:.04em;color:#eef0ff;margin-top:20px;margin-bottom:10px;font-size:24px;font-weight:800}.request-actions{justify-self:end;gap:10px;display:flex}.request-actions button{box-sizing:border-box;text-align:center;white-space:nowrap;justify-content:center;align-items:center;width:84px;height:36px;padding:0;display:flex}body{background:#080a10;margin:0;font-family:DM Mono,Courier New,monospace}.friends-page{background:#080a10;justify-content:center;align-items:stretch;min-height:100vh;display:flex}.friends-screen{background:linear-gradient(#0c0e14,#141726);flex-direction:column;width:min(90vw,900px);min-width:100vw;min-height:100vh;display:flex}.friends-top{box-sizing:border-box;background:linear-gradient(#0c0e14,#141726);border-bottom:1px solid #2f3550;align-items:center;min-height:180px;padding:20px 16px;display:flex;position:relative}.user-text{color:#eef0ff;margin-left:28px;font-weight:700;line-height:1.1}.username,.userid{color:#eef0ff;font-size:32px}.close-btn{color:#cfd4ff;cursor:pointer;background:linear-gradient(145deg,#1b1f2e,#141726);border:1px solid #2f3550;border-radius:50%;width:50px;height:50px;font-size:32px;font-weight:700;transition:filter .15s,transform .15s;position:absolute;top:18px;right:16px}.close-btn:hover{filter:brightness(1.15);transform:translateY(-1px)}.friends-search-row{box-sizing:border-box;background:linear-gradient(#141726,#0c0e14);border-bottom:1px solid #2f3550;align-items:center;gap:10px;padding:12px;display:flex}.friends-title{color:#eef0ff;white-space:nowrap;letter-spacing:.04em;font-size:22px;font-weight:700}.search-input{box-sizing:border-box;color:#eef0ff;background:linear-gradient(145deg,#1b1f2e,#141726);border:1px solid #2f3550;border-radius:8px;outline:none;flex:1;height:38px;padding:0 10px;font-family:inherit;font-size:16px;transition:border-color .15s}.search-input:focus{border-color:#5f6dff;box-shadow:0 0 0 2px #5f6dff33}.friends-list{flex:1;overflow-y:auto}.friend-row-shell{background:#141726;border-bottom:12px solid #0c0e14;position:relative;overflow:hidden}.remove-friend-btn{color:#fff;cursor:pointer;z-index:1;background:linear-gradient(135deg,#5f6dff,#8b25ff);border:none;width:140px;height:100%;font-family:inherit;font-size:18px;font-weight:700;position:absolute;top:0;right:0}.friend-card-swipe{z-index:2;touch-action:pan-y;transition:transform .2s;position:relative}.friend-card{box-sizing:border-box;background:linear-gradient(145deg,#1b1f2e,#141726);align-items:center;gap:18px;min-height:140px;padding:18px;display:flex}.friend-icon{color:#eef0ff;background-image:linear-gradient(145deg,#1b1f2e,#0c0e14),linear-gradient(135deg,#5f6dff 0%,#8b25ff 50%,#ab8cff 100%);background-origin:border-box;background-clip:padding-box,border-box;border:1px solid #0000;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:100px;height:100px;font-weight:700;display:flex;box-shadow:0 6px 16px #00000080}.friend-text{line-height:1.2}.friend-name{color:#eef0ff;font-size:22px;font-weight:700}.friend-info{color:#7b83b8;font-size:16px;font-weight:700}.friends-empty{color:#7b83b8;padding:24px;font-size:20px;font-weight:700}.friends-bottom{border-top:1px solid #1f2338;justify-content:center;align-items:center;padding:22px 0;display:flex}.add-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#5f6dff 0%,#8b25ff 50%,#ab8cff 100%);border:1px solid #3b4679;border-radius:50%;width:92px;height:92px;font-size:52px;font-weight:700;line-height:1;transition:transform .15s,box-shadow .15s;box-shadow:0 12px 28px #000000a6,0 4px 12px #5f6dff40,inset 0 1px #ffffff26}.add-btn:hover{transform:scale(1.08)translateY(-2px);box-shadow:0 18px 36px #000000bf,0 6px 18px #5f6dff59,inset 0 1px #fff3}.player-photo{color:#eef0ff;text-align:center;background-image:linear-gradient(145deg,#1b1f2e,#0c0e14),linear-gradient(135deg,#5f6dff 0%,#8b25ff 50%,#ab8cff 100%);background-origin:border-box;background-clip:padding-box,border-box;border:1px solid #0000;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:125px;height:125px;font-weight:700;line-height:1.1;display:flex;box-shadow:0 10px 24px #0000008c}.home-page{background:linear-gradient(#080a10,#0c0e14);justify-content:center;min-height:100vh;font-family:DM Mono,Courier New,monospace;display:flex}.home-screen{background:linear-gradient(#0c0e14,#141726);flex-direction:column;justify-content:center;align-items:center;gap:0;width:min(90vw,900px);min-width:100vw;min-height:100vh;display:flex}.home-title{color:#eef0ff;letter-spacing:.04em;text-align:center;background:linear-gradient(135deg,#eef0ff 30%,#ab8cff 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:10px;font-size:56px;font-weight:800}.home-subtitle{color:#7b83b8;letter-spacing:.04em;text-align:center;margin-bottom:30px;font-size:18px}.home-button{color:#fff;cursor:pointer;letter-spacing:.05em;background:linear-gradient(135deg,#5f6dff 0%,#8b25ff 50%,#ab8cff 100%);border:1px solid #3b4679;border-radius:10px;padding:16px 40px;font-family:inherit;font-size:16px;font-weight:700;transition:transform .15s,box-shadow .15s;box-shadow:0 10px 24px #5f6dff59,inset 0 1px #ffffff1f}.home-button:hover{transform:translateY(-2px);box-shadow:0 16px 32px #5f6dff73,inset 0 1px #ffffff26}.home-button:active{transform:scale(.97)}.login-page{background:linear-gradient(#080a10,#0c0e14);justify-content:center;min-height:100vh;font-family:DM Mono,Courier New,monospace;display:flex}.login-screen{background:linear-gradient(#0c0e14,#141726);flex-direction:column;justify-content:center;align-items:center;width:min(90vw,900px);min-width:100vw;min-height:100vh;display:flex}.login-title{color:#eef0ff;letter-spacing:.04em;background:linear-gradient(135deg,#eef0ff 30%,#ab8cff 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:6px;font-size:56px;font-weight:800}.login-subtitle{color:#7b83b8;letter-spacing:.04em;margin-bottom:24px;font-size:18px}.login-input{box-sizing:border-box;color:#eef0ff;background:linear-gradient(145deg,#1b1f2e,#141726);border:1px solid #2f3550;border-radius:10px;outline:none;width:65%;max-width:320px;height:46px;margin-bottom:16px;padding:0 14px;font-family:inherit;font-size:15px;transition:border-color .2s,box-shadow .2s}.login-input:focus{border-color:#5f6dff;box-shadow:0 0 0 3px #5f6dff33}.login-input::placeholder{color:#3b4679}.login-button{color:#fff;cursor:pointer;letter-spacing:.05em;background:linear-gradient(135deg,#5f6dff 0%,#8b25ff 50%,#ab8cff 100%);border:1px solid #3b4679;border-radius:12px;width:250px;margin-top:20px;padding:12px 40px;font-family:inherit;font-size:16px;font-weight:700;transition:transform .2s,box-shadow .2s;box-shadow:0 10px 24px #5f6dff59,inset 0 1px #ffffff1f}.login-button:hover{transform:translateY(-2px);box-shadow:0 16px 32px #5f6dff73,inset 0 1px #ffffff26}.login-button:active{transform:scale(.96)}.login-p{color:#7b83b8;letter-spacing:.02em;font-size:14px}.login-p a{color:#ab8cff;text-decoration:none}.login-p a:hover{text-decoration:underline}.login-error{color:#ff9b8a;background:#a3341f33;border:1px solid #a3341f66;border-radius:8px;margin-bottom:10px;padding:10px 12px;font-size:14px;font-weight:600}.customization-page{background:linear-gradient(#080a10,#0c0e14);justify-content:center;min-height:100vh;font-family:DM Mono,Courier New,monospace;display:flex}.customization-screen{background:linear-gradient(#0c0e14,#141726);flex-direction:column;align-items:stretch;width:min(100vw,960px);min-height:100vh;display:flex}.customization-header{color:#eef0ff;background:linear-gradient(#0c0e14,#141726);border-bottom:1px solid #2f3550;justify-content:center;align-items:center;width:100%;height:85px;margin-bottom:12px;display:flex;position:relative}.customization-title{color:#eef0ff;letter-spacing:.05em;margin:0;font-size:22px;font-weight:700}.close-button{color:#cfd4ff;cursor:pointer;background:linear-gradient(145deg,#1b1f2e,#141726);border:1px solid #2f3550;border-radius:50%;width:50px;height:50px;font-size:32px;font-weight:700;transition:filter .15s,transform .15s;position:absolute;top:18px;right:16px}.close-button:hover{filter:brightness(1.15);transform:translateY(-1px)}.preview-panel{grid-template-columns:1fr;align-items:center;gap:8px;padding:8px 24px;display:grid}.preview-stage{background:#1f233880;border:1px solid #2f3550;border-radius:24px;justify-content:center;align-items:center;min-height:280px;padding:8px;display:flex;overflow:hidden}.container{box-sizing:border-box;background:linear-gradient(#141726,#0c0e14);border-top:1px solid #2f3550;border-top-left-radius:28px;border-top-right-radius:28px;flex-direction:column;flex:1;width:100%;min-height:0;margin-top:0;padding:20px 24px 32px;display:flex}.tabs{flex-wrap:wrap;justify-content:center;gap:10px;margin:6px 0 18px;display:flex}.tab{cursor:pointer;color:#7b83b8;letter-spacing:.04em;background:linear-gradient(145deg,#1b1f2e,#141726);border:1px solid #2f3550;border-radius:999px;padding:9px 16px;font-family:inherit;font-size:14px;font-weight:600;transition:filter .15s,color .15s}.tab:hover{filter:brightness(1.1);color:#cfd4ff}.tab.active{color:#fff;background:linear-gradient(135deg,#5f6dff,#8b25ff);border-color:#3b4679;box-shadow:0 4px 14px #5f6dff4d}.section-header{justify-content:space-between;align-items:center;gap:16px;margin-bottom:18px;display:flex}.section-title{color:#eef0ff;letter-spacing:.03em;font-size:24px;font-weight:700}.section-subtitle{color:#7b83b8;margin-top:4px;font-size:13px}.clear-btn{color:#cfd4ff;cursor:pointer;letter-spacing:.03em;background:linear-gradient(145deg,#1b1f2e,#141726);border:1px solid #2f3550;border-radius:999px;padding:10px 16px;font-family:inherit;font-weight:700;transition:filter .15s}.clear-btn:hover{filter:brightness(1.1)}.clear-btn:disabled{opacity:.35;cursor:not-allowed}.item-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;display:grid}.item-card{cursor:pointer;color:#cfd4ff;background:linear-gradient(145deg,#1b1f2e,#141726);border:1px solid #2f3550;border-radius:22px;flex-direction:column;align-items:center;gap:14px;padding:16px;transition:transform .15s,box-shadow .15s,border-color .15s;display:flex}.item-card:hover{border-color:#3b4679;transform:translateY(-2px);box-shadow:0 8px 24px #00000080}.item-card.active{background:linear-gradient(145deg,#1f2540,#161a30);border:2px solid #5f6dff;box-shadow:0 0 0 1px #5f6dff33,0 8px 24px #5f6dff33}.item-card.locked{opacity:.45}.item-card-icon-wrap{background:linear-gradient(145deg,#252a40,#1b1f2e);border:1px solid #2f3550;border-radius:24px;justify-content:center;align-items:center;width:88px;height:88px;display:flex}.item-card-icon{object-fit:contain;width:68px;height:68px}.item-card-title{color:#eef0ff;letter-spacing:.03em;font-size:15px;font-weight:700}.item-card-action{color:#7b83b8;font-size:13px;font-weight:700}.item-card-price{color:#ab8cff;font-size:13px;font-weight:700}.item-card-action-btn{color:#fff;cursor:pointer;letter-spacing:.04em;background:linear-gradient(135deg,#5f6dff,#8b25ff);border:1px solid #3b4679;border-radius:999px;width:100%;padding:10px 14px;font-family:inherit;font-weight:700;transition:transform .12s,box-shadow .12s;box-shadow:0 4px 12px #5f6dff4d}.item-card-action-btn:hover{transform:translateY(-1px);box-shadow:0 6px 16px #5f6dff66}.item-card-action-btn.equipped{background:linear-gradient(135deg,#2d8a5e,#1a6e47);border-color:#1a6e47;box-shadow:0 4px 12px #2d8a5e4d}@media (width<=760px){.preview-stage{min-height:240px}.section-header{flex-direction:column;align-items:stretch}}.shop-page{background:linear-gradient(#080a10,#0c0e14);justify-content:center;align-items:stretch;min-height:100vh;font-family:DM Mono,Courier New,monospace;display:flex}.shop-screen{background:linear-gradient(#0c0e14,#141726);flex-direction:column;width:min(90vw,900px);min-width:100vw;min-height:100vh;display:flex}.shop-top{box-sizing:border-box;background:linear-gradient(#0c0e14,#141726);border-bottom:1px solid #2f3550;align-items:center;min-height:180px;padding:10px;display:flex;position:relative}.shop-player-icon{color:#eef0ff;text-align:center;background-image:linear-gradient(145deg,#1b1f2e,#0c0e14),linear-gradient(135deg,#5f6dff 0%,#8b25ff 50%,#ab8cff 100%);background-origin:border-box;background-clip:padding-box,border-box;border:1px solid #0000;border-radius:50%;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;width:85px;height:85px;font-size:16px;font-weight:700;line-height:1.1;display:flex;overflow:hidden;box-shadow:0 10px 20px #0000008c}.shop-user-text{color:#eef0ff;margin-left:28px;font-weight:700;line-height:1.1}.shop-username,.shop-userid{color:#eef0ff;font-size:32px}.shop-close-btn{color:#cfd4ff;cursor:pointer;background:linear-gradient(145deg,#1b1f2e,#141726);border:1px solid #2f3550;border-radius:50%;width:50px;height:50px;font-size:32px;font-weight:700;transition:filter .15s,transform .15s;position:absolute;top:18px;right:16px}.shop-close-btn:hover{filter:brightness(1.15);transform:translateY(-1px)}.shop-header-row{background:linear-gradient(#141726,#0c0e14);border-bottom:1px solid #2f3550;align-items:center;padding:12px;display:flex}.shop-title{color:#eef0ff;letter-spacing:.05em;font-size:22px;font-weight:700}.shop-list{flex:1;padding-bottom:24px;overflow-y:auto}.shop-section{padding-top:10px}.shop-section-header{padding:0 18px 12px}.shop-section-title{color:#eef0ff;letter-spacing:.03em;margin:0;font-size:22px;font-weight:800}.shop-section-description{color:#7b83b8;margin:6px 0 0;font-size:13px;font-weight:600}.shop-section-items{flex-direction:column;display:flex}.shop-card{box-sizing:border-box;background:linear-gradient(145deg,#1b1f2e,#141726);border-bottom:12px solid #0c0e14;justify-content:space-between;align-items:center;gap:18px;min-height:140px;padding:18px;transition:filter .15s;display:flex}.shop-card:hover{filter:brightness(1.04)}.shop-card-left{flex:1;align-items:center;gap:18px;display:flex}.shop-icon{text-align:center;box-sizing:border-box;color:#cfd4ff;background:linear-gradient(145deg,#252a40,#1b1f2e);border:1px solid #2f3550;border-radius:20px;flex-shrink:0;justify-content:center;align-items:center;width:100px;height:100px;padding:0 8px;font-size:14px;font-weight:700;line-height:1.2;display:flex}.shop-icon-image{object-fit:contain;width:76px;height:76px}.shop-text{line-height:1.2}.shop-name{color:#eef0ff;font-size:22px;font-weight:700}.shop-info{color:#7b83b8;font-size:16px;font-weight:700}.buy-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#5f6dff 0%,#8b25ff 50%,#ab8cff 100%);border:1px solid #3b4679;border-radius:20px;flex-shrink:0;width:92px;height:92px;font-family:inherit;font-size:18px;font-weight:700;transition:transform .12s,box-shadow .12s;box-shadow:0 8px 20px #5f6dff4d}.buy-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 28px #5f6dff66}.buy-btn:disabled{cursor:not-allowed;color:#3b4679;box-shadow:none;background:linear-gradient(145deg,#1b1f2e,#141726);border-color:#2f3550}.shop-bottom{border-top:1px solid #1f2338;justify-content:center;align-items:center;padding:22px 0;display:flex}html,body,#root{width:100%;min-height:100%;margin:0;padding:0}body{background:#efefef;font-family:Arial,Helvetica,sans-serif}
