*,:before,:after{box-sizing:border-box;-webkit-tap-highlight-color:transparent}body{color:#111;background:#fafafa;margin:0}.stories-strip{-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:16px;padding:8px 16px 16px;display:flex;overflow-x:auto}.stories-strip::-webkit-scrollbar{display:none}.story{cursor:pointer;background:0 0;border:none;flex-direction:column;flex-shrink:0;align-items:center;gap:6px;width:68px;padding:0;display:flex}.story-ring{background:#e5e7eb;border-radius:50%;width:68px;height:68px;padding:3px;transition:background .2s}.story.active .story-ring{background:linear-gradient(135deg,#c17b5c,#e8a87c)}.story-avatar{background:#f3f3f3;border:2.5px solid #fff;border-radius:50%;width:100%;height:100%;overflow:hidden}.story-avatar img{object-fit:cover;width:100%;height:100%;display:block}.story-placeholder{color:#c17b5c;text-transform:uppercase;background:linear-gradient(135deg,#f5e6df,#e8d5c4);justify-content:center;align-items:center;width:100%;height:100%;font-size:1.4rem;font-weight:700;display:flex}.story-name{color:#374151;text-align:center;-webkit-line-clamp:2;-webkit-box-orient:vertical;max-width:68px;font-size:.72rem;line-height:1.2;display:-webkit-box;overflow:hidden}.story.active .story-name{color:#c17b5c;font-weight:600}.lightbox-overlay{z-index:200;touch-action:pan-y;background:#000000eb;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.lightbox-media{box-sizing:border-box;justify-content:center;align-items:center;width:100%;height:100%;padding:52px 16px 16px;display:flex}.lightbox-img{object-fit:contain;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;border-radius:6px;max-width:100%;max-height:calc(100dvh - 68px)}.lightbox-video{border-radius:6px;max-width:100%;max-height:calc(100dvh - 68px)}.lightbox-top-right{z-index:210;gap:8px;display:flex;position:fixed;top:14px;right:14px}.lightbox-icon-btn{color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#00000073;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:1rem;transition:background .15s;display:flex}.lightbox-icon-btn:active{background:#000000b3}.lightbox-icon-btn:disabled{opacity:.5;cursor:default}.lightbox-counter{color:#fff9;z-index:210;pointer-events:none;letter-spacing:.04em;align-items:center;height:40px;font-size:.82rem;display:flex;position:fixed;top:14px;left:50%;transform:translate(-50%)}.lightbox-arrow{color:#fff;cursor:pointer;z-index:210;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#00000059;border:none;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;font-size:1.8rem;transition:background .15s;display:flex;position:fixed;top:50%;transform:translateY(-50%);box-shadow:0 2px 12px #0006}.lightbox-arrow:active{background:#000000a6}.lightbox-arrow--left{left:12px}.lightbox-arrow--right{right:12px}.lightbox-delete-btn{bottom:calc(14px + env(safe-area-inset-bottom));color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:210;background:#b41e1ebf;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;transition:background .15s;display:flex;position:fixed;left:14px}.lightbox-delete-btn:active{background:#b41e1e}.gallery{max-width:960px;margin:0 auto;padding:0 0 120px;font-family:system-ui,-apple-system,sans-serif}.gallery-header{text-align:center;padding:14px 16px 10px}.gallery-header h1{letter-spacing:-.02em;font-size:1.5rem;font-weight:700}.gallery-description{color:#6b7280;margin-top:4px;font-size:.9rem;line-height:1.5}.error-banner{color:#b91c1c;background:#fee2e2;border-radius:10px;margin:0 16px 12px;padding:12px 16px;font-size:.9rem;line-height:1.4}.empty-state{text-align:center;color:#9ca3af;padding:80px 32px;font-size:1rem}.photo-grid{grid-template-columns:repeat(3,1fr);gap:8px;padding:0 16px;display:grid}.photo-tile{aspect-ratio:3/4;background:#ebebeb;border-radius:4px;position:relative;overflow:hidden}.photo-tile img{object-fit:cover;object-position:center;width:100%;height:100%;display:block}.photo-tile .video-badge{color:#fff;filter:drop-shadow(0 1px 3px #0009);pointer-events:none;position:absolute;top:6px;right:6px}.fab{z-index:50;color:#fff;cursor:pointer;background:#c17b5c;border:none;border-radius:28px;align-items:center;gap:8px;min-height:52px;padding:14px 22px;font-size:1rem;font-weight:600;transition:background .15s,transform .1s;display:flex;position:fixed;bottom:76px;right:20px;box-shadow:0 4px 16px #c17b5c73}.fab:active{transform:scale(.96)}.fab:disabled{opacity:.5;cursor:not-allowed}.modal-overlay{z-index:100;padding-bottom:calc(60px + env(safe-area-inset-bottom));background:#0006;align-items:flex-end;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:20px 20px 0 0;flex-direction:column;gap:16px;width:100%;max-height:90vh;padding:12px 20px 40px;display:flex;overflow-y:auto}.modal:before{content:"";background:#d1d5db;border-radius:2px;width:40px;height:4px;margin:0 auto 8px;display:block}.modal h2{font-size:1.2rem;font-weight:700}.field-label{color:#6b7280;margin-bottom:-8px;font-size:.85rem;font-weight:500}.modal select{cursor:pointer;background:#fff;border:1.5px solid #e5e7eb;border-radius:10px;width:100%;min-height:48px;padding:13px 14px;font-size:1rem}.btn-primary{color:#fff;cursor:pointer;background:#c17b5c;border:none;border-radius:12px;min-height:52px;padding:15px;font-size:1rem;font-weight:600;transition:background .15s}.btn-primary:active{background:#a8654a}.btn-cancel{cursor:pointer;color:#6b7280;background:0 0;border:1.5px solid #e5e7eb;border-radius:12px;min-height:48px;padding:13px;font-size:1rem}.progress-list{flex-direction:column;gap:12px;display:flex}.progress-item{flex-direction:column;gap:4px;display:flex}.progress-name{color:#374151;white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;overflow:hidden}.progress-row{align-items:center;gap:8px;display:flex}.progress-bar{background:#e5e7eb;border-radius:3px;flex:1;height:6px;overflow:hidden}.progress-fill{background:#c17b5c;border-radius:3px;height:100%;transition:width .1s}.progress-pct{color:#9ca3af;text-align:right;flex-shrink:0;width:32px;font-size:.75rem}.scroll-sentinel{justify-content:center;align-items:center;height:40px;display:flex}.loading-more{color:#9ca3af;font-size:.85rem}@media (width>=600px){.modal-overlay{align-items:center}.modal{border-radius:16px;max-width:440px;margin:0 auto;padding-bottom:28px}.modal:before{display:none}}.bingo{max-width:960px;margin:0 auto;padding:0 16px 80px;font-family:system-ui,-apple-system,sans-serif}.bingo-header{text-align:center;padding:14px 0 16px}.bingo-header h1{letter-spacing:-.02em;font-size:1.5rem;font-weight:700}.bingo-error{color:#b91c1c;cursor:pointer;background:#fee2e2;border-radius:10px;margin-bottom:16px;padding:12px 16px;font-size:.9rem}.bingo-reward{color:#92640a;background:linear-gradient(135deg,#fef9ec,#fdf0d5);border:1px solid #f5d98b;border-radius:10px;margin-top:10px;padding:10px 14px;font-size:.85rem;font-weight:600;line-height:1.45}.bingo-hint{color:#9ca3af;margin-top:6px;font-size:.8rem}.bingo-progress{color:#9ca3af;letter-spacing:.03em;margin-top:8px;font-size:.82rem;font-weight:600}.bingo-grid{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.bingo-tile{aspect-ratio:1;cursor:pointer;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;background:linear-gradient(135deg,#e8c4b0,#c17b5c);border-radius:12px;flex-direction:column;justify-content:flex-end;align-items:center;transition:transform .1s;display:flex;position:relative;overflow:hidden}.bingo-tile:active{transform:scale(.96)}.bingo-tile.uploading{cursor:default;opacity:.7}.bingo-tile-bg{object-fit:cover;width:100%;height:100%;position:absolute;inset:0}.bingo-tile-overlay{background:linear-gradient(#0000 0%,#0000001a 45%,#0009 100%);position:absolute;inset:0}.bingo-tile-label{z-index:1;color:#fff;text-align:center;text-shadow:0 1px 4px #0006;padding:0 8px 10px;font-size:.78rem;font-weight:600;line-height:1.3;position:relative}.bingo-tile:not(.done) .bingo-tile-overlay{background:linear-gradient(#0000 40%,#0000004d 100%)}.bingo-tile-check{z-index:2;color:#fff;background:#22c55e;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:.75rem;font-weight:700;display:flex;position:absolute;top:8px;right:8px;box-shadow:0 1px 4px #0000004d}.bingo-tile-spinner{z-index:2;border:3px solid #ffffff59;border-top-color:#fff;border-radius:50%;width:28px;height:28px;animation:.7s linear infinite bingo-spin;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes bingo-spin{0%{transform:translate(-50%,-50%)rotate(0)}to{transform:translate(-50%,-50%)rotate(360deg)}}.bottom-nav{z-index:100;height:60px;padding-bottom:env(safe-area-inset-bottom);background:#fff;border-top:1px solid #f0f0f0;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -1px 12px #0000000f}.bottom-nav-tab{cursor:pointer;color:#9ca3af;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding:0;font-size:.7rem;font-weight:500;transition:color .15s;display:flex}.bottom-nav-tab.active{color:#c17b5c}.bottom-nav-tab svg{transition:stroke .15s}
