body{font-family:Georgia,serif;color:#333;line-height:1.6;margin:0;padding:0}.app{min-height:100vh;padding:20px;transition:background-color .3s ease}.container{max-width:600px;width:100%;margin:0 auto;text-align:center}h1,h2,h3,h4,h5,h6{color:#555;font-family:Playfair Display,serif}.message{font-size:1.2em;margin-bottom:20px}.carousel{position:relative;width:100%}.carousel img{width:200px;height:200px;object-fit:cover;border-radius:50%;border:3px solid #555;box-shadow:0 2px 8px #0000001a}@media (max-width: 600px){.carousel img{width:140px;height:140px}}.controls button{font-size:1.5em;border:none;padding:10px 20px;margin:0 10px;border-radius:8px;cursor:pointer;transition:background .3s ease}@media (max-width: 600px){h1{font-size:1.5em}.message{font-size:1em}button{padding:8px 12px;font-size:1em}}.spotify-player{margin:20px 0}.color-picker{display:flex;justify-content:center;gap:15px;margin:20px auto}.color-circle{width:40px;height:40px;border-radius:50%;border:3px solid transparent;cursor:pointer;transition:transform .2s ease,border-color .2s ease}.color-circle:hover{transform:scale(1.1)}.color-circle.selected{border-color:#555}.arrow-btn{background:none;border:none;color:#555;font-size:2rem;cursor:pointer;padding:0 15px;-webkit-user-select:none;user-select:none;transition:color .3s ease}.arrow-btn:hover{color:#333}.line-color-b9e2f8{color:#b9e2f8}.line-color-c9cfe9{color:#c9cfe9}.line-color-e9f6f9{color:#e9f6f9}.hidden-lines p{font-family:serif;font-size:1.2em;margin:.2em 0;transition:color .3s ease;text-align:center}@media (max-width: 600px){header{display:block;font-size:1.5rem;color:#555}}.tab-content{display:none;position:relative}.tab-content.active{display:block}.tabs{display:flex;max-width:600px;width:100%;margin:0 auto;box-sizing:border-box;align-items:center;justify-content:space-between}.tab{flex:1 1 0;min-width:0;text-align:center;padding:14px 20px;font-family:Georgia,serif;font-size:1.1em;cursor:pointer;background:none;border:none;transition:background .2s,color .2s}.tab:hover{background-color:#00000008}.tab.active{background:none;border-bottom:3px solid #2c3e50;color:#2c3e50;font-weight:600}.countdown-timer{display:flex;justify-content:center;gap:20px;font-family:Georgia,serif}.countdown-timer div{text-align:center;color:#333}.countdown-timer span{font-size:2.5em;font-weight:700;display:block}.countdown-timer label{font-size:.9em;color:#777}@media (max-width: 600px){.countdown-header{flex-direction:row;gap:8px;align-items:flex-start;text-align:left;justify-content:flex-start}.countdown-header h3{text-align:left;margin:0;font-size:1.1em}.countdown-timer{flex-direction:row;align-items:center;gap:8px}.countdown-timer span{font-size:1.8em}.countdown-timer label{font-size:.7em}.form-actions{flex-direction:column}.pagination{flex-direction:column;gap:12px}}.carousel-text{margin:20px 0;line-height:1.8}.carousel-text p{margin-bottom:15px}.carousel-controls{display:flex;justify-content:center;align-items:center;gap:20px;margin:20px 0}.page-number{font-family:Georgia,serif;color:#555;font-size:1.1em}.countdown-controls{margin:20px 0}.add-timer-btn{background:#555;color:#fff;border:none;padding:12px 24px;border-radius:8px;cursor:pointer;font-size:1em;font-family:Georgia,serif;transition:background .3s ease}.add-timer-btn:hover{background:#333}.modal-backdrop,.game-modal-backdrop,.leaderboard-modal-backdrop,.logout-modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#2c3e50cc;z-index:1000;display:flex;flex-direction:column;align-items:center;justify-content:center;animation:fadeInModalBg .2s}@keyframes fadeInModalBg{0%{opacity:0}to{opacity:1}}.add-timer-form{background:#fff;padding:30px;border-radius:12px;box-shadow:0 8px 32px #0003;margin:0;position:relative;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.add-timer-form h3{margin-top:0;margin-bottom:20px;text-align:center;color:#555}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:700;color:#555;font-family:Georgia,serif}.form-group input{width:100%;padding:12px;border:2px solid #e0e0e0;border-radius:6px;font-size:1em;font-family:Georgia,serif;box-sizing:border-box;transition:border-color .3s ease}.form-group input:focus{outline:none;border-color:#555}.form-actions{display:flex;justify-content:center;gap:15px;margin-top:30px}.confirm-btn{background:#555;color:#fff;border:none;padding:12px 24px;border-radius:6px;cursor:pointer;font-size:1em;font-family:Georgia,serif;transition:background .3s ease}.confirm-btn:hover{background:#333}.cancel-btn{background:#e0e0e0;color:#555;border:none;padding:12px 24px;border-radius:6px;cursor:pointer;font-size:1em;font-family:Georgia,serif;transition:background .3s ease}.cancel-btn:hover{background:#ccc}.countdown-list{margin:20px 0}.countdown-item{position:relative;background:#ffffffe6;border-radius:12px;padding:28px 20px 20px;margin-bottom:16px;box-shadow:0 2px 8px #0000001a;transition:transform .2s ease,box-shadow .2s ease}.countdown-item:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000026}.countdown-item.inactive{opacity:.6}.countdown-header{display:flex;flex-direction:row;justify-content:space-between;align-items:flex-start;margin-bottom:8px;padding:0;text-align:left;width:100%}.countdown-header h3{margin:0;color:#555;font-size:1.3em;font-family:Playfair Display,serif;font-weight:600;text-align:left;line-height:1.2}.countdown-actions{position:static;margin-left:12px;display:flex;align-items:flex-start}.toggle-btn,.delete-btn,.edit-btn{background:none;border:none;font-size:1.2em;cursor:pointer;padding:4px;border-radius:4px;transition:background .2s ease;color:#2c3e50}.toggle-btn:hover,.delete-btn:hover,.edit-btn:hover{background:#0000001a}.edit-btn svg{stroke:#2c3e50}.pagination-btn{background:#555;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:.9em;font-family:Georgia,serif;transition:background .3s ease}.pagination-btn:hover:not(:disabled){background:#333}.pagination-btn:disabled{background:#ccc;cursor:not-allowed}.page-info{font-family:Georgia,serif;color:#555;font-size:.9em}.loading{text-align:center;padding:40px;font-family:Georgia,serif;color:#555;font-size:1.1em}@media (max-width: 600px){.countdown-header{flex-direction:row;gap:8px;align-items:center;text-align:center;justify-content:center}.countdown-header h3{text-align:center;margin:0}.form-actions{flex-direction:column}.pagination{gap:12px;margin-top:16px;padding-top:16px;flex-direction:row}}.form-group select{width:100%;padding:12px;border:2px solid #e1e5e9;border-radius:8px;font-size:16px;background-color:#fff;transition:border-color .3s ease}.form-group select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.countdown-info{margin:15px 0;padding:10px;background-color:#ffffff1a;border-radius:8px;border-left:4px solid #007bff}.countdown-info p{margin:5px 0;font-size:14px;color:#333}.countdown-info .target-date{font-weight:500;color:#2c3e50}.countdown-info .timezone-info{color:#7f8c8d;font-style:italic}.countdown-info small{font-size:12px}.confirm-btn.disabled,.confirm-btn:disabled{background-color:#ccc;color:#666;cursor:not-allowed;opacity:.6;transition:all .3s ease}.confirm-btn.disabled:hover,.confirm-btn:disabled:hover{background-color:#ccc;transform:none;box-shadow:none}.form-group.error input,.form-group.error select{border-color:#e74c3c;box-shadow:0 0 0 3px #e74c3c1a}.form-group.error label{color:#e74c3c;font-weight:600}.error-message{color:#e74c3c;font-size:12px;margin-top:4px;display:block;font-weight:500}.empty-state{text-align:center;padding:60px 20px;background-color:#ffffff1a;border-radius:12px;margin:20px 0}.empty-icon{font-size:48px;margin-bottom:20px;opacity:.7}.empty-state h3{margin:0 0 10px;color:#2c3e50;font-size:24px;font-weight:600}.empty-state p{color:#7f8c8d;font-size:16px;line-height:1.5;max-width:400px;margin:0 auto 30px}.empty-state .add-timer-btn{margin:0;font-size:16px;padding:12px 24px}.close-form-btn,.leaderboard-close-btn{position:absolute;top:12px;right:12px;background:none;border:none;font-size:28px;color:#7f8c8d;cursor:pointer;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s,color .2s;z-index:10}.close-form-btn:hover,.leaderboard-close-btn:hover{background:#e1e5e9;color:#2c3e50}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background:linear-gradient(135deg,#b9e2f8,#e9f6f9);font-family:Georgia,serif}.loading-spinner{width:40px;height:40px;border:4px solid rgba(255,255,255,.3);border-top:4px solid #555;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.login-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#b9e2f8,#e9f6f9);padding:20px}.login-container{background:#fff;padding:40px;border-radius:12px;box-shadow:0 8px 32px #0000001a;width:100%;max-width:400px;text-align:center}.login-header h1{margin:0 0 10px;color:#2c3e50;font-family:Georgia,serif;font-size:2.5em}.login-header p{margin:0 0 30px;color:#7f8c8d;font-size:1.1em}.login-form .form-group{margin-bottom:20px;text-align:left}.login-form label{display:block;margin-bottom:8px;color:#2c3e50;font-weight:600;font-family:Georgia,serif}.login-form input{width:100%;padding:12px;border:2px solid #e1e5e9;border-radius:8px;font-size:16px;transition:border-color .3s ease;box-sizing:border-box}.login-form input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.login-btn{width:100%;background:#555;color:#fff;border:none;padding:14px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background .3s ease;margin-top:10px}.login-btn:hover:not(:disabled){background:#333}.login-btn:disabled{background:#ccc;cursor:not-allowed}.login-footer{margin-top:30px;padding-top:20px;border-top:1px solid #e1e5e9}.login-footer p{margin:0;color:#7f8c8d;font-size:14px}.toggle-auth-btn{background:none;border:none;color:#007bff;cursor:pointer;text-decoration:underline;margin-left:5px;font-size:14px}.toggle-auth-btn:hover:not(:disabled){color:#0056b3}.toggle-auth-btn:disabled{color:#ccc;cursor:not-allowed}.app-header{background:#ffffff1a;padding:15px 20px;border-bottom:1px solid rgba(255,255,255,.2)}.user-info{display:flex;justify-content:flex-end;align-items:center;gap:15px;font-family:Georgia,serif}.user-info span{color:#2c3e50;font-weight:500}.sign-out-btn{background:#fff3;color:#2c3e50;border:1px solid rgba(255,255,255,.3);padding:8px 16px;border-radius:6px;cursor:pointer;font-family:Georgia,serif;font-size:14px;transition:all .3s ease}.sign-out-btn:hover{background:#ffffff4d;border-color:#ffffff80}.user-select-row{display:flex;justify-content:center;gap:40px;margin:40px 0 0}.user-circle{display:flex;flex-direction:column;align-items:center;border:none;background:none;cursor:pointer;padding:0;transition:box-shadow .2s,transform .2s;outline:none;width:130px;height:auto;position:relative}.user-circle.selected,.user-circle:focus{box-shadow:0 0 0 4px #2c3e50aa;transform:scale(1.05)}.user-avatar-bg{display:flex;align-items:center;justify-content:center;width:90px;height:90px;border-radius:50%;margin:0 auto 8px;box-shadow:0 1px 4px #00000014;border:2px solid #fff;overflow:hidden}.user-avatar-img{width:82px;height:82px;border-radius:50%;object-fit:cover;display:block}.user-avatar-fallback{width:82px;height:82px;border-radius:50%;background:none;color:#555;font-size:3em;display:flex;align-items:center;justify-content:center}.user-name{font-size:1.1em;color:#2c3e50;font-weight:600;margin:0;font-family:Georgia,serif;text-align:center;line-height:1.2}.modal-question{position:relative;background:#fff;border-radius:22px;box-shadow:0 8px 32px #2c3e502e;padding:36px 32px 28px;min-width:320px;max-width:90vw;text-align:center;display:flex;flex-direction:column;align-items:center}.modal-question h3{margin-top:0;margin-bottom:12px;color:#2c3e50;font-family:Georgia,serif;font-size:1.5em}.modal-question p{color:#7f8c8d;margin-bottom:18px;font-size:1.1em}.modal-question input[type=text],.question-input{width:100%;padding:12px;border:2px solid #e1e5e9;border-radius:10px;font-size:1em;margin-bottom:12px;box-sizing:border-box;transition:border-color .3s;font-family:inherit}.modal-question input[type=text]:focus,.question-input:focus{outline:none;border-color:#2c3e50;box-shadow:0 0 0 3px #2c3e5022}.modal-actions{display:flex;gap:16px;justify-content:center;margin-top:8px}.login-container.expanded{transition:box-shadow .3s,min-height 1.25s cubic-bezier(.4,2,.6,1);min-height:480px}.question-section{width:100%;overflow:hidden;transition:max-height 1.25s cubic-bezier(.4,2,.6,1);margin-top:10px;display:flex;flex-direction:column;align-items:center}.input-send-row{width:100%;display:flex;align-items:center;position:relative}.send-btn svg circle{stroke:#2c3e50}.send-btn svg path{stroke:#2c3e50}.send-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:#007bff;font-size:1.5em;cursor:pointer;padding:0 4px;display:flex;align-items:center;justify-content:center;height:32px;width:32px;border-radius:50%;transition:background .2s}.send-btn:active,.send-btn:focus{background:#00000012!important;outline:none}.login-separator{width:100%;border:none;border-top:1.5px solid #e1e5e9;margin:32px 0 0}.typewriter-question{width:100%;background:none;display:flex;flex-direction:column;align-items:center;padding:0 0 8px}.typewriter-question h3{margin:0 0 10px;color:#2c3e50;font-family:Georgia,serif;font-size:1.3em}.typewriter-text{min-height:1.5em;font-size:1.1em;color:#7f8c8d;margin-bottom:18px;font-family:inherit;letter-spacing:.01em;white-space:pre-line;width:100%;text-align:center}@keyframes wobble{0%{transform:translate(0)}15%{transform:translate(-8px)}30%{transform:translate(6px)}45%{transform:translate(-6px)}60%{transform:translate(4px)}75%{transform:translate(-4px)}to{transform:translate(0)}}.wobble{animation:wobble .4s cubic-bezier(.36,.07,.19,.97) both}.question-input.wobble{border-color:#e74c3c;background:#fdeaea}.user-select-row.collide{justify-content:center;gap:0;position:relative}.user-select-row.collide .user-circle{transition:transform 1.1s cubic-bezier(.4,2,.6,1),opacity .3s;z-index:2}.user-select-row.collide .user-circle-0{transform:translate(60px)}.user-select-row.collide .user-circle-1{transform:translate(-60px)}.user-select-row.collide .user-name{opacity:0;transition:opacity .2s}.celebration-center{display:flex;align-items:center;justify-content:center;min-height:180px;margin-top:40px}.celebration-img{width:90px;height:90px;animation:popIn .7s cubic-bezier(.4,2,.6,1)}@keyframes popIn{0%{transform:scale(.5);opacity:0}60%{transform:scale(1.15);opacity:1}to{transform:scale(1);opacity:1}}.user-select-row.hide .user-circle{opacity:0;pointer-events:none;transition:opacity .4s .1s}.center-celebration-circle{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:10;display:flex;align-items:center;justify-content:center;width:120px;height:120px;background:#fff;border-radius:50%;box-shadow:0 2px 12px #2c3e501a;animation:popIn .7s cubic-bezier(.4,2,.6,1)}.center-celebration-img{width:70px;height:70px;border-radius:50%;object-fit:cover;opacity:0;animation:fadeInCelebration .7s .1s forwards,expandCelebration 3s cubic-bezier(.4,2,.6,1) .7s forwards}.user-circle.final-center{z-index:10!important;position:absolute!important;left:50%!important;top:50%!important;transform:translate(-50%,-50%)!important;transition:none!important}.center-celebration-img.expand{animation:expandCelebration 3s cubic-bezier(.4,2,.6,1) forwards}@keyframes expandCelebration{0%{transform:scale(1)}to{transform:scale(4)}}.fade-all{transition:opacity .7s}.fade-all.fade-out{opacity:0;pointer-events:none}.center-celebration-fadein{display:flex;align-items:center;justify-content:center;min-height:320px;height:100%;width:100%;position:absolute;left:0;top:0;z-index:20}.center-fadein-bg{width:90px;height:90px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 12px #2c3e501a;animation:popIn .7s cubic-bezier(.4,2,.6,1),expandCelebration 2s cubic-bezier(.4,2,.6,1) .7s forwards}.center-fadein-img{width:70px;height:70px;border-radius:50%;object-fit:cover;opacity:0;animation:fadeInCelebration .7s .1s forwards,expandCelebration 5s cubic-bezier(.4,2,.6,1) .7s forwards}@keyframes fadeInCelebration{0%{opacity:0}to{opacity:1}}.tabbar-right{display:flex;align-items:center;margin-left:auto;gap:12px}.tabbar-avatar{width:38px;height:38px;border-radius:50%;object-fit:cover;border:2px solid #e1e5e9;box-shadow:0 1px 4px #00000014}.tabbar-menu-container{position:relative}.tabbar-hamburger,.tabbar-hamburger-btn,.hamburger-bar,.tabbar-dropdown.hamburger-dropdown{display:none!important}.tabs,.tabbar-right,.tabbar-menu-container{overflow:visible!important}.countdown-item{position:relative}.countdown-avatar{position:absolute;bottom:10px;left:10px;width:36px;height:36px;border-radius:50%;object-fit:cover;border:2px solid #e1e5e9;box-shadow:0 1px 4px #00000014;background:#fff;z-index:1}.countdown-created{position:absolute;right:10px;bottom:10px;background:#ffffffe6;color:#5559;font-size:.4em;padding:2px 6px;border-radius:4px;z-index:2}.delete-btn-form{background:#e74c3c;color:#fff;border:none;padding:12px 24px;border-radius:6px;cursor:pointer;font-size:1em;font-family:Georgia,serif;transition:background .3s ease;display:flex;align-items:center;gap:8px}.delete-btn-form:hover{background:#c0392b}.delete-btn-form svg{stroke:#fff}.countdown-edit-abs{position:absolute;top:16px;right:16px;z-index:3;background:none;border:none;padding:0;cursor:pointer;display:flex;align-items:center;justify-content:center}@media (max-width: 600px){.countdown-item{padding:20px 8px 12px}.countdown-header h3{font-size:1.1em}.countdown-edit-abs{top:8px;right:8px}}.thoughts-chat{width:100%;display:flex;flex-direction:column;gap:24px;margin:32px 0 40px;align-items:stretch}.thought-bubble{width:100%;display:flex;align-items:flex-end;position:relative;min-width:0}.thought-bubble-akash{flex-direction:row-reverse;justify-content:flex-end}.thought-bubble-hannah{flex-direction:row;justify-content:flex-start}.thought-bubble-content{flex:1 1 auto;width:auto;min-width:120px;max-width:420px;margin:0 8px;background:#f5f7fa!important;color:#222!important;border-radius:18px 18px 18px 6px!important;padding:18px 22px!important;font-size:1.08em!important;box-shadow:0 2px 8px #0000000f!important;max-width:80%!important;word-break:break-word!important;border:none!important}.thought-bubble-akash .thought-bubble-content{background:#b8f5c7!important;color:#2c3e50!important;border-radius:18px 18px 6px!important}.thought-bubble-hannah .thought-bubble-content{background:#f0f2f5!important;color:#2c3e50!important;border-radius:18px 18px 18px 6px!important}.thought-bubble-message p{margin:0 0 .7em;line-height:1.6}.thought-bubble-timestamp{font-size:.75em;color:#888;margin-top:8px;font-style:italic;text-align:left}.thought-bubble-akash .thought-bubble-timestamp{text-align:right}.thought-bubble-hannah .thought-bubble-timestamp{text-align:left}.thought-bubble-avatar.left{width:38px;height:38px;border-radius:50%;object-fit:cover;margin-left:12px;margin-bottom:0;box-shadow:0 1px 4px #00000014;background:#fff;border:2px solid #e0e0e0}.thought-bubble-avatar.right{width:38px;height:38px;border-radius:50%;object-fit:cover;margin-right:12px;margin-bottom:0;box-shadow:0 1px 4px #00000014;background:#fff;border:2px solid #e0e0e0}.thought-bubble{max-width:98vw}@media (max-width: 600px){.thoughts-chat{gap:16px;margin:18px 0 24px}.thought-bubble-content{max-width:95%;min-width:0;margin:0 4px}.thought-bubble-avatar.left{width:30px;height:30px;margin-left:7px}.thought-bubble-avatar.right{width:30px;height:30px;margin-right:7px}.thought-bubble{width:100%}.thought-bubble-timestamp{font-size:.7em;margin-top:6px}}.thought-bubble-message p:last-child{margin-bottom:0}.thought-bubble-message.clickable{cursor:pointer;transition:opacity .2s ease}.thought-bubble-message.clickable:hover{opacity:.8}.read-more-text{color:#6c757d;font-size:.85em;font-weight:500;cursor:pointer;margin-top:8px;margin-bottom:4px;text-decoration:underline;transition:color .2s ease}.read-more-text:hover{color:#495057}.message-modal{background:#fff;border-radius:12px;padding:24px;max-width:90vw;max-height:80vh;width:600px;position:relative;box-shadow:0 10px 30px #0000004d;animation:modalSlideIn .3s ease-out}.message-modal h3{margin:0 0 20px;color:#2c3e50;font-family:Playfair Display,serif;font-size:1.4em}.message-modal-content{max-height:60vh;overflow-y:auto;padding-right:10px;line-height:1.6;font-size:1.1em}.message-modal-content p{margin:0 0 1em}.message-modal-content p:last-child{margin-bottom:0}@media (max-width: 600px){.message-modal{width:85vw;padding:20px;max-height:85vh}.message-modal h3{font-size:1.1em;margin-bottom:15px}.message-modal-content{max-height:70vh;font-size:.95em;line-height:1.5}}.message-input-container{margin:20px 0 30px;width:100%}.message-input-wrapper{display:flex;width:100%}.input-with-icon{position:relative;width:100%;display:flex;align-items:flex-end}.message-input{width:100%;padding:12px 50px 12px 16px;border:2px solid #e1e5e9;border-radius:12px;font-family:Georgia,serif;font-size:1em;line-height:1.5;resize:none;min-height:1.5em;max-height:200px;overflow-y:auto;transition:border-color .2s ease;background:#fff;box-sizing:border-box}.message-input:focus{outline:none;border-color:#000}.message-input:disabled{background:#f8f9fa;color:#6c757d;cursor:not-allowed}.input-with-icon .send-btn{position:absolute;right:8px;bottom:8px;background:none;border:none;padding:0;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s ease;z-index:2}.input-with-icon .send-btn:hover:not(:disabled){transform:scale(1.1)}.input-with-icon .send-btn:disabled{opacity:.5;cursor:not-allowed}.input-with-icon .send-btn:disabled:hover{transform:none}@media (max-width: 600px){.message-input{min-height:50px;font-size:.95em;padding-right:45px}.input-with-icon .send-btn{right:6px;bottom:6px}.input-with-icon .send-btn svg{width:20px;height:20px}}.loading-inline{display:flex;justify-content:center;align-items:center;margin-bottom:16px}.end-of-chat-history{text-align:center;padding:20px;color:#7f8c8d;font-style:italic;font-size:14px}.game-section{margin-bottom:40px}.game-section h2{color:#2c3e50;margin-bottom:10px;font-family:Georgia,serif}.game-section p{color:#7f8c8d;margin-bottom:20px;line-height:1.5}.theme-section{margin-top:40px;padding-top:30px;border-top:1px solid rgba(127,140,141,.2)}.theme-section h3{color:#2c3e50;margin-bottom:15px;font-family:Georgia,serif}.slider-puzzle{display:flex;flex-direction:column;align-items:center;gap:20px;max-width:500px;margin:0 auto}.puzzle-info{display:flex;justify-content:space-between;align-items:center;width:100%;padding:15px;background:#ffffff1a;border-radius:12px;box-shadow:0 2px 10px #0000001a}.stats{display:flex;gap:20px;font-family:Georgia,serif;font-weight:600;color:#2c3e50}.stats span{background:#fffc;padding:8px 12px;border-radius:6px;font-size:14px}.controls{display:flex;gap:10px;width:95%;justify-content:space-between}.controls .puzzle-btn{border:1px solid #000!important}.puzzle-btn{background:transparent;color:#fff;padding:4px 8px;border-radius:6px;cursor:pointer;font-size:12px;font-family:Georgia,serif;font-weight:600;transition:all .3s ease;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.puzzle-btn:hover:not(:disabled){background:#333;transform:translateY(-1px);box-shadow:0 4px 12px #0003}.puzzle-btn:active,.puzzle-btn:focus{background:#00000012!important;outline:none}.puzzle-btn:disabled{background:#ccc;color:#666;cursor:not-allowed;transform:none;box-shadow:none}.puzzle-container{position:relative;width:400px;height:400px;background:#ffffff1a;border-radius:12px;padding:10px;box-shadow:0 4px 20px #00000026}.puzzle-grid{display:grid;grid-template-columns:repeat(4,100px);grid-template-rows:repeat(4,100px);width:400px;height:400px;background:#ddd;border-radius:8px;overflow:hidden}.puzzle-tile{position:relative;background:#fff;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;font-family:Georgia,serif;font-weight:700;font-size:18px;color:#2c3e50;-webkit-user-select:none;user-select:none}.puzzle-tile:hover:not(.empty){transform:scale(.98);box-shadow:inset 0 0 0 2px #007bff}.puzzle-tile.empty{background:transparent;border:2px dashed #ccc;cursor:default}.puzzle-tile.won{animation:celebrate .6s ease-in-out}@keyframes celebrate{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.tile-number{position:absolute;top:5px;left:5px;background:#000000b3;color:#fff;padding:2px 6px;border-radius:4px;font-size:12px;font-weight:700}.win-message{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;padding:30px;border-radius:12px;box-shadow:0 10px 40px #0000004d;text-align:center;z-index:1000;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translate(-50%,-60%)}to{opacity:1;transform:translate(-50%,-50%)}}.win-message h3{margin:0 0 15px;color:#2c3e50;font-family:Georgia,serif;font-size:24px}.win-message p{margin:0 0 20px;color:#7f8c8d;font-size:16px}.best-score{color:#f39c12!important;font-weight:700;font-size:18px!important;margin:10px 0 20px!important}@media (max-width: 600px){.slider-puzzle{max-width:100%}.puzzle-container{width:300px;height:300px}.puzzle-grid{grid-template-columns:repeat(4,75px);grid-template-rows:repeat(4,75px);width:300px;height:300px}.puzzle-info{flex-direction:column;gap:15px;text-align:center}.stats,.controls{justify-content:center}.puzzle-tile{font-size:14px}.tile-number{font-size:10px;padding:1px 4px}.win-message{width:90%;max-width:300px;padding:20px}.win-message h3{font-size:20px}.win-message p{font-size:14px}}.games-grid{display:flex;flex-wrap:wrap;gap:32px;margin:32px 0 40px;justify-content:flex-start}.game-tile{background:#fff;border-radius:16px;box-shadow:0 4px 24px #2c3e5014;width:220px;height:260px;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;cursor:pointer;transition:box-shadow .2s,transform .2s;position:relative;overflow:hidden;border:2px solid #e1e5e9}.game-tile:hover{box-shadow:0 8px 32px #2c3e502e;transform:translateY(-2px) scale(1.03);border-color:#b9e2f8}.game-tile-img{width:100%;height:140px;object-fit:cover;border-top-left-radius:14px;border-top-right-radius:14px;background:#eee}.game-tile-title{font-family:Georgia,serif;font-size:1.2em;font-weight:700;color:#2c3e50;margin:16px 0 6px;text-align:center}.game-tile-desc{color:#7f8c8d;font-size:.98em;text-align:center;padding:0 12px}.game-modal{background:#f8fafd;border-radius:18px;box-shadow:0 8px 40px #2c3e502e;padding:32px 24px 24px;min-width:340px;max-width:98vw;position:relative;animation:popInModal .25s}@keyframes popInModal{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.game-modal .close-form-btn{position:absolute;top:18px;right:18px;z-index:10;background:none;border:none;font-size:28px;color:#7f8c8d;cursor:pointer;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s}.game-modal .close-form-btn:hover{background:#e1e5e9;color:#2c3e50}@media (max-width: 600px){.games-grid{flex-direction:column;gap:20px;align-items:center;width:100%}.game-tile{width:92vw;max-width:340px;min-width:0;height:auto;margin:0 auto 16px;padding:0}.game-tile-img{height:80px}.game-tile-title{font-size:1.08em;margin:12px 0 4px}.game-tile-desc{font-size:.97em;padding:0 8px 12px}.game-modal{min-width:0;width:85vw;padding:12px 2vw}}.more-tab{position:relative;cursor:pointer;-webkit-user-select:none;user-select:none}.more-tab:focus{outline:none;background-color:#00000008}.more-dropdown{position:absolute;left:50%;transform:translate(-50%);top:100%;margin-top:8px;min-width:160px;background:#fff;border-radius:10px;box-shadow:0 4px 24px #2c3e501f;z-index:1001;padding:8px 0;animation:fadeInModalBg .18s}@media (max-width: 600px){.more-dropdown{min-width:120px;left:50%;transform:translate(-50%);top:100%;margin-top:6px}}.tabbar-avatar-btn{background:none;border:none;padding:0;margin:0;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:box-shadow .2s}.tabbar-avatar-btn:focus,.tabbar-avatar-btn:hover{box-shadow:0 0 0 3px #2c3e50aa;outline:none}.tabbar-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;background:#eee;box-shadow:0 2px 8px #2c3e5014}.logout-modal{background:#fff;border-radius:16px;box-shadow:0 8px 40px #2c3e502e;padding:32px 28px 24px;min-width:320px;max-width:98vw;text-align:center;animation:popInModal .22s}.logout-modal h3{margin:0 0 18px;color:#2c3e50;font-family:Georgia,serif;font-size:1.25em}.logout-modal-actions{display:flex;gap:18px;justify-content:center;margin-top:18px}@media (max-width: 600px){.logout-modal{min-width:0;width:85vw;padding:16px 2vw}.logout-modal-actions{flex-direction:column;gap:10px}}.more-dropdown .tabbar-dropdown-item{background:#fff;color:#2c3e50;font-family:Georgia,serif;font-size:1em;text-align:left;padding:10px 18px;cursor:pointer;border:none;width:100%;border-radius:6px;transition:background .18s,color .18s}.more-dropdown .tabbar-dropdown-item:hover{background:#f2f2f2;color:#2c3e50}@media (max-width: 600px){.tabs{width:100%;box-sizing:border-box;padding:0 4vw;overflow-x:auto;flex-wrap:nowrap;display:flex;align-items:center}.tab{font-size:1em;padding:10px 8px;min-width:0;flex:1 1 0;text-align:center}.tabbar-right{gap:6px;margin-left:4px}.tabbar-avatar{width:30px;height:30px}.more-tab{font-size:1em;padding:10px 8px;min-width:0;flex:1 1 0;text-align:center}}.leaderboard-modal{background:#fff;border-radius:16px;box-shadow:0 8px 40px #2c3e502e;padding:32px 28px 24px;min-width:320px;max-width:98vw;text-align:center;animation:popInModal .22s;position:relative}@media (max-width: 600px){.leaderboard-modal{min-width:0;width:85vw;padding:16px 2vw}}.modal-close-row{display:flex;justify-content:center;margin-top:12px}.modal-close-btn{background:#fff;border:1px solid #ddd;color:#2c3e50;font-family:Georgia,serif;font-size:1.08em;font-weight:600;cursor:pointer;padding:8px 18px;border-radius:6px;transition:background .18s,color .18s}.modal-close-btn:hover{background:#f8f9fa;border-color:#adb5bd;color:#007bff}.leaderboard-list{margin-top:18px;max-height:55vh;overflow-y:auto}.leaderboard-puzzle-section{margin-bottom:22px;padding-bottom:10px;border-bottom:1px solid #f0f0f0}.leaderboard-puzzle-title{font-family:Georgia,serif;font-size:1.08em;font-weight:600;color:#2c3e50;margin-bottom:8px;text-align:left}.leaderboard-rankings{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px;align-items:stretch}.leaderboard-ranking-item{display:flex;align-items:center;gap:10px;background:#f8f9fa;border-radius:10px;padding:8px 14px;min-width:180px;box-shadow:0 1px 4px #2c3e500f;font-size:1em;position:relative;margin-bottom:4px}.leaderboard-ranking-item.first-place{border:2px solid #f39c12;background:#fffbe6;z-index:1}.leaderboard-rank{font-family:Georgia,serif;font-size:1.1em;color:#888;font-weight:600;width:18px;text-align:right;margin-right:4px}.leaderboard-username{font-family:Georgia,serif;font-size:1em;color:#2c3e50;font-weight:600;margin-right:2px}.leaderboard-username.first{font-weight:700}.leaderboard-you{color:#aaa;font-size:.95em;font-weight:400;margin-left:2px}.leaderboard-time{font-family:monospace;font-size:1em;color:#888;margin-left:auto;font-weight:500}.logout-modal .puzzle-btn:first-child{background:#111;color:#fff;border:1px solid #111}.logout-modal .puzzle-btn:first-child:hover,.logout-modal .puzzle-btn:first-child:focus{background:#222;color:#fff;border:1.5px solid #111}.win-message .puzzle-btn{background:#111;color:#fff;border:1px solid #111}.win-message .puzzle-btn:hover,.win-message .puzzle-btn:focus{background:#222;color:#fff;border:1.5px solid #111}.help-toggle-btn{position:absolute;z-index:2;background:#f0f0f0;border:1px solid #ccc;border-radius:20px;padding:8px 16px;font-size:14px;cursor:pointer;transition:all .2s ease}.help-toggle-btn:hover{background:#e0e0e0}.help-toggle-btn.active{background:#007bff;color:#fff;border-color:#0056b3}.help-toggle-btn.active:hover{background:#0056b3}.help-toggle-switch{position:absolute;z-index:2;display:inline-block;width:48px;height:28px}.help-toggle-switch input{opacity:0;width:0;height:0}.help-toggle-switch .slider{position:relative;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#ccc;transition:.3s;border-radius:34px;width:48px;height:28px;display:block}.help-toggle-switch .slider:before{position:absolute;content:"";height:20px;width:20px;left:4px;bottom:4px;background-color:#fff;transition:.3s;border-radius:50%}.help-toggle-switch input:checked+.slider{background-color:#111}.help-toggle-switch input:checked+.slider:before{transform:translate(20px)}.help-toggle-row{display:flex;justify-content:flex-end;align-items:center;margin-top:0;width:100%;box-sizing:border-box}.help-toggle-label{margin-right:8px;font-size:1rem;font-weight:500;color:#222}.help-toggle-switch{position:static;z-index:2;display:inline-block;width:48px;height:28px;box-sizing:border-box;margin-right:0}.game-selection{margin:20px 0;text-align:center;position:relative}.game-selection label{display:block;margin-bottom:8px;font-weight:600;color:#2c3e50}.search-container{position:relative;display:inline-block;min-width:250px}.game-search-input{padding:10px 15px;border:2px solid #ddd;border-radius:8px;font-size:1em;background:#fff;color:#2c3e50;width:100%;box-sizing:border-box;transition:border-color .2s ease}.game-search-input:focus{outline:none;border-color:#3498db}.game-search-input:hover{border-color:#bdc3c7}.game-search-input.error{border-color:#e74c3c;background-color:#fff5f5}.game-search-input.error:focus{border-color:#e74c3c;box-shadow:0 0 0 2px #e74c3c33}.search-suggestions{position:absolute;top:100%;left:0;right:0;background:#fff;border:2px solid #3498db;border-top:none;border-radius:0 0 8px 8px;max-height:200px;overflow-y:auto;z-index:1000;box-shadow:0 4px 12px #0000001a}.suggestion-item{padding:10px 15px;cursor:pointer;border-bottom:1px solid #f0f0f0;transition:background-color .2s ease}.suggestion-item:hover{background-color:#f8f9fa}.suggestion-item:last-child{border-bottom:none}.suggestion-item.create-new{color:#27ae60;font-weight:600;background-color:#f8fff9}.suggestion-item.create-new:hover{background-color:#e8f5e8}.error-message{color:#e74c3c;font-size:.9em;margin-top:8px;text-align:center;font-weight:500}.recently-played{margin:40px 0;background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 12px #0000001a}.recently-played h3{margin:0 0 20px;color:#2c3e50;font-size:1.3em;text-align:center}.recent-table{width:100%;max-width:800px;margin:0 auto;border-radius:8px;overflow:hidden;border:1px solid #e0e0e0}.table-header{display:grid;grid-template-columns:2fr 1fr 2fr 1fr;background:#f8f9fa;border-bottom:2px solid #e0e0e0}.header-cell{padding:12px 16px;font-weight:600;color:#2c3e50;text-align:left;font-size:.9em;text-transform:uppercase;letter-spacing:.5px}.table-body{background:#fff}.table-row{display:grid;grid-template-columns:2fr 1fr 2fr 1fr;border-bottom:1px solid #f0f0f0;transition:background-color .2s ease}.table-row:hover{background-color:#f8f9fa}.table-row:last-child{border-bottom:none}.table-cell{padding:12px 16px;color:#2c3e50;font-size:.9em;display:flex;align-items:center}.avatar-small{width:24px;height:24px;border-radius:50%;border:2px solid #2c3e50;margin-right:8px}.timestamp{font-family:monospace;font-size:.8em;color:#666}.draw-badge{padding:4px 8px;background:#f39c12;color:#fff;border-radius:12px;font-size:.8em;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.empty-row{grid-template-columns:1fr}.empty-message{justify-content:center;color:#999;font-style:italic;grid-column:1 / -1}.pagination{display:flex;justify-content:center;align-items:center;gap:20px;margin-top:20px;padding-top:20px;border-top:1px solid #e0e0e0;flex-direction:row}.pagination-btn{padding:8px 16px;border:1px solid #ddd;background:#fff;color:#2c3e50;border-radius:6px;cursor:pointer;font-size:.9em;transition:all .2s ease}.pagination-btn:hover:not(:disabled){background:#f8f9fa;border-color:#bdc3c7}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.page-info{font-size:.9em;color:#666;font-weight:500}@media (max-width: 600px){.recently-played{margin:20px 0;padding:16px}.recently-played h3{font-size:1.1em;margin-bottom:16px}.table-header{grid-template-columns:1fr 1fr 1.5fr 1fr;font-size:.8em}.table-row{grid-template-columns:1fr 1fr 1.5fr 1fr}.header-cell{padding:8px 6px;font-size:.75em}.table-cell{padding:8px 6px;font-size:.8em}.avatar-small{width:20px;height:20px;margin-right:4px}.timestamp{font-size:.7em}.pagination{gap:12px;margin-top:16px;padding-top:16px;flex-direction:row}.pagination-btn{padding:6px 12px;font-size:.8em}.page-info{font-size:.8em}}.tug-of-war-container{display:flex;align-items:center;justify-content:space-between;margin:40px 0;gap:20px}.avatar-section{display:flex;flex-direction:column;align-items:center;text-align:center;min-width:100px}.avatar{width:80px;height:80px;border-radius:50%;border:4px solid #2c3e50;box-shadow:0 4px 12px #00000026;margin-bottom:8px}.avatar-name{font-size:1.1em;font-weight:600;color:#2c3e50;margin-bottom:4px}.avatar-score{font-size:1.5em;font-weight:700;color:#2c3e50;font-family:Playfair Display,serif}.tug-of-war-bar{flex:1;position:relative;height:40px;background:#f0f0f0;border-radius:20px;overflow:hidden;box-shadow:inset 0 2px 4px #0000001a}.bar-background{position:relative;width:100%;height:100%;display:flex}.bar-fill{height:100%;transition:width .5s ease;position:relative}.hannah-fill{background:linear-gradient(90deg,#e74c3c,#c0392b)}.akash-fill{background:linear-gradient(90deg,#3498db,#2980b9)}.bar-center-line{position:absolute;left:50%;top:0;bottom:0;width:2px;background:#2c3e50;z-index:2}.game-controls{margin:30px 0;text-align:center}.current-user-info{margin-bottom:20px}.current-user-info p{font-size:1.1em;color:#555}.control-buttons{display:flex;justify-content:center;gap:20px}.win-btn{background:#27ae60;color:#fff;border:1px solid #27ae60}.win-btn:hover{background:#229954;border-color:#229954}.draw-btn{background:#f39c12;color:#fff;border:1px solid #f39c12}.draw-btn:hover{background:#e67e22;border-color:#e67e22}.loss-btn{background:#e74c3c;color:#fff;border:1px solid #e74c3c}.loss-btn:hover{background:#c0392b;border-color:#c0392b}.game-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin:30px 0;background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 12px #0000001a}.stat-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #f0f0f0}.stat-item:last-child{border-bottom:none}.stat-label{font-weight:600;color:#555}.stat-value{font-weight:700;color:#2c3e50;font-family:Playfair Display,serif}@media (max-width: 600px){.tug-of-war-container{flex-direction:row;gap:10px;width:100%}.avatar-section{min-width:60px}.avatar{width:48px;height:48px}.tug-of-war-bar{height:24px;min-width:0;margin:0 4px}.avatar-name,.avatar-score{font-size:1em}}@media (max-width: 600px){.control-buttons{flex-direction:row;gap:8px}.control-buttons .puzzle-btn{flex:1 1 0;min-width:0;width:auto;margin:0}}.winner-label{margin-left:6px;font-weight:600;font-size:.95em;color:#2c3e50;text-transform:capitalize;letter-spacing:.2px;display:inline-block}.draw-fill{background:linear-gradient(90deg,#ccc,#e0e0e0);height:100%;transition:width .5s ease;position:relative}.pie-chart-container{margin:30px 0;padding:20px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.pie-chart-container h3{margin:0 0 20px;color:#555;font-family:Playfair Display,serif;font-size:1.3em;text-align:center}.chart-wrapper{position:relative;height:300px;margin:20px 0}.no-data-message{text-align:center;color:#666;font-style:italic;padding:40px 20px;background:#f9f9f9;border-radius:8px;margin:20px 0}.chart-stats{display:flex;justify-content:space-around;flex-wrap:wrap;gap:15px;margin-top:20px;padding-top:20px;border-top:1px solid #eee}.chart-stats .stat-item{display:flex;flex-direction:column;align-items:center;min-width:80px}.chart-stats .stat-label{font-size:.9em;color:#666;margin-bottom:5px;text-align:center}.chart-stats .stat-value{font-size:1.2em;font-weight:700;color:#333}@media (max-width: 600px){.pie-chart-container{margin:20px 0;padding:15px}.chart-wrapper{height:250px}.chart-stats{gap:10px}.chart-stats .stat-item{min-width:70px}.chart-stats .stat-label{font-size:.8em}.chart-stats .stat-value{font-size:1.1em}}body{margin:0;font-family:Georgia,serif;height:100vh;width:100vw}main{display:flex;flex-direction:column;align-items:stretch}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s;color:#fff}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}ul{padding-inline-start:0;margin-block-start:0;margin-block-end:0;list-style-type:none;display:flex;flex-direction:column;margin:8px 0;border:1px solid black;gap:1px;background-color:#000;border-radius:8px;overflow:auto}li{background-color:#fff;padding:8px}li:hover{background:#dadbf9}a{font-weight:800;text-decoration:none}
