:root{--bg:#fffdf5;--fg:#1e293b;--muted:#f1f5f9;--muted-fg:#64748b;--accent:#8b5cf6;--accent-fg:#fff;--secondary:#f472b6;--tertiary:#fbbf24;--quaternary:#34d399;--border:#e2e8f0;--card:#fff;--ring:#8b5cf6;--danger:#ef4444;--font-heading:"Outfit", system-ui, sans-serif;--font-body:"Plus Jakarta Sans", system-ui, sans-serif;--radius-sm:8px;--radius-md:16px;--radius-lg:24px;--radius-leaf:24px 4px 24px 4px;--radius-pill:9999px;--radius-full:9999px;--shadow-pop:4px 4px 0px 0px var(--fg);--shadow-pop-hover:6px 6px 0px 0px var(--fg);--shadow-pop-active:2px 2px 0px 0px var(--fg);--shadow-soft:6px 6px 0px 0px var(--border);--shadow-pink:6px 6px 0px 0px var(--secondary);--shadow-violet:6px 6px 0px 0px var(--accent);--bounce:cubic-bezier(.34, 1.56, .64, 1);--transition:.3s var(--bounce);--priority-overdue:#ef4444;--priority-critical:#f97316;--priority-high:#fbbf24;--priority-medium:#8b5cf6;--priority-low:#34d399;--priority-minimal:#94a3b8;--status-pending:#fbbf24;--status-progress:#8b5cf6;--status-completed:#34d399}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-body);background:var(--bg);color:var(--fg);-webkit-font-smoothing:antialiased;background-image:radial-gradient(circle,#e2e8f0 1px,#0000 1px);background-size:24px 24px;min-height:100vh;line-height:1.6;position:relative;overflow-x:hidden}#root{z-index:1;flex-direction:column;min-height:100vh;display:flex;position:relative}h1,h2,h3,h4{font-family:var(--font-heading);color:var(--fg);letter-spacing:-.02em;font-weight:800}a{color:var(--accent);font-weight:700;text-decoration:none;transition:color .2s}a:hover{color:var(--secondary)}button{cursor:pointer;font-family:var(--font-body);border:none;outline:none}input,select,textarea{font-family:var(--font-body);outline:none}.bg-decor{pointer-events:none;z-index:-1;border:2px solid var(--fg);position:fixed}.circle-1{background:var(--tertiary);opacity:.15;border-radius:50%;width:400px;height:400px;top:-200px;right:-100px}.square-1{background:var(--secondary);opacity:.15;border-radius:var(--radius-md);width:150px;height:150px;bottom:10%;left:-50px;transform:rotate(20deg)}.dots-1{background-image:radial-gradient(var(--accent) 2px, transparent 2px);opacity:.1;background-size:15px 15px;border:none;width:200px;height:200px;top:40%;right:5%}.navbar{background:var(--card);border-bottom:3px solid var(--fg);z-index:100;justify-content:space-between;align-items:center;padding:1rem 2rem;display:flex;position:sticky;top:0}.navbar-brand{font-family:var(--font-heading);color:var(--fg);flex-shrink:0;align-items:center;gap:.75rem;font-size:1.5rem;font-weight:800;display:flex}.navbar-brand .brand-icon{background:var(--tertiary);border:2px solid var(--fg);border-radius:var(--radius-sm);width:40px;height:40px;box-shadow:3px 3px 0px 0px var(--fg);transition:transform var(--transition);justify-content:center;align-items:center;font-size:1.2rem;display:flex;transform:rotate(-5deg)}.navbar-brand:hover .brand-icon{transform:rotate(5deg)scale(1.1)}.navbar-actions{align-items:center;gap:1rem;display:flex}.navbar-user{color:var(--fg);background:var(--muted);border-radius:var(--radius-full);transition:all var(--transition);border:2px solid #0000;align-items:center;gap:.625rem;padding:.35rem .75rem .35rem .35rem;font-size:.85rem;font-weight:800;display:flex}.navbar-user:hover{border-color:var(--fg);box-shadow:4px 4px 0px 0px var(--fg);background:#fff;transform:translateY(-2px)}.user-name{text-overflow:ellipsis;white-space:nowrap;max-width:140px;line-height:1;overflow:hidden}.navbar-avatar{border-radius:var(--radius-full);background:var(--secondary);border:2px solid var(--fg);color:#fff;width:38px;height:38px;box-shadow:2px 2px 0px 0px var(--fg);justify-content:center;align-items:center;font-size:.85rem;font-weight:800;display:flex}.btn{border-radius:var(--radius-pill);border:2px solid var(--fg);transition:all var(--transition);justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.9rem;font-weight:800;display:inline-flex;position:relative}.btn-primary{background:var(--accent);color:#fff;box-shadow:var(--shadow-pop)}.btn-primary:hover{box-shadow:var(--shadow-pop-hover);transform:translate(-2px,-2px)}.btn-primary:active{box-shadow:var(--shadow-pop-active);transform:translate(2px,2px)}.btn-secondary{color:var(--fg);background:0 0}.btn-secondary:hover{background:var(--tertiary);transform:translateY(-2px)}.btn-danger{background:var(--danger);color:#fff;box-shadow:var(--shadow-pop)}.btn-danger:hover{box-shadow:var(--shadow-pop-hover);transform:translate(-2px,-2px)}.btn-ghost{color:var(--muted-fg);border-radius:var(--radius-sm);background:0 0;border:none;padding:.5rem}.btn-ghost:hover{color:var(--fg);background:var(--muted);transform:scale(1.1)}.btn-sm{padding:.4rem .8rem;font-size:.8rem}.btn-lg{padding:.875rem 2rem;font-size:1rem}.btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:var(--shadow-pop)!important;transform:none!important}.form-group{flex-direction:column;gap:.5rem;display:flex}.form-label{color:var(--fg);text-transform:uppercase;letter-spacing:.1em;font-size:.8rem;font-weight:800}.form-input{border:2px solid var(--fg);border-radius:var(--radius-md);color:var(--fg);background:#fff;padding:.875rem 1.125rem;font-size:.95rem;transition:all .2s;box-shadow:4px 4px #0000}.form-input:focus{border-color:var(--accent);box-shadow:4px 4px 0px var(--accent)}.form-input::placeholder{color:var(--muted-fg)}.form-select{border:2px solid var(--fg);border-radius:var(--radius-md);color:var(--fg);appearance:none;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%231E293B' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E") right 1rem center no-repeat;padding:.875rem 3rem .875rem 1.125rem;font-size:.95rem;transition:all .2s;box-shadow:4px 4px #0000}.form-select:focus{border-color:var(--accent);box-shadow:4px 4px 0px var(--accent)}.auth-page{flex-direction:column;justify-content:flex-start;align-items:center;min-height:100vh;padding:4rem 1.5rem 0;display:flex;position:relative}.auth-card{background:var(--card);border:2px solid var(--fg);border-radius:var(--radius-leaf);width:100%;max-width:440px;box-shadow:10px 10px 0px 0px var(--fg);z-index:1;animation:popIn .6s var(--bounce) both;background-image:repeating-linear-gradient(45deg,#0000,#0000 10px,#8b5cf608 10px 20px);margin-bottom:4rem;padding:3rem 2.5rem;position:relative}@keyframes popIn{0%{opacity:0;transform:scale(.8)translateY(20px)}to{opacity:1;transform:scale(1)translateY(0)}}.auth-header{text-align:center;margin-bottom:2.5rem}.auth-header h1{font-family:var(--font-heading);color:var(--fg);flex-wrap:wrap;justify-content:center;align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:2.25rem;font-weight:800;display:flex}.auth-header h1 .highlight{color:var(--accent);position:relative}.auth-header h1 .highlight:after{content:"";background:var(--tertiary);z-index:-1;opacity:.5;width:100%;height:8px;position:absolute;bottom:4px;left:0}.auth-header p{color:var(--muted-fg);font-size:.95rem;font-weight:500}.auth-form{flex-direction:column;gap:1.5rem;display:flex}.auth-form .btn-primary{margin-top:.5rem;padding:1rem;font-size:1rem}.auth-footer{text-align:center;color:var(--muted-fg);margin-top:2rem;font-size:.9rem;font-weight:600}.auth-footer a{color:var(--accent);font-weight:800}.auth-error{border:2px solid var(--danger);border-radius:var(--radius-md);color:var(--danger);text-align:center;box-shadow:4px 4px 0px var(--danger);background:#fef2f2;margin-bottom:1.5rem;padding:.875rem 1.125rem;font-size:.875rem;font-weight:700}.dashboard{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:3rem 2rem;position:relative}.dashboard-header{justify-content:space-between;align-items:center;margin-bottom:2.5rem;display:flex}.dashboard-header h1{font-size:2rem;font-weight:800}.dashboard-greeting{color:var(--muted-fg);margin-top:.35rem;font-size:1rem;font-weight:500}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1.5rem;margin-bottom:3rem;display:grid}.stat-card{background:var(--card);border:2px solid var(--fg);border-radius:var(--radius-md);box-shadow:6px 6px 0px 0px var(--fg);transition:all var(--transition);padding:1.5rem;position:relative;overflow:hidden}.stat-card:hover{box-shadow:10px 10px 0px 0px var(--fg);transform:translate(-4px,-4px)}.stat-card .stat-icon{border-radius:var(--radius-full);border:2px solid var(--fg);color:#fff;width:44px;height:44px;box-shadow:2px 2px 0px 0px var(--fg);justify-content:center;align-items:center;margin-bottom:1rem;font-size:1.25rem;display:flex}.stat-card.total .stat-icon{background:var(--accent)}.stat-card.completed .stat-icon{background:var(--quaternary)}.stat-card.pending .stat-icon{background:var(--tertiary)}.stat-card.progress .stat-icon{background:var(--accent)}.stat-card.overdue .stat-icon{background:var(--danger)}.stat-card.today .stat-icon{background:var(--secondary)}.stat-card .stat-value{font-family:var(--font-heading);margin-bottom:.35rem;font-size:2.5rem;font-weight:800;line-height:1}.stat-card .stat-label{color:var(--muted-fg);text-transform:uppercase;letter-spacing:.08em;font-size:.8rem;font-weight:800}.section-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.section-header h2{font-size:1.5rem;font-weight:800}.task-filters{flex-wrap:wrap;gap:.625rem;display:flex}.filter-btn{border-radius:var(--radius-pill);background:var(--card);color:var(--fg);border:2px solid var(--fg);transition:all var(--transition);padding:.5rem 1.125rem;font-size:.85rem;font-weight:800}.filter-btn:hover{background:var(--tertiary);transform:translateY(-2px)}.filter-btn.active{background:var(--accent);color:#fff;box-shadow:4px 4px 0px var(--fg)}.task-list{flex-direction:column;gap:1rem;display:flex}.task-card{background:var(--card);border:2px solid var(--fg);border-radius:var(--radius-leaf);box-shadow:6px 6px 0px 0px var(--fg);transition:all var(--transition);animation:cardSlide .5s var(--bounce) both;align-items:flex-start;gap:1.5rem;padding:1.5rem 2rem;display:flex;position:relative;overflow:hidden}@keyframes cardSlide{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.task-card:hover{box-shadow:8px 8px 0px 0px var(--fg);transform:translate(-2px,-2px)rotate(.5deg)}.task-card.completed{opacity:.7;filter:grayscale(.5)}.task-card.overdue{border-left:8px solid var(--danger);box-shadow:6px 6px 0px 0px var(--danger)}.task-card.high-priority{border-left:8px solid var(--tertiary)}.task-priority-dot{border-radius:var(--radius-full);border:2px solid var(--fg);flex-shrink:0;width:18px;height:18px;margin-top:.4rem;box-shadow:2px 2px #0000001a}.task-content{flex:1;min-width:0}.task-title{font-family:var(--font-heading);margin-bottom:.35rem;font-size:1.1rem;font-weight:800}.task-card.completed .task-title{color:var(--muted-fg);text-decoration:line-through}.task-description{color:var(--muted-fg);margin-bottom:.75rem;font-size:.9rem;font-weight:500}.task-meta{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.task-badge{border-radius:var(--radius-pill);text-transform:uppercase;letter-spacing:.05em;border:2px solid var(--fg);align-items:center;gap:.4rem;padding:.25rem .75rem;font-size:.75rem;font-weight:800;display:inline-flex}.badge-category{color:var(--accent);background:#ede9fe}.badge-deadline{background:var(--muted);color:var(--fg)}.badge-deadline.overdue{color:var(--danger);border-color:var(--danger);background:#fef2f2}.badge-status.pending{color:#92400e;background:#fef9c3}.badge-status.in-progress{color:var(--accent);background:#ede9fe}.badge-status.completed-badge{color:#065f46;background:#d1fae5}.task-actions{flex-shrink:0;align-items:center;gap:.5rem;display:flex}.task-actions .btn-ghost{border-radius:var(--radius-sm);opacity:0;transition:all var(--transition);border:2px solid #0000;padding:.5rem;font-size:1.25rem}.task-card:hover .task-actions .btn-ghost{opacity:1}.task-actions .btn-ghost:hover{border-color:var(--fg);background:#fff;transform:translateY(-2px)}.action-divider{background:var(--border);width:2px;height:24px;margin:0 .25rem}.task-actions .btn-ghost.start,.task-actions .btn-ghost.reverse,.task-actions .btn-ghost.complete{opacity:1;border-color:var(--border)}.btn-ghost.start:hover{color:#8b5cf6;background:#8b5cf61a;border-color:#8b5cf6}.btn-ghost.reverse:hover{color:#f59e0b;background:#f59e0b1a;border-color:#f59e0b}.btn-ghost.complete:hover{color:#10b981;background:#10b9811a;border-color:#10b981}.btn-ghost.delete:hover{color:#ef4444;background:#ef44441a;border-color:#ef4444}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:200;background:#1e293b99;justify-content:center;align-items:flex-start;padding:1.5rem;display:flex;position:fixed;inset:0;overflow-y:auto}.modal-content{background:var(--card);border:3px solid var(--fg);border-radius:var(--radius-leaf);width:100%;max-width:520px;box-shadow:12px 12px 0px 0px var(--fg);animation:modalPop .5s var(--bounce) both;margin-top:2rem;margin-bottom:2rem;padding:2.5rem}@keyframes modalPop{0%{opacity:0;transform:scale(.9)translateY(40px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.modal-header h2{font-family:var(--font-heading);font-size:1.5rem;font-weight:800}.task-form{flex-direction:column;gap:1.5rem;display:flex}.task-form .form-row{grid-template-columns:1fr 1fr;gap:1.25rem;display:grid}.task-form .form-actions{justify-content:flex-end;gap:1rem;margin-top:1rem;display:flex}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:6rem 2rem;display:flex}.empty-state .empty-icon{margin-bottom:1.5rem;font-size:5rem;animation:3s ease-in-out infinite float}@keyframes float{0%,to{transform:translateY(0)rotate(0)}50%{transform:translateY(-15px)rotate(5deg)}}.empty-state h3{font-family:var(--font-heading);margin-bottom:.75rem;font-size:1.5rem;font-weight:800}.empty-state p{color:var(--muted-fg);max-width:340px;font-size:1rem;font-weight:500}.category-section{margin-top:3rem}.category-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem;display:grid}.category-chip{background:var(--card);border:2px solid var(--fg);border-radius:var(--radius-leaf);text-align:center;box-shadow:4px 4px 0px 0px var(--border);transition:all var(--transition);padding:1.25rem}.category-chip:hover{box-shadow:6px 6px 0px 0px var(--accent);transform:translateY(-5px)rotate(-3deg)}.category-chip .cat-count{font-family:var(--font-heading);color:var(--accent);font-size:2rem;font-weight:800;line-height:1}.category-chip .cat-name{color:var(--fg);text-transform:uppercase;letter-spacing:.05em;margin-top:.5rem;font-size:.85rem;font-weight:800}.profile-modal{text-align:center;max-width:440px}.profile-info{flex-direction:column;align-items:center;gap:1.5rem;margin:1.5rem 0 2.5rem;display:flex}.profile-avatar-large{border-radius:var(--radius-full);background:var(--secondary);border:4px solid var(--fg);width:100px;height:100px;font-family:var(--font-heading);color:#fff;box-shadow:6px 6px 0px 0px var(--fg);justify-content:center;align-items:center;font-size:2.5rem;font-weight:800;animation:4s ease-in-out infinite float;display:flex}.profile-details h3{margin-bottom:.25rem;font-size:1.75rem}.profile-details p{color:var(--muted-fg);justify-content:center;align-items:center;gap:.5rem;font-weight:700;display:flex}.profile-stats-mini{grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:2rem;display:grid}.mini-stat{background:var(--bg);border:2px solid var(--fg);border-radius:var(--radius-md);text-align:left;padding:1rem}.mini-stat-label{color:var(--muted-fg);text-transform:uppercase;margin-bottom:.25rem;font-size:.7rem;font-weight:800;display:block}.mini-stat-value{color:var(--fg);align-items:center;gap:.4rem;font-size:.95rem;font-weight:800;display:flex}.profile-badges{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.p-badge{border-radius:var(--radius-pill);border:2px solid var(--fg);box-shadow:3px 3px 0px 0px var(--fg);padding:.4rem 1rem;font-size:.75rem;font-weight:800}.p-badge.pink{background:var(--secondary);color:#fff}.p-badge.violet{background:var(--accent);color:#fff}.p-badge.yellow{background:var(--tertiary);color:var(--fg)}.footer{background:var(--card);border-top:3px solid var(--fg);z-index:10;width:100%;margin-top:auto;padding:4rem 2rem;position:relative}.footer-content{text-align:center;flex-direction:column;align-items:center;gap:1.5rem;max-width:1200px;margin:0 auto;display:flex}.footer-brand{font-family:var(--font-heading);color:var(--fg);align-items:center;gap:.75rem;font-size:1.75rem;font-weight:800;display:flex}.footer-brand .brand-icon{background:var(--tertiary);border:2px solid var(--fg);border-radius:var(--radius-sm);width:44px;height:44px;box-shadow:4px 4px 0px 0px var(--fg);justify-content:center;align-items:center;font-size:1.25rem;display:flex;transform:rotate(5deg)}.footer-tagline{color:var(--muted-fg);font-size:1.1rem;font-weight:700}.footer-links{flex-wrap:wrap;justify-content:center;gap:2rem;margin:1rem 0;display:flex}.footer-link{color:var(--fg);transition:all var(--transition);border-radius:var(--radius-md);border:2px solid #0000;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.95rem;font-weight:800;display:flex}.footer-link:hover{color:var(--accent);background:var(--bg);border-color:var(--fg);box-shadow:4px 4px 0px 0px var(--fg);transform:translateY(-3px)rotate(-2deg)}.footer-link svg{font-size:1.25rem}.footer-bottom{border-top:2px solid var(--border);width:100%;color:var(--muted-fg);margin-top:2rem;padding-top:2rem;font-size:.85rem;font-weight:600}.habit-section{margin-bottom:2.5rem}.habit-list{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem;margin-top:1.25rem;display:grid}.habit-card{background:var(--card);border:2px solid var(--fg);border-radius:var(--radius-md);box-shadow:4px 4px 0px 0px var(--fg);transition:all var(--transition);align-items:center;gap:1rem;padding:1.25rem;display:flex}.habit-card.completed{background:var(--muted);border-color:var(--border);box-shadow:2px 2px 0px 0px var(--border);opacity:.8}.habit-info{flex:1}.habit-title{font-family:var(--font-heading);color:var(--fg);margin-bottom:.15rem;font-size:1.1rem;font-weight:800}.habit-freq{color:var(--muted-fg);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:700}.habit-streak{font-family:var(--font-heading);color:var(--muted-fg);align-items:center;gap:.35rem;font-weight:800;display:flex}.habit-streak.active{color:#f97316}.habit-actions{gap:.5rem;display:flex}.btn-check{border:2px solid var(--fg);width:40px;height:40px;color:var(--fg);cursor:pointer;transition:all var(--transition);background:#fff;border-radius:50%;justify-content:center;align-items:center;font-size:1.5rem;display:flex}.btn-check:hover:not(:disabled){background:var(--secondary);color:#fff;transform:scale(1.1)}.btn-check.checked{background:var(--secondary);color:#fff;border-color:var(--secondary);cursor:default}.btn-delete-small{color:var(--muted-fg);cursor:pointer;background:0 0;border:none;padding:5px;transition:color .2s}.btn-delete-small:hover{color:#ef4444}.habit-add-form{background:var(--card);border:2px dashed var(--border);border-radius:var(--radius-md);flex-direction:column;gap:1rem;margin-top:1rem;padding:1.5rem;display:flex}.task-type-selector{flex-wrap:wrap;gap:.625rem;display:flex}.type-btn{border:2px solid var(--border);border-radius:var(--radius-md);background:var(--card);min-width:80px;transition:all var(--transition);cursor:pointer;flex-direction:column;flex:1;align-items:center;gap:.25rem;padding:.75rem .5rem;display:flex}.type-btn .type-icon{font-size:1.25rem}.type-btn .type-text{text-transform:uppercase;letter-spacing:.02em;font-size:.75rem;font-weight:800}.type-btn:hover{border-color:var(--fg);transform:translateY(-2px)}.type-btn.active{border-color:var(--accent);color:var(--accent);box-shadow:4px 4px 0px 0px var(--accent);background:#8b5cf61a}.type-btn.challenge.active{border-color:var(--tertiary);color:#92400e;box-shadow:4px 4px 0px 0px var(--tertiary);background:#fbbf241a}.repeat-hint{color:var(--accent);border-radius:var(--radius-sm);border-left:3px solid var(--accent);background:#8b5cf60f;margin-top:.5rem;padding:.5rem .75rem;font-size:.8rem;font-weight:600}.repeat-hint strong{font-weight:800}.task-habit-badge{color:var(--accent);border:1.5px solid var(--accent);border-radius:var(--radius-pill);text-transform:uppercase;letter-spacing:.04em;background:#8b5cf61a;align-items:center;gap:.25rem;padding:.15rem .5rem;font-size:.7rem;font-weight:800;display:inline-flex}.task-subtasks-preview{background:var(--muted);border-radius:var(--radius-md);cursor:pointer;margin-top:1rem;padding:.75rem;transition:background .2s}.task-subtasks-preview:hover{background:#e5e7eb}.subtask-progress-info{justify-content:space-between;align-items:center;margin-bottom:.5rem;font-size:.85rem;font-weight:700;display:flex}.subtask-progress-bar{background:#fff;border-radius:3px;width:100%;height:6px;overflow:hidden}.subtask-progress-fill{background:var(--accent);height:100%;transition:width .4s var(--bounce)}.subtasks-list{flex-direction:column;gap:.5rem;margin-top:.75rem;padding-left:.5rem;animation:.3s gnSlideIn;display:flex}.subtask-item{cursor:pointer;border-radius:var(--radius-sm);align-items:center;gap:.75rem;padding:.35rem .5rem;font-size:.9rem;font-weight:600;transition:background .2s;display:flex}.subtask-item:hover{background:var(--muted)}.subtask-check{color:var(--border);font-size:1.2rem;transition:color .2s}.subtask-item.completed{color:var(--muted-fg);text-decoration:line-through}.subtask-item.completed .subtask-check{color:var(--secondary)}.subtask-add-row{gap:.5rem;margin-bottom:.75rem;display:flex}.subtask-add-row .form-input{flex:1;min-width:0}@media (width<=480px){.subtask-add-row{flex-direction:column;gap:.75rem}.subtask-add-row .btn{width:100%}}.alarm-overlay{z-index:9999;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000d9;justify-content:center;align-items:flex-start;padding:2rem 1.5rem;animation:1s ease-in-out infinite alarmPulse;display:flex;position:fixed;inset:0;overflow-y:auto}@keyframes alarmPulse{0%,to{background:#dc2626d9}50%{background:#000000e6}}.alarm-card{border:4px solid var(--fg);border-radius:var(--radius-leaf);text-align:center;width:100%;max-width:420px;box-shadow:12px 12px 0px var(--fg);animation:alarmBounce .5s var(--bounce);background:#fff;margin-top:auto;margin-bottom:auto;padding:3rem 2.5rem}@keyframes alarmBounce{0%{opacity:0;transform:scale(.8)rotate(-3deg)}to{opacity:1;transform:scale(1)rotate(0)}}.alarm-shake{animation:.5s shakeCard}@keyframes shakeCard{0%,to{transform:translate(0)}10%{transform:translate(-12px)rotate(-2deg)}30%{transform:translate(12px)rotate(2deg)}50%{transform:translate(-8px)rotate(-1deg)}70%{transform:translate(8px)rotate(1deg)}90%{transform:translate(-4px)}}.alarm-icon-ring{border:3px solid var(--fg);background:linear-gradient(135deg,#ef4444,#dc2626);border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 1.5rem;animation:.3s ease-in-out infinite alternate ringBell;display:flex}@keyframes ringBell{0%{transform:rotate(-15deg)}to{transform:rotate(15deg)}}.alarm-bell{color:#fff;font-size:2.5rem}.alarm-title{font-family:var(--font-heading);color:#dc2626;margin-bottom:.25rem;font-size:2rem;font-weight:900}.alarm-task-name{color:var(--fg);margin-bottom:.5rem;font-size:1.1rem;font-weight:800}.alarm-subtitle{color:var(--muted-fg);margin-bottom:1.5rem;font-size:.9rem;font-weight:600}.alarm-problem{background:var(--muted);border:3px solid var(--fg);border-radius:var(--radius-md);margin-bottom:1.5rem;padding:1.25rem}.alarm-question{font-family:var(--font-heading);color:var(--fg);font-size:2.2rem;font-weight:900}.alarm-form{gap:.75rem;margin-bottom:1rem;display:flex}.alarm-input{border:3px solid var(--fg);border-radius:var(--radius-md);text-align:center;transition:all var(--transition);outline:none;flex:1;padding:.85rem 1rem;font-size:1.3rem;font-weight:800}.alarm-input:focus{border-color:#dc2626;box-shadow:4px 4px #dc2626}.alarm-submit{color:#fff;border:3px solid var(--fg);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);background:#10b981;padding:.85rem 1.5rem;font-size:1rem;font-weight:800}.alarm-submit:hover{box-shadow:4px 4px 0px var(--fg);transform:translateY(-2px)}.alarm-warning{color:#dc2626;font-size:.8rem;font-weight:700}.task-card.challenge-card{border-left:5px solid var(--accent)}.task-challenge-badge{color:var(--fg);border:2px solid var(--fg);border-radius:var(--radius-pill);text-transform:uppercase;cursor:pointer;transition:all var(--transition);background:linear-gradient(135deg,#fde68a,#f59e0b);align-items:center;gap:.25rem;padding:.2rem .6rem;font-size:.7rem;font-weight:800;display:inline-flex}.task-challenge-badge:hover{box-shadow:2px 2px 0px var(--fg);transform:scale(1.05)}.task-alarm-badge{color:#991b1b;border:2px solid var(--fg);border-radius:var(--radius-pill);background:linear-gradient(135deg,#fee2e2,#fca5a5);align-items:center;gap:.25rem;padding:.2rem .6rem;font-size:.7rem;font-weight:800;display:inline-flex}.challenge-inline{margin-top:1rem}.challenge-toggle{border:2px solid var(--fg);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);background:linear-gradient(135deg,#fef3c7,#fde68a);align-items:center;gap:.5rem;padding:.75rem 1rem;font-size:.9rem;font-weight:700;display:flex}.challenge-toggle:hover{box-shadow:3px 3px 0px var(--fg);transform:translateY(-1px)}.challenge-board{border:2px solid var(--border);border-radius:var(--radius-md);background:#fff;margin-top:1rem;padding:1.5rem;animation:.3s gnSlideIn}.day-grid{grid-template-columns:repeat(7,1fr);gap:.5rem;margin-bottom:1.5rem;display:grid}.day-tile{aspect-ratio:1;border:2px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-heading);transition:all .2s var(--bounce);cursor:default;background:var(--muted);color:var(--muted-fg);flex-direction:column;justify-content:center;align-items:center;font-size:.9rem;font-weight:800;display:flex;position:relative}.day-tile:hover{box-shadow:3px 3px 0px var(--border);transform:translateY(-3px)}.day-tile.p1{background:#f0fdf4;border-color:#86efac}.day-tile.p2{background:#eff6ff;border-color:#93c5fd}.day-tile.p3{background:#f5f3ff;border-color:#c4b5fd}.day-tile.p4{background:#fdf2f8;border-color:#f9a8d4}.day-tile.done{color:#fff;background:#10b981;border-color:#059669;box-shadow:2px 2px #047857}.day-tile.done:hover{box-shadow:3px 3px #047857}.day-check{color:#fff;background:#059669;border-radius:50%;font-size:.8rem;position:absolute;top:-4px;right:-4px}.day-tile.now{background:var(--accent);border-color:var(--fg);color:#fff;box-shadow:4px 4px 0px var(--fg);animation:2s ease-in-out infinite currentPulse}@keyframes currentPulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}.day-decor{font-size:.75rem;position:absolute;top:-10px;right:-6px}.today-progress{margin-bottom:1rem}.today-bar{background:var(--muted);border:2px solid var(--fg);border-radius:var(--radius-pill);height:10px;margin-bottom:.5rem;overflow:hidden}.today-fill{background:linear-gradient(90deg, var(--accent), var(--secondary));height:100%;transition:width .5s var(--bounce)}.today-label{color:var(--muted-fg);font-size:.8rem;font-weight:700}.record-time-row{align-items:center;gap:.75rem;margin-top:.75rem;display:flex}.time-input{border:2px solid var(--fg);border-radius:var(--radius-sm);text-align:center;width:70px;padding:.5rem;font-size:.9rem;font-weight:700}.time-label{color:var(--muted-fg);font-size:.85rem;font-weight:700}.challenge-mastered{border:2px solid var(--fg);border-radius:var(--radius-md);text-align:center;box-shadow:4px 4px 0px var(--fg);background:linear-gradient(135deg,#fde68a,#f59e0b);padding:1rem;font-size:1rem;font-weight:800}.challenge-hint{color:#92400e;background:#f59e0b0f;border-left-color:#f59e0b}.repeat-pill.challenge{border-color:#f59e0b}.repeat-pill.challenge.active{border-color:var(--fg);color:var(--fg);background:linear-gradient(135deg,#fde68a,#f59e0b)}.gamified-header{animation:cardSlide .6s var(--bounce) both;margin-bottom:2.5rem}.gamified-header-inner{background:var(--card);border:2px solid var(--fg);border-radius:var(--radius-leaf);box-shadow:6px 6px 0px 0px var(--fg);transition:all var(--transition);background-image:repeating-linear-gradient(135deg,#0000,#0000 20px,#8b5cf608 20px 40px);flex-wrap:wrap;align-items:center;gap:2rem;padding:2rem 2.5rem;display:flex;position:relative;overflow:hidden}.gamified-header-inner:hover{box-shadow:10px 10px 0px 0px var(--fg);transform:translate(-2px,-2px)}.gh-level-badge{flex-direction:column;flex-shrink:0;align-items:center;gap:.35rem;display:flex}.gh-level-ring{justify-content:center;align-items:center;width:72px;height:72px;display:flex;position:relative}.gh-ring-svg{width:100%;height:100%;position:absolute;inset:0;transform:rotate(-90deg)}.gh-ring-bg{fill:none;stroke:var(--border);stroke-width:3px}.gh-ring-fill{fill:none;stroke:var(--accent);stroke-width:3px;stroke-linecap:round;filter:drop-shadow(0 0 6px #8b5cf680);transition:stroke-dasharray 1s}.gh-level-number{font-family:var(--font-heading);color:var(--accent);z-index:1;font-size:1.75rem;font-weight:800;line-height:1}.gh-level-label{text-transform:uppercase;letter-spacing:.15em;color:var(--muted-fg);font-size:.65rem;font-weight:800}.gh-xp-section{flex:1;min-width:200px}.gh-xp-info{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.gh-xp-label{font-family:var(--font-heading);color:var(--fg);align-items:center;gap:.35rem;font-size:1rem;font-weight:800;display:flex}.gh-xp-icon{color:var(--tertiary);font-size:1.1rem}.gh-xp-next{color:var(--muted-fg);font-size:.75rem;font-weight:700}.gh-xp-bar-track{background:var(--muted);border:2px solid var(--fg);border-radius:var(--radius-pill);width:100%;height:14px;position:relative;overflow:hidden}.gh-xp-bar-fill{background:linear-gradient(90deg, var(--accent), var(--secondary));border-radius:var(--radius-pill);z-index:1;height:100%;transition:width 1s;position:relative}.gh-xp-bar-glow{background:linear-gradient(90deg, var(--accent), var(--secondary));border-radius:var(--radius-pill);filter:blur(8px);opacity:.4;z-index:0;height:100%;transition:width 1s;position:absolute;top:0;left:0}.gh-stats-row{flex-shrink:0;gap:1.5rem;display:flex}.gh-stat{flex-direction:column;align-items:center;gap:.15rem;min-width:60px;display:flex}.gh-stat-icon{font-size:1.25rem;transition:all .3s}.gh-stat-icon.fire{color:var(--muted-fg)}.gh-stat-icon.fire.active{color:#f97316;animation:1.5s ease-in-out infinite fireGlow}.gh-stat-icon.trend{color:var(--quaternary)}.gh-stat-icon.star{color:var(--tertiary)}@keyframes fireGlow{0%,to{filter:drop-shadow(0 0 2px #f97316);transform:scale(1)}50%{filter:drop-shadow(0 0 8px #f97316);transform:scale(1.2)}}.gh-stat-value{font-family:var(--font-heading);color:var(--fg);font-size:1.25rem;font-weight:800;line-height:1}.gh-stat-label{text-transform:uppercase;letter-spacing:.1em;color:var(--muted-fg);font-size:.65rem;font-weight:800}.gh-badges-preview{background:var(--muted);border:2px solid var(--border);border-radius:var(--radius-pill);cursor:pointer;transition:all var(--transition);flex-shrink:0;align-items:center;gap:.75rem;padding:.5rem 1rem;display:flex}.gh-badges-preview:hover{border-color:var(--fg);box-shadow:4px 4px 0px 0px var(--fg);background:#fff;transform:translateY(-2px)}.gh-badges-icons{align-items:center;gap:.25rem;display:flex}.gh-badge-icon{font-size:1.25rem;transition:transform .2s}.gh-badge-icon:hover{transform:scale(1.3)}.gh-badge-more{color:var(--muted-fg);margin-left:.25rem;font-size:.75rem;font-weight:800}.gh-badges-label{color:var(--accent);white-space:nowrap;font-size:.75rem;font-weight:800}.badge-modal{max-width:600px;max-height:85vh;overflow-y:auto}.badge-progress-summary{background:var(--muted);border:2px solid var(--border);border-radius:var(--radius-md);align-items:center;gap:1.25rem;margin-bottom:2rem;padding:1.5rem;display:flex}.badge-progress-ring{align-items:baseline;gap:.25rem;display:flex}.badge-earned-count{font-family:var(--font-heading);color:var(--accent);font-size:2.5rem;font-weight:800;line-height:1}.badge-total-count{font-family:var(--font-heading);color:var(--muted-fg);font-size:1.25rem;font-weight:800}.badge-progress-text{color:var(--fg);font-size:.95rem;font-weight:700}.badge-section{margin-bottom:2rem}.badge-section-title{font-family:var(--font-heading);text-transform:uppercase;letter-spacing:.1em;color:var(--muted-fg);margin-bottom:1rem;font-size:1rem;font-weight:800}.badge-grid{flex-direction:column;gap:.75rem;display:flex}.badge-card{border:2px solid var(--fg);border-radius:var(--radius-md);background:var(--card);transition:all var(--transition);align-items:center;gap:1rem;padding:1rem 1.25rem;display:flex}.badge-card.earned{box-shadow:4px 4px 0px 0px var(--accent)}.badge-card.earned:hover{box-shadow:6px 6px 0px 0px var(--accent);transform:translate(-2px,-2px)}.badge-card.locked{opacity:.5;box-shadow:none;border-style:dashed}.badge-card-icon{flex-shrink:0;font-size:2rem;line-height:1}.badge-card-icon.locked-icon{filter:grayscale()}.badge-card-info{flex:1}.badge-card-name{font-family:var(--font-heading);color:var(--fg);font-size:1rem;font-weight:800}.badge-card-desc{color:var(--muted-fg);font-size:.85rem;font-weight:600}.badge-card-date{color:var(--accent);margin-top:.25rem;font-size:.7rem;font-weight:700}.gn-container{z-index:300;pointer-events:none;flex-direction:column;gap:.75rem;display:flex;position:fixed;top:80px;right:1.5rem}.gn-toast{background:var(--card);border:2px solid var(--fg);border-radius:var(--radius-md);box-shadow:6px 6px 0px 0px var(--fg);color:var(--fg);pointer-events:auto;white-space:nowrap;align-items:center;gap:.75rem;padding:.875rem 1.5rem;font-size:.9rem;font-weight:700;display:flex}.gn-toast.gn-xp{border-left:6px solid var(--tertiary)}.gn-toast.gn-level_up{border-left:6px solid var(--accent);background:linear-gradient(135deg, #ede9fe 0%, var(--card) 100%)}.gn-toast.gn-badge{border-left:6px solid var(--quaternary)}.gn-enter{animation:gnSlideIn .5s var(--bounce) both}.gn-exit{animation:.4s forwards gnSlideOut}@keyframes gnSlideIn{0%{opacity:0;transform:translate(100px)scale(.8)}to{opacity:1;transform:translate(0)scale(1)}}@keyframes gnSlideOut{0%{opacity:1;transform:translate(0)scale(1)}to{opacity:0;transform:translate(100px)scale(.8)}}.gn-icon{font-size:1.5rem;line-height:1}.gn-level-icon{animation:.6s infinite levelPulse}@keyframes levelPulse{0%,to{transform:scale(1)}50%{transform:scale(1.3)}}.gn-text{font-size:.9rem;font-weight:700}.gn-text strong{color:var(--accent);font-weight:800}.skeleton{background:linear-gradient(90deg, var(--muted) 25%, var(--border) 50%, var(--muted) 75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s infinite shimmer}.skeleton-card{border:2px solid var(--border);height:100px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media (width<=768px){.dashboard{padding:2rem 1.25rem}.dashboard-header{flex-direction:column;align-items:flex-start;gap:1.5rem}.stats-grid{grid-template-columns:repeat(2,1fr);gap:1rem}.task-form .form-row{grid-template-columns:1fr}.navbar{padding:.75rem 1rem}.navbar-brand{gap:.5rem;font-size:1.25rem}.navbar-brand .brand-icon{width:32px;height:32px;font-size:1rem}.navbar-actions{gap:.5rem}.navbar-user{padding-right:.35rem}.navbar-user .user-name{display:none!important}.task-card{flex-direction:column;gap:1rem;padding:1.25rem}.task-actions{align-self:flex-end}.task-actions .btn-ghost{opacity:1;border-color:var(--border)}.action-divider{height:20px}.bg-decor{display:none}.gamified-header-inner{flex-direction:column;align-items:stretch;gap:1.5rem;padding:1.5rem}.gh-level-badge{flex-direction:row;gap:.75rem}.gh-level-ring{width:56px;height:56px}.gh-level-number{font-size:1.4rem}.gh-stats-row{justify-content:space-around}.gh-badges-preview{justify-content:center}.gn-container{left:.75rem;right:.75rem}.gn-toast{white-space:normal;padding:.75rem 1rem;font-size:.8rem}}@media (width<=480px){.stats-grid{grid-template-columns:1fr}.auth-page{padding:2rem 1rem 0}.auth-card{box-shadow:6px 6px 0px 0px var(--fg);border-radius:20px 4px;margin-bottom:3rem;padding:2rem 1.5rem}.auth-header h1{font-size:1.8rem}.auth-form .btn-primary{width:100%}.modal-content{padding:1.5rem 1.25rem}.task-type-selector{gap:.5rem!important}.type-btn{min-width:65px!important;padding:.5rem .25rem!important}.footer-links{flex-direction:column;align-items:center;gap:.5rem}.footer-link{justify-content:center;width:100%;padding:.75rem;font-size:.85rem}.gh-xp-section{min-width:0}}.btn-nav{border-radius:var(--radius-pill);color:var(--muted-fg);cursor:pointer;transition:all var(--transition);background:0 0;border:2px solid #0000;align-items:center;gap:.4rem;padding:.5rem 1rem;font-size:.85rem;font-weight:700;display:flex}.btn-nav:hover{color:var(--fg);background:var(--muted)}.btn-nav.active{color:var(--accent);border-color:var(--accent);background:#8b5cf61a}.nav-divider{background:var(--border);width:2px;height:24px;margin:0 .5rem}.extension-banner{border:3px solid var(--fg);border-radius:var(--radius-leaf);box-shadow:8px 8px 0px var(--fg);animation:cardSlide .6s var(--bounce) both;background:linear-gradient(135deg,#ede9fe,#ddd6fe,#c4b5fd);align-items:center;gap:1.5rem;margin-top:3rem;padding:1.5rem 2rem;animation-delay:.4s;display:flex}.ext-banner-icon{background:var(--accent);color:#fff;border:3px solid var(--fg);width:56px;height:56px;box-shadow:3px 3px 0px var(--fg);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1.8rem;display:flex}.ext-banner-content{flex:1}.ext-banner-content h3{font-family:var(--font-heading);margin-bottom:.2rem;font-size:1.15rem;font-weight:800}.ext-banner-content p{color:var(--muted-fg);font-size:.85rem;font-weight:600;line-height:1.4}.ext-banner-btn{background:var(--fg);color:#fff;border:3px solid var(--fg);border-radius:var(--radius-pill);white-space:nowrap;transition:all var(--transition);box-shadow:0 0 0 0 var(--accent);align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.9rem;font-weight:800;text-decoration:none;display:flex}.ext-banner-btn:hover{background:var(--accent);box-shadow:4px 4px 0px var(--fg);transform:translateY(-3px)}@media (width<=768px){.extension-banner{text-align:center;flex-direction:column}.ext-banner-btn{justify-content:center;width:100%}}.social-page{max-width:900px;margin:0 auto;padding:2rem 2rem 4rem}.social-header{margin-bottom:2rem}.social-header h1{font-family:var(--font-heading);align-items:center;gap:.5rem;font-size:2.2rem;font-weight:900;display:flex}.social-header p{color:var(--muted-fg);margin-top:.25rem;font-weight:600}.social-tabs{flex-wrap:wrap;gap:.5rem;margin-bottom:2rem;display:flex}.social-tab{border:2px solid var(--fg);border-radius:var(--radius-pill);background:var(--card);cursor:pointer;transition:all var(--transition);align-items:center;gap:.4rem;padding:.75rem 1.5rem;font-size:.9rem;font-weight:800;display:flex;position:relative}.social-tab:hover{box-shadow:3px 3px 0px var(--fg);transform:translateY(-2px)}.social-tab.active{background:var(--accent);color:#fff;box-shadow:4px 4px 0px var(--fg)}.tab-badge{background:var(--danger);color:#fff;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:.65rem;font-weight:800;display:flex;position:absolute;top:-8px;right:-8px}.podium{justify-content:center;align-items:flex-end;gap:1.5rem;margin-bottom:2.5rem;display:flex}.podium-card{text-align:center;border:3px solid var(--fg);border-radius:var(--radius-leaf);background:var(--card);box-shadow:6px 6px 0px var(--fg);transition:all var(--transition);min-width:140px;padding:1.5rem;position:relative}.podium-card:hover{box-shadow:8px 8px 0px var(--fg);transform:translateY(-4px)}.podium-card.rank-1{background:linear-gradient(135deg,#fef3c7,#fde68a);order:2;transform:translateY(-20px)}.podium-card.rank-2{background:linear-gradient(135deg,#e2e8f0,#cbd5e1);order:1}.podium-card.rank-3{background:linear-gradient(135deg,#fed7aa,#fdba74);order:3}.podium-rank{margin-bottom:.5rem;font-size:2rem}.podium-avatar{background:var(--accent);color:#fff;border:3px solid var(--fg);border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto .75rem;font-size:1.5rem;font-weight:800;display:flex}.podium-name{margin-bottom:.25rem;font-size:1rem;font-weight:800}.podium-xp{color:var(--accent);justify-content:center;align-items:center;gap:.25rem;font-size:.85rem;font-weight:700;display:flex}.podium-meta{color:var(--muted-fg);justify-content:center;align-items:center;gap:.25rem;margin-top:.25rem;font-size:.75rem;font-weight:600;display:flex}.btn-add-friend{background:var(--accent);color:#fff;border:2px solid var(--fg);cursor:pointer;width:32px;height:32px;transition:all var(--transition);border-radius:50%;justify-content:center;align-items:center;font-size:1rem;display:flex;position:absolute;top:-10px;right:-10px}.btn-add-friend:hover{box-shadow:2px 2px 0px var(--fg);transform:scale(1.15)}.you-badge,.you-badge-sm{background:var(--accent);color:#fff;border-radius:var(--radius-pill);padding:.15rem .5rem;font-size:.65rem;font-weight:800}.leaderboard-list{flex-direction:column;gap:.5rem;display:flex}.lb-row{border:2px solid var(--border);border-radius:var(--radius-md);background:var(--card);transition:all var(--transition);align-items:center;gap:1rem;padding:1rem 1.25rem;display:flex}.lb-row:hover{border-color:var(--fg);box-shadow:3px 3px 0px var(--fg);transform:translateY(-1px)}.lb-row.lb-self{border-color:var(--accent);background:#8b5cf60a}.lb-rank{text-align:center;min-width:36px;font-size:.9rem;font-weight:800}.lb-avatar{background:var(--secondary);color:#fff;border:2px solid var(--fg);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-weight:800;display:flex}.lb-info{flex-direction:column;flex:1;display:flex}.lb-name{align-items:center;gap:.5rem;font-size:.95rem;font-weight:800;display:flex}.lb-stats{color:var(--muted-fg);align-items:center;gap:.25rem;font-size:.75rem;font-weight:600;display:flex}.lb-xp{color:var(--accent);align-items:center;gap:.25rem;font-size:.9rem;font-weight:800;display:flex}.friends-container{flex-direction:column;gap:2rem;display:flex}.pending-section h3,.friends-list h3{font-family:var(--font-heading);margin-bottom:1rem;font-size:1.2rem;font-weight:800}.pending-card,.friend-card{border:2px solid var(--border);border-radius:var(--radius-md);background:var(--card);transition:all var(--transition);align-items:center;gap:1rem;margin-bottom:.5rem;padding:1rem 1.25rem;display:flex}.pending-card:hover,.friend-card:hover{border-color:var(--fg);box-shadow:3px 3px 0px var(--fg)}.pending-avatar,.friend-avatar{background:var(--tertiary);width:44px;height:44px;color:var(--fg);border:2px solid var(--fg);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1.1rem;font-weight:800;display:flex}.pending-info,.friend-info{flex-direction:column;flex:1;display:flex}.pending-name,.friend-name{font-weight:800}.pending-level,.friend-stats{color:var(--muted-fg);align-items:center;gap:.25rem;font-size:.8rem;font-weight:600;display:flex}.pending-actions{gap:.5rem;display:flex}.btn-accept{color:#fff;border:2px solid var(--fg);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);background:#10b981;align-items:center;gap:.25rem;padding:.4rem .8rem;font-size:.8rem;font-weight:700;display:flex}.btn-accept:hover{box-shadow:2px 2px 0px var(--fg);transform:translateY(-1px)}.btn-decline{background:var(--muted);border:2px solid var(--border);border-radius:var(--radius-sm);color:var(--muted-fg);cursor:pointer;transition:all var(--transition);align-items:center;padding:.4rem .6rem;display:flex}.btn-decline:hover{border-color:var(--danger);color:var(--danger)}.btn-chat{background:var(--accent);color:#fff;border:2px solid var(--fg);border-radius:var(--radius-pill);cursor:pointer;transition:all var(--transition);align-items:center;gap:.25rem;padding:.5rem 1rem;font-size:.85rem;font-weight:700;display:flex}.btn-chat:hover{box-shadow:3px 3px 0px var(--fg);transform:translateY(-2px)}.empty-friends{text-align:center;color:var(--muted-fg);padding:3rem}.empty-friends svg{margin-bottom:1rem;font-size:3rem}.chat-container{border:3px solid var(--fg);border-radius:var(--radius-leaf);background:var(--card);box-shadow:8px 8px 0px var(--fg);flex-direction:column;height:500px;display:flex;overflow:hidden}.chat-header{border-bottom:3px solid var(--fg);background:var(--muted);align-items:center;gap:.75rem;padding:1rem 1.25rem;display:flex}.chat-user-avatar{background:var(--accent);color:#fff;border:2px solid var(--fg);border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-weight:800;display:flex}.chat-user-name{font-weight:800}.chat-user-level{color:var(--muted-fg);font-size:.75rem;font-weight:600}.chat-messages{flex-direction:column;flex:1;gap:.75rem;padding:1.5rem;display:flex;overflow-y:auto}.chat-empty{height:100%;color:var(--muted-fg);flex-direction:column;justify-content:center;align-items:center;font-weight:600;display:flex}.chat-empty svg{margin-bottom:.5rem;font-size:3rem}.chat-bubble{border-radius:var(--radius-md);border:2px solid var(--border);max-width:75%;padding:.75rem 1rem;font-size:.9rem;position:relative}.chat-bubble.sent{background:var(--accent);color:#fff;border-color:var(--fg);box-shadow:3px 3px 0px var(--fg);border-radius:16px 4px 16px 16px;align-self:flex-end}.chat-bubble.received{background:var(--muted);box-shadow:3px 3px 0px var(--border);border-radius:4px 16px 16px;align-self:flex-start}.chat-time{opacity:.7;text-align:right;margin-top:.25rem;font-size:.65rem;display:block}.chat-input-row{padding:1rem;padding-bottom:calc(1rem + env(safe-area-inset-bottom,0px));border-top:3px solid var(--fg);background:var(--muted);gap:.5rem;display:flex}.chat-input{border:2px solid var(--fg);border-radius:var(--radius-pill);transition:all var(--transition);outline:none;flex:1;padding:.75rem 1rem;font-size:.9rem;font-weight:600}.chat-input:focus{border-color:var(--accent);box-shadow:3px 3px 0px var(--accent)}@media (width<=768px){.social-page{padding:1rem}.podium{flex-direction:column;align-items:center}.podium-card.rank-1{order:1;transform:none}.podium-card.rank-2{order:2}.podium-card.rank-3{order:3}.nav-label{display:none}.social-tabs{grid-template-columns:1fr 1fr;gap:.5rem;display:grid}.social-tab{justify-content:center;width:100%;margin:0;padding:.6rem;font-size:.85rem}.social-tab:nth-child(3):last-child{grid-column:span 2}.pending-card,.friend-card,.search-result-card{flex-flow:wrap;align-items:center;padding:1rem}.pending-actions,.friend-actions,.search-result-actions{flex:100%;justify-content:flex-end;width:100%;margin-top:.5rem}.search-form{flex-direction:column!important;gap:.75rem!important}.search-form input,.search-form button{flex:none!important;width:100%!important}.lb-row{gap:.5rem;padding:.75rem}.lb-rank{min-width:24px;font-size:.85rem}.lb-name{font-size:.85rem}.groups-grid{grid-template-columns:1fr}.chat-container{animation:popUp var(--transition);z-index:10000!important;background:var(--card)!important;width:100vw!important;height:auto!important;max-height:none!important;box-shadow:none!important;border:none!important;border-radius:0!important;flex-direction:column!important;display:flex!important;position:fixed!important;inset:0!important}.chat-container .chat-messages{flex:1!important;max-height:none!important}.chat-maximize-toggle{display:none!important}.search-friend-card{padding:1rem!important}.my-id-badge{text-align:center;width:100%;margin-bottom:.5rem}}.chat-bubble.received .chat-sender-name{color:var(--accent)!important;margin-bottom:2px!important;font-size:.75rem!important;font-weight:800!important;display:block!important}.groups-container{flex-direction:column;gap:1.5rem;display:flex}.groups-actions h3{color:var(--fg);font-weight:800}.groups-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;display:grid}.chat-container.chat-maximized{animation:popUp var(--transition);z-index:10000!important;background:var(--card)!important;border:3px solid var(--fg)!important;border-radius:var(--radius-md)!important;flex-direction:column!important;width:calc(100vw - 2rem)!important;height:calc(100vh - 2rem)!important;max-height:none!important;display:flex!important;position:fixed!important;inset:1rem!important;box-shadow:0 10px 50px #0000004d!important}@keyframes popUp{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.chat-container.chat-maximized .chat-messages{flex:1!important;max-height:none!important}
