*,:before,:after{box-sizing:border-box}:root{--bg:#0f1419;--surface:#1a2332;--surface-hover:#243044;--border:#2d3a4f;--text:#e8eef5;--muted:#8b9cb3;--accent:#5b9fd4;--accent-dim:#3d7aad;--success:#6bcf8e;--radius:12px;--font:"DM Sans", system-ui, sans-serif}html,body{min-height:100%;margin:0}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;line-height:1.5}#root{min-height:100vh}.app{flex-direction:column;min-height:100vh;display:flex}.app-loading{justify-content:center;align-items:center}.main{flex:1;width:100%;max-width:720px;margin:0 auto;padding:1.25rem 1rem 2rem}:is(.main:has(.feed-layout),.main:has(.admin-page)){max-width:1040px}.feed-layout{align-items:start;gap:1.25rem;width:100%;display:grid}@media (width<=879px){.feed-main-column{order:-1}}@media (width>=880px){.feed-layout{grid-template-columns:240px minmax(0,1fr)}}.feed-main-column{min-width:0}.feed-sidebar-column{flex-direction:column;gap:1rem;min-width:0;display:flex}.friends-sidebar{margin-bottom:0}.friend-requests-title{letter-spacing:-.01em;margin:0 0 .75rem;font-size:1rem;font-weight:700}.friend-requests-empty{color:var(--muted);margin:0;font-size:.9rem}.friend-requests-list{flex-direction:column;gap:.75rem;margin:0;padding:0;list-style:none;display:flex}.friend-request-item{margin:0;padding:0}.friend-request-email{word-break:break-all;color:var(--text);margin:0 0 .5rem;font-size:.9rem}.friend-request-actions{flex-wrap:wrap;gap:.4rem;display:flex}.friend-request-btn{padding:.35rem .65rem;font-size:.85rem}.friend-requests-error{margin:.65rem 0 0}.friends-sidebar-title{letter-spacing:-.01em;margin:0 0 .75rem;font-size:1rem;font-weight:700}.friends-sidebar-empty{color:var(--muted);margin:0;font-size:.9rem}.friends-list{flex-direction:column;gap:.5rem;margin:0;padding:0;list-style:none;display:flex}.friends-list-item{border-bottom:1px solid var(--border);margin:0;padding:.45rem 0;font-size:.9rem}.friends-list-item:last-child{border-bottom:none;padding-bottom:0}.friends-list-name{text-overflow:ellipsis;white-space:nowrap;color:var(--text);display:block;overflow:hidden}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font-family:inherit}input,textarea,select{font-family:inherit;font-size:1rem}.page-title{letter-spacing:-.02em;margin:0 0 .35rem;font-size:1.75rem;font-weight:700}.page-lead{color:var(--muted);margin:0 0 1.25rem}.page-footer{text-align:center;margin-top:1.5rem;font-size:.9rem}.profile-section-title{letter-spacing:-.01em;margin:0 0 1rem;font-size:1.05rem;font-weight:700}.profile-dl{margin:0 0 1.25rem}.profile-dl-row{gap:.25rem 1rem;margin-bottom:.85rem;display:grid}.profile-dl-row:last-child{margin-bottom:0}@media (width>=520px){.profile-dl-row{grid-template-columns:11rem minmax(0,1fr);align-items:baseline}}.profile-dl dt{color:var(--muted);font-size:.85rem;font-weight:500}.profile-dl dd{word-break:break-word;margin:0;font-size:.95rem}.profile-dl--streaks .profile-dl-row dt{align-items:center;gap:.35rem;display:flex}.profile-display-form{border-top:1px solid var(--border);flex-direction:column;gap:.75rem;padding-top:1rem;display:flex}.profile-field-hint{color:var(--muted);font-size:.8rem;line-height:1.4}.profile-save-toast{color:var(--success);margin:0;font-size:.9rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:1rem;padding:1.1rem 1.15rem}.form-card{flex-direction:column;gap:1rem;display:flex}.field{flex-direction:column;gap:.35rem;display:flex}.field span,.field label{color:var(--muted);font-size:.85rem;font-weight:500}.field input,.field textarea,.field select{border:1px solid var(--border);background:var(--bg);width:100%;color:var(--text);border-radius:8px;padding:.65rem .75rem}.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 2px #5b9fd440}.form-error{color:#f0a8a8;margin:0;font-size:.9rem}.btn{border:none;border-radius:8px;justify-content:center;align-items:center;padding:.65rem 1rem;font-size:.95rem;font-weight:600;transition:background .15s,opacity .15s;display:inline-flex}.btn:disabled{opacity:.65;cursor:not-allowed}.btn-primary{background:var(--accent);color:#0a0e14}.btn-primary:hover:not(:disabled){background:var(--accent-dim)}.btn-secondary{background:var(--surface-hover);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--border)}.btn-ghost{color:var(--muted);background:0 0;padding:.5rem}.btn-ghost:hover:not(:disabled){color:var(--text)}.navbar{border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10;background:#0f1419d9;position:sticky;top:0}.navbar-inner{justify-content:space-between;align-items:center;gap:1rem;max-width:720px;margin:0 auto;padding:.85rem 1rem;display:flex}.navbar-brand{color:var(--text);font-size:1.1rem;font-weight:700;text-decoration:none}.navbar-brand:hover{color:var(--accent);text-decoration:none}.navbar-links{flex:1;gap:.5rem;min-width:0;display:flex}.navbar-user{flex-shrink:0;align-items:center;gap:.5rem;margin-left:auto;display:flex}.navbar-user-label{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;max-width:10rem;font-size:.85rem;overflow:hidden}.navbar-streak{color:var(--accent);white-space:nowrap;align-items:center;gap:.4rem;font-size:.82rem;font-weight:600;display:inline-flex}.navbar-streak-emoji{padding:0 .1rem;display:inline-block}.btn-navbar-logout{padding:.4rem .75rem;font-size:.85rem}.nav-link{color:var(--muted);border-radius:8px;padding:.4rem .65rem;font-size:.9rem;font-weight:500;text-decoration:none}.nav-link:hover{color:var(--text);background:var(--surface);text-decoration:none}.nav-link-active{color:var(--accent);background:var(--surface)}.feed-list{flex-direction:column;gap:0;display:flex}.feed-intro{margin-top:0}.feed-empty{color:var(--muted);text-align:center;margin:0;padding:1.25rem 0;font-size:1rem}.post-card{margin-bottom:.75rem}.post-header{justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:.5rem;display:flex}.post-header-meta{flex-shrink:0;align-items:center;gap:.5rem;display:flex}.post-author{min-width:0;font-weight:600}.post-remove{border:1px solid var(--border);color:var(--muted);background:0 0;border-radius:6px;padding:.25rem .5rem;font-size:.8rem;font-weight:600}.post-remove:hover{color:#f0a8a8;background:#f0a8a814;border-color:#f0a8a873}.post-body{white-space:pre-wrap;margin:0}.post-image-wrap{border:1px solid var(--border);border-radius:8px;margin-top:.65rem;line-height:0;display:block;overflow:hidden}.post-image{object-fit:contain;background:var(--bg);width:100%;max-height:420px}.post-votes{border-top:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:.5rem;margin-top:.75rem;padding-top:.75rem;display:flex}.post-validation-msg{width:100%;color:var(--success);margin:0 0 .35rem;font-size:.9rem;font-weight:600}.post-validation-msg--not{color:var(--muted)}.post-vote-summary{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.post-vote-readonly{color:var(--text);align-items:center;gap:.25rem;font-size:.9rem;display:inline-flex}.post-vote-btn{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:8px;align-items:center;gap:.25rem;padding:.35rem .6rem;font-size:.9rem;display:inline-flex}.post-vote-btn:hover:not(:disabled){background:var(--surface-hover)}.post-vote-btn--active{border-color:var(--accent);background:#5b9fd426;box-shadow:0 0 0 1px #5b9fd459}.post-vote-count{font-variant-numeric:tabular-nums;color:var(--muted);font-size:.85rem;font-weight:600}.post-vote-btn--active .post-vote-count{color:var(--text)}.post-vote-error{width:100%;margin:.25rem 0 0}.post-comments{border-top:1px solid var(--border);margin-top:1rem;padding-top:1rem}.post-comments-heading{margin:0 0 .65rem;font-size:.95rem;font-weight:600}.post-comments-list{flex-direction:column;gap:.75rem;margin:0 0 1rem;padding:0;list-style:none;display:flex}.post-comments-empty{color:var(--muted);margin:0;font-size:.9rem}.post-comment-item{background:var(--bg);border:1px solid var(--border);border-radius:8px;margin:0;padding:.5rem .65rem}.post-comment-email{color:var(--accent);margin-bottom:.35rem;font-size:.8rem;font-weight:600;display:block}.post-comment-text{white-space:pre-wrap;word-break:break-word;margin:.35rem 0 0;font-size:.9rem}.post-comment-form{flex-direction:column;gap:.5rem;display:flex}.post-comment-input-row{align-items:flex-start;gap:.5rem;display:flex}.post-comment-input{border:1px solid var(--border);background:var(--bg);min-width:0;color:var(--text);resize:vertical;border-radius:8px;flex:1;min-height:3rem;padding:.5rem .65rem}.post-comment-input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 2px #5b9fd440}.post-comment-emoji-wrap{flex-shrink:0;position:relative}.post-comment-emoji-toggle{padding:.45rem .55rem;font-size:1.1rem;line-height:1}.post-comment-emoji-picker{background:var(--surface);border:1px solid var(--border);z-index:6;border-radius:8px;grid-template-columns:repeat(5,1fr);gap:.2rem;width:max-content;max-width:min(240px,85vw);margin-bottom:.35rem;padding:.5rem;display:grid;position:absolute;bottom:100%;right:0;box-shadow:0 6px 20px #00000059}.post-comment-emoji-btn{cursor:pointer;background:0 0;border:none;border-radius:6px;padding:.25rem;font-size:1.25rem;line-height:1.2}.post-comment-emoji-btn:hover{background:var(--surface-hover)}.post-comment-submit{align-self:flex-start}.post-comments-hint{color:var(--muted);margin:0 0 .25rem;font-size:.9rem}.snap-prompt{flex-direction:column;gap:.75rem;display:flex}.snap-photo-row{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.snap-file-input{opacity:0;pointer-events:none;width:0;height:0;position:absolute}.snap-preview{border:1px solid var(--border);background:var(--bg);border-radius:8px;max-height:240px;overflow:hidden}.snap-preview-img{object-fit:contain;width:100%;max-height:240px;display:block}.snap-prompt textarea{resize:vertical;min-height:4.5rem}.snap-label{color:var(--muted);font-size:.85rem;font-weight:500}.add-friend .card-title{margin:0 0 .35rem;font-size:1rem}.add-friend .card-desc{color:var(--muted);margin:0 0 .75rem;font-size:.85rem}.add-friend-form{flex-wrap:wrap;gap:.5rem;display:flex}.add-friend-form input{border:1px solid var(--border);background:var(--bg);min-width:180px;color:var(--text);border-radius:8px;flex:1;padding:.55rem .65rem}.add-friend-toast{color:var(--success);margin:.75rem 0 0;font-size:.85rem}.schedule-form .schedule-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.schedule-row-triple{grid-template-columns:1fr 1fr 1fr}.schedule-list{margin:0;padding:0;list-style:none}.schedule-item{flex-direction:column;gap:.75rem;margin-bottom:.75rem;display:flex}.schedule-item-row{grid-template-columns:auto auto minmax(0,1fr) auto;align-items:center;gap:.65rem .75rem;display:grid}.schedule-item-active{border-color:var(--accent);box-shadow:0 0 0 1px #5b9fd459}.schedule-item-upcoming{border-color:#8b9cb399;box-shadow:0 0 0 1px #8b9cb340}.schedule-countdown-ended{border-top-color:var(--border);background:#1a233299}.schedule-countdown-ended-text{color:var(--muted);margin:0;font-size:.9rem;font-weight:600}.schedule-day{color:var(--accent);min-width:2.5rem;font-weight:600}.schedule-time{font-variant-numeric:tabular-nums;color:var(--muted);font-size:.9rem}.schedule-label{text-align:left;text-overflow:ellipsis;min-width:0;overflow:hidden}.schedule-countdown-banner{background:#5b9fd41f;border-top:1px solid #5b9fd459;border-radius:0 0 10px 10px;flex-direction:column;justify-content:center;align-items:center;gap:.35rem;margin:0 -.15rem -.15rem;padding:1rem .75rem;display:flex}.schedule-time-remaining-label{text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-size:.8rem;font-weight:700}.schedule-time-remaining-hms{font-variant-numeric:tabular-nums;color:var(--accent);letter-spacing:.06em;font-size:clamp(1.75rem,5vw,2.75rem);font-weight:800;line-height:1.1}.schedule-delete-btn{border:1px solid var(--border);background:var(--surface-hover);width:2.25rem;height:2.25rem;color:var(--muted);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:1.35rem;line-height:1;display:inline-flex}.schedule-delete-btn:hover{color:#f0a8a8;background:#a0505026;border-color:#a05050}.schedule-list-empty{padding:.5rem 0 0;list-style:none}.schedule-modal-overlay{z-index:200;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#05080cb8;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.schedule-modal{background:var(--surface);border:1px solid var(--border);border-radius:16px;width:100%;max-width:420px;padding:1.75rem 1.5rem;box-shadow:0 24px 48px #00000073}.schedule-modal-title{letter-spacing:-.03em;color:var(--text);margin:0 0 .75rem;font-size:1.65rem;font-weight:800;line-height:1.2}.schedule-modal-body{color:var(--muted);margin:0 0 1.5rem;font-size:1rem;line-height:1.5}.schedule-modal-block{color:var(--accent);font-weight:600}.schedule-modal-actions{flex-direction:column;gap:.65rem;display:flex}.schedule-modal-primary{padding:.85rem 1rem;font-size:1.05rem}.schedule-modal-prominent .schedule-modal-title{font-size:clamp(1.5rem,4vw,2rem)}.admin-lead code{color:var(--accent);font-size:.9em}.admin-stat-grid{grid-template-columns:repeat(auto-fill,minmax(11rem,1fr));gap:.75rem;margin-bottom:1.25rem;display:grid}.admin-stat-card{margin-bottom:0}.admin-stat-label{color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin:0 0 .35rem;font-size:.8rem;font-weight:600}.admin-stat-value{font-variant-numeric:tabular-nums;color:var(--accent);margin:0;font-size:1.65rem;font-weight:800;line-height:1.2}.admin-stat-note{color:var(--muted);margin:.35rem 0 0;font-size:.75rem;line-height:1.35}.admin-stat-note code{font-size:.85em}.admin-stat-card--clickable{text-align:left;cursor:pointer;border:1px solid var(--border);width:100%;transition:border-color .15s,box-shadow .15s,transform .12s}.admin-stat-card--clickable:hover:not(:disabled){border-color:#60a5fa73;box-shadow:0 0 0 1px #60a5fa33}.admin-stat-card--clickable:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.admin-stat-card--clickable:disabled{cursor:not-allowed;opacity:.65}.admin-stat-hint{letter-spacing:.02em;color:var(--muted);opacity:.85;margin-top:.5rem;font-size:.7rem;font-weight:500;display:block}.admin-modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#080c18b8;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.admin-modal{border:1px solid var(--border);background:var(--surface);border-radius:12px;flex-direction:column;width:min(52rem,100%);max-height:min(85vh,40rem);display:flex;box-shadow:0 16px 48px #00000059}.admin-modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;gap:.75rem;padding:1rem 1.1rem;display:flex}.admin-modal-title{letter-spacing:-.02em;margin:0;font-size:1.1rem;font-weight:700;line-height:1.3}.admin-modal-close{flex-shrink:0}.admin-modal-body{flex-direction:column;min-height:0;padding:.75rem 1.1rem 1rem;display:flex;overflow:hidden}.admin-modal-count{color:var(--muted);margin:0 0 .5rem;font-size:.85rem}.admin-modal-table-wrap{flex:1;min-height:0;max-height:min(58vh,28rem);margin:0;overflow:auto}.admin-section-title{letter-spacing:-.01em;margin:0 0 .75rem;font-size:1.05rem;font-weight:700}.admin-table-section{margin-bottom:1rem}.admin-table-wrap{margin:0 -.15rem;overflow-x:auto}.admin-table{border-collapse:collapse;width:100%;font-size:.9rem}.admin-table th,.admin-table td{text-align:left;border-bottom:1px solid var(--border);padding:.5rem .65rem}.admin-table th{color:var(--muted);font-size:.8rem;font-weight:600}.admin-table-mono{word-break:break-all;color:var(--muted);font-size:.8rem}.admin-table-empty{color:var(--muted);font-style:italic}.admin-error-card{border-color:#f0a8a859}.admin-error-title{margin:0 0 .5rem;font-weight:700}.admin-error-pre{background:var(--bg);border:1px solid var(--border);white-space:pre-wrap;color:#f0a8a8;border-radius:8px;margin:0 0 1rem;padding:.75rem;font-size:.8rem;overflow:auto}.admin-error-hint{margin:0;font-size:.9rem}.admin-error-hint code{color:var(--accent);font-size:.85em}
