.auth-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--bg-elevated-strong);display:flex;justify-content:center;align-items:center;z-index:10000}.auth-modal{background:var(--bg-card);border-radius:12px 8px 14px 10px/10px 12px 8px 9px;padding:32px;width:90%;max-width:400px;box-shadow:4px 4px 0 0 var(--border-medium),8px 8px 0 0 var(--border-soft),12px 12px 0 0 var(--border-accent);position:relative;border:3px solid var(--border-accent);transform:rotate(-.3deg)}.auth-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.auth-modal-header h2{margin:0;color:var(--text-primary);font-size:24px;display:flex;align-items:center;gap:.5rem;font-family:inherit}.auth-modal-icon{margin-right:.5rem;vertical-align:middle;flex-shrink:0}.close-btn{background:var(--bg-card);border:2px solid var(--border-accent);font-size:32px;color:var(--text-primary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px 8px 6px 10px/6px 4px 8px 5px;transition:transform .1s ease,box-shadow .1s ease;box-shadow:1px 1px 0 0 var(--border-medium);transform:rotate(.2deg)}.close-btn:hover{background:var(--accent-coral);color:var(--bg-card);transform:rotate(-.3deg) translateY(-1px);box-shadow:2px 2px 0 0 var(--border-medium)}.auth-modal-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-weight:600;color:var(--text-primary);font-size:14px;font-family:inherit}.form-group input{padding:12px;border:3px solid var(--border-accent);border-radius:6px 10px 8px 12px/8px 6px 10px 7px;font-size:16px;transition:transform .1s ease,box-shadow .1s ease;background:var(--bg-paper);color:var(--text-primary);font-family:inherit;box-shadow:2px 2px 0 0 var(--border-medium);transform:rotate(-.1deg)}.form-group input:focus{outline:none;border-color:var(--accent-blue);background:var(--accent-yellow);box-shadow:3px 3px 0 0 var(--border-medium);transform:rotate(.1deg)}.form-hint{font-size:12px;color:var(--text-light);margin-top:-4px;font-family:inherit}.auth-error{background:var(--accent-coral);border:3px solid var(--border-accent);color:var(--bg-card);padding:12px;border-radius:6px 10px 8px 12px/8px 6px 10px 7px;font-size:14px;box-shadow:2px 2px 0 0 var(--border-medium);transform:rotate(-.2deg);font-family:inherit}.auth-submit-btn{padding:14px;background:var(--accent-blue);color:var(--bg-card);border:3px solid var(--border-accent);border-radius:6px 10px 8px 12px/8px 6px 10px 7px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .1s ease,box-shadow .1s ease;margin-top:8px;font-family:inherit;box-shadow:3px 3px 0 0 var(--border-medium);transform:rotate(-.3deg)}.auth-submit-btn:hover:not(:disabled){background:var(--accent-purple);color:var(--bg-card);transform:rotate(.3deg) translateY(-1px);box-shadow:4px 4px 0 0 var(--border-medium)}.auth-submit-btn:disabled{background:var(--bg-elevated);color:var(--text-light);cursor:not-allowed;transform:rotate(0);box-shadow:1px 1px 0 0 var(--border-medium)}.auth-modal-footer{margin-top:24px;text-align:center;color:var(--text-light);font-size:14px;font-family:inherit}.link-btn{background:none;border:none;color:var(--accent-blue);cursor:pointer;text-decoration:underline;font-size:14px;padding:0;margin-left:4px;font-family:inherit;transition:color .1s ease}.link-btn:hover{color:var(--accent-purple)}.confirm-dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:transparent;display:flex;justify-content:center;align-items:center;z-index:10000}.confirm-dialog{background:var(--bg-card);border-radius:12px 8px 14px 10px/10px 12px 8px 9px;padding:32px;width:90%;max-width:450px;box-shadow:4px 4px 0 0 var(--border-medium),8px 8px 0 0 var(--border-soft),12px 12px 0 0 var(--border-accent);position:relative;border:3px solid var(--border-accent);transform:rotate(-.3deg);animation:dialogAppear .2s ease-out}@keyframes dialogAppear{0%{opacity:0;transform:rotate(-.3deg) scale(.95) translateY(-10px)}to{opacity:1;transform:rotate(-.3deg) scale(1) translateY(0)}}.confirm-dialog-header{margin-bottom:20px}.confirm-dialog-header h2{margin:0;color:var(--text-primary);font-size:24px;font-weight:600;font-family:inherit;transform:rotate(.2deg)}.confirm-dialog-body{margin-bottom:24px}.confirm-dialog-body p{margin:0;color:var(--text-primary);font-size:16px;line-height:1.5;font-family:inherit}.confirm-dialog-footer{display:flex;gap:12px;justify-content:flex-end}.confirm-dialog-btn{padding:10px 20px;border:3px solid var(--border-accent);border-radius:6px 10px 8px 12px/8px 6px 10px 7px;color:var(--bg-card);font-size:.95em;font-weight:600;cursor:pointer;transition:transform .1s ease,box-shadow .1s ease,opacity .1s ease;font-family:inherit;box-shadow:2px 2px 0 0 var(--border-medium);transform:rotate(.3deg);min-width:100px}.confirm-dialog-btn-cancel{background:var(--bg-card);color:var(--text-primary);transform:rotate(-.3deg)}.confirm-dialog-btn-cancel:hover{background:var(--accent-blue);color:var(--bg-card);transform:rotate(.2deg) translateY(-1px);box-shadow:3px 3px 0 0 var(--border-medium);opacity:.9}.confirm-dialog-btn-confirm{color:var(--bg-card)}.confirm-dialog-btn-confirm:hover{transform:rotate(-.2deg) translateY(-1px);box-shadow:3px 3px 0 0 var(--border-medium);opacity:.9}.confirm-dialog-btn:active{transform:rotate(0) translateY(0);box-shadow:2px 2px 0 0 var(--border-medium)}.friends-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:10001;animation:fadeIn .2s ease-out}.friends-modal{background:var(--bg-card);border-radius:12px 8px 14px 10px/10px 12px 8px 9px;padding:32px;max-width:500px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:4px 4px 0 0 var(--border-medium),8px 8px 0 0 var(--border-soft),12px 12px 0 0 var(--border-accent);animation:slideUp .3s ease-out;position:relative;border:3px solid var(--border-accent);transform:rotate(-.3deg)}.friends-modal-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.friends-modal-title{margin:0;display:flex;align-items:center;gap:.5rem;font-size:24px;color:var(--text-primary);font-family:inherit}.friends-modal-header-icon{flex-shrink:0}.close-modal-btn{background:var(--bg-card);border:2px solid var(--border-accent);font-size:28px;cursor:pointer;padding:4px 8px;color:var(--text-primary);line-height:1;display:flex;align-items:center;justify-content:center;border-radius:4px 8px 6px 10px/6px 4px 8px 5px;transition:transform .1s ease,box-shadow .1s ease;box-shadow:1px 1px 0 0 var(--border-medium);transform:rotate(.2deg)}.close-modal-btn:hover{color:var(--bg-card);background:var(--accent-coral);transform:rotate(-.3deg) translateY(-1px);box-shadow:2px 2px 0 0 var(--border-medium)}.friends-message{padding:12px;border-radius:8px;margin-bottom:16px;font-size:14px;border:3px solid var(--border-accent);box-shadow:2px 2px 0 0 var(--border-medium);transform:rotate(-.2deg)}.friends-message-success{background:var(--accent-green);color:var(--bg-card);border-color:var(--border-accent)}.friends-message-error{background:var(--accent-coral);color:var(--bg-card);border-color:var(--border-accent)}.friends-modal-tabs{display:flex;gap:8px;margin-bottom:24px;padding-bottom:8px;position:relative}.friends-modal-tabs:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--border-accent);z-index:0}.friends-tab{flex:1;padding:12px 16px;background:var(--bg-paper);border:3px solid var(--border-accent);cursor:pointer;font-size:14px;font-weight:600;color:var(--text-primary);transition:transform .1s ease,box-shadow .1s ease;border-radius:6px 10px 8px 12px/8px 6px 10px 7px;font-family:inherit;transform:rotate(-.3deg);box-shadow:2px 2px 0 0 var(--border-medium);position:relative;z-index:1}.friends-tab:nth-child(2){transform:rotate(.2deg)}.friends-tab:nth-child(3){transform:rotate(-.4deg)}.friends-tab:hover{color:var(--text-primary);background:var(--accent-yellow);transform:rotate(.3deg) translateY(-1px);box-shadow:3px 3px 0 0 var(--border-medium);z-index:2}.friends-tab.active{color:var(--text-primary);background:var(--accent-yellow);border-color:var(--border-accent);transform:rotate(-.5deg);box-shadow:3px 3px 0 0 var(--border-medium);z-index:2}.friends-tab.active:after{content:"";position:absolute;bottom:-11px;left:-3px;right:-3px;height:3px;background:var(--accent-yellow);z-index:3}.friends-modal-content{min-height:200px}.friends-loading{text-align:center;padding:40px;color:var(--text-muted);font-size:14px}.friends-empty{text-align:center;padding:40px;color:var(--text-light);font-size:14px}.friends-list{display:flex;flex-direction:column;gap:8px}.friends-item{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:var(--bg-paper);border-radius:6px 10px 8px 12px/8px 6px 10px 7px;border:3px solid var(--border-accent);box-shadow:2px 2px 0 0 var(--border-medium);transition:transform .1s ease,box-shadow .1s ease;transform:rotate(-.2deg)}.friends-item:hover{background:var(--accent-yellow);transform:rotate(.3deg) translateY(-1px);box-shadow:3px 3px 0 0 var(--border-medium)}.friends-item:nth-child(2n){transform:rotate(.2deg)}.friends-item:nth-child(2n):hover{transform:rotate(-.3deg) translateY(-1px)}.friends-item-info{flex:1}.friends-item-username{font-weight:500;color:var(--text-primary);font-size:14px}.friends-item-action-btn{background:var(--bg-card);border:3px solid var(--border-accent);color:var(--accent-coral);cursor:pointer;padding:8px 10px;border-radius:4px 8px 6px 10px/6px 4px 8px 5px;display:flex;align-items:center;transition:transform .1s ease,box-shadow .1s ease;box-shadow:2px 2px 0 0 var(--border-medium);transform:rotate(.2deg)}.friends-item-action-btn:hover{background:var(--accent-coral);color:var(--bg-card);transform:rotate(-.3deg) translateY(-1px);box-shadow:3px 3px 0 0 var(--border-medium)}.friends-requests{display:flex;flex-direction:column;gap:8px}.friends-request-item{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:var(--bg-paper);border-radius:6px 10px 8px 12px/8px 6px 10px 7px;border:3px solid var(--border-accent);box-shadow:2px 2px 0 0 var(--border-medium);transform:rotate(-.2deg)}.friends-request-item:nth-child(2n){transform:rotate(.2deg)}.friends-request-info{flex:1;display:flex;flex-direction:column;gap:4px}.friends-request-username{font-weight:500;color:var(--text-primary);font-size:14px}.friends-request-hint{font-size:12px;color:var(--text-muted)}.friends-request-actions{display:flex;gap:8px}.friends-request-accept-btn{padding:10px 18px;background:var(--accent-green);color:var(--bg-card);border:3px solid var(--border-accent);border-radius:6px 10px 8px 12px/8px 6px 10px 7px;cursor:pointer;font-size:13px;font-weight:600;transition:transform .1s ease,box-shadow .1s ease;box-shadow:2px 2px 0 0 var(--border-medium);transform:rotate(-.3deg);font-family:inherit}.friends-request-accept-btn:hover{background:var(--accent-green);transform:rotate(.5deg) translateY(-1px);box-shadow:3px 3px 0 0 var(--border-medium)}.friends-request-reject-btn{padding:10px 18px;background:var(--accent-coral);color:var(--bg-card);border:3px solid var(--border-accent);border-radius:6px 10px 8px 12px/8px 6px 10px 7px;cursor:pointer;font-size:13px;font-weight:600;transition:transform .1s ease,box-shadow .1s ease;box-shadow:2px 2px 0 0 var(--border-medium);transform:rotate(.3deg);font-family:inherit}.friends-request-reject-btn:hover{background:var(--accent-coral);transform:rotate(-.5deg) translateY(-1px);box-shadow:3px 3px 0 0 var(--border-medium)}.friends-add{display:flex;flex-direction:column;gap:16px}.friends-search-input{padding:12px;border:3px solid var(--border-accent);border-radius:6px 10px 8px 12px/8px 6px 10px 7px;font-size:14px;transition:transform .1s ease,box-shadow .1s ease;background:var(--bg-paper);color:var(--text-primary);box-shadow:2px 2px 0 0 var(--border-medium);transform:rotate(-.2deg);font-family:inherit}.friends-search-input:focus{outline:none;border-color:var(--border-accent);background:var(--accent-yellow);transform:rotate(.2deg);box-shadow:3px 3px 0 0 var(--border-medium)}.friends-search-results{display:flex;flex-direction:column;gap:8px}.friends-search-item{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:var(--bg-paper);border-radius:6px 10px 8px 12px/8px 6px 10px 7px;border:3px solid var(--border-accent);box-shadow:2px 2px 0 0 var(--border-medium);transform:rotate(-.2deg)}.friends-search-item:nth-child(2n){transform:rotate(.2deg)}.friends-search-info{flex:1}.friends-search-username{font-weight:500;color:var(--text-primary);font-size:14px}.friends-search-status{font-size:12px;color:var(--text-muted);font-style:italic}.friends-search-add-btn{display:flex;align-items:center;gap:6px;padding:10px 18px;background:var(--accent-blue);color:var(--bg-card);border:3px solid var(--border-accent);border-radius:6px 10px 8px 12px/8px 6px 10px 7px;cursor:pointer;font-size:13px;font-weight:600;transition:transform .1s ease,box-shadow .1s ease;box-shadow:2px 2px 0 0 var(--border-medium);transform:rotate(-.3deg);font-family:inherit}.friends-search-add-btn:hover{background:var(--accent-blue);transform:rotate(.5deg) translateY(-1px);box-shadow:3px 3px 0 0 var(--border-medium)}.settings-modal{max-width:500px;width:90%}.settings-section{margin-bottom:24px}.settings-section h3{margin:0 0 8px;font-size:18px;color:var(--text-primary)}.settings-description{margin:0 0 20px;color:var(--text-muted);font-size:14px;line-height:1.5}.settings-field{margin-bottom:20px}.settings-field label{display:block;margin-bottom:8px;font-weight:500;color:var(--text-primary);font-size:14px}.settings-input{width:100%;padding:10px 12px;border:1px solid var(--border-color);border-radius:6px;font-size:14px;background:var(--bg-input);color:var(--text-primary);transition:border-color .2s}.settings-input:focus{outline:none;border-color:var(--accent-blue)}.settings-hint{margin:6px 0 0;font-size:12px;color:var(--text-muted);line-height:1.4}.settings-error{margin:12px 0;padding:10px 12px;background:#ff6b6b1a;border:1px solid rgba(255,107,107,.3);border-radius:6px;color:#ff6b6b;font-size:14px}.settings-success{margin:12px 0;padding:10px 12px;background:#4caf501a;border:1px solid rgba(76,175,80,.3);border-radius:6px;color:#4caf50;font-size:14px}.settings-info{margin-top:20px;padding:16px;background:var(--bg-card);border-radius:6px;border:1px solid var(--border-color)}.settings-info p{margin:8px 0;font-size:14px;color:var(--text-primary)}.settings-info p:first-child{margin-top:0}.settings-info p:last-child{margin-bottom:0}.settings-info strong{color:var(--text-primary);font-weight:600}.layout{min-height:100vh;width:100%;display:flex;flex-direction:column;margin:0;padding:0}.navbar{background:linear-gradient(135deg,#845ef7,#f06595,#4dabf7);background-size:200% 200%;animation:gradientShift 30s ease-in-out infinite;border-bottom:3px solid var(--border-accent);padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;position:fixed;top:0;left:0;right:0;width:100%;z-index:1000;box-shadow:0 3px 0 0 var(--border-medium),0 6px 20px #845ef74d}.navbar-brand{font-size:1.5rem;font-weight:700}.navbar-brand a{color:var(--bg-card);text-decoration:none;transition:all .3s ease;display:flex;align-items:center;gap:.5rem;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.navbar-brand a:hover{transform:scale(1.1) rotate(2deg);text-shadow:2px 2px 8px rgba(255,255,255,.5);filter:drop-shadow(0 0 8px rgba(255,255,255,.3))}.navbar-links{display:flex;gap:1.5rem;align-items:center;flex-wrap:wrap}.navbar-links a,.navbar-links .nav-link-btn{color:var(--bg-card);text-decoration:none;font-weight:500;padding:.5rem 1rem;border-radius:6px 10px 8px 12px/8px 6px 10px 7px;transition:all .2s ease;display:flex;align-items:center;gap:.5rem;background:#ffffff40;border:2px solid var(--bg-card);cursor:pointer;font-family:inherit;font-size:inherit;box-shadow:1px 1px #0003;transform:rotate(-.2deg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:relative;overflow:hidden}.navbar-links a:before,.navbar-links .nav-link-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s ease}.navbar-links a:hover:before,.navbar-links .nav-link-btn:hover:before{left:100%}.nav-link-btn{color:var(--text-primary)}.nav-icon{margin-right:.5rem;vertical-align:middle;flex-shrink:0}.nav-link-with-badge{position:relative}.notification-badge{position:absolute;top:-4px;right:4px;background:var(--accent-coral);color:#fff;border-radius:50%;min-width:18px;height:18px;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;padding:0 4px;border:2px solid var(--bg-card);box-shadow:1px 1px #0000004d;transform:rotate(-5deg);line-height:1}.navbar-links a:hover,.navbar-links .nav-link-btn:hover{color:var(--bg-card);background:#ffffff80;transform:rotate(.5deg) translateY(-2px) scale(1.05);box-shadow:3px 3px #0000004d,0 4px 12px #fff3;animation:bounce .3s ease}@keyframes bounce{0%,to{transform:rotate(.5deg) translateY(-2px) scale(1.05)}50%{transform:rotate(-.2deg) translateY(-4px) scale(1.08)}}.navbar-links a.active{color:var(--text-primary)!important;background:linear-gradient(135deg,#ffd43b,#ff922b);border-bottom:3px solid var(--bg-card);transform:rotate(.5deg);box-shadow:2px 2px #0000004d,0 4px 12px #ffd43b66;animation:activePulse 2s ease-in-out infinite}@keyframes activePulse{0%,to{box-shadow:2px 2px #0000004d,0 4px 12px #ffd43b66}50%{box-shadow:2px 2px #0000004d,0 6px 16px #ffd43b99}}.navbar-user{display:flex;align-items:center;gap:1rem;margin-left:1rem;padding-left:1rem;border-left:2px solid var(--bg-card)}.user-name{color:#fff!important;font-weight:600;display:flex;align-items:center;gap:.5rem;text-shadow:1px 1px 2px rgba(0,0,0,.3)}.user-name *{color:#fff!important}.btn-login,.btn-signup,.btn-logout,.btn-settings{padding:.5rem 1rem;border:3px solid var(--bg-card);border-radius:6px 10px 8px 12px/8px 6px 10px 7px;cursor:pointer;font-weight:500;font-size:.95rem;transition:all .2s ease;display:flex;align-items:center;gap:.5rem;font-family:inherit;box-shadow:2px 2px #0003;transform:rotate(-.3deg);position:relative;overflow:hidden}.btn-login:hover,.btn-signup:hover,.btn-logout:hover,.btn-settings:hover{transform:rotate(.3deg) translateY(-2px) scale(1.05);box-shadow:3px 3px #0000004d,0 4px 12px #fff3}.btn-login{background:#fff3;color:var(--bg-card);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.btn-login:hover{background:#fff6;color:var(--bg-card);transform:rotate(.3deg) translateY(-1px);box-shadow:3px 3px #0000004d}.btn-signup{background:var(--accent-yellow);color:var(--text-primary)!important}.btn-signup:hover{background:var(--accent-orange);color:var(--text-primary)!important;transform:rotate(.5deg) translateY(-1px);box-shadow:3px 3px #0000004d}.btn-settings{background:#fff3;color:var(--bg-card);font-size:.85rem;padding:.4rem .8rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.btn-settings:hover{background:#fff6;color:var(--bg-card);transform:rotate(.3deg) translateY(-1px);box-shadow:3px 3px #0000004d}.btn-logout{background:#fff3;color:var(--bg-card);font-size:.85rem;padding:.4rem .8rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.btn-logout:hover{background:#ff6b6bcc;color:var(--bg-card);transform:rotate(-.5deg) translateY(-1px);box-shadow:3px 3px #0000004d}.main-content{padding-top:80px;flex:1;width:100%;min-width:0;min-height:0;overflow-y:auto;display:flex;flex-direction:column}@media (max-width: 768px){.navbar{padding:1rem;flex-direction:column;gap:1rem}.navbar-links{width:100%;justify-content:center;gap:.5rem}.navbar-links a{padding:.4rem .8rem;font-size:.9rem}.navbar-user{margin-left:0;padding-left:0;border-left:none;border-top:1px solid rgba(255,255,255,.2);padding-top:1rem;width:100%;justify-content:center}}.rating-stars{display:flex;flex-direction:column;gap:.3rem}.rating-main-row{display:flex;align-items:center;gap:.75rem}.stars-container{display:flex;gap:.25rem;align-items:center}.stars-display-only{pointer-events:none}.rating-stars .star{background:none;border:none;padding:0;color:#666;transition:color .2s ease;display:flex;align-items:center;justify-content:center;cursor:default}.rating-stars .star.filled{color:gold}.rating-stars-small .star svg{width:16px;height:16px}.rating-stars-medium .star svg{width:20px;height:20px}.rating-stars-large .star svg{width:24px;height:24px}.rating-info{display:flex;align-items:center;gap:.25rem;font-size:.9rem;color:#ffffffe6}.rating-value{font-weight:600}.rating-count{font-size:.85rem;opacity:.7}.rating-footer,.rating-control-wrapper{display:flex;align-items:center}.rate-link{font-size:.85rem;color:var(--text-primary);background:var(--accent-yellow);border:2px solid var(--border-accent);border-radius:6px;padding:.35rem .7rem;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;gap:.3rem;font-weight:600;white-space:nowrap;box-shadow:2px 2px 0 0 var(--border-medium)}.rate-link:hover{background:var(--accent-orange);transform:translateY(-1px);box-shadow:3px 3px 0 0 var(--border-medium)}.rate-link:active{transform:translateY(0);box-shadow:1px 1px 0 0 var(--border-medium)}.rate-link .your-rating-number{font-weight:700;color:var(--text-primary)}.rating-control-popup-wrapper{margin-top:.5rem;display:flex;justify-content:flex-start}.rating-control-popup{display:flex;align-items:center;gap:.5rem;background:#000000d9;padding:.5rem .75rem;border-radius:8px;box-shadow:0 4px 12px #0000004d;border:1px solid rgba(255,255,255,.1)}.rating-control-stars{display:flex;gap:.2rem;align-items:center}.rating-star-btn{background:none;border:none;padding:0;cursor:pointer;color:#666;transition:all .15s ease;display:flex;align-items:center;justify-content:center;width:24px;height:24px}.rating-star-btn svg{width:20px;height:20px}.rating-star-btn:hover,.rating-star-btn.hovered{color:gold;transform:scale(1.1)}.rating-star-btn.selected{color:gold}.rating-control-stars .rating-star-btn.selected~.rating-star-btn:not(.hovered){color:#666}.rating-close{font-size:1.2rem;width:20px;height:20px;border:none;background:transparent;color:#ffffff80;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;line-height:1;margin-left:.25rem;transition:color .2s ease}.rating-close:hover{color:#ffffffe6}.login-to-rate{font-size:.75rem;color:#ffffff80;font-style:italic}.animation-player-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem}.animation-player-modal{background:var(--bg-card);border-radius:12px 8px 14px 10px/10px 12px 8px 9px;max-width:85vw;max-height:85vh;width:100%;min-width:500px;display:flex;flex-direction:column;box-shadow:3px 3px 0 0 var(--border-medium),6px 6px 0 0 var(--border-soft),0 20px 60px #0000004d;border:3px solid var(--border-accent);position:relative;transform:rotate(.3deg);margin:2rem}.animation-player-close{position:absolute;top:1.25rem;right:1.25rem;background:var(--accent-yellow);border:2px solid var(--border-accent);border-radius:4px 8px 6px 10px/6px 4px 8px 5px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-primary);transition:transform .1s ease,box-shadow .1s ease,background .2s;z-index:10;box-shadow:1px 1px 0 0 var(--border-medium);transform:rotate(-.2deg)}.animation-player-close:hover{background:var(--accent-coral);color:var(--bg-card);transform:rotate(.3deg) scale(1.05);box-shadow:2px 2px 0 0 var(--border-medium)}.animation-player-header{padding:1.25rem 1.5rem .875rem;border-bottom:3px solid var(--border-accent)}.animation-player-header h2{margin:0;font-size:1.5rem;color:var(--text-primary);font-weight:600;line-height:1.3}.animation-player-creator{margin:.4rem 0 0;font-size:.95rem;color:var(--text-muted);line-height:1.4}.animation-player-content{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem 1.5rem;min-height:400px;max-height:calc(85vh - 250px);background:var(--bg-paper);overflow:hidden}.animation-player-image{max-width:calc(100% - 2rem);max-height:calc(70vh - 4rem);width:auto;height:auto;object-fit:contain;border-radius:8px 12px 10px 14px/10px 8px 12px 9px;box-shadow:2px 2px 0 0 var(--border-medium),4px 4px 0 0 var(--border-soft);border:2px solid var(--border-accent);background:var(--bg-card);padding:1rem}.animation-player-placeholder{color:var(--text-muted);font-size:1.2rem}.animation-player-controls{display:flex;align-items:center;justify-content:center;gap:1rem;padding:1.25rem 1.5rem;border-top:3px solid var(--border-accent);background:var(--bg-elevated)}.animation-player-btn{background:var(--bg-card);border:3px solid var(--border-accent);border-radius:6px 10px 8px 12px/8px 6px 10px 7px;padding:.75rem 1.5rem;color:var(--text-primary);font-size:1.2rem;cursor:pointer;transition:transform .1s ease,box-shadow .1s ease;min-width:60px;font-family:inherit;box-shadow:2px 2px 0 0 var(--border-medium);transform:rotate(-.3deg);display:flex;align-items:center;justify-content:center;line-height:1}.animation-player-btn:hover:not(:disabled){background:var(--accent-blue);color:var(--bg-card);border-color:var(--border-accent);transform:rotate(.3deg) translateY(-2px);box-shadow:3px 3px 0 0 var(--border-medium)}.animation-player-btn:disabled{opacity:.5;cursor:not-allowed}.animation-player-play-btn{font-size:1.5rem;min-width:80px;background:var(--accent-yellow);color:var(--text-primary)}.animation-player-play-btn:hover:not(:disabled){background:var(--accent-orange);color:var(--bg-card)}.animation-player-counter{margin-left:1rem;color:var(--text-muted);font-size:.95rem;font-weight:500;display:flex;align-items:center;min-height:44px}@media (max-width: 768px){.animation-player-modal-overlay{padding:1rem}.animation-player-modal{max-width:95vw;max-height:95vh;min-width:90vw;border-radius:8px 10px 9px 11px/9px 8px 10px 7px;margin:1rem}.animation-player-content{min-height:300px;max-height:calc(95vh - 250px);padding:1.5rem 1rem}.animation-player-image{max-width:calc(100% - 1rem);max-height:calc(95vh - 4rem);padding:.75rem}.animation-player-content{padding:1rem;min-height:300px}.animation-player-header{padding:1rem 1rem .75rem}.animation-player-close{top:1rem;right:1rem;width:32px;height:32px}.animation-player-controls{padding:1rem;flex-wrap:wrap;gap:.75rem}.animation-player-counter{margin-left:0;margin-top:.5rem;min-height:auto;width:100%;justify-content:center}}.home-container{min-height:100vh;width:100%;max-width:100%;background:var(--bg-paper);background-image:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.03) 2px,rgba(0,0,0,.03) 4px),repeating-linear-gradient(90deg,transparent,transparent 2px,rgba(0,0,0,.03) 2px,rgba(0,0,0,.03) 4px);background-size:100% 100%;animation:none;padding:0;color:var(--text-primary);box-sizing:border-box;margin:0;overflow-x:hidden}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.home-shell{max-width:1400px;margin:0 auto;padding:4.5rem 2rem 3rem}.home-content{padding-top:.75rem}.home-heading{display:flex;align-items:center;gap:.75rem;margin:.5rem 0 .75rem}.home-heading h1{font-size:1.4rem;margin:0;font-weight:700}.home-heading p{margin:.2rem 0 0;font-size:.95rem;opacity:.85}.home-controls{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin:1.5rem 0 1rem;flex-wrap:wrap}.home-actions{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.hero-btn-icon{flex-shrink:0}.btn-compact{padding:.55rem .9rem;font-size:.85rem}.btn-primary,.btn-secondary{padding:.65rem 1rem;font-size:.9rem;border:none;border-radius:10px;cursor:pointer;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;gap:.5rem;box-shadow:0 4px 12px #00000026}.btn-primary{background:var(--accent-yellow);color:var(--text-primary);border:3px solid var(--border-accent)!important;border-style:solid!important;box-shadow:3px 3px 0 0 var(--border-medium);transform:rotate(-.5deg)}.btn-primary:hover{transform:rotate(.5deg) translateY(-2px) scale(1.02);box-shadow:4px 4px 0 0 var(--border-medium);background:var(--accent-orange);border:3px solid var(--border-accent)!important}.btn-secondary{background:var(--accent-purple);color:var(--bg-card);border:3px solid var(--border-accent)!important;border-style:solid!important;box-shadow:2px 2px 0 0 var(--border-medium);transform:rotate(.3deg)}.btn-secondary:hover{background:var(--accent-pink);color:var(--bg-card);transform:rotate(-.3deg) translateY(-2px) scale(1.02);box-shadow:3px 3px 0 0 var(--border-medium);border:3px solid var(--border-accent)!important}.home-filters{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.home-search-box{position:relative;width:200px}.home-search-input{width:100%;padding:.45rem .65rem .45rem 2rem;font-size:.85rem;border:3px solid var(--border-accent)!important;border-style:solid!important;border-radius:20px 25px 22px 28px/22px 20px 25px 24px;background:var(--bg-card);color:var(--text-primary);transition:transform .1s ease,box-shadow .1s ease;box-shadow:2px 2px 0 0 var(--border-medium);transform:rotate(-.2deg);font-family:inherit}.home-search-input::placeholder{color:var(--text-light)}.home-search-input:focus{outline:none;border-color:var(--accent-blue);background:var(--accent-yellow);box-shadow:3px 3px 0 0 var(--border-medium);transform:rotate(.2deg)}.home-search-icon{position:absolute;left:.6rem;top:50%;transform:translateY(-50%);pointer-events:none;color:var(--text-muted)!important}.sort-controls{display:flex;gap:.4rem;align-items:center}.sort-btn{width:32px;height:32px;padding:0;border:3px solid var(--border-accent);border-radius:50%;background:var(--bg-card);color:var(--text-primary);cursor:pointer;transition:transform .1s ease,box-shadow .1s ease;font-weight:500;display:inline-flex;align-items:center;justify-content:center;box-shadow:1px 1px 0 0 var(--border-medium);transform:rotate(-.3deg)}.sort-btn:hover{background:var(--accent-blue);color:var(--bg-card);border-color:var(--border-accent);transform:rotate(.3deg) translateY(-1px);box-shadow:2px 2px 0 0 var(--border-medium)}.sort-btn.active{background:var(--accent-yellow);border-color:var(--border-accent);box-shadow:3px 3px 0 0 var(--border-medium);transform:rotate(-.5deg)}.sort-icon{width:14px;height:14px;display:block;flex-shrink:0}.gallery-section{padding:0}.animation-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.25rem;margin-top:.75rem}.gallery-card{background:var(--bg-card);border-radius:12px 8px 14px 10px/10px 12px 8px 9px;overflow:hidden;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;border:3px solid var(--border-accent);box-shadow:3px 3px 0 0 var(--border-medium),6px 6px 0 0 var(--border-soft);position:relative;transform:rotate(.3deg)}.gallery-card:nth-child(2n){transform:rotate(-.3deg)}.gallery-card:nth-child(3n){transform:rotate(.5deg)}.gallery-card:hover{transform:rotate(-.5deg) translateY(-4px) scale(1.02);box-shadow:4px 4px 0 0 var(--border-medium),8px 8px 0 0 var(--border-soft);border-color:var(--border-accent)}.card-thumbnail{width:100%;aspect-ratio:16/9;background:var(--bg-paper);display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative;border-bottom:2px solid var(--border-accent)}.card-thumbnail img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.gallery-card:hover .card-thumbnail img{transform:scale(1.05)}.card-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%}.card-placeholder svg{color:var(--text-muted)!important}.card-header-row{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;margin-bottom:.5rem}.card-title-section{flex:1;min-width:0}.card-play-button{flex-shrink:0;width:36px;height:36px;border-radius:50%;background:var(--accent-yellow);border:3px solid var(--border-accent);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;box-shadow:2px 2px 0 0 var(--border-medium);transform:rotate(-.3deg);opacity:0;pointer-events:none}.gallery-card:hover .card-play-button{opacity:1;pointer-events:auto;transform:rotate(.5deg) scale(1.1);background:var(--accent-orange);box-shadow:3px 3px 0 0 var(--border-medium)}.card-play-button:hover{transform:rotate(-.3deg) scale(1.15);background:var(--accent-orange);box-shadow:4px 4px 0 0 var(--border-medium)}.card-play-button:active{transform:rotate(0) scale(1.05);box-shadow:2px 2px 0 0 var(--border-medium)}.card-content{padding:1.25rem}.card-title{margin:0 0 .5rem;font-size:1.2rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-creator{margin:0 0 .75rem;font-size:.9rem;opacity:.85;font-style:italic}.card-rating{margin:.75rem 0}.card-meta{font-size:.85rem;opacity:.75;margin-top:.75rem;display:flex;align-items:center;gap:.5rem}.empty-gallery{text-align:center;padding:4rem 2rem;opacity:.9}.empty-gallery svg{margin-bottom:1.5rem;opacity:.6}.empty-gallery p{margin:.5rem 0;font-size:1.2rem}.empty-subtitle{font-size:1rem!important;opacity:.8!important;margin-bottom:1.5rem!important}.loading-spinner{text-align:center;padding:4rem;font-size:1.2rem;opacity:.9}@media (max-width: 768px){.home-shell{padding:0 1rem 2rem}.home-heading{margin-top:.35rem}.home-controls{flex-direction:column;align-items:stretch;gap:.75rem}.home-actions,.btn-primary,.btn-secondary{width:100%}.home-filters{flex-direction:column;align-items:stretch}.home-search-box{width:100%}.sort-controls{justify-content:flex-start}.animation-gallery{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}}@media (max-width: 480px){.animation-gallery{grid-template-columns:1fr}}.canvas-container{display:flex;align-items:center;justify-content:center;width:100%;height:100%}.drawing-canvas{display:block;background:var(--bg-card);border-radius:8px 12px 10px 14px/10px 8px 12px 9px;cursor:crosshair;touch-action:none;box-shadow:4px 4px 0 0 var(--border-medium),8px 8px 0 0 var(--border-soft);border:4px solid var(--border-accent);max-width:100%;max-height:calc(100vh - 300px);width:auto;height:auto;object-fit:contain;transform:rotate(-.2deg)}.drawing-canvas:active{cursor:grabbing}.drawing-canvas.eraser-cursor{cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none'%3E%3Cpath d='M16.24 3.56l4.95 4.94c.78.79.78 2.05 0 2.84L12 20.53a4.008 4.008 0 0 1-5.66 0L2.81 17c-.78-.79-.78-2.05 0-2.84l10.1-10.1c.79-.78 2.05-.78 2.83 0zm-1.41 1.42L12.7 6.3 4.92 14.08l2.12 2.12 7.78-7.78 2.01-2.01z' fill='%23000'/%3E%3C/svg%3E") 12 12,auto}.drawing-canvas.fill-cursor{cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none'%3E%3Cpath fill='%23000' d='M16.56 8.94L7.62 0 6.21 1.41l2.38 2.38-5.15 5.15c-.59.59-.59 1.54 0 2.12l5.5 5.5c.29.29.68.44 1.06.44s.77-.15 1.06-.44l5.5-5.5c.59-.58.59-1.53 0-2.12zM5.21 10L10 5.21 14.79 10H5.21zM19 11.5s-2 2.17-2 3.5c0 1.1.9 2 2 2s2-.9 2-2c0-1.33-2-3.5-2-3.5z'/%3E%3C/svg%3E") 8 12,auto}.drawing-canvas.pipette-cursor{cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M20.71 5.63l-2.34-2.34c-.39-.39-1.02-.39-1.41 0l-1.83 1.83 3.75 3.75 1.83-1.83c.39-.38.39-1.02 0-1.41zM17.08 7.29l-3.75-3.75-8.5 8.5c-.78.78-.78 2.05 0 2.83l1.42 1.42c.78.78 2.05.78 2.83 0l8.5-8.5zM3 17.25V21h3.75L17.81 9.94l-3.75-3.75L3 17.25z'/%3E%3C/svg%3E") 2 22,crosshair}.drawing-canvas.crosshair-cursor{cursor:crosshair}.drawing-canvas.grab-cursor{cursor:grab}.drawing-canvas.grab-cursor:active,.drawing-canvas.grabbing-cursor{cursor:grabbing}.drawing-canvas.text-cursor{cursor:text}.drawing-canvas.nwse-resize-cursor{cursor:nwse-resize}.frame-strip{width:100%;max-width:100%;background:var(--bg-card);border-top:3px solid var(--border-accent);padding:20px 8px 8px;flex:0 0 auto;overflow-x:auto;overflow-y:visible;transition:margin-left .3s ease;position:relative;z-index:10;box-sizing:border-box;margin:0;height:auto;min-height:102px;box-shadow:0 -3px 0 0 var(--border-medium)}.frame-strip.recordings-panel-open{margin-left:280px;width:calc(100% - 280px)}.frame-strip h3{display:none}.frames-container{display:flex;gap:6px;flex-wrap:nowrap;padding:0 0 8px;background:transparent;border-radius:0;overflow-x:auto;overflow-y:visible;min-height:86px;align-items:flex-start;width:max-content}.frame-thumbnail{position:relative;width:70px;height:70px;border:3px solid var(--border-accent);border-radius:6px 10px 8px 12px/8px 6px 10px 7px;cursor:grab;overflow:hidden;background:var(--bg-paper);transition:transform .1s ease,box-shadow .1s ease;flex-shrink:0;-webkit-user-select:none;user-select:none;box-shadow:2px 2px 0 0 var(--border-medium);transform:rotate(-.2deg)}.frame-thumbnail:active{cursor:grabbing}.frame-thumbnail.dragging{opacity:.5;cursor:grabbing}.frame-thumbnail.drag-over{border-color:var(--accent-blue);border-width:4px;transform:rotate(.5deg) scale(1.1);z-index:10;box-shadow:3px 3px 0 0 var(--border-medium)}.frame-thumbnail:hover{border-color:var(--border-accent);background:var(--accent-blue);transform:rotate(.3deg) translateY(-1px);box-shadow:3px 3px 0 0 var(--border-medium)}.frame-thumbnail.active{border-color:var(--border-accent);border-width:4px;box-shadow:4px 4px 0 0 var(--border-medium);background:var(--accent-yellow);transform:rotate(-.5deg)}.frame-thumbnail img{width:100%;height:100%;object-fit:contain}.empty-frame{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-light);font-size:.8em;background:var(--bg-paper);font-family:inherit}.frame-number{position:absolute;top:4px;left:4px;background:var(--accent-yellow);color:var(--text-primary);padding:2px 6px;border-radius:4px 8px 6px 10px/6px 4px 8px 5px;font-size:.75em;font-weight:600;border:2px solid var(--border-accent);box-shadow:1px 1px 0 0 var(--border-medium);font-family:inherit;z-index:1}.frame-actions{position:absolute;bottom:4px;right:4px;display:flex;gap:4px;opacity:0;transition:opacity .2s}.frame-thumbnail:hover .frame-actions{opacity:1}.frame-btn{background:var(--bg-card);border:2px solid var(--border-accent);border-radius:4px 8px 6px 10px/6px 4px 8px 5px;padding:4px;cursor:pointer;font-size:.9em;transition:transform .1s ease,box-shadow .1s ease;color:var(--text-primary);box-shadow:1px 1px 0 0 var(--border-medium);transform:rotate(-.1deg)}.frame-btn:hover{background:var(--accent-blue);color:var(--bg-card);border-color:var(--border-accent);transform:rotate(.2deg) translateY(-1px);box-shadow:2px 2px 0 0 var(--border-medium)}.delete-btn:hover{background:var(--accent-coral);border-color:var(--border-accent);color:var(--bg-card)}.add-frame-btn{width:70px;height:70px;border:3px dashed var(--border-accent);border-radius:6px 10px 8px 12px/8px 6px 10px 7px;background:var(--bg-paper);color:var(--text-light);font-size:1.2em;font-weight:300;cursor:pointer;transition:transform .1s ease,box-shadow .1s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:2px 2px 0 0 var(--border-medium);transform:rotate(.2deg)}.add-frame-btn:hover{background:var(--accent-green);border-color:var(--border-accent);color:var(--bg-card);border-style:solid;transform:rotate(-.3deg) translateY(-1px);box-shadow:3px 3px 0 0 var(--border-medium)}.frame-thumbnail.game-mode-hidden{border-color:#999;background:#f0f0f0;opacity:.6}.game-mode-info{padding:8px;border-radius:4px;margin-bottom:8px;font-size:14px;font-weight:500}.toolbar{display:flex;flex-direction:column;gap:16px;padding:16px;background:var(--bg-card);border-right:3px solid var(--border-accent);width:280px;flex-shrink:0;overflow-y:auto;overflow-x:hidden;align-items:stretch;height:100%;max-height:100%;min-height:0;box-shadow:3px 0 0 0 var(--border-medium)}.toolbar-section{display:flex;flex-direction:column;gap:8px;padding:12px;background:var(--bg-paper);border-radius:8px 12px 10px 14px/10px 8px 12px 9px;border:3px solid var(--border-accent);box-shadow:2px 2px 0 0 var(--border-medium);transform:rotate(-.2deg)}.toolbar-section label{font-weight:600;color:var(--text-primary);font-size:.85em;text-transform:uppercase;letter-spacing:.5px}.tool-selector{display:flex;gap:8px;flex-wrap:wrap}.tool-btn{width:50px;height:50px;border:3px solid var(--border-accent);border-radius:6px 10px 8px 12px/8px 6px 10px 7px;background:var(--bg-card);font-size:1.4em;cursor:pointer;transition:transform .1s ease,box-shadow .1s ease;display:flex;align-items:center;justify-content:center;color:var(--text-primary);box-shadow:2px 2px 0 0 var(--border-medium);transform:rotate(-.3deg)}.tool-btn:nth-child(2n){transform:rotate(.3deg)}.tool-btn:hover{background:var(--accent-blue);border-color:var(--border-accent);color:var(--bg-card);transform:rotate(.5deg) translateY(-1px);box-shadow:3px 3px 0 0 var(--border-medium)}.tool-btn.active{border-color:var(--border-accent);background:var(--accent-yellow);color:var(--text-primary);box-shadow:4px 4px 0 0 var(--border-medium);transform:rotate(-.5deg)}.color-section{position:relative;z-index:100}.color-picker-container{display:flex;flex-direction:column;gap:12px;align-items:stretch}.color-picker-wrapper{position:relative}.color-preview-btn{width:100%;height:50px;border:3px solid var(--border-accent);border-radius:6px 10px 8px 12px/8px 6px 10px 7px;cursor:pointer;transition:transform .1s ease,box-shadow .1s ease;box-shadow:2px 2px 0 0 var(--border-medium);background-color:var(--preview-color, #000000);transform:rotate(-.2deg)}.color-preview-btn:hover{border-color:var(--border-accent);box-shadow:3px 3px 0 0 var(--border-medium);transform:rotate(.3deg) translateY(-1px)}.color-picker-popup{position:absolute;top:60px;left:0;z-index:1000;background:var(--bg-card);border-radius:8px 12px 10px 14px/10px 8px 12px 9px;box-shadow:4px 4px 0 0 var(--border-medium),8px 8px 0 0 var(--border-soft);padding:16px;display:flex;flex-direction:column;gap:12px;animation:slideDown .2s ease-out;border:3px solid var(--border-accent);transform:rotate(.2deg)}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.color-picker-popup .react-colorful{width:200px;height:200px}.color-hex-input{display:flex;align-items:center;gap:5px}.color-hex-input input{width:100%;padding:8px;border:3px solid var(--border-accent);border-radius:4px 8px 6px 10px/6px 4px 8px 5px;font-size:13px;font-family:inherit;text-align:center;background:var(--bg-paper);color:var(--text-primary);box-shadow:1px 1px 0 0 var(--border-medium);transform:rotate(-.1deg)}.color-hex-input input:focus{outline:none;border-color:var(--accent-blue);box-shadow:2px 2px 0 0 var(--border-medium);background:var(--accent-yellow);transform:rotate(.1deg)}.color-picker-close{position:absolute;top:8px;right:8px;cursor:pointer;color:var(--text-primary);z-index:1001;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:4px 8px 6px 10px/6px 4px 8px 5px;background:var(--bg-card);border:2px solid var(--border-accent);transition:transform .1s ease,box-shadow .1s ease;box-shadow:1px 1px 0 0 var(--border-medium);transform:rotate(.2deg)}.color-picker-close:hover{background:var(--accent-coral);color:var(--bg-card);transform:rotate(-.3deg) translateY(-1px);box-shadow:2px 2px 0 0 var(--border-medium)}.color-presets{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.color-preset{width:100%;aspect-ratio:1;border:3px solid var(--border-accent);border-radius:4px 8px 6px 10px/6px 4px 8px 5px;cursor:pointer;transition:transform .1s ease,box-shadow .1s ease;box-shadow:1px 1px 0 0 var(--border-medium);background-color:var(--preset-color, #999999);transform:rotate(-.2deg)}.color-preset:nth-child(2n){transform:rotate(.2deg)}.color-preset:hover{border-color:var(--border-accent);transform:rotate(.5deg) scale(1.05);box-shadow:2px 2px 0 0 var(--border-medium)}.color-preset.active{border-color:var(--border-accent);border-width:4px;box-shadow:3px 3px 0 0 var(--border-medium);transform:rotate(-.5deg)}.brush-slider{width:100%;cursor:pointer;accent-color:var(--accent-blue)}.brush-slider::-webkit-slider-thumb{background:var(--accent-blue);border:2px solid var(--border-accent);border-radius:50%;box-shadow:1px 1px 0 0 var(--border-medium)}.brush-slider::-moz-range-thumb{background:var(--accent-blue);border:2px solid var(--border-accent);border-radius:50%;box-shadow:1px 1px 0 0 var(--border-medium)}.toolbar-btn{padding:10px 16px;border:3px solid var(--border-accent);border-radius:6px 10px 8px 12px/8px 6px 10px 7px;background:var(--bg-card);color:var(--text-primary);font-size:.9em;font-weight:500;cursor:pointer;transition:transform .1s ease,box-shadow .1s ease;font-family:inherit;width:100%;text-align:left;display:flex;align-items:center;box-shadow:2px 2px 0 0 var(--border-medium);transform:rotate(-.3deg)}.toolbar-btn:hover{background:var(--accent-blue);border-color:var(--border-accent);color:var(--bg-card);transform:rotate(.3deg) translateY(-1px);box-shadow:3px 3px 0 0 var(--border-medium)}.toolbar-btn:active{background:var(--bg-elevated-strong);transform:rotate(-.5deg) translateY(0);box-shadow:1px 1px 0 0 var(--border-medium)}.play-btn.playing{background:var(--accent-green);color:var(--bg-card);border-color:var(--border-accent)}.clear-btn:hover{background:var(--accent-coral);border-color:var(--border-accent);color:var(--bg-card)}.record-btn{background:var(--accent-coral)!important;border-color:var(--border-accent)!important;color:var(--bg-card)!important}.record-btn:hover{background:var(--accent-pink)!important;border-color:var(--border-accent)!important}.stop-btn{background:var(--accent-orange)!important;border-color:var(--border-accent)!important;color:var(--bg-card)!important}.stop-btn:hover{background:var(--accent-yellow)!important;border-color:var(--border-accent)!important}.recording-pulse{animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;box-shadow:2px 2px 0 0 var(--border-medium)}50%{opacity:.9;box-shadow:4px 4px 0 0 var(--border-medium)}}.recordings-btn{background:var(--accent-purple)!important;border-color:var(--border-accent)!important;color:var(--bg-card)!important}.recordings-btn:hover{background:var(--accent-cyan)!important;border-color:var(--border-accent)!important}.delete-audio-btn:hover{background:var(--accent-coral);border-color:var(--border-accent);color:var(--bg-card)}.audio-indicator{padding:8px;background:var(--bg-paper);border-radius:4px 8px 6px 10px/6px 4px 8px 5px;border:2px solid var(--border-accent);font-size:.85em;color:var(--accent-blue);text-align:center;margin-top:4px;box-shadow:1px 1px 0 0 var(--border-medium);transform:rotate(-.2deg)}@media (max-width: 768px){.toolbar,.toolbar-section{flex-direction:column;align-items:stretch}.color-picker-container{flex-direction:column}}.users-list{position:fixed;top:80px;right:20px;background:#fff;border-radius:8px;padding:12px;box-shadow:0 2px 12px #00000040;min-width:220px;z-index:1000;border:2px solid #007bff}.users-list-header{display:flex;flex-direction:column;gap:8px;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid #eee}.users-title-row{display:flex;justify-content:space-between;align-items:center}.users-title{font-weight:600;font-size:14px;color:#333}.room-id-container{display:flex;align-items:center}.room-id{font-size:11px;color:#666;font-family:monospace;background:#f5f5f5;padding:4px 8px;border-radius:4px;display:inline-block;width:100%}.room-settings-btn{background:#007bff!important;color:#fff!important;border:none!important;border-radius:6px;padding:8px 10px!important;cursor:pointer;transition:background .2s,transform .1s;display:flex;align-items:center;justify-content:center;gap:4px;flex-shrink:0;font-size:12px;font-weight:600;box-shadow:0 2px 4px #007bff4d}.room-settings-btn:hover{background:#0056b3!important;transform:scale(1.05);box-shadow:0 2px 6px #007bff66}.room-settings-btn:active{transform:scale(.95)}.users-container{display:flex;flex-direction:column;gap:8px}.user-item{display:flex;align-items:center;gap:8px;font-size:13px}.user-color{width:12px;height:12px;border-radius:50%;border:2px solid #ddd;flex-shrink:0;background-color:var(--user-color, #999)}.user-name{color:#555;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-item.current-user .user-name{font-weight:600;color:#333}.remote-cursors-container{position:fixed;top:0;left:0;pointer-events:none;z-index:9999}.remote-cursor{position:absolute;left:var(--cursor-left, 0);top:var(--cursor-top, 0);width:20px;height:20px;border:2px solid var(--cursor-color, #999);border-radius:50% 50% 50% 0;transform:rotate(-45deg);margin-left:-10px;margin-top:-10px;pointer-events:none;animation:pulse 2s infinite}.cursor-name{position:absolute;top:24px;left:-50%;transform:rotate(45deg);padding:2px 6px;border-radius:4px;font-size:11px;font-weight:600;color:#fff;white-space:nowrap;box-shadow:0 2px 4px #0003;background-color:var(--cursor-color, #999)}@keyframes pulse{0%,to{opacity:1;transform:rotate(-45deg) scale(1)}50%{opacity:.7;transform:rotate(-45deg) scale(1.1)}}.room-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.room-modal{background:#fff;border-radius:12px;padding:32px;max-width:400px;width:90%;box-shadow:0 8px 32px #0000004d;animation:slideUp .3s ease-out;position:relative}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.close-modal-btn{background:none!important;border:none!important;font-size:28px!important;cursor:pointer;padding:4px 8px!important;color:#666!important;line-height:1;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.close-modal-btn:hover{color:#333!important;background:#f0f0f0!important}.room-modal h2{margin:0 0 24px;text-align:center;font-size:24px;color:#333}.room-modal-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.room-modal-title{margin:0;display:flex;align-items:center;gap:.5rem;font-size:24px;color:#333}.room-modal-header-icon{flex-shrink:0}.room-info-section{margin-bottom:24px}.room-info-label{font-size:14px;color:#666;margin-bottom:8px}.room-info-id-container{display:flex;align-items:center;gap:12px;margin-bottom:8px}.room-info-id{font-size:24px;font-weight:700;color:#333;flex:1;font-family:Courier New,monospace;letter-spacing:2px}.room-copy-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:#007bff;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:background .2s;white-space:nowrap}.room-copy-btn:hover{background:#0056b3}.room-copy-btn:active{background:#004085}.room-info-user{font-size:12px;color:#999}.room-modal-actions-column{display:flex;flex-direction:column;gap:12px}.join-btn-secondary{background-color:#f0f0f0;color:#333}.join-btn-secondary:hover:not(:disabled){background-color:#e0e0e0}.join-btn-danger{background-color:#f44;color:#fff}.join-btn-danger:hover:not(:disabled){background-color:#c33}.room-modal-hint{font-size:11px;color:#999;margin-top:8px;text-align:center}.connection-status-spacing{margin-top:24px}.connection-hint{font-size:11px;color:#999;margin-top:4px}.room-modal-actions{display:flex;gap:8px;margin-bottom:24px}.action-btn{flex:1;padding:10px 16px;border:2px solid #ddd;background:#fff;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.action-btn:hover{border-color:#007bff;background:#f0f8ff}.action-btn.active{border-color:#007bff;background:#007bff;color:#fff}.room-modal-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:14px;font-weight:500;color:#555}.form-group input{padding:10px 12px;border:2px solid #ddd;border-radius:6px;font-size:14px;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#007bff}.join-btn{padding:12px 24px;background:#007bff;color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:background .2s;margin-top:8px}.join-btn:hover:not(:disabled){background:#0056b3}.join-btn:disabled{background:#ccc;cursor:not-allowed}.connection-status{margin-top:16px;text-align:center;font-size:12px}.status-connected{color:#28a745}.status-disconnected{color:#dc3545}.room-invite-section{margin-top:24px;padding-top:24px;border-top:1px solid #e0e0e0}.room-invite-label{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:#333;margin-bottom:12px}.room-invite-hint{font-size:13px;color:#666;text-align:center;padding:12px;background:#f8f9fa;border-radius:8px;margin-bottom:12px}.room-friends-list{display:flex;flex-direction:column;gap:8px;margin-bottom:12px;max-height:200px;overflow-y:auto}.room-friend-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:#f8f9fa;border-radius:6px;transition:background .2s}.room-friend-item:hover{background:#e9ecef}.room-friend-username{font-size:14px;color:#333;font-weight:500}.room-invite-friend-btn{display:flex;align-items:center;gap:4px;padding:6px 12px;background:#28a745;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;transition:background .2s}.room-invite-friend-btn:hover{background:#218838}.room-friends-more{font-size:12px;color:#666;text-align:center;padding:8px;font-style:italic}.room-manage-friends-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;background:#6c757d;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:background .2s}.room-manage-friends-btn:hover{background:#5a6268}.app{padding-top:4.25rem;display:flex;flex-direction:column;height:100vh;width:100%;max-width:100%;background:var(--bg-paper);overflow:hidden;margin:0;box-sizing:border-box}.app-header{background:var(--bg-card);padding:24px 20px 12px;border-bottom:3px solid var(--border-accent);border-bottom-style:solid;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;flex-wrap:wrap;gap:1rem;width:100%;max-width:100%;box-sizing:border-box;margin:0;box-shadow:0 3px 0 0 var(--border-medium);position:relative}.app-header:after{content:"";position:absolute;bottom:-3px;left:0;right:0;height:1px;background:var(--border-medium);border-radius:0 0 2px 2px}.header-left{display:flex;align-items:center;gap:1rem;flex-shrink:0;min-width:0}.back-btn{background:var(--bg-card);border:3px solid var(--border-accent);color:var(--text-primary);padding:.5rem 1rem;border-radius:6px 10px 8px 12px/8px 6px 10px 7px;cursor:pointer;font-size:.9rem;transition:transform .1s ease,box-shadow .1s ease;white-space:nowrap;font-family:inherit;box-shadow:2px 2px 0 0 var(--border-medium);transform:rotate(-.5deg)}.back-btn:hover{background:var(--accent-yellow);color:var(--text-primary)!important;transform:rotate(.5deg) translate(-2px);box-shadow:3px 3px 0 0 var(--border-medium)}.app-header h1{font-size:1.5em;color:var(--text-primary);margin:0;font-weight:600;display:flex;align-items:center;gap:10px;white-space:nowrap}.editor-header-icon{margin-right:.5rem;vertical-align:middle;flex-shrink:0}.app-header p{display:none}.header-controls{display:flex;align-items:center;gap:15px;flex:1;min-width:0;justify-content:flex-end;flex-wrap:wrap}.room-status-header{display:flex!important;align-items:center;gap:8px;padding:8px 12px;background:var(--accent-blue)!important;border:3px solid var(--border-accent)!important;border-radius:6px 10px 8px 12px/8px 6px 10px 7px;color:var(--bg-card)!important;font-size:.9em;white-space:nowrap;flex-shrink:0;z-index:10;box-shadow:2px 2px 0 0 var(--border-medium);transform:rotate(-.3deg)}.room-status-text{font-family:inherit;font-weight:600;color:var(--bg-card)!important}.room-settings-header-btn{background:var(--accent-purple)!important;border-color:var(--border-accent)!important;color:var(--bg-card)!important;margin-left:4px;padding:4px 10px!important;font-size:.85em}.room-settings-header-btn:hover{background:var(--accent-cyan)!important;border-color:var(--border-accent)!important;color:var(--bg-card)!important}.room-join-prompt{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:9999;background:#fff;border-radius:12px;padding:24px;box-shadow:0 8px 32px #0000004d;max-width:400px;width:90%;border:2px solid #007bff}.room-join-prompt-content{display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center}.room-join-prompt-content h3{margin:0;color:#333;font-size:20px}.room-join-prompt-content p{margin:0;color:#666;font-size:14px}.room-join-prompt-btn{padding:12px 24px;background:#007bff;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background .2s}.room-join-prompt-btn:hover{background:#0056b3}.animation-name-input{display:flex;align-items:center;gap:10px;flex-shrink:0;min-width:0}.header-buttons{display:flex;align-items:center;gap:8px;flex-wrap:wrap;min-width:0}.header-btn{padding:8px 16px;border:3px solid var(--border-accent);border-radius:6px 10px 8px 12px/8px 6px 10px 7px;background:var(--bg-card);color:var(--text-primary);display:inline-flex;align-items:center;justify-content:center;gap:6px;font-size:.9em;font-weight:500;cursor:pointer;transition:transform .1s ease,box-shadow .1s ease;font-family:inherit;white-space:nowrap;box-shadow:2px 2px 0 0 var(--border-medium);transform:rotate(-.3deg)}.header-btn.new-btn{background:var(--accent-yellow);color:var(--text-primary)!important}.header-btn.new-btn:hover{background:var(--accent-yellow);color:var(--text-primary)!important;opacity:.9;transform:rotate(.5deg) translateY(-1px)}.header-btn.save-btn{background:var(--accent-blue);color:var(--bg-card)}.header-btn.save-btn:hover{background:var(--accent-blue);opacity:.9;transform:rotate(.5deg) translateY(-1px)}.btn-text{min-width:4.5ch;margin-left:6px;display:inline-block;text-align:left}.header-btn:hover{background:var(--accent-blue);border-color:var(--border-accent);color:var(--bg-card);transform:rotate(.5deg) translateY(-1px);box-shadow:3px 3px 0 0 var(--border-medium)}.header-btn.new-btn:hover{background:var(--accent-yellow);color:var(--text-primary)!important;border-color:var(--border-accent)}.header-btn:active{background:var(--bg-elevated-strong);transform:rotate(-1deg) translateY(0);box-shadow:1px 1px 0 0 var(--border-medium)}.header-btn.play-btn{background:var(--accent-green);color:var(--bg-card)}.header-btn.play-btn:hover{background:var(--accent-green);opacity:.9}.header-btn.play-btn.playing{background:var(--accent-green);color:var(--bg-card);border-color:var(--border-accent)}.header-btn.export-btn{background:var(--accent-purple);color:var(--bg-card)}.header-btn.export-btn:hover{background:var(--accent-purple);opacity:.9}.header-btn.import-btn{background:var(--accent-cyan);color:var(--bg-card)}.header-btn.import-btn:hover{background:var(--accent-cyan);opacity:.9}.header-btn.export-video-btn{background:var(--accent-orange)!important;border-color:var(--border-accent)!important;color:var(--bg-card)!important}.header-btn.export-video-btn:hover{background:var(--accent-yellow)!important;border-color:var(--border-accent)!important;color:var(--text-primary)!important}.header-btn:disabled{opacity:.6;cursor:not-allowed}.public-toggle{display:flex;align-items:center;gap:.5rem;padding:8px 12px;border:3px solid var(--border-accent);border-radius:6px 10px 8px 12px/8px 6px 10px 7px;background:var(--accent-pink);color:var(--bg-card);cursor:pointer;transition:transform .1s ease,box-shadow .1s ease,background .2s ease;font-size:.9rem;box-shadow:2px 2px 0 0 var(--border-medium);transform:rotate(-.3deg)}.public-toggle.checked{background:var(--accent-green)}.public-toggle:hover{background:var(--accent-pink);border-color:var(--border-accent);transform:rotate(.3deg) translateY(-1px);box-shadow:3px 3px 0 0 var(--border-medium);opacity:.9}.public-toggle.checked:hover{background:var(--accent-green)}.public-toggle .toggle-label{color:var(--bg-card)}.public-toggle input[type=checkbox]{cursor:pointer;width:16px;height:16px}.public-toggle input[type=checkbox]:disabled{cursor:not-allowed;opacity:.6}.toggle-label{-webkit-user-select:none;user-select:none}.header-btn.saving{background:var(--accent-blue);border-color:var(--border-accent);color:var(--bg-card);position:relative;pointer-events:none;cursor:wait}.header-btn:has(.save-spinner),.header-btn.saving{min-width:120px}.header-btn:has([class*=SaveIcon]){min-width:120px}.header-btn.saving:hover{background:var(--accent-blue);border-color:var(--border-accent);color:var(--bg-card)}.save-spinner{display:inline-block;width:14px;height:14px;margin-left:8px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;vertical-align:middle;flex-shrink:0;flex-grow:0}.header-btn.save-btn .save-spinner,.header-btn.saving .save-spinner{border:2px solid rgba(255,255,255,.3);border-top-color:#fff;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.name-input{padding:8px 12px;background:var(--bg-card);border:3px solid var(--border-accent);border-radius:6px 10px 8px 12px/8px 6px 10px 7px;color:var(--text-primary);font-size:.9em;font-family:inherit;min-width:200px;transition:transform .1s ease,box-shadow .1s ease;box-shadow:2px 2px 0 0 var(--border-medium);transform:rotate(.2deg)}.name-input:focus{outline:none;border-color:var(--accent-blue);background:var(--accent-yellow);box-shadow:3px 3px 0 0 var(--border-medium);transform:rotate(-.2deg)}.name-input::placeholder{color:var(--text-light)}.main-content{display:flex;flex:1;overflow:hidden;gap:0;width:100%;max-width:100%;box-sizing:border-box;margin:0;padding:0;min-height:0}.editor-sidebar{position:relative;height:100%;max-height:100%;display:flex;flex-shrink:0;overflow:hidden;min-height:0}.editor-canvas-area{flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative;min-height:0;min-width:0;height:100%;max-height:100%}.editor-frames-loading{flex:0 0 auto;padding:8px 16px;background:var(--bg-elevated, #2a2a2a);color:var(--text-secondary, #aaa);font-size:14px;text-align:center}.canvas-wrapper{flex:1 1 auto;display:flex;align-items:center;justify-content:center;padding:20px;background:var(--bg-paper);overflow-y:auto;overflow-x:auto;position:relative;width:100%;max-width:100%;box-sizing:border-box;min-width:0;min-height:0}.hidden-file-input{display:none}@media (min-width: 1200px){.main-content{flex-direction:row}}.animations-container{width:100%;flex:1;min-height:0;background:var(--bg-paper);background-image:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.03) 2px,rgba(0,0,0,.03) 4px),repeating-linear-gradient(90deg,transparent,transparent 2px,rgba(0,0,0,.03) 2px,rgba(0,0,0,.03) 4px);color:var(--text-primary);display:flex;flex-direction:column;box-sizing:border-box;overflow:hidden;padding-top:4.5rem}.animations-header{width:100%;max-width:1400px;margin:0 auto;padding:2rem;flex-shrink:0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;box-sizing:border-box}.animations-header-content{width:100%;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1.5rem}.animations-header h1{margin:0;font-size:2.5rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:.5rem}.header-icon{margin-right:.75rem;vertical-align:middle}.search-box{position:relative;display:flex;align-items:center}.search-input{padding:.75rem 2.5rem .75rem 1rem;background:var(--bg-card);border:3px solid var(--border-accent);border-radius:8px 12px 10px 14px/10px 8px 12px 9px;color:var(--text-primary);font-size:.95rem;width:300px;transition:transform .1s ease,box-shadow .1s ease;box-shadow:2px 2px 0 0 var(--border-medium);transform:rotate(-.2deg);font-family:inherit}.search-input:focus{outline:none;border-color:var(--accent-blue);background:var(--accent-yellow);box-shadow:3px 3px 0 0 var(--border-medium);transform:rotate(.2deg)}.search-input::placeholder{color:var(--text-light)}.search-icon{position:absolute;right:.75rem;pointer-events:none;opacity:.7}.btn-primary,.btn-secondary{padding:.75rem 1.5rem;border:none;border-radius:8px;cursor:pointer;font-weight:600;font-size:.95rem;transition:all .2s;white-space:nowrap}.btn-primary{background:var(--accent-purple);color:var(--bg-card);box-shadow:3px 3px 0 0 var(--border-medium);border:3px solid var(--border-accent);transform:rotate(-.5deg)}.btn-primary:hover{background:var(--accent-pink);color:var(--bg-card);transform:rotate(.5deg) translateY(-1px);box-shadow:4px 4px 0 0 var(--border-medium)}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border:3px solid var(--border-accent);box-shadow:2px 2px 0 0 var(--border-medium);transform:rotate(.3deg)}.btn-secondary:hover{background:var(--accent-blue);color:var(--bg-card);border-color:var(--border-accent);transform:rotate(-.3deg) translateY(-1px);box-shadow:3px 3px 0 0 var(--border-medium)}.btn-icon-left{margin-right:.5rem;vertical-align:middle}.animations-content{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding:0 2rem 2rem;box-sizing:border-box}.error-message{max-width:1400px;margin:0 auto 2rem;padding:1rem 1.5rem;background:var(--accent-coral);border:3px solid var(--border-accent);border-left:5px solid var(--border-accent);border-radius:8px 12px 10px 14px/10px 8px 12px 9px;color:var(--bg-card);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;box-shadow:3px 3px 0 0 var(--border-medium);transform:rotate(-.3deg)}.error-icon{margin-right:.5rem;vertical-align:middle}.error-retry-btn{margin-left:1rem}.animations-grid{max-width:1400px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.5rem;padding:.5rem 0 2rem}.animation-card{background:var(--bg-card);border-radius:12px 8px 14px 10px/10px 12px 8px 9px;overflow:hidden;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;border:3px solid var(--border-accent);display:flex;flex-direction:column;box-shadow:3px 3px 0 0 var(--border-medium),6px 6px 0 0 var(--border-soft);transform:rotate(.3deg)}.animation-card:nth-child(2n){transform:rotate(-.3deg)}.animation-card:nth-child(3n){transform:rotate(.5deg)}.animation-card:hover{transform:rotate(-.5deg) translateY(-4px);box-shadow:4px 4px 0 0 var(--border-medium),8px 8px 0 0 var(--border-soft);border-color:var(--border-accent)}.animation-thumbnail{position:relative;width:100%;aspect-ratio:16/9;background:var(--bg-paper);display:flex;align-items:center;justify-content:center;overflow:hidden;border-bottom:2px solid var(--border-accent)}.animation-thumbnail img{width:100%;height:100%;object-fit:cover;transition:opacity .1s ease-in-out}.animation-placeholder{display:flex;align-items:center;justify-content:center;opacity:.5;color:var(--text-muted)}.animation-overlay{position:absolute;top:0;right:0;padding:.5rem;opacity:0;transition:opacity .2s}.animation-card:hover .animation-overlay{opacity:1}.btn-icon{background:var(--bg-elevated-strong);border:2px solid var(--border-accent);border-radius:4px 8px 6px 10px/6px 4px 8px 5px;padding:.5rem;cursor:pointer;transition:transform .1s ease,box-shadow .1s ease;display:flex;align-items:center;justify-content:center;box-shadow:1px 1px 0 0 var(--border-medium);transform:rotate(-.2deg)}.btn-icon:hover{background:var(--accent-coral);color:var(--bg-card);transform:rotate(.3deg) scale(1.05);box-shadow:2px 2px 0 0 var(--border-medium)}.delete-btn{color:var(--accent-coral)}.animation-info{padding:1.25rem;flex:1;display:flex;flex-direction:column;gap:.5rem}.animation-info h3{margin:0;font-size:1.05rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.animation-meta{font-size:.9rem;color:var(--text-muted);margin:0 0 .5rem;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.animation-date{font-size:.85rem;color:var(--text-muted);margin:0;font-weight:400}.empty-state{max-width:600px;margin:4rem auto;text-align:center;padding:3rem}.empty-icon{display:inline-flex;align-items:center;justify-content:center;width:80px;height:80px;border-radius:50%;background:var(--bg-card);border:3px solid var(--border-accent);margin:0 auto;box-shadow:2px 2px 0 0 var(--border-medium);transform:rotate(-.3deg)}.empty-icon-spacing{margin-bottom:1rem}.empty-title{font-size:1.2rem;margin-bottom:.5rem;color:var(--text-muted)}.empty-description{margin-bottom:1.5rem;opacity:.8;color:var(--text-muted)}.empty-state p{font-size:1.2rem;margin-bottom:1.5rem;color:var(--text-muted)}@media (max-width: 768px){.animations-header{padding:1.5rem}.animations-header-content{flex-direction:column;align-items:stretch;gap:1rem}.animations-header h1{font-size:1.75rem}.header-actions{flex-direction:column;width:100%}.search-input{width:100%}.animations-grid{padding:0 1rem 1rem;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem}.error-message{margin:1rem;flex-direction:column;align-items:stretch}}.rooms-container{min-height:100vh;width:100%;max-width:100%;background:var(--bg-paper);background-image:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.03) 2px,rgba(0,0,0,.03) 4px),repeating-linear-gradient(90deg,transparent,transparent 2px,rgba(0,0,0,.03) 2px,rgba(0,0,0,.03) 4px);color:var(--text-primary);padding:5.5rem 2rem 2rem;box-sizing:border-box;margin:0;overflow-x:hidden}.rooms-header{max-width:1400px;width:100%;margin:0 auto 2rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;box-sizing:border-box}.rooms-header h1{margin:0;font-size:2.5rem;display:flex;align-items:center;gap:.75rem}.rooms-header-icon{margin-right:.75rem;vertical-align:middle;flex-shrink:0}.header-actions{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.header-actions button{display:flex;align-items:center;gap:.5rem}.btn-with-icon{display:flex;align-items:center;justify-content:center;gap:.5rem}.btn-icon-left{margin-right:.5rem;vertical-align:middle;flex-shrink:0}.btn-primary,.btn-secondary{padding:.75rem 1.5rem;border:3px solid var(--border-accent);border-radius:6px 10px 8px 12px/8px 6px 10px 7px;cursor:pointer;font-weight:600;font-size:1rem;transition:transform .1s ease,box-shadow .1s ease;font-family:inherit;box-shadow:2px 2px 0 0 var(--border-medium);transform:rotate(-.3deg)}.btn-primary{background:var(--accent-purple);color:var(--bg-card)}.btn-primary:hover{background:var(--accent-pink);color:var(--bg-card);transform:rotate(.5deg) translateY(-2px);box-shadow:3px 3px 0 0 var(--border-medium)}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border:3px solid var(--border-accent)}.btn-secondary:hover{background:var(--accent-blue);color:var(--bg-card);transform:rotate(-.3deg) translateY(-2px);box-shadow:3px 3px 0 0 var(--border-medium)}.error-message{max-width:1400px;width:100%;margin:0 auto 2rem;padding:1rem 1.5rem;background:var(--accent-coral);border:3px solid var(--border-accent);border-left:5px solid var(--border-accent);border-radius:8px 12px 10px 14px/10px 8px 12px 9px;color:var(--bg-card);box-sizing:border-box;box-shadow:3px 3px 0 0 var(--border-medium);transform:rotate(-.3deg)}.rooms-content{max-width:1400px;width:100%;margin:0 auto;box-sizing:border-box}.rooms-section{margin-bottom:3rem}.rooms-section:last-child{margin-bottom:0}.rooms-section-title{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin:0 0 1.5rem;padding-bottom:.5rem;border-bottom:3px solid var(--border-accent);transform:rotate(-.2deg)}.rooms-info{background:var(--bg-card);border-radius:12px 8px 14px 10px/10px 12px 8px 9px;padding:2rem;margin-bottom:2rem;border:3px solid var(--border-accent);box-shadow:3px 3px 0 0 var(--border-medium),6px 6px 0 0 var(--border-soft);transform:rotate(.3deg)}.rooms-info h2{margin:0 0 1rem;font-size:1.5rem}.rooms-info p{margin:0;line-height:1.6;color:var(--text-muted)}.rooms-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem}.room-card{background:var(--bg-card);border-radius:12px 8px 14px 10px/10px 12px 8px 9px;padding:2rem;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;border:3px solid var(--border-accent);display:flex;flex-direction:column;align-items:center;text-align:center;position:relative;box-shadow:3px 3px 0 0 var(--border-medium),6px 6px 0 0 var(--border-soft);transform:rotate(.3deg)}.room-card:nth-child(2n){transform:rotate(-.3deg)}.room-card:nth-child(3n){transform:rotate(.5deg)}.room-card:hover{transform:rotate(-.5deg) translateY(-4px);box-shadow:4px 4px 0 0 var(--border-medium),8px 8px 0 0 var(--border-soft);border-color:var(--border-accent)}.room-icon{margin-bottom:1rem;display:flex;align-items:center;justify-content:center}.room-info h3{margin:0 0 .5rem;font-size:1.3rem}.room-meta{font-size:.95rem;color:var(--text-muted);margin:0 0 .5rem}.room-date{font-size:.85rem;color:var(--text-muted);margin:0}.room-delete-btn{position:absolute;top:1rem;right:1rem;background:var(--bg-elevated-strong);border:2px solid var(--border-accent);border-radius:4px 8px 6px 10px/6px 4px 8px 5px;padding:.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .1s ease,box-shadow .1s ease;z-index:10;box-shadow:1px 1px 0 0 var(--border-medium);transform:rotate(-.2deg);color:var(--accent-coral)}.room-delete-btn:hover{background:var(--accent-coral);color:var(--bg-card);border-color:var(--border-accent);transform:rotate(.3deg) scale(1.05);box-shadow:2px 2px 0 0 var(--border-medium)}.room-delete-btn:active{transform:rotate(-1deg) scale(.95);box-shadow:1px 1px 0 0 var(--border-medium)}.empty-state{max-width:600px;margin:4rem auto;text-align:center;padding:3rem;background:var(--bg-card);border-radius:12px 8px 14px 10px/10px 12px 8px 9px;border:3px solid var(--border-accent);box-shadow:3px 3px 0 0 var(--border-medium),6px 6px 0 0 var(--border-soft);transform:rotate(.3deg)}.empty-state p{font-size:1.2rem;margin-bottom:.5rem;color:var(--text-muted)}.empty-subtitle{font-size:1rem!important;margin-bottom:2rem!important;opacity:.8}.empty-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.empty-actions button{display:flex;align-items:center;gap:.5rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:center;z-index:10000}.modal-content{background:var(--bg-card);border-radius:12px 8px 14px 10px/10px 12px 8px 9px;padding:2rem;width:90%;max-width:500px;box-shadow:3px 3px 0 0 var(--border-medium),6px 6px 0 0 var(--border-soft),0 20px 60px #0000004d;border:3px solid var(--border-accent)}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.modal-header h2{margin:0;color:var(--text-primary);font-size:1.5rem}.modal-close{background:var(--bg-elevated);border:2px solid var(--border-accent);font-size:2rem;color:var(--text-muted);cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:4px 8px 6px 10px/6px 4px 8px 5px;transition:transform .1s ease,box-shadow .1s ease,background .2s;box-shadow:1px 1px 0 0 var(--border-medium);transform:rotate(-.2deg)}.modal-close:hover{background:var(--accent-coral);color:var(--bg-card);transform:rotate(.3deg);box-shadow:2px 2px 0 0 var(--border-medium)}.modal-body{margin-bottom:1.5rem}.modal-body label{display:block;margin-bottom:.5rem;color:var(--text-primary);font-weight:500}.modal-body input{width:100%;padding:.75rem;background:var(--bg-card);border:3px solid var(--border-accent);border-radius:6px 10px 8px 12px/8px 6px 10px 7px;color:var(--text-primary);font-size:1rem;box-sizing:border-box;font-family:inherit;box-shadow:2px 2px 0 0 var(--border-medium);transform:rotate(.2deg);transition:transform .1s ease,box-shadow .1s ease}.modal-body input:focus{outline:none;border-color:var(--accent-blue);background:var(--accent-yellow);box-shadow:3px 3px 0 0 var(--border-medium);transform:rotate(-.2deg)}.modal-hint{margin-top:1rem;font-size:.9rem;color:var(--text-muted);line-height:1.5}.modal-footer{display:flex;justify-content:flex-end;gap:1rem}.loading-spinner{text-align:center;padding:4rem;font-size:1.5rem;color:var(--text-muted)}@media (max-width: 768px){.rooms-header{flex-direction:column;align-items:stretch}.header-actions{flex-direction:column}.btn-primary,.btn-secondary{width:100%}.rooms-grid{grid-template-columns:1fr}.empty-actions{flex-direction:column}.empty-actions button{width:100%}}.animation-editor{display:flex;flex-direction:column;height:100%;width:100%}.editor-header-left,.editor-header-right{padding:8px 16px}.editor-playback-controls{position:fixed;bottom:20px;right:20px;z-index:100}.editor-playback-controls .play-btn{background:var(--accent-blue);color:#fff;border:none;border-radius:8px;padding:12px 24px;font-size:16px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;box-shadow:0 4px 12px #0003;transition:transform .2s,box-shadow .2s}.editor-playback-controls .play-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0000004d}.editor-playback-controls .play-btn.playing{background:var(--accent-coral)}.the-secret-game{display:flex;flex-direction:column;height:100vh;width:100%}.game-header{display:flex;justify-content:space-between;align-items:center;padding:12px 24px;background:var(--bg-header);border-bottom:2px solid var(--border-accent)}.game-header .header-left,.game-header .header-controls{display:flex;align-items:center;gap:16px}.game-status{display:flex;align-items:center;gap:12px}.game-status-text{color:#fff;font-size:14px}.header-btn{padding:8px 16px;background:var(--accent-green);color:#fff;border:2px solid var(--border-accent);border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:2px 2px 0 0 var(--border-medium)}.header-btn:hover{background:var(--accent-green-dark, #45a049);transform:translateY(-1px);box-shadow:3px 3px 0 0 var(--border-medium)}.header-btn:active{transform:translateY(0);box-shadow:1px 1px 0 0 var(--border-medium)}.done-btn{background:var(--accent-green);font-weight:600}.game-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:16px}.game-error p{font-size:18px;color:var(--text-primary)}.game-error button{padding:12px 24px;background:var(--accent-blue);color:#fff;border:none;border-radius:8px;font-size:16px;cursor:pointer}.game-error button:hover{background:var(--accent-blue-dark)}.game-lobby{flex:1;display:flex;flex-direction:column;padding:24px;max-width:800px;margin:0 auto;width:100%;overflow-y:auto;overflow-x:hidden}.lobby-content{display:flex;flex-direction:column;gap:24px}.lobby-section{background:var(--bg-card);border:2px solid var(--border-accent);border-radius:8px;padding:24px}.lobby-section h2{margin-top:0;margin-bottom:16px;color:var(--text-primary);font-size:20px}.lobby-info{display:flex;flex-direction:column;gap:8px}.lobby-info p{margin:0;color:var(--text-secondary)}.lobby-info code{background:var(--bg-secondary);padding:4px 8px;border-radius:4px;font-family:monospace;font-size:14px}.players-list{display:flex;flex-direction:column;gap:12px}.player-item{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-secondary);border-radius:6px}.player-number{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--accent-blue);color:#fff;border-radius:50%;font-weight:600;font-size:14px}.player-name{flex:1;color:var(--text-primary);font-weight:500}.player-badge{padding:4px 8px;background:var(--accent-coral);color:#fff;border-radius:4px;font-size:12px;font-weight:600}.invite-section{display:flex;flex-direction:column;gap:12px}.invite-section p{margin:0;color:var(--text-secondary)}.share-link{display:flex;gap:8px}.link-input{flex:1;padding:10px 12px;border:2px solid var(--border-accent);border-radius:6px;background:var(--bg-secondary);color:var(--text-primary);font-family:monospace;font-size:14px}.link-input:focus{outline:none;border-color:var(--accent-blue)}.btn-large{padding:16px 32px;font-size:18px;font-weight:600}.lobby-hint{margin-top:8px;color:var(--text-secondary);font-size:14px;text-align:center}.invite-options{margin-bottom:16px}.friends-invite-list{margin-top:16px;padding:16px;background:var(--bg-secondary);border-radius:6px;border:1px solid var(--border-accent)}.friend-invite-list{display:flex;flex-direction:column}.friends-checkbox-list{display:flex;flex-direction:column;gap:8px;max-height:200px;overflow-y:auto}.friend-checkbox-item{display:flex;align-items:center;gap:8px;padding:8px;cursor:pointer;border-radius:4px;transition:background .2s}.friend-checkbox-item:hover{background:var(--bg-card)}.friend-checkbox-item input[type=checkbox]{width:18px;height:18px;cursor:pointer}.friend-name{color:var(--text-primary);font-weight:500}.games-container{padding:24px;max-width:1200px;margin:0 auto}.games-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.games-header h1{display:flex;align-items:center;gap:12px;font-size:32px;color:var(--text-primary)}.games-header-icon{color:var(--accent-blue)}.games-content{display:flex;flex-direction:column;gap:32px}.games-info{background:var(--bg-card);padding:24px;border-radius:8px;border:2px solid var(--border-accent)}.games-info h2{margin-top:0;margin-bottom:12px;color:var(--text-primary)}.games-info p{color:var(--text-secondary);line-height:1.6}.games-section-title{font-size:24px;color:var(--text-primary);margin-bottom:16px}.games-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;margin-bottom:32px}.game-card{background:var(--bg-card);border:2px solid var(--border-accent);border-radius:8px;padding:24px;cursor:pointer;transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column;align-items:center;text-align:center;gap:16px}.game-card:hover{transform:translateY(-4px);box-shadow:0 8px 16px #0000001a;border-color:var(--accent-blue)}.game-icon{font-size:48px;margin-bottom:8px}.game-info h3{margin:0 0 8px;color:var(--text-primary);font-size:20px}.game-description{color:var(--text-secondary);font-size:14px;line-height:1.5;margin:0}.games-list{display:flex;flex-direction:column;gap:12px}.game-item{background:var(--bg-card);border:2px solid var(--border-accent);border-radius:8px;padding:16px;cursor:pointer;transition:transform .2s,box-shadow .2s;display:flex;align-items:center;gap:16px}.game-item:hover{transform:translate(4px);box-shadow:0 4px 8px #0000001a;border-color:var(--accent-blue)}.game-item-icon{font-size:32px}.game-item-info{flex:1}.game-item-info h3{margin:0 0 4px;color:var(--text-primary);font-size:18px}.game-item-meta{margin:0;font-size:14px;color:var(--text-secondary)}.error-message{background:#ffebee;color:#c62828;padding:12px 16px;border-radius:4px;margin-bottom:16px}.loading-spinner{text-align:center;padding:48px;color:var(--text-secondary);font-size:18px}.games-invitations{margin-bottom:32px}.invitations-list{display:flex;flex-direction:column;gap:16px}.invitation-item{background:var(--bg-card);border:2px solid var(--accent-blue);border-radius:8px;padding:20px;display:flex;justify-content:space-between;align-items:flex-start;gap:20px}.invitation-info{flex:1}.invitation-header{display:flex;align-items:center;gap:16px;margin-bottom:12px}.invitation-icon{font-size:32px}.invitation-header h3{margin:0 0 4px;color:var(--text-primary);font-size:20px}.invitation-meta{margin:0;color:var(--text-secondary);font-size:14px}.invitation-details{margin-top:12px;padding-top:12px;border-top:1px solid var(--border-accent);display:flex;flex-direction:column;gap:4px}.invitation-details p{margin:0;color:var(--text-secondary);font-size:14px}.invitation-actions{display:flex;flex-direction:column;gap:8px;min-width:100px}*{margin:0;padding:0;box-sizing:border-box}svg.defs-only{position:absolute;width:0;height:0;overflow:hidden}:root{--bg-base: #1a1a1a;--bg-elevated: #2d2d2d;--bg-elevated-strong: #3a3a3a;--bg-paper: #f5f5e8;--bg-card: #ffffff;--border-soft: #4a4a4a;--border-medium: #6b6b6b;--border-strong: #8c8c8c;--border-accent: #2c2c2c;--text-primary: #1a1a1a;--text-muted: #5a5a5a;--text-light: #8a8a8a;--accent-coral: #ff6b6b;--accent-blue: #4dabf7;--accent-yellow: #ffd43b;--accent-green: #51cf66;--accent-purple: #845ef7;--accent-orange: #ff922b;--accent-pink: #f06595;--accent-cyan: #3bc9db;--shadow-sketch: 3px 3px 0px 0px #2c2c2c, 6px 6px 0px 0px #1a1a1a;--shadow-soft: 4px 4px 8px #1a1a1a}body{font-family:Comic Neue,Comic Sans MS,Marker Felt,Chalkboard,Kalam,Caveat,cursive,sans-serif;background:#f0f0e8;background-image:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.03) 2px,rgba(0,0,0,.03) 4px),repeating-linear-gradient(90deg,transparent,transparent 2px,rgba(0,0,0,.03) 2px,rgba(0,0,0,.03) 4px);min-height:100vh;padding:0;margin:0;width:100%;overflow-x:hidden;color:var(--text-primary)}html{width:100%;overflow-x:hidden}#root{width:100%;min-width:0;min-height:100vh;height:auto;display:flex;flex-direction:column;margin:0;padding:0}.hand-drawn-border{border:3px solid var(--border-accent);border-radius:8px 12px 10px 14px/10px 8px 12px 9px;position:relative;box-shadow:var(--shadow-sketch)}.hand-drawn-border:before{content:"";position:absolute;top:-2px;left:-2px;right:-2px;bottom:-2px;border:1px solid var(--border-medium);border-radius:8px 12px 10px 14px/10px 8px 12px 9px;pointer-events:none}.sketchy-button{border:3px solid var(--border-accent);border-radius:6px 10px 8px 12px/8px 6px 10px 7px;background:var(--bg-card);position:relative;transform:rotate(-.5deg);transition:transform .1s ease,box-shadow .1s ease;box-shadow:var(--shadow-soft)}.sketchy-button:hover{transform:rotate(.5deg) translateY(-2px);box-shadow:5px 5px 10px #1a1a1a}.sketchy-button:active{transform:rotate(-1deg) translateY(0);box-shadow:2px 2px 4px #1a1a1a}.hand-drawn-card{background:var(--bg-card);border:3px solid var(--border-accent);border-radius:12px 8px 14px 10px/10px 12px 8px 9px;box-shadow:var(--shadow-sketch);position:relative;transform:rotate(.3deg)}.hand-drawn-card:nth-child(2n){transform:rotate(-.3deg)}.rough-text{text-shadow:1px 1px 0px var(--text-primary),2px 2px 0px rgba(0,0,0,.1);letter-spacing:.5px}
