*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #ffffff;--surface: #fafafa;--border: #dbdbdb;--text: #262626;--muted: #8e8e8e;--accent: #262626;--danger: #ed4956;--success: #1db954;--nav-w: 244px;--nav-w-sm: 72px;--nav-h: 56px;--radius: 12px;--radius-sm: 8px;--radius-xs: 4px;--font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif}html{font-family:var(--font);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;height:100%}body{min-height:100%}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer;border:none;background:none}input,textarea{font-family:inherit;font-size:inherit}img,video{display:block}#root{min-height:100dvh}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-thumb{background:#ccc;border-radius:2px}@media (min-width: 1600px){html{font-size:17px}}.app-shell{display:flex;min-height:100dvh}.page-content{flex:1;min-width:0;min-height:100dvh}.sidebar{width:var(--nav-w-sm);flex-shrink:0;position:fixed;top:0;left:0;height:100dvh;display:flex;flex-direction:column;border-right:1px solid var(--border);background:var(--bg);z-index:200;padding:12px 0}.sidebar-logo{font-weight:800;font-size:1.1rem;letter-spacing:-.5px;padding:12px 20px 20px;display:flex;align-items:center;justify-content:center}.sidebar-logo-full{display:none}.sidebar-nav{display:flex;flex-direction:column;gap:4px;padding:0 8px;flex:1}.sidebar-item{display:flex;align-items:center;gap:16px;padding:12px;border-radius:var(--radius-sm);color:var(--text);font-size:.95rem;transition:background .15s;justify-content:center}.sidebar-item:hover{background:var(--surface)}.sidebar-item.active{font-weight:700}.sidebar-item-label{display:none}.sidebar-bottom{padding:8px;border-top:1px solid var(--border);margin-top:8px}.sidebar-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:var(--text);cursor:pointer;margin:0 auto;border:2px solid transparent;transition:border-color .15s}.sidebar-avatar:hover{border-color:var(--text)}@media (min-width: 1265px){.sidebar{width:var(--nav-w)}.sidebar-logo{justify-content:flex-start;font-size:1.25rem}.sidebar-logo-full{display:inline}.sidebar-logo-short{display:none}.sidebar-item{justify-content:flex-start;padding:12px 16px}.sidebar-item-label{display:block}.sidebar-avatar{margin:0}}@media (min-width: 769px){.page-content{margin-left:var(--nav-w-sm)}}@media (min-width: 1265px){.page-content{margin-left:var(--nav-w)}}.bottom-nav{display:none}@media (max-width: 768px){.sidebar{display:none}.page-content{margin-left:0;padding-bottom:var(--nav-h)}.bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;height:var(--nav-h);background:var(--bg);border-top:1px solid var(--border);z-index:200;align-items:center;justify-content:space-around;padding-bottom:env(safe-area-inset-bottom)}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;padding:8px 16px;color:var(--text);border-radius:var(--radius-xs);transition:opacity .15s}.bottom-nav-item:not(.active){opacity:.5}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 20px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);font-size:.875rem;font-weight:600;color:var(--text);transition:all .15s;cursor:pointer}.btn:hover{background:var(--surface)}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent);width:100%}.btn-primary:hover{opacity:.88;background:var(--accent)}.btn-sm{padding:6px 14px;font-size:.8rem}.btn-ghost{border:none;background:none;color:var(--muted);padding:6px 10px}.btn-ghost:hover{color:var(--text);background:var(--surface)}.btn-danger{color:var(--danger);border-color:var(--danger)}.btn-danger:hover{background:#fff0f0}.btn-link{background:none;border:none;color:#0095f6;font-weight:600;font-size:.85rem;padding:0}.btn-link:hover{opacity:.8}.form-input{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.9rem;background:var(--surface);color:var(--text);outline:none;transition:border-color .15s}.form-input:focus{border-color:#a0a0a0;background:var(--bg)}.error-msg{background:#fff0f0;color:var(--danger);padding:10px 14px;border-radius:var(--radius-sm);font-size:.85rem;margin-bottom:16px}.success-msg{background:#f0fff4;color:var(--success);padding:10px 14px;border-radius:var(--radius-sm);font-size:.85rem;margin-bottom:16px}.auth-page{display:flex;align-items:center;justify-content:center;min-height:100dvh;padding:24px;background:var(--surface)}.auth-box{width:100%;max-width:360px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:32px}.auth-box h1{font-size:1.75rem;font-weight:800;letter-spacing:-1px;text-align:center;margin-bottom:28px}.form-group{margin-bottom:14px}.form-group label{display:block;font-size:.8rem;font-weight:500;color:var(--muted);margin-bottom:4px}.auth-divider{text-align:center;margin:20px 0;font-size:.85rem;color:var(--muted)}.auth-switch{text-align:center;margin-top:16px;font-size:.85rem;color:var(--muted)}.auth-switch a{font-weight:700;color:var(--text)}.calendar-page{display:flex;flex-direction:column;height:100dvh;overflow:hidden}@media (max-width: 768px){.calendar-page{height:calc(100dvh - var(--nav-h))}}.calendar-topbar{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);flex-shrink:0}.calendar-topbar-title{font-size:1rem;font-weight:700}.calendar-topbar-friend{display:flex;align-items:center;gap:10px}.calendar-topbar-friend h2{font-size:1rem;font-weight:700}.month-nav{display:flex;align-items:center;gap:4px}.month-nav-btn{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text);transition:background .15s}.month-nav-btn:hover{background:var(--surface)}.month-nav-label{font-size:.9rem;font-weight:600;min-width:130px;text-align:center}.stories-row{display:flex;gap:16px;padding:12px 20px;overflow-x:auto;border-bottom:1px solid var(--border);flex-shrink:0;scrollbar-width:none}.stories-row::-webkit-scrollbar{display:none}.story-item{display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;flex-shrink:0}.story-avatar{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;color:var(--text);border:2px solid var(--border);transition:border-color .15s;overflow:hidden}.story-item:hover .story-avatar{border-color:var(--text)}.story-add-avatar{background:var(--surface);border:2px dashed var(--border);font-size:1.5rem;color:var(--muted)}.story-name{font-size:.7rem;color:var(--text);max-width:56px;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.calendar-grid-wrapper{flex:1;display:flex;flex-direction:column;overflow:hidden}.calendar-day-headers{display:grid;grid-template-columns:repeat(7,1fr);border-bottom:1px solid var(--border);flex-shrink:0}.calendar-day-header{text-align:center;padding:8px 4px;font-size:.7rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.calendar-days{flex:1;display:grid;grid-template-columns:repeat(7,1fr)}.cal-cell{border-right:1px solid var(--border);border-bottom:1px solid var(--border);position:relative;cursor:pointer;overflow:hidden;transition:background .1s}.cal-cell:nth-child(7n){border-right:none}.cal-cell.empty{cursor:default;background:var(--surface)}.cal-cell:not(.empty):hover{background:#f8f8f8}.cal-cell.is-today:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border:2px solid var(--text);pointer-events:none}.cal-cell-bg{position:absolute;top:0;right:0;bottom:0;left:0;background-size:cover;background-position:center}.cal-cell-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to bottom,rgba(0,0,0,.25) 0%,transparent 50%)}.cal-cell-num{position:relative;z-index:1;font-size:.8rem;font-weight:600;padding:6px 8px;line-height:1}.cal-cell.has-photo .cal-cell-num{color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.5)}.cal-cell-dots{position:absolute;bottom:6px;left:0;right:0;display:flex;justify-content:center;gap:3px;z-index:1}.cal-dot{width:4px;height:4px;border-radius:50%;background:var(--text)}.cal-cell.has-photo .cal-dot{background:#ffffffe6}.day-page{min-height:100dvh;display:flex;flex-direction:column}.day-topbar{position:sticky;top:0;z-index:50;background:var(--bg);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:14px 20px;flex-shrink:0}.day-topbar-back{display:flex;align-items:center;gap:6px;font-size:.85rem;color:var(--muted);padding:4px 0;transition:color .15s}.day-topbar-back:hover{color:var(--text)}.day-topbar-title{font-size:.95rem;font-weight:700;text-align:center}.day-topbar-title small{display:block;font-size:.7rem;font-weight:400;color:var(--muted);margin-top:1px}.day-topbar-nav{display:flex;gap:4px}.day-topbar-nav button{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text);transition:background .15s}.day-topbar-nav button:hover{background:var(--surface)}.day-friend-banner{padding:10px 20px;background:var(--surface);border-bottom:1px solid var(--border);font-size:.85rem;color:var(--muted);font-style:italic}.day-entries{flex:1;max-width:640px;width:100%;margin:0 auto;padding:24px 16px 100px;display:flex;flex-direction:column;gap:16px}.entry-card{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:var(--bg);animation:fadeUp .25s ease}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.entry-text-body{padding:16px;font-size:.95rem;line-height:1.65;white-space:pre-wrap;color:var(--text)}.entry-media img,.entry-media video{width:100%}.entry-media img{cursor:zoom-in}.entry-footer{display:flex;align-items:center;justify-content:space-between;padding:8px 14px 10px}.entry-caption{font-size:.85rem;color:var(--muted)}.entry-time{font-size:.72rem;color:var(--muted);margin-left:auto}.entry-delete-btn{color:var(--muted);font-size:.75rem;padding:2px 6px;border-radius:var(--radius-xs);transition:all .15s}.entry-delete-btn:hover{color:var(--danger);background:#fff0f0}.day-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--muted);padding:40px 20px}.day-empty p{font-size:.9rem}.fab{position:fixed;bottom:calc(var(--nav-h) + 16px);right:20px;width:52px;height:52px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #0000002e;z-index:50;transition:transform .15s,box-shadow .15s}.fab:hover{transform:scale(1.06);box-shadow:0 6px 20px #00000038}@media (min-width: 769px){.fab{bottom:24px}}.skeleton{background:linear-gradient(90deg,var(--surface) 25%,#ececec 50%,var(--surface) 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:var(--radius-sm)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skel-entry{height:110px;border-radius:var(--radius)}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000eb;z-index:1000;display:flex;align-items:center;justify-content:center;cursor:zoom-out}.lightbox img{max-width:95vw;max-height:95dvh;object-fit:contain;border-radius:var(--radius-sm)}.add-page{min-height:100dvh;display:flex;flex-direction:column}.add-topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--border);flex-shrink:0}.add-topbar h2{font-size:.95rem;font-weight:700}.add-body{flex:1;max-width:600px;width:100%;margin:0 auto;padding:20px 20px 40px;display:flex;flex-direction:column;gap:16px}.add-date-row{display:flex;align-items:center;gap:10px;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface)}.add-date-row input[type=date]{border:none;background:none;font-size:.875rem;font-weight:600;color:var(--text);outline:none;cursor:pointer;flex:1;font-family:var(--font)}.add-type-row{display:flex;gap:8px}.add-type-pill{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;border:1px solid var(--border);border-radius:20px;background:var(--bg);font-size:.8rem;font-weight:500;color:var(--muted);cursor:pointer;transition:all .15s}.add-type-pill:hover{border-color:var(--text);color:var(--text)}.add-type-pill.selected{background:var(--text);color:#fff;border-color:var(--text)}.add-type-pill.selected svg{stroke:#fff}.draft-items-list{display:flex;flex-direction:column;gap:10px}.draft-item{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);animation:fadeIn .2s ease}.draft-item-icon{width:28px;height:28px;border-radius:var(--radius-xs);background:var(--surface);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--muted)}.draft-item-body{flex:1;min-width:0}.draft-item-text{font-size:.875rem;color:var(--text);line-height:1.5;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.draft-item-thumb{width:100%;max-height:120px;object-fit:cover;border-radius:var(--radius-xs)}.draft-item-filename{font-size:.8rem;color:var(--muted)}.draft-item-caption{font-size:.75rem;color:var(--muted);margin-top:2px}.draft-item-remove{color:var(--muted);font-size:1rem;line-height:1;flex-shrink:0;padding:2px 4px;border-radius:4px;transition:all .15s}.draft-item-remove:hover{background:#fff0f0;color:var(--danger)}.draft-composer{border:1.5px solid var(--border);border-radius:var(--radius);overflow:hidden}.draft-composer-inner{padding:12px;display:flex;flex-direction:column;gap:10px;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.add-textarea{width:100%;min-height:100px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);resize:vertical;font-size:.9rem;line-height:1.6;outline:none;background:var(--bg);transition:border-color .15s}.add-textarea:focus{border-color:#a0a0a0}.add-file-drop{border:2px dashed var(--border);border-radius:var(--radius-sm);padding:28px 20px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:border-color .15s,background .15s;background:var(--surface);color:var(--muted);font-size:.82rem}.add-file-drop:hover{border-color:var(--text);background:#f5f5f5}.add-preview{border-radius:var(--radius-sm);overflow:hidden;max-height:200px;position:relative}.add-preview img,.add-preview video{width:100%;max-height:200px;object-fit:cover}.add-change-file{position:absolute;top:6px;right:6px;background:#0009;color:#fff;border-radius:var(--radius-xs);padding:3px 8px;font-size:.72rem;font-weight:600}.add-caption{padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.875rem;outline:none;width:100%;background:var(--bg)}.add-caption:focus{border-color:#a0a0a0}.draft-composer-actions{display:flex;justify-content:flex-end;gap:8px;padding:10px 12px;border-top:1px solid var(--border);background:var(--surface)}.add-progress{height:3px;background:var(--border);border-radius:2px;overflow:hidden}.add-progress-bar{height:100%;background:var(--accent);transition:width .2s}.weather-selector{display:flex;align-items:center;gap:12px}.weather-selector-label{font-size:.75rem;font-weight:600;color:var(--muted);flex-shrink:0}.weather-options{display:flex;gap:4px;flex-wrap:wrap}.weather-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 8px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);color:var(--muted);cursor:pointer;transition:all .15s;line-height:1}.weather-btn:hover{border-color:var(--text);color:var(--text);background:var(--surface)}.weather-btn.selected{border-color:#4e9af1;background:#eef4ff;color:#2563eb}.weather-btn-label{font-size:.75rem;font-weight:500;white-space:nowrap}.story-item.has-new .story-avatar{border-color:transparent;background-clip:padding-box;box-shadow:0 0 0 2.5px #e8474a,0 0 0 4px var(--bg)}.friends-page{padding:24px 20px;max-width:600px;margin:0 auto}.page-title{font-size:1.2rem;font-weight:700;margin-bottom:24px}.search-row{display:flex;gap:8px;margin-bottom:28px}.section-label{font-size:.7rem;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--muted);margin-bottom:12px}.friend-card{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}.friend-card:last-child{border-bottom:none}.friend-avatar{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;flex-shrink:0;color:var(--text)}.friend-info{flex:1;min-width:0}.friend-name{font-weight:600;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.friend-username{font-size:.78rem;color:var(--muted)}.friend-actions{display:flex;gap:8px;flex-shrink:0}.friends-section{margin-bottom:32px}.profile-page{padding:32px 20px;max-width:480px;margin:0 auto}.profile-header{display:flex;align-items:center;gap:24px;margin-bottom:32px;padding-bottom:28px;border-bottom:1px solid var(--border)}.profile-avatar-lg{width:86px;height:86px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;flex-shrink:0;color:var(--text)}.profile-info{flex:1;min-width:0}.profile-username{font-size:1.1rem;font-weight:700;margin-bottom:4px}.profile-display-name{font-size:.9rem;color:var(--muted);margin-bottom:12px}.profile-stats{display:flex;gap:20px}.stat-block{text-align:center}.stat-num{font-size:1rem;font-weight:700;display:block}.stat-label{font-size:.72rem;color:var(--muted)}.profile-section{margin-bottom:28px}.profile-section-title{font-size:.75rem;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--muted);margin-bottom:12px}.profile-edit-form{display:flex;gap:8px;align-items:center}.profile-logout-btn{display:flex;align-items:center;gap:10px;color:var(--danger);font-size:.9rem;font-weight:500;padding:12px 0;width:100%;border-top:1px solid var(--border);margin-top:12px}.profile-logout-btn:hover{opacity:.75}
