@import "https://fonts.googleapis.com/css2?family=Press+Start+2P&display=swap";:root{--bg:#fef6e4;--text:#001858;--primary:#f582ae;--secondary:#8bd3dd;--accent:#ffc6d3;--panel:#fff;--border:#001858}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg);color:var(--text);font-family:"Press Start 2P",monospace;font-size:10px;line-height:1.8}.app{min-height:100vh}.page-enter{animation:.25s ease-out fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.spinner-container{flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:48px;display:flex}.spinner{border:4px solid var(--accent);border-top-color:var(--primary);border-radius:50%;width:32px;height:32px;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.spinner-text{color:var(--primary);font-size:8px}button:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.navbar{background:var(--primary);border-bottom:4px solid var(--border);justify-content:space-between;align-items:center;padding:12px 24px;display:flex}.navbar .logo{color:#fff;text-shadow:2px 2px var(--border);font-size:16px;text-decoration:none}.nav-links{align-items:center;gap:16px;display:flex}.nav-links a{color:#fff;font-size:8px;text-decoration:none}.nav-links a.nav-active{color:var(--secondary);text-decoration:underline}.nav-links button{background:var(--secondary);border:2px solid var(--border);cursor:pointer;padding:6px 12px;font-family:inherit;font-size:8px}.mobile-tab-bar{z-index:900;background:var(--panel);border-top:3px solid var(--border);padding:6px 0 env(safe-area-inset-bottom,6px);justify-content:space-around;align-items:center;display:none;position:fixed;bottom:0;left:0;right:0}.tab-item{color:var(--text);cursor:pointer;background:0 0;border:none;border-radius:8px;flex-direction:column;align-items:center;gap:2px;padding:4px 12px;font-family:inherit;text-decoration:none;transition:background .15s;display:flex}.tab-item:hover{background:#f582ae1a}.tab-icon{font-size:18px;line-height:1}.tab-label{font-family:"Press Start 2P",monospace;font-size:6px}.tab-active{color:var(--primary)}.tab-active .tab-label{font-weight:700}.content{max-width:900px;margin:0 auto;padding:24px}.empty-state{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:32px 16px;display:flex}.empty-state-icon{font-size:36px}.empty-state-text{color:#999;font-size:8px;line-height:2}h1{margin-bottom:16px;font-size:16px}h3{margin-bottom:8px;font-size:10px}button{background:var(--secondary);border:3px solid var(--border);cursor:pointer;padding:8px 16px;font-family:"Press Start 2P",monospace;font-size:8px;transition:transform .1s,background .15s,box-shadow .15s}button:hover{transform:scale(1.05)}button:active{transform:scale(.95)}button.active{background:var(--primary);color:#fff}input,select{border:3px solid var(--border);background:var(--panel);width:100%;margin-bottom:8px;padding:8px;font-family:"Press Start 2P",monospace;font-size:8px;transition:border-color .15s,box-shadow .15s}input:focus,select:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 2px #f582ae4d}.auth-page{text-align:center;max-width:380px;margin:40px auto;padding:32px 24px}.auth-page form{margin:24px 0}.auth-page form input{margin-bottom:12px;padding:14px 12px;font-size:10px}.auth-page form button{width:100%;margin-top:4px;padding:14px;font-size:10px}.auth-page p{margin-top:16px;font-size:8px}.auth-page p a{color:var(--primary)}.auth-cat{width:80px;height:80px;image-rendering:pixelated;margin:0 auto 8px;display:block}.error{color:#e74c3c;margin-bottom:8px;font-size:8px}.pet-editor{text-align:center}.slots{text-align:left;grid-template-columns:1fr 1fr;gap:12px;margin-top:16px;display:grid}.slot-panel{background:var(--panel);border:3px solid var(--border);padding:12px}.item-list{flex-wrap:wrap;gap:4px;margin-top:8px;display:flex}.room-editor,.room-viewer{text-align:center}.room-canvas-center{justify-content:center;margin:12px 0;display:flex}.room-toolbar{flex-wrap:wrap;justify-content:center;align-items:center;gap:10px;margin-bottom:12px;display:flex}.room-zoom{align-items:center;gap:4px;display:flex}.zoom-label{text-align:center;min-width:32px;color:var(--text);font-size:7px}.room-actions-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.room-canvas-zoom{transition:transform .2s}.room-controls{text-align:left;flex-direction:column;gap:10px;max-width:500px;margin:16px auto 0;display:flex}.room-mode-toggle{border:2px solid var(--border);border-radius:8px;display:flex;overflow:hidden}.mode-btn{background:var(--panel);cursor:pointer;border:none;flex:1;padding:6px 4px;font-size:6px;transition:background .15s}.mode-btn.active{background:var(--primary);color:#fff}.mode-btn:first-child{border-right:2px solid var(--border)}.room-tabs{gap:2px;display:flex}.room-tab{background:var(--panel);border:2px solid var(--border);cursor:pointer;border-bottom:none;border-radius:6px 6px 0 0;flex:1;padding:6px 4px;font-size:6px;transition:background .15s}.room-tab.active{background:var(--accent);font-weight:700}.room-tab-content{border:2px solid var(--border);background:var(--panel);border-radius:0 0 8px 8px;min-height:80px;max-height:240px;padding:8px;overflow-y:auto}.room-inventory{flex-wrap:wrap;gap:6px;display:flex}.room-inv-item{border:2px solid var(--border);cursor:pointer;background:var(--bg);border-radius:8px;flex-direction:column;align-items:center;gap:4px;width:72px;padding:6px;transition:all .15s;display:flex}.room-inv-item:hover{background:#f582ae26}.room-inv-item.active{border-color:var(--primary);background:#8bd3dd4d;box-shadow:0 0 0 2px #f582ae4d}.room-inv-thumb{object-fit:contain;width:40px;height:40px}.room-inv-name{text-align:center;color:var(--text);text-overflow:ellipsis;white-space:nowrap;width:100%;font-size:5px;overflow:hidden}.room-hint{width:100%;color:var(--primary);text-align:center;background:#f582ae1a;border-radius:6px;padding:6px;font-size:6px}.room-empty{color:#aaa;text-align:center;padding:16px 8px;font-size:7px}.room-layers{flex-direction:column;gap:2px;display:flex}.room-layer-item{cursor:pointer;border-radius:6px;align-items:center;gap:8px;padding:6px 8px;transition:background .15s;display:flex}.room-layer-item:hover{background:#f582ae1a}.room-layer-item.active{border-left:3px solid var(--primary);background:#8bd3dd40}.room-layer-thumb{object-fit:contain;border:2px solid var(--border);background:var(--bg);border-radius:4px;flex-shrink:0;width:28px;height:28px}.room-layer-name{text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:6px;overflow:hidden}.room-layer-actions{flex-shrink:0;gap:2px;display:flex}.room-layer-actions button{background:var(--secondary);border:2px solid var(--border);cursor:pointer;border-radius:4px;padding:2px 6px;font-size:8px;line-height:1}.room-layer-actions button:hover{background:#a0e0ea}.room-backgrounds{flex-wrap:wrap;gap:4px;display:flex}.room-bg-btn{text-transform:capitalize;padding:6px 8px;font-size:6px}.room-selection-controls{border:2px solid var(--primary);background:linear-gradient(#fff5f9 0%,#fff 100%);border-radius:8px;flex-direction:column;flex-shrink:0;align-items:center;gap:8px;margin-top:4px;padding:10px;display:flex}.room-selection-title{background:var(--accent);border-radius:12px;padding:3px 12px;font-size:8px;font-weight:700}.room-selection-row{justify-content:center;gap:6px;width:100%;display:flex}.friends-page{max-width:600px}.invite-section{background:var(--panel);border:3px solid var(--border);margin-bottom:16px;padding:16px}.invite-link{align-items:center;gap:8px;margin-top:8px;display:flex}.invite-link code{background:var(--bg);border:2px solid var(--border);text-overflow:ellipsis;flex:1;padding:8px;font-size:7px;overflow:hidden}.friend-card{border-bottom:2px solid var(--accent);align-items:center;gap:12px;padding:8px;display:flex}.friend-card a{color:var(--primary)}.friend-pet-mini{flex-shrink:0;width:64px;height:64px}.friend-pet-mini canvas{image-rendering:pixelated}.guestbook{text-align:left;margin-top:16px}.guestbook form{align-items:stretch;gap:8px;margin-bottom:12px;display:flex}.guestbook form input{flex:1;min-width:0;padding:10px;font-size:9px}.guestbook form select{width:auto;min-width:60px}.guestbook form button{white-space:nowrap}.guestbook ul{list-style:none}.guestbook li{border-bottom:1px solid var(--accent);word-break:break-word;align-items:center;gap:8px;padding:10px 8px;display:flex}.guestbook li strong{flex-shrink:0}.guestbook li button{color:#e74c3c;background:0 0;border:none;flex-shrink:0;padding:4px 8px;font-size:12px}.toast-container{z-index:1000;flex-direction:column;gap:8px;display:flex;position:fixed;top:16px;right:16px}.toast{border:3px solid var(--border);padding:12px 16px;font-family:"Press Start 2P",monospace;font-size:8px;animation:.3s ease-out toastIn}.toast.toast-exit{animation:.3s ease-in forwards toastOut}.toast-success{background:var(--secondary);color:var(--text)}.toast-error{color:#fff;background:#e74c3c}@keyframes toastIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes toastOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}.pet-dressup{width:100%;display:inline-block;position:relative}.dressup-layout{justify-content:center;align-items:flex-start;gap:16px;display:flex}.dressup-canvas-wrap{flex-direction:column;align-items:center;display:flex}.layers-sidebar{border:3px solid var(--border);width:160px;box-shadow:4px 4px 0px var(--accent);background:linear-gradient(#fff5f9 0%,#fff 100%);border-radius:12px;flex-shrink:0;overflow:hidden}.layers-title{text-align:center;background:var(--accent);color:var(--text);letter-spacing:1px;border-bottom:2px solid var(--border);padding:8px;font-size:9px;font-weight:700}.layers-empty{text-align:center;color:#aaa;padding:16px 8px;font-size:7px}.layer-item{cursor:pointer;border-bottom:1px solid var(--accent);align-items:center;gap:8px;padding:8px 10px;transition:background .15s;display:flex}.layer-item:last-child{border-bottom:none}.layer-item:hover{background:#f582ae1a}.layer-active{border-left:4px solid var(--primary);background:#8bd3dd40!important}.layer-thumb{object-fit:contain;border:2px solid var(--border);background:var(--bg);border-radius:4px;flex-shrink:0;width:32px;height:32px}.layer-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.layer-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:7px;font-weight:700;overflow:hidden}.layer-slot{color:var(--primary);text-transform:uppercase;letter-spacing:.5px;font-size:6px}.layer-actions{flex-direction:column;flex-shrink:0;gap:2px;display:flex}.layer-btn{background:var(--secondary);border:2px solid var(--border);cursor:pointer;border-radius:4px;min-width:0;padding:2px 6px;font-size:8px;line-height:1}.layer-btn:hover{background:#a0e0ea}.dressup-controls,.layer-controls{border:3px solid var(--border);box-shadow:4px 4px 0px var(--accent);background:linear-gradient(#fff5f9 0%,#fff 100%);border-radius:12px;flex-direction:column;align-items:center;gap:10px;margin-top:12px;padding:16px 20px;display:flex}.dressup-title{color:var(--text);background:var(--accent);letter-spacing:1px;border-radius:20px;padding:4px 16px;font-size:11px;font-weight:700}.control-row{justify-content:center;align-items:center;gap:8px;width:100%;display:flex}.control-label{text-align:right;min-width:44px;color:var(--primary);letter-spacing:.5px;font-size:7px;font-weight:700}.ctrl-value{text-align:center;min-width:36px;color:var(--text);font-size:9px;font-weight:700}.ctrl-btn{background:var(--secondary);border:2px solid var(--border);cursor:pointer;color:var(--text);border-radius:6px;padding:6px 10px;font-family:"Press Start 2P",monospace;font-size:8px;transition:all .15s;box-shadow:2px 2px #00185833}.ctrl-btn:hover{background:#a0e0ea;transform:translateY(-1px);box-shadow:2px 3px #00185840}.ctrl-btn:active{transform:translateY(1px);box-shadow:1px 1px #00185833}.ctrl-btn.wide{min-width:60px;padding:6px 14px}.ctrl-btn.reset{background:var(--accent);border-radius:20px;margin-top:4px;padding:6px 20px;font-size:7px}.ctrl-btn.reset:hover{background:#ffb0c8}.ctrl-btn.delete{background:#ffb3b3;border-radius:20px;margin-top:4px;padding:6px 20px;font-size:7px}.ctrl-btn.delete:hover{background:#ff8a8a}.global-audio{z-index:999;position:fixed;bottom:20px;right:20px}.audio-settings{display:inline-block;position:relative}.audio-toggle{background:var(--primary);border:3px solid var(--border);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;padding:0;transition:all .15s;animation:2s ease-in-out infinite music-pulse;display:flex;position:relative;box-shadow:3px 3px #0018584d}.audio-toggle:hover{background:var(--accent);transform:scale(1.15);box-shadow:4px 4px #00185859}@keyframes music-pulse{0%,to{box-shadow:3px 3px #0018584d,0 0 #f582ae66}50%{box-shadow:3px 3px #0018584d,0 0 0 8px #f582ae00}}.music-icon{font-size:22px;line-height:1}.audio-dropdown{border:3px solid var(--border);z-index:100;min-width:160px;box-shadow:4px 4px 0px var(--accent);background:linear-gradient(#fff5f9 0%,#fff 100%);border-radius:12px;flex-direction:column;gap:10px;padding:14px;display:flex;position:absolute;bottom:calc(100% + 8px);right:0}.audio-dropdown-title{text-align:center;color:var(--text);background:var(--accent);letter-spacing:1px;border-radius:20px;align-self:center;padding:4px 12px;font-size:9px;font-weight:700}.audio-vol-row{align-items:center;gap:8px;display:flex}.audio-vol-label{color:var(--primary);min-width:20px;font-size:7px;font-weight:700}.audio-vol-value{color:var(--text);text-align:right;min-width:20px;font-size:7px;font-weight:700}.audio-dropdown input[type=range]{border:none;width:70px;margin:0;padding:0}.info-banner{border-bottom:3px solid var(--border);color:var(--text);text-align:center;background:linear-gradient(90deg,#ffc6d3 0%,#8bd3dd 100%);justify-content:center;align-items:center;gap:12px;padding:10px 20px;font-size:7px;line-height:1.6;display:flex}.banner-close{border:2px solid var(--border);cursor:pointer;background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;padding:0;font-family:sans-serif;font-size:14px;line-height:1;display:flex}.banner-close:hover{background:#0000001a}.confirm-overlay{z-index:2000;background:#00185880;justify-content:center;align-items:center;animation:.15s ease-out fadeIn;display:flex;position:fixed;inset:0}.confirm-dialog{border:3px solid var(--border);width:90%;max-width:320px;box-shadow:6px 6px 0px var(--accent);text-align:center;background:linear-gradient(#fff5f9 0%,#fff 100%);border-radius:12px;padding:24px}.confirm-message{color:var(--text);margin-bottom:20px;font-size:9px;line-height:2}.confirm-buttons{justify-content:center;gap:12px;display:flex}.confirm-btn{border-radius:8px;padding:8px 20px;font-size:8px}.confirm-no{background:var(--panel);border:2px solid var(--border)}.confirm-yes{background:var(--primary);color:#fff;border:2px solid var(--border)}.pet-mood{justify-content:center;gap:16px;margin:12px 0;display:flex}.mood-bar{flex-direction:column;align-items:center;gap:4px;display:flex}.mood-label{font-size:7px}.mood-track{background:var(--accent);border:2px solid var(--border);border-radius:4px;width:80px;height:8px;overflow:hidden}.mood-fill{border-radius:2px;height:100%;transition:width .3s}.mood-fill.happy{background:#6c6}.mood-fill.neutral{background:#cc6}.mood-fill.sad{background:#c66}.pet-name-edit{text-align:center;color:var(--text);cursor:pointer;border:none;border-bottom:2px dashed var(--accent);background:0 0;margin-bottom:8px;padding:4px 8px;font-family:"Press Start 2P",monospace;font-size:14px}.pet-name-edit:focus{border-bottom-color:var(--primary);outline:none}.pet-actions{justify-content:center;gap:12px;margin:8px 0;display:flex}.shop-page{max-width:600px}.shop-coins{text-align:center;color:var(--primary);margin-bottom:16px;font-size:10px}.shop-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:12px;display:grid}.shop-item{background:var(--panel);border:3px solid var(--border);text-align:center;border-radius:8px;flex-direction:column;align-items:center;gap:6px;padding:12px 8px;display:flex}.shop-item.owned{opacity:.6}.shop-thumb{width:48px;height:48px;image-rendering:pixelated;object-fit:contain}.shop-name{font-size:6px}.shop-price{color:var(--primary);font-size:7px}@media (width<=768px){.desktop-nav .nav-links{display:none}.mobile-tab-bar{display:flex}.content{padding:12px 12px 72px}.slots{grid-template-columns:1fr}.dressup-layout{flex-direction:column;align-items:center}.layers-sidebar{flex-flow:wrap;width:100%;max-width:320px;display:flex}.layers-sidebar .layers-title{width:100%}.layers-sidebar .layer-item{flex:1;min-width:140px}.room-controls{max-width:100%}.room-inv-item{width:64px}.room-inv-thumb{width:32px;height:32px}.guestbook form{flex-wrap:wrap}.guestbook form input{flex:100%;padding:12px;font-size:10px}.guestbook form select,.guestbook form button{flex:1}.invite-link{flex-direction:column}.invite-link code{font-size:6px}.friend-card{flex-wrap:wrap}h1{font-size:12px}canvas{max-width:100%;height:auto!important}}@media (width<=480px){.navbar .logo{font-size:12px}button{padding:6px 10px;font-size:7px}input,select{padding:6px;font-size:7px}.auth-page{margin:24px auto;padding:24px 16px}.auth-page form input{padding:12px 10px;font-size:9px}.auth-page form button{padding:12px;font-size:9px}.global-audio{bottom:72px}}
