@import"https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,300;9..144,600;9..144,700&family=DM+Sans:ital,wght@0,300;0,400;0,500;0,600;1,300&display=swap";:root{--navbar-h: 60px;--paper: #faf8f5;--paper-alt: #f3f0eb;--ink: #1a1410;--ink-soft: #3d3530;--muted: #7a6e66;--mint: #e8f5f0;--mint-mid: #c8ece2;--sea: #1a7a6e;--sea-light: #22a092;--sea-strong: #0f5c52;--sea-glow: rgba(26, 122, 110, .18);--sand: #f5e6cc;--accent: #e8843a;--accent-light: #fdf0e6;--danger: #c43d3d;--danger-light: #fdf0f0;--success: #1a7a4a;--success-light: #eefaf4;--panel: rgba(250, 248, 245, .92);--panel-raised: rgba(255, 254, 252, .97);--border: rgba(26, 20, 16, .1);--border-strong: rgba(26, 20, 16, .18);--border-accent: rgba(26, 122, 110, .28);--shadow-sm: 0 2px 8px rgba(26, 20, 16, .06);--shadow-md: 0 8px 24px rgba(26, 20, 16, .1);--shadow-lg: 0 20px 48px rgba(26, 20, 16, .12);--shadow-sea: 0 8px 24px rgba(26, 122, 110, .2);--radius-sm: 10px;--radius-md: 16px;--radius-lg: 24px;--radius-xl: 32px;--radius-pill: 999px;--font-display: "Fraunces", Georgia, serif;--font-body: "DM Sans", "Segoe UI", sans-serif}*,*:before,*:after{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;font-family:var(--font-body);font-size:15px;line-height:1.55;color:var(--ink);background-color:var(--paper);background-image:radial-gradient(ellipse 80% 60% at 10% 5%,rgba(232,132,58,.08) 0%,transparent 55%),radial-gradient(ellipse 60% 70% at 90% 95%,rgba(26,122,110,.1) 0%,transparent 55%);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--sea-strong);text-decoration:none;transition:color .15s ease}a:hover{color:var(--sea-light);text-decoration:underline}button,input,textarea,select{font:inherit}img{display:block;max-width:100%}p{margin:0}.auth-page,.dashboard-page{position:relative;width:100%;min-height:calc(100vh - 60px);overflow:hidden}.ambient{position:absolute;border-radius:999px;pointer-events:none;filter:blur(60px);opacity:.6}.ambient-one{width:400px;height:400px;left:-140px;top:-140px;background:radial-gradient(circle,#e8843a59,#f5e6cc33);animation:float 8s ease-in-out infinite}.ambient-two{width:320px;height:320px;right:-120px;bottom:-120px;background:radial-gradient(circle,#1a7a6e4d,#c8ece233);animation:float 11s ease-in-out infinite reverse}.ambient-three{width:480px;height:480px;right:-200px;top:-200px;background:radial-gradient(circle,rgba(232,132,58,.2),transparent);animation:float 13s ease-in-out infinite}.auth-card{position:relative;z-index:1;width:min(480px,calc(100% - 2rem));margin:2rem auto;padding:2.5rem;border-radius:var(--radius-xl);background:var(--panel-raised);border:1px solid var(--border);box-shadow:var(--shadow-lg);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);animation:rise .48s cubic-bezier(.16,1,.3,1) both}.auth-card--wide{max-width:520px}.auth-card--padless{padding:0}.auth-eyebrow,.dashboard-eyebrow{margin:0;letter-spacing:.14em;text-transform:uppercase;font-weight:600;font-size:.72rem;color:var(--sea)}.auth-title,.dashboard-title{margin:.5rem 0 0;font-family:var(--font-display);font-size:clamp(1.7rem,4vw,2.2rem);font-weight:600;line-height:1.1}.auth-subtitle{margin:.75rem 0 1.25rem;color:var(--muted);font-size:.95rem;line-height:1.6}.auth-switch{margin:1rem 0 0;font-size:.9rem;color:var(--muted);text-align:center}.notice{margin:.8rem 0;padding:.75rem 1rem;border-radius:var(--radius-sm);border:1px solid transparent;font-size:.9rem;line-height:1.5}.notice.error{background:var(--danger-light);border-color:#c43d3d40;color:#8b1d1d}.notice.success{background:var(--success-light);border-color:#1a7a4a40;color:#0e5231}.notice.info{background:var(--mint);border-color:var(--border-accent);color:var(--sea-strong)}.auth-form,.task-form{display:grid;gap:.6rem}.input-label{font-size:.82rem;color:var(--muted);font-weight:600;letter-spacing:.02em}.input-field{width:100%;border:1.5px solid var(--border);background:#ffffffd9;color:var(--ink);border-radius:var(--radius-sm);padding:.7rem .9rem;font-size:.95rem;transition:border-color .18s ease,box-shadow .18s ease}.input-field::placeholder{color:#7a6e668c}.input-field:focus{outline:none;border-color:var(--sea);box-shadow:0 0 0 3px var(--sea-glow);background:#fff}.text-area{min-height:88px;resize:vertical}.char-count{font-size:.75rem;color:var(--muted);text-align:right;margin:-4px 0 4px}.checkbox-row{display:flex;align-items:center;gap:8px;margin:8px 0;cursor:pointer}.checkbox-row input[type=checkbox]{width:16px;height:16px;accent-color:var(--sea);cursor:pointer}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1.5px solid transparent;border-radius:var(--radius-sm);font-weight:600;font-size:.9rem;cursor:pointer;transition:transform .14s ease,box-shadow .14s ease,background .14s ease,color .14s ease,border-color .14s ease;white-space:nowrap;text-decoration:none!important}.btn:disabled{opacity:.55;cursor:not-allowed;transform:none!important}.btn:not(:disabled):hover{transform:translateY(-1px)}.btn:not(:disabled):active{transform:translateY(0)}.btn-primary{padding:.72rem 1.2rem;background:linear-gradient(135deg,var(--sea) 0%,var(--sea-light) 100%);color:#f0fffe;box-shadow:var(--shadow-sea);border-color:transparent}.btn-primary:not(:disabled):hover{box-shadow:0 12px 28px #1a7a6e4d}.btn-outline{padding:.58rem 1rem;color:var(--sea-strong);border-color:var(--border-accent);background:var(--mint)}.btn-outline:not(:disabled):hover{background:var(--mint-mid)}.btn-ghost{padding:.52rem .9rem;border-color:var(--border);background:#fff;color:var(--ink-soft)}.btn-ghost:not(:disabled):hover{background:var(--paper-alt);border-color:var(--border-strong)}.btn-danger{padding:.52rem .9rem;border-color:#c43d3d47;background:var(--danger-light);color:var(--danger)}.btn-icon{width:36px;height:36px;padding:0;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--muted);font-size:1.1rem;cursor:pointer;transition:background .15s ease,color .15s ease}.btn-icon:hover{background:var(--paper-alt);color:var(--ink)}.btn-link{background:none;border:none;padding:0;color:var(--sea-strong);font-size:.88rem;cursor:pointer;text-decoration:underline;font-family:inherit;font-weight:500}.btn-link:disabled{opacity:.5;cursor:not-allowed}.btn-create{padding:.58rem 1rem;color:#f0fffe;background:linear-gradient(135deg,var(--sea) 0%,var(--sea-light) 100%);box-shadow:var(--shadow-sea)}.btn-cancel{flex:1;padding:.7rem;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:transparent;color:var(--muted);cursor:pointer;font-weight:500;transition:background .14s ease,border-color .14s ease}.btn-cancel:hover{background:var(--paper-alt);border-color:var(--border-strong)}.btn-row{display:flex;gap:8px;margin-top:8px}.btn-row .btn{flex:1}.plus-glyph{font-weight:700;font-size:1rem;line-height:1}.forgot-link-row{text-align:center;margin:4px 0 0}.forgot-link{font-size:.87rem;color:var(--muted)}.forgot-link:hover{color:var(--sea)}.otp-input{text-align:center;font-size:1.75rem;font-weight:700;letter-spacing:.6em;padding:.9rem 1rem;color:var(--ink);font-family:var(--font-display)}.otp-footer{display:flex;justify-content:space-between;align-items:center;margin-top:4px}.otp-steps{display:flex;gap:8px;justify-content:center;margin:4px 0 20px}.otp-step-dot{width:10px;height:10px;border-radius:50%;background:var(--border);transition:background .2s}.otp-step-dot.active{background:var(--sea)}.otp-step-dot.done{background:var(--success)}.navbar{position:sticky;top:0;z-index:100;display:flex;align-items:center;gap:16px;padding:0 32px;height:60px;background:var(--panel);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm)}.navbar-brand{font-family:var(--font-display);font-weight:600;font-size:1.3rem;color:var(--sea);text-decoration:none!important;letter-spacing:-.01em;flex-shrink:0}.navbar-brand:hover{color:var(--sea-strong)}.navbar-links{display:flex;gap:4px;margin-right:auto}.navbar-links a{font-size:.9rem;color:var(--muted);text-decoration:none;font-weight:500;padding:.4rem .65rem;border-radius:var(--radius-sm);transition:background .15s ease,color .15s ease}.navbar-links a:hover{background:var(--paper-alt);color:var(--ink);text-decoration:none}.navbar-links a.active{background:var(--mint);color:var(--sea-strong)}.navbar-logout{background:none;border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:5px 14px;font-size:.85rem;color:var(--muted);cursor:pointer;font-weight:500;transition:border-color .15s ease,color .15s ease,background .15s ease;flex-shrink:0}.navbar-logout:hover{border-color:var(--danger);color:var(--danger);background:var(--danger-light)}.feed-layout{max-width:620px;margin:32px auto;padding:0 16px}.post-composer{background:var(--panel-raised);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;margin-bottom:24px;box-shadow:var(--shadow-md)}.post-composer__textarea{width:100%;border:none;background:transparent;resize:none;font-size:.97rem;font-family:var(--font-body);color:var(--ink);outline:none;line-height:1.6}.post-composer__textarea::placeholder{color:var(--muted)}.post-composer__char-count{font-size:.75rem;color:var(--muted);text-align:right;margin:4px 0 12px}.post-composer__divider{height:1px;background:var(--border);margin:12px 0}.post-composer__image-preview{position:relative;margin-bottom:12px}.post-composer__image-preview img{width:100%;border-radius:var(--radius-md);max-height:320px;object-fit:cover}.post-composer__remove-image{position:absolute;top:8px;right:8px;background:#0009;color:#fff;border:none;border-radius:50%;width:30px;height:30px;cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center;transition:background .15s ease}.post-composer__remove-image:hover{background:#000000d9}.post-composer__actions{display:flex;justify-content:space-between;align-items:center}.photo-upload-label{cursor:pointer;color:var(--sea);font-size:.875rem;font-weight:500;display:inline-flex;align-items:center;gap:8px;padding:.4rem .7rem;border-radius:var(--radius-sm);transition:background .15s ease}.photo-upload-label:hover{background:var(--mint)}.post-card{background:var(--panel-raised);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:20px;box-shadow:var(--shadow-md);overflow:hidden;transition:box-shadow .2s ease}.post-card:hover{box-shadow:var(--shadow-lg)}.post-card__header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px}.post-author-link{display:flex;align-items:center;gap:10px;text-decoration:none!important}.post-card__image{width:100%;max-height:420px;object-fit:cover}.post-card__caption{padding:12px 16px;font-size:.95rem;color:var(--ink);line-height:1.55}.post-card__actions{padding:10px 16px;border-top:1px solid var(--border);display:flex;align-items:center;gap:8px}.like-btn{background:none;border:none;cursor:pointer;font-size:1.4rem;padding:4px;line-height:1;transition:transform .2s cubic-bezier(.34,1.56,.64,1)}.like-btn:hover{transform:scale(1.2)}.likes-count{font-size:.875rem;color:var(--muted);font-weight:500}.post-date{font-size:.78rem;color:var(--muted);margin-left:auto}.delete-post-btn{background:none;border:none;color:var(--muted);cursor:pointer;font-size:1.1rem;padding:4px 8px;border-radius:var(--radius-sm);line-height:1;transition:background .15s ease,color .15s ease}.delete-post-btn:hover{background:var(--danger-light);color:var(--danger)}.post-card__comments{border-top:1px solid var(--border)}.feed-loading,.feed-empty{text-align:center;padding:40px 24px;color:var(--muted);background:var(--panel-raised);border-radius:var(--radius-lg);border:1px dashed var(--border)}.feed-loading{border-style:solid}.feed-empty__emoji{font-size:2rem;margin-bottom:8px}.avatar{border-radius:50%;background:var(--mint-mid);overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;border:2px solid var(--sea)}.avatar img{width:100%;height:100%;object-fit:cover}.avatar--initial{font-weight:700;color:var(--sea);font-family:var(--font-display)}.avatar--sm{width:30px;height:30px;font-size:13px;border-width:1.5px}.avatar--md{width:40px;height:40px;font-size:17px}.avatar--lg{width:46px;height:46px;font-size:18px}.avatar--xl{width:100px;height:100px;font-size:36px;border-width:3px}.user-info__name{font-weight:600;color:var(--ink);font-size:.93rem}.user-info__handle{font-size:.78rem;color:var(--muted)}.profile-loading{text-align:center;margin-top:40vh;color:var(--muted)}.profile-avatar-section{display:flex;flex-direction:column;align-items:center;margin-bottom:24px}.profile-avatar-actions{display:flex;gap:8px;margin-top:12px}.profile-view{text-align:center}.profile-view__user-id{font-size:.72rem;color:var(--muted);margin-bottom:2px}.profile-view__name{margin:0 0 4px;font-size:1.4rem;font-family:var(--font-display);font-weight:600}.profile-view__handle{color:var(--sea);margin-bottom:8px;font-weight:500}.profile-view__bio{color:var(--muted);margin-bottom:8px;font-size:.9rem}.profile-view__website{font-size:.875rem}.profile-stats{display:flex;justify-content:center;gap:32px;margin:16px 0}.profile-stat{text-align:center}.profile-stat strong{display:block;font-size:1.1rem;font-family:var(--font-display)}.profile-stat__label{font-size:.78rem;color:var(--muted)}.profile-edit__bio-counter{font-size:.75rem;color:var(--muted);text-align:right;margin:-6px 0 6px}.profile-back-link{text-align:center;margin-top:16px;font-size:.875rem}.user-profile-center{display:flex;flex-direction:column;align-items:center;margin-bottom:20px}.user-profile-actions{display:flex;flex-direction:column;align-items:center;gap:8px;margin-top:4px}.follow-btn{min-width:140px}.follow-btn--following{background:transparent!important;color:var(--sea)!important;border-color:var(--sea)!important}.follow-btn--pending{background:transparent!important;color:var(--muted)!important;border-color:var(--border-strong)!important}.message-btn{min-width:140px;border-color:var(--border-accent)!important;background:var(--mint)!important;color:var(--sea-strong)!important}.message-btn:hover{background:var(--mint-mid)!important}.private-account-notice{text-align:center;padding:20px;border:1.5px dashed var(--border);border-radius:var(--radius-md);color:var(--muted);font-size:.9rem;background:var(--paper-alt)}.error-centered{max-width:400px;margin:40vh auto 0}.comments{padding:12px 16px 16px}.comments__error{color:var(--danger);font-size:.82rem;margin:4px 0}.comments__loading,.comments__empty{font-size:.82rem;color:var(--muted);margin:4px 0 12px}.comments__list{max-height:210px;overflow-y:auto;margin-bottom:12px;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.comment-item{display:flex;gap:8px;margin-bottom:12px;align-items:flex-start}.comment-bubble{flex:1;background:var(--mint);border-radius:0 var(--radius-md) var(--radius-md) var(--radius-md);padding:8px 12px}.comment-bubble__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.comment-author-link{font-weight:600;font-size:.82rem;color:var(--ink);text-decoration:none!important}.comment-author-link:hover{color:var(--sea)}.comment-meta{display:flex;align-items:center;gap:8px}.comment-date{font-size:.72rem;color:var(--muted)}.comment-delete-btn{background:none;border:none;cursor:pointer;font-size:.82rem;color:var(--muted);padding:0;line-height:1;transition:color .15s ease}.comment-delete-btn:hover{color:var(--danger)}.comment-text{font-size:.88rem;color:var(--ink);line-height:1.45}.comment-form{display:flex;gap:8px}.comment-form .input-field{flex:1;margin:0;padding:.5rem .85rem;font-size:.875rem}.comment-submit{padding:.5rem 1rem;font-size:.875rem}.searchbar{position:relative}.searchbar__input{margin:0;width:220px;padding:.48rem .9rem;font-size:.875rem}.searchbar__dropdown{position:absolute;top:calc(100% + 6px);left:0;background:var(--panel-raised);border:1px solid var(--border);border-radius:var(--radius-md);width:240px;box-shadow:var(--shadow-lg);z-index:200;overflow:hidden;animation:menu-drop .16s ease-out both}.searchbar__loading,.searchbar__empty{padding:.75rem 1rem;font-size:.82rem;color:var(--muted)}.searchbar__result{display:flex;align-items:center;gap:10px;padding:.65rem 1rem;cursor:pointer;border-bottom:1px solid var(--border);transition:background .15s ease}.searchbar__result:last-child{border-bottom:none}.searchbar__result:hover{background:var(--mint)}.searchbar__result-name{font-weight:600;font-size:.88rem}.searchbar__result-handle{font-size:.75rem;color:var(--muted)}.notif-bell{position:relative}.notif-bell__btn{position:relative;background:none;border:none;cursor:pointer;font-size:1.25rem;padding:6px;line-height:1;border-radius:var(--radius-sm);transition:background .15s ease}.notif-bell__btn:hover{background:var(--paper-alt)}.notif-bell__badge{position:absolute;top:-4px;right:-4px;background:var(--danger);color:#fff;border-radius:50%;font-size:.65rem;padding:2px 5px;font-weight:700;line-height:1;border:2px solid var(--panel)}.notif-dropdown{position:absolute;right:0;top:calc(100% + 8px);background:var(--panel-raised);border:1px solid var(--border);border-radius:var(--radius-md);width:330px;box-shadow:var(--shadow-lg);z-index:1000;max-height:420px;overflow-y:auto;animation:menu-drop .16s ease-out both}.notif-dropdown__header{padding:12px 16px;font-weight:700;font-size:.9rem;border-bottom:1px solid var(--border)}.notif-dropdown__empty{padding:20px 16px;text-align:center;color:var(--muted);font-size:.875rem}.notif-item{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:8px;transition:background .15s ease}.notif-item:last-child{border-bottom:none}.notif-item--unread{background:var(--mint)}.notif-item--read{background:transparent}.notif-item:hover{background:var(--paper-alt)}.notif-item__content{display:flex;align-items:center;gap:12px}.notif-item__avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;flex-shrink:0;border:1.5px solid var(--border)}.notif-item__message{font-size:.875rem;color:var(--ink);line-height:1.4}.notif-item__time{font-size:.72rem;color:var(--muted);margin-top:2px}.notif-item__actions{display:flex;gap:8px;padding-left:46px}.notif-accept-btn{padding:4px 14px;background:var(--sea);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.82rem;font-weight:600;font-family:inherit;transition:background .15s ease}.notif-accept-btn:hover{background:var(--sea-strong)}.notif-decline-btn{padding:4px 14px;background:var(--paper-alt);border:1px solid var(--border);border-radius:6px;cursor:pointer;font-size:.82rem;font-family:inherit;transition:background .15s ease}.notif-decline-btn:hover{background:var(--danger-light);border-color:#c43d3d40}.messages-header{padding:20px 24px;border-bottom:1px solid var(--border)}.messages-header h2{margin:0;font-size:1.15rem;font-family:var(--font-display);font-weight:600}.messages-loading,.messages-empty{text-align:center;padding:40px 24px;color:var(--muted)}.messages-empty__emoji{font-size:2rem;margin-bottom:8px}.messages-empty__hint{font-size:.82rem;margin-top:4px}.conversation-item{display:flex;align-items:center;gap:14px;padding:14px 24px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .18s ease}.conversation-item:last-child{border-bottom:none}.conversation-item:hover,.conversation-item--unread{background:var(--mint)}.conversation-item__info{flex:1;min-width:0}.conversation-item__name{font-weight:500;font-size:.93rem}.conversation-item__name--bold{font-weight:700}.conversation-item__handle{font-size:.8rem;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.unread-badge{background:var(--sea);color:#fff;border-radius:50%;font-size:.72rem;padding:2px 7px;font-weight:700;flex-shrink:0;line-height:1.4}.chat-window{max-width:640px;overflow:hidden}.chat-header{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--border)}.chat-header__back{background:none;border:none;cursor:pointer;font-size:1.2rem;color:var(--muted);padding:4px;border-radius:var(--radius-sm);transition:background .15s ease;line-height:1}.chat-header__back:hover{background:var(--paper-alt);color:var(--ink)}.chat-header__user-name{font-weight:600;font-size:.97rem}.chat-header__user-handle{font-size:.78rem;color:var(--muted)}.chat-messages{height:400px;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.chat-messages__loading{text-align:center;color:var(--muted);margin-top:40px}.chat-message-row{display:flex;position:relative}.chat-message-row--me{justify-content:flex-end}.chat-message-row--them{justify-content:flex-start}.chat-message-bubble{max-width:72%;padding:.55rem .9rem;border-radius:var(--radius-md);font-size:.9rem;line-height:1.45;position:relative;word-break:break-word}.chat-message-bubble--me{background:var(--sea);color:#f0fffe;border-bottom-right-radius:4px}.chat-message-bubble--them{background:var(--paper-alt);color:var(--ink);border:1px solid var(--border);border-bottom-left-radius:4px}.chat-message-meta{font-size:.68rem;margin-top:3px;opacity:.75;text-align:right}.chat-typing{display:flex;justify-content:flex-start}.chat-typing__bubble{background:var(--paper-alt);border:1px solid var(--border);border-radius:var(--radius-md);border-bottom-left-radius:4px;padding:.55rem .9rem;font-size:.82rem;color:var(--muted);font-style:italic}.chat-input-area{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--border)}.chat-input-area .input-field{flex:1;margin:0}.chat-send-btn{min-width:72px}.dashboard-shell{width:min(1120px,calc(100% - 2rem));margin:2rem auto;position:relative;z-index:1;transition:filter .2s ease,transform .2s ease}.dashboard-shell.is-blurred{filter:blur(2px) saturate(.82);transform:scale(.995);pointer-events:none}.panel{border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--panel);box-shadow:var(--shadow-lg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.dashboard-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:1.3rem 1.45rem;margin-bottom:1rem;animation:rise .44s ease-out both}.dashboard-stats{display:flex;align-items:center;gap:.9rem;flex-wrap:wrap}.dashboard-stats>div{min-width:74px;padding:.5rem .65rem;border-radius:var(--radius-sm);background:#ffffffc7;border:1px solid var(--border);text-align:center}.dashboard-stats strong{display:block;font-family:var(--font-display);font-size:1.08rem}.stat-label{display:block;font-size:.74rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.dashboard-grid{display:grid;grid-template-columns:minmax(280px,.9fr) minmax(0,1.7fr);gap:1rem}.dashboard-grid-single{grid-template-columns:1fr}.board-panel{padding:1.25rem;animation:rise .52s ease-out both}.board-panel h2{margin:0;font-family:var(--font-display);font-size:1.25rem}.board-panel-full{min-height:420px}.board-header{display:flex;align-items:center;justify-content:space-between;gap:.8rem;margin-bottom:1rem;flex-wrap:wrap}.board-header-column{align-items:flex-start;flex-direction:column;gap:.25rem}.board-subtitle{margin:0;color:var(--muted);font-size:.9rem}.category-strip{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1rem;padding:.42rem;border-radius:12px;border:1px solid rgba(26,122,110,.14);background:#ffffff9e}.category-chip{border:1px solid rgba(26,20,16,.12);border-radius:var(--radius-pill);background:#ffffffd9;color:var(--muted);padding:.36rem .82rem;cursor:pointer;transition:background .16s ease,color .16s ease,border-color .16s ease}.category-chip:hover{border-color:var(--border-accent);color:var(--sea-strong)}.category-chip.active{border-color:var(--border-accent);background:var(--mint);color:var(--sea-strong);font-weight:600}.task-list{display:grid;gap:.75rem}.task-card{border:1px solid var(--border);border-radius:var(--radius-md);background:#ffffffe0;padding:.92rem;transition:transform .2s ease,box-shadow .2s ease,filter .2s ease,opacity .2s ease}.task-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.task-card.is-completed{background:#e9ecf0e6;border-color:#1a141014;filter:saturate(.2);opacity:.82}.task-card h3{margin:.45rem 0 .3rem;font-family:var(--font-display);font-size:1.08rem}.task-card-top{display:flex;justify-content:space-between;gap:.6rem;align-items:center}.task-top-right{margin-left:auto;display:inline-flex;align-items:center;gap:.28rem}.task-check{display:inline-flex;align-items:center;gap:.45rem;font-size:.82rem;color:var(--muted);font-weight:600}.task-check input{width:18px;height:18px;accent-color:var(--sea);cursor:pointer}.task-check input:disabled{cursor:not-allowed}.task-menu-container{position:relative}.menu-trigger{width:2rem;height:2rem;border:0;background:transparent;color:#0b5f56d1;font-size:1.6rem;font-weight:700;line-height:1;padding:0;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;transition:background .16s ease,color .16s ease,transform .16s ease}.menu-trigger:hover{color:var(--sea-strong);background:#1a7a6e1a;transform:translateY(-1px)}.menu-trigger:focus-visible{outline:2px solid rgba(26,122,110,.45);outline-offset:2px}.menu-trigger-glyph{transform:translateY(-1px)}.task-menu{position:absolute;top:calc(100% + .35rem);right:0;min-width:112px;border:1px solid var(--border-accent);border-radius:var(--radius-sm);background:#fcfffe;box-shadow:var(--shadow-md);padding:.3rem;z-index:20;animation:menu-drop .16s ease-out both}.task-menu button{width:100%;border:0;border-radius:8px;background:transparent;color:var(--ink);text-align:left;padding:.44rem .48rem;cursor:pointer;font-size:.88rem}.task-menu button:hover:not(:disabled){background:var(--mint)}.task-menu button:disabled{cursor:not-allowed;opacity:.6}.task-menu .danger-item{color:var(--danger)}.task-time{color:var(--muted);font-size:.8rem}.task-description{color:var(--ink-soft);line-height:1.4}.task-category-tag{margin:.3rem 0 .42rem;color:var(--sea-strong);font-size:.8rem;letter-spacing:.02em;font-weight:600}.task-description.empty{color:var(--muted);font-style:italic}.task-edit-mode{display:grid;gap:.5rem}.task-actions{margin-top:.75rem;display:flex;flex-wrap:wrap;gap:.45rem}.status-toast{position:fixed;right:1.3rem;bottom:1.3rem;z-index:50;border-radius:var(--radius-pill);padding:.68rem 1.1rem;background:#11786df2;color:#f2fffc;font-weight:600;box-shadow:0 16px 30px #11786d4d;animation:toast-pop 2s ease both;font-size:.9rem}.empty-state{margin:0;padding:1rem;border-radius:var(--radius-md);border:1px dashed var(--border);background:#fff9;color:var(--muted)}.modal-overlay{position:fixed;inset:0;z-index:80;padding:1rem;display:grid;place-items:center;background:radial-gradient(circle at 50% 20%,#1a7a6e29,#1a141052);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);animation:modal-backdrop-in .2s ease-out both}.create-modal{width:min(560px,100%);max-height:calc(100vh - 2rem);overflow:auto;padding:1.1rem 1.1rem 1.2rem;animation:modal-card-in .24s cubic-bezier(.16,1,.3,1) both}.create-modal-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.8rem;margin-bottom:.8rem}.create-modal-header h2{margin:.34rem 0 0;font-family:var(--font-display)}.create-modal-actions{display:flex;justify-content:flex-end;gap:.55rem;margin-top:.8rem}.modal-hint{margin:0;color:var(--muted);font-size:.84rem}.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:var(--muted)}.text-sea{color:var(--sea)}.text-danger{color:var(--danger)}.text-sm{font-size:.85rem}.text-xs{font-size:.75rem}.font-display{font-family:var(--font-display)}@keyframes rise{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes float{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(22px) scale(1.02)}}@keyframes toast-pop{0%{opacity:0;transform:translateY(14px) scale(.95)}15%{opacity:1;transform:translateY(0) scale(1)}80%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(6px) scale(.98)}}@keyframes menu-drop{0%{opacity:0;transform:translateY(-4px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes modal-backdrop-in{0%{opacity:0}to{opacity:1}}@keyframes modal-card-in{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.mobile-nav{display:none}.mobile-nav__item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--muted);text-decoration:none;border:none;background:none;cursor:pointer;padding:6px 2px;font-family:var(--font-body);transition:color .15s ease,background .15s ease;-webkit-tap-highlight-color:transparent}.mobile-nav__item:hover,.mobile-nav__item--active{color:var(--sea-strong);text-decoration:none}.mobile-nav__item .material-icons-round{font-size:1.4rem;line-height:1}.mobile-nav__label{font-size:.6rem;font-weight:600;letter-spacing:.02em;text-transform:uppercase;line-height:1}.mobile-nav__notif{flex:1;display:flex;align-items:center;justify-content:center;position:relative}.mobile-nav__notif-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;background:none;border:none;cursor:pointer;color:var(--muted);font-family:var(--font-body);padding:6px 2px;width:100%;transition:color .15s ease;-webkit-tap-highlight-color:transparent}.mobile-nav__notif-btn:hover{color:var(--sea-strong)}.mobile-nav__notif-btn .material-icons-round{font-size:1.4rem;line-height:1}.notif-dropdown--mobile{bottom:calc(100% + 8px);top:auto!important;right:0;left:auto;width:280px;max-width:calc(100vw - 32px)}.messages-header{display:flex;align-items:center;gap:10px;padding:14px 20px;border-bottom:1px solid var(--border)}.messages-header h2{margin:0;font-size:1.1rem;font-family:var(--font-display)}.messages-back-btn{background:none;border:none;cursor:pointer;color:var(--muted);display:flex;align-items:center;padding:4px;border-radius:var(--radius-sm);transition:background .15s ease,color .15s ease;line-height:1}.messages-back-btn:hover{background:var(--paper-alt);color:var(--ink)}.messages-back-btn .material-icons-round{font-size:1.2rem}.profile-logout-btn{position:absolute;top:16px;right:16px;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;color:var(--muted);display:flex;align-items:center;justify-content:center;padding:6px;transition:background .15s ease,color .15s ease,border-color .15s ease;line-height:1}.profile-logout-btn:hover{background:var(--danger-light);color:var(--danger);border-color:var(--danger)}.profile-logout-btn .material-icons-round{font-size:1.1rem}.navbar-mobile-search{display:none}.navbar-search-btn{background:none;border:none;cursor:pointer;color:var(--muted);display:flex;align-items:center;padding:6px;border-radius:var(--radius-sm);transition:color .15s ease;line-height:1}.navbar-search-btn:hover{color:var(--sea)}.navbar-search-btn .material-icons-round{font-size:1.3rem}.mobile-search-overlay{display:none;position:fixed;top:50px;left:0;right:0;z-index:300;background:var(--panel);padding:12px 16px;border-bottom:1px solid var(--border);box-shadow:var(--shadow-md)}.mobile-search-overlay.is-open{display:block}@media(max-width:920px){.dashboard-grid{grid-template-columns:1fr}.dashboard-header{align-items:stretch;flex-direction:column}.dashboard-stats{justify-content:flex-start}}@media(max-width:640px){.navbar{padding:0 16px;height:50px;justify-content:space-between}.navbar-links,.navbar-logout,.searchbar{display:none}.navbar-mobile-search{display:flex;align-items:center}.mobile-search-overlay .searchbar{display:flex;width:100%}.mobile-search-overlay .searchbar__input{width:100%}.mobile-nav{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:200;height:58px;background:var(--panel);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-top:1px solid var(--border);box-shadow:0 -4px 16px #1a141014;align-items:stretch}body{padding-bottom:58px}.auth-page{min-height:calc(100vh - 108px);overflow:visible;width:100%;padding:12px;box-sizing:border-box}.auth-card{margin:1rem auto;width:100%;max-width:100%}.feed-layout{margin-top:12px;padding-bottom:16px}.chat-page{top:50px!important;bottom:58px!important;padding:0!important}.chat-card{border-radius:0;border:none;height:100%}.chat-page-loading{position:fixed;inset:50px 0 58px;display:flex;align-items:center;justify-content:center;height:auto}.ambient{display:none}}@media(max-width:560px){.auth-card{margin-top:2.5rem;padding:1.4rem}.feed-layout{margin-top:16px}.dashboard-shell{width:calc(100% - 1rem);margin-top:1rem}.board-panel,.dashboard-header{padding:1rem}.task-actions{flex-direction:column}.task-actions .btn{width:100%}.notif-dropdown{width:290px}.chat-messages{height:300px}}.btn-sm{padding:6px 14px;font-size:13px}.chat-page{position:fixed;inset:60px 0 0;display:flex;align-items:stretch;justify-content:center;padding:20px 16px;box-sizing:border-box;background-color:var(--paper);background-image:radial-gradient(ellipse 80% 60% at 10% 5%,rgba(232,132,58,.08) 0%,transparent 55%),radial-gradient(ellipse 60% 70% at 90% 95%,rgba(26,122,110,.1) 0%,transparent 55%);overflow:hidden;z-index:1}.chat-card{width:min(600px,100%);height:100%;display:flex;flex-direction:column;border-radius:var(--radius-xl);background:var(--panel-raised);border:1px solid var(--border);box-shadow:var(--shadow-lg);overflow:hidden;animation:rise .4s cubic-bezier(.16,1,.3,1) both}.chat-card__header{display:flex;align-items:center;gap:12px;padding:14px 20px;border-bottom:1px solid var(--border);flex-shrink:0}.chat-card__back{background:none;border:none;cursor:pointer;font-size:1.2rem;color:var(--muted);padding:4px 6px;border-radius:var(--radius-sm);line-height:1;transition:background .15s ease,color .15s ease}.chat-card__back:hover{background:var(--paper-alt);color:var(--ink)}.chat-card__user-name{margin:0;font-weight:600;font-size:.97rem}.chat-card__user-handle{margin:0;font-size:.78rem;color:var(--muted)}.chat-card__messages{flex:1;overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column;gap:8px;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.chat-card__empty{text-align:center;color:var(--muted);margin-top:40px;font-size:.9rem}.chat-msg-row{display:flex;width:100%}.chat-msg-row--me{justify-content:flex-end}.chat-msg-row--them{justify-content:flex-start}.chat-msg-row--me>div{display:flex;justify-content:flex-end;width:100%}.chat-msg-row--them>div{display:flex;justify-content:flex-start;width:100%}.chat-bubble{position:relative;display:block;max-width:70%;min-width:90px;padding:8px 12px 4px;font-size:.9rem;line-height:1.45;word-break:break-word;overflow-wrap:break-word;cursor:context-menu;-webkit-user-select:none;user-select:none;transition:opacity .15s ease;overflow:hidden}.chat-bubble--me{background:var(--sea);color:#fff;border-radius:18px 18px 4px}.chat-bubble--them{background:var(--mint);color:var(--ink);border-radius:18px 18px 18px 4px}.chat-bubble--deleted{background:var(--paper-alt)!important;color:var(--muted)!important;font-style:italic;cursor:default}.chat-bubble--sending{opacity:.6}.chat-bubble__body{display:block;word-break:break-word;overflow-wrap:break-word}.chat-bubble__spacer{display:block;float:right;height:0;overflow:hidden;visibility:hidden;font-size:.68rem;letter-spacing:-1px;margin-left:12px;white-space:nowrap;line-height:1}.chat-bubble__meta{float:right;clear:right;font-size:.68rem;line-height:1;padding-top:4px;margin-left:8px;display:flex;align-items:center;gap:3px;white-space:nowrap;opacity:.75}.chat-bubble__ticks{font-size:.72rem;font-weight:700;letter-spacing:-2px;white-space:nowrap;display:inline-block}.chat-bubble__ticks--read{color:#4fc3f7}.chat-bubble__ticks--unread{color:#ffffff8c}.chat-context-menu{position:absolute;bottom:calc(100% + 4px);background:var(--panel-raised);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);z-index:100;min-width:170px;overflow:hidden;animation:menu-drop .14s ease-out both}.chat-context-menu--me{right:0}.chat-context-menu--them{left:0}.chat-context-btn{display:block;width:100%;padding:10px 16px;text-align:left;background:none;border:none;cursor:pointer;font-size:.875rem;font-family:inherit;color:var(--ink);transition:background .14s ease}.chat-context-btn:hover{background:var(--mint)}.chat-context-btn--danger{color:var(--danger)}.chat-context-btn--danger:hover{background:var(--danger-light)}.chat-typing-row{display:flex;justify-content:flex-start}.chat-typing-bubble{padding:10px 14px;border-radius:18px 18px 18px 4px;background:var(--mint);font-size:.82rem;color:var(--muted);font-style:italic}.chat-card__input{display:flex;gap:10px;padding:14px 20px;border-top:1px solid var(--border);flex-shrink:0}.chat-card__input .input-field{flex:1;margin:0}.chat-card__send{min-width:70px}.chat-page-loading{display:flex;align-items:center;justify-content:center;height:calc(100vh - 60px);color:var(--muted)}@media(max-width:560px){.chat-page{padding:0}.chat-card{border-radius:0;border:none;height:100%}}
