:root{--color-bg: #F4F5F7;--color-surface: #FFFFFF;--color-surface-alt: #F4F5F7;--color-border: #111820;--color-text: #111820;--color-text-muted: #666666;--color-primary: #1C68C5;--color-primary-dark: #1552A0;--color-danger: #E53E3E;--color-success: #7EBA8C;--color-warning: #F28C38;--accent-orange: #F28C38;--accent-green: #7EBA8C;--ink: #111820;--radius-sm: 10px;--radius-md: 16px;--radius-lg: 24px;--radius-pill: 999px;--border-thick: 3px solid var(--ink);--shadow-hard: 4px 4px 0px var(--ink);--shadow-hard-active: 1px 1px 0px var(--ink);--shadow-card: 4px 4px 0px var(--ink);--font-heading: "Inter", "Helvetica Neue", Arial, sans-serif;--font-body: "Inter", "Helvetica Neue", Arial, sans-serif;--bottom-nav-height: 64px;--swipe-deck-height: 470px}[data-theme=dark]{--color-bg: #1A1A1A;--color-surface: #242424;--color-surface-alt: #1A1A1A;--color-border: #E8E8E8;--color-text: #F0F0F0;--color-text-muted: #999999;--ink: #E8E8E8;--shadow-hard: 4px 4px 0px var(--ink);--shadow-hard-active: 1px 1px 0px var(--ink);--shadow-card: 4px 4px 0px var(--ink)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{height:100%;overscroll-behavior:none}body{height:100%;font-family:var(--font-body);background-color:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;overflow:hidden;position:relative}#root{height:100%;position:relative;z-index:1}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;opacity:.05;background-image:radial-gradient(var(--color-primary) 2px,transparent 2px);background-size:30px 30px}h1,h2,h3{font-family:var(--font-heading);font-weight:900;text-transform:uppercase;letter-spacing:-.03em;color:var(--color-primary)}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.page{display:flex;flex-direction:column;height:100%;overflow:hidden}.page-content{flex:1;overflow:hidden;padding:16px 20px calc(var(--bottom-nav-height) + 16px)}.page-content.scrollable{overflow-y:auto}.page-content.centered{display:flex;align-items:center;justify-content:center}.top-bar{display:flex;align-items:center;justify-content:space-between;padding:24px 20px 12px;background:var(--color-bg);flex-shrink:0}.top-bar-title{font-size:32px;font-weight:900;color:var(--color-primary);text-transform:uppercase;letter-spacing:-1.5px;line-height:1}.top-bar-actions{display:flex;align-items:center;gap:8px}.avatar-btn{width:40px;height:40px;border-radius:50%;background:var(--color-surface);color:var(--color-text);font-weight:900;font-size:16px;border:var(--border-thick);box-shadow:var(--shadow-hard);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .1s ease}.avatar-btn:active{transform:translate(3px,3px);box-shadow:var(--shadow-hard-active)}.streak-badge,.points-badge{font-size:13px;font-weight:800;background:var(--color-surface);border:var(--border-thick);box-shadow:var(--shadow-hard);border-radius:var(--radius-pill);padding:4px 12px;color:var(--color-text)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:var(--bottom-nav-height);display:flex;background:var(--color-surface);border-top:var(--border-thick);z-index:100}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;text-decoration:none;color:var(--color-text-muted);font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;transition:color .15s}.bottom-nav-item.active{color:var(--color-primary)}.bottom-nav-icon{font-size:20px;line-height:1}.bottom-nav-label{line-height:1}.swipe-page-content{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;overflow:hidden;padding:8px 20px calc(var(--bottom-nav-height) + 16px)}.swipe-deck-wrapper{display:flex;flex-direction:column;align-items:center;gap:16px;width:100%;max-width:380px}.swipe-deck{position:relative;width:100%;height:470px}.tinder-card-wrapper{position:absolute;width:100%}.tinder-card-wrapper.gone{display:none}.swipe-card{background:var(--color-surface);border-radius:var(--radius-lg);border:var(--border-thick);box-shadow:var(--shadow-hard);overflow:hidden;-webkit-user-select:none;user-select:none;cursor:grab;width:100%;display:flex;flex-direction:column}.swipe-card:active{cursor:grabbing}.swipe-card-header{min-height:195px;display:flex;align-items:center;justify-content:center;border-bottom:var(--border-thick);position:relative;overflow:hidden}.swipe-card-body{padding:20px;display:flex;flex-direction:column;gap:12px}.creator-badge{align-self:flex-start;font-size:12px;font-weight:700;padding:5px 12px;background:var(--color-bg);border:2px solid var(--ink);border-radius:var(--radius-pill);color:var(--color-text-muted);display:flex;align-items:center;gap:6px}.activity-name{font-size:42px;font-weight:900;color:var(--color-primary);text-transform:uppercase;letter-spacing:-2px;line-height:.92}.activity-meta{display:flex;flex-direction:column;gap:10px}.meta-row{display:flex;align-items:flex-start;gap:12px}.meta-dot{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:900;color:var(--color-primary);flex-shrink:0;margin-top:1px}.meta-label{font-size:11px;font-weight:700;letter-spacing:.5px;color:var(--color-text-muted);text-transform:uppercase}.meta-value{font-size:15px;font-weight:700;color:var(--color-text)}.divider{border:none;border-top:2px dashed var(--ink);margin-top:auto}.progress-section{display:flex;flex-direction:column;gap:6px}.progress-header{display:flex;justify-content:space-between;align-items:center;font-size:13px;font-weight:700}.progress-label{text-transform:uppercase;letter-spacing:.05em}.progress-count{font-weight:900}.progress-count.confirmed{color:var(--accent-green)}.progress-track{height:12px;background:var(--color-bg);border-radius:var(--radius-pill);overflow:hidden;border:2px solid var(--ink)}.progress-fill{height:100%;background:var(--accent-green);border-right:2px solid var(--ink);transition:width .3s ease}.progress-fill.confirmed{background:var(--accent-green)}.swipe-buttons{display:flex;gap:16px;width:100%}.swipe-btn{flex:1;height:72px;border-radius:var(--radius-pill);border:var(--border-thick);box-shadow:var(--shadow-hard);font-family:var(--font-heading);font-weight:900;font-size:20px;letter-spacing:.02em;text-transform:uppercase;cursor:pointer;transition:all .1s ease;display:flex;align-items:center;justify-content:center}.swipe-btn:disabled{opacity:.5;cursor:not-allowed}.swipe-btn.decline{background:var(--color-surface);color:var(--color-text)}.swipe-btn.join{background:var(--color-primary);color:#fff}.swipe-btn:not(:disabled):active{transform:translate(3px,3px);box-shadow:var(--shadow-hard-active)}.all-swiped-view{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:16px;padding:32px 24px}.all-swiped-emoji{font-size:72px}.all-swiped-title{font-size:28px;letter-spacing:-1px;color:var(--color-primary)}.all-swiped-text{color:var(--color-text-muted);font-size:16px}.all-swiped-hint{font-size:14px;color:var(--color-text-muted)}.streak-reward{display:flex;align-items:center;gap:12px;background:var(--color-surface);border:var(--border-thick);box-shadow:var(--shadow-hard);border-radius:var(--radius-lg);padding:16px 20px}.streak-reward-icon{font-size:32px}.streak-reward-points{font-size:22px;font-weight:900;color:var(--color-primary)}.streak-reward-label{font-size:13px;color:var(--color-text-muted)}.auth-page{min-height:100%;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:24px 20px 40px;overflow-y:auto;gap:16px}.auth-card{width:100%;max-width:400px;background:var(--color-surface);border-radius:var(--radius-lg);border:var(--border-thick);box-shadow:var(--shadow-hard);padding:32px 24px;display:flex;flex-direction:column;gap:20px}.auth-title{font-size:32px;text-align:center;letter-spacing:-1.5px}.auth-subtitle{text-align:center;color:var(--color-text-muted);margin-top:-12px}.auth-link{text-align:center;font-size:14px;color:var(--color-text-muted)}.auth-link a{color:var(--color-primary);font-weight:700;text-decoration:none}.auth-hint{text-align:center;font-size:13px;color:var(--color-text-muted)}.pending-icon{font-size:56px;text-align:center}.auth-form,.create-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px;flex:1}.form-group label{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted)}.form-group input,.form-group select{height:48px;padding:0 16px;background:var(--color-surface-alt);border:2px solid var(--ink);border-radius:var(--radius-md);font-size:16px;color:var(--color-text);font-family:var(--font-body);outline:none;transition:box-shadow .1s ease}.form-group input:focus,.form-group select:focus{box-shadow:3px 3px 0 var(--ink)}.form-row{display:flex;gap:12px;overflow:hidden}.form-row .form-group{min-width:0}.form-error{background:#fff0f0;border:2px solid var(--color-danger);border-radius:var(--radius-sm);padding:10px 14px;font-size:14px;font-weight:700;color:var(--color-danger)}.form-hint{font-size:13px}.form-hint.success{color:var(--accent-green);font-weight:700}.btn{display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-weight:900;text-transform:uppercase;letter-spacing:.04em;cursor:pointer;border:var(--border-thick);box-shadow:var(--shadow-hard);border-radius:var(--radius-pill);transition:all .1s ease;text-decoration:none;white-space:nowrap}.btn:not(:disabled):active{transform:translate(3px,3px);box-shadow:var(--shadow-hard-active)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-sm{height:36px;padding:0 16px;font-size:13px}.btn-md{height:48px;padding:0 24px;font-size:14px}.btn-lg{height:60px;padding:0 32px;font-size:18px}.btn-full{width:100%}.btn-primary{background:var(--color-primary);color:#fff}.btn-outline{background:var(--color-surface);color:var(--color-text)}.btn-ghost{background:transparent;color:var(--color-text);box-shadow:none}.btn-danger{background:var(--color-danger);color:#fff}.emoji-grid,.color-grid{display:flex;flex-wrap:wrap;gap:8px}.emoji-option{width:44px;height:44px;border-radius:var(--radius-sm);border:2px solid var(--ink);background:var(--color-surface-alt);font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .1s ease;box-shadow:2px 2px 0 var(--ink)}.emoji-option:active{transform:translate(2px,2px);box-shadow:none}.emoji-option.selected{border-color:var(--color-primary);background:var(--color-primary);color:#fff;box-shadow:2px 2px 0 var(--ink)}.color-option{width:36px;height:36px;border-radius:50%;border:3px solid transparent;cursor:pointer;transition:all .15s;box-shadow:2px 2px 0 var(--ink)}.color-option.selected{border-color:var(--ink);transform:scale(1.15)}.activity-preview{display:flex;align-items:center;gap:16px;padding:16px;background:var(--color-surface-alt);border-radius:var(--radius-md);border:var(--border-thick);box-shadow:var(--shadow-hard)}.preview-name{font-size:20px;font-weight:900;color:var(--color-primary);text-transform:uppercase;letter-spacing:-.5px}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:2px solid var(--ink)}.toggle-label{font-weight:700;font-size:15px}.toggle-desc{font-size:13px;color:var(--color-text-muted);margin-top:2px}.toggle{width:44px;height:24px;accent-color:var(--color-primary);cursor:pointer;flex-shrink:0}.activity-list-card{display:flex;align-items:center;gap:12px;padding:14px;background:var(--color-surface);border-radius:var(--radius-md);border:var(--border-thick);box-shadow:var(--shadow-hard);margin-bottom:12px}.activity-list-card.cancelled{opacity:.7}.activity-list-info{flex:1;min-width:0}.activity-list-name{font-weight:800;font-size:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.activity-list-meta{font-size:13px;color:var(--color-text-muted);margin-top:2px}.activity-list-relative{font-size:12px;font-weight:800;color:var(--color-primary);margin-top:2px;text-transform:uppercase;letter-spacing:.03em}.badge{padding:4px 12px;border-radius:var(--radius-pill);font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;flex-shrink:0;border:2px solid var(--ink)}.badge-joined,.badge-completed{background:var(--accent-green);color:var(--ink)}.badge-cancelled{background:#ffb3b3;color:var(--ink)}.badge-open{background:var(--color-surface-alt);color:var(--color-text-muted)}.section-title{font-size:14px;font-weight:800;color:var(--color-text-muted);margin-bottom:12px;margin-top:8px;text-transform:uppercase;letter-spacing:.06em}.month-selector{display:flex;align-items:center;justify-content:space-between;padding:12px 0;margin-bottom:8px}.month-selector button{background:var(--color-surface);border:var(--border-thick);box-shadow:var(--shadow-hard);border-radius:50%;width:40px;height:40px;font-size:18px;cursor:pointer;color:var(--color-text);transition:all .1s ease;display:flex;align-items:center;justify-content:center}.month-selector button:not(:disabled):active{transform:translate(3px,3px);box-shadow:var(--shadow-hard-active)}.month-selector button:disabled{opacity:.3;cursor:not-allowed;box-shadow:none}.month-label{font-weight:900;font-size:18px;letter-spacing:-.5px}.award-card{display:flex;align-items:center;gap:16px;padding:16px;border-radius:var(--radius-lg);border:var(--border-thick);box-shadow:var(--shadow-hard);margin-bottom:12px}.award-card.winner{background:#fffbeb}.award-card.bailer{background:#fff5f5}.award-emoji{font-size:36px}.award-title{font-size:11px;font-weight:800;text-transform:uppercase;color:var(--color-text-muted);letter-spacing:.06em}.award-name{font-size:22px;font-weight:900;color:var(--color-text);letter-spacing:-.5px}.award-points{font-size:14px;font-weight:700;color:var(--color-text-muted)}.leaderboard-list{display:flex;flex-direction:column;gap:6px}.leaderboard-row{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--color-surface);border-radius:var(--radius-md);border:var(--border-thick);box-shadow:var(--shadow-hard)}.leaderboard-row.top{background:var(--color-surface)}.leaderboard-row.me{background:var(--color-primary);color:#fff}.leaderboard-row.me .lb-points,.leaderboard-row.me .lb-name{color:#fff}.lb-rank{font-size:18px;width:32px;text-align:center;font-weight:900}.lb-name{flex:1;font-weight:700}.lb-streak{font-size:13px}.lb-points{font-weight:900;color:var(--color-primary)}.profile-header{display:flex;align-items:center;gap:16px;padding:16px;background:var(--color-surface);border-radius:var(--radius-lg);border:var(--border-thick);box-shadow:var(--shadow-hard);margin-bottom:16px;flex-wrap:wrap}.profile-avatar{width:64px;height:64px;border-radius:50%;background:var(--color-surface);color:var(--color-text);font-size:28px;font-weight:900;border:var(--border-thick);box-shadow:var(--shadow-hard);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .1s ease}.profile-avatar:active{transform:translate(3px,3px);box-shadow:var(--shadow-hard-active)}.profile-name{font-size:22px;font-weight:900;letter-spacing:-.5px}.profile-fullname{font-size:14px;color:var(--color-text-muted)}.profile-room{font-size:13px;color:var(--color-text-muted)}.profile-role{font-size:12px;font-weight:800;color:var(--color-primary);text-transform:uppercase;letter-spacing:.06em;margin-top:4px}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:16px}.stat-card{background:var(--color-surface);border:var(--border-thick);box-shadow:var(--shadow-hard);border-radius:var(--radius-md);padding:12px 8px;text-align:center}.stat-value{font-size:24px;font-weight:900;color:var(--color-primary);letter-spacing:-1px}.stat-label{font-size:10px;font-weight:700;color:var(--color-text-muted);margin-top:2px;text-transform:uppercase;letter-spacing:.04em}.point-event{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--color-surface);border-radius:var(--radius-md);border:2px solid var(--ink);box-shadow:2px 2px 0 var(--ink);margin-bottom:6px}.point-event-desc{flex:1;font-size:13px;font-weight:600}.point-event-date{font-size:11px;color:var(--color-text-muted)}.point-event-amount{font-weight:900;font-size:15px}.point-event-amount.pos{color:var(--accent-green)}.point-event-amount.neg{color:var(--color-danger)}.profile-actions{margin-top:16px;display:flex;flex-direction:column;gap:12px}.admin-user-card{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px;background:var(--color-surface);border:var(--border-thick);box-shadow:var(--shadow-hard);border-radius:var(--radius-md);margin-bottom:10px}.admin-user-name{font-weight:800;font-size:16px;display:flex;align-items:center;gap:6px}.admin-user-meta{font-size:13px;color:var(--color-text-muted);margin-top:2px}.admin-user-actions{display:flex;gap:8px;flex-shrink:0;align-items:center}.admin-inline-input{height:36px;padding:0 10px;border:2px solid var(--ink);border-radius:var(--radius-sm);font-size:15px;color:var(--color-text);background:var(--color-surface-alt);min-width:0}.admin-role-select{height:36px;padding:0 8px;border:2px solid var(--ink);border-radius:var(--radius-sm);font-size:13px;background:var(--color-surface-alt);color:var(--color-text);cursor:pointer}.btn-icon{background:none;border:none;cursor:pointer;font-size:14px;padding:2px}.empty-state{text-align:center;color:var(--color-text-muted);padding:32px 16px;font-size:15px;font-weight:600}.centered{display:flex;align-items:center;justify-content:center}.loading-spinner{width:40px;height:40px;border:4px solid var(--color-bg);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.create-form{padding-bottom:32px}.install-prompt{display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--color-surface);color:var(--color-text);padding:12px 16px;font-size:13px;font-weight:700;border:var(--border-thick);box-shadow:var(--shadow-hard);border-radius:var(--radius-md);width:100%;max-width:400px}.install-prompt-close{background:none;border:none;color:var(--color-text-muted);font-size:16px;cursor:pointer;padding:0 4px;flex-shrink:0}.profile-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:var(--color-bg);display:flex;flex-direction:column;overflow:hidden}.emoji-picker-popover{display:flex;flex-wrap:wrap;gap:8px;background:var(--color-surface);border:var(--border-thick);box-shadow:var(--shadow-hard);border-radius:var(--radius-md);padding:12px;margin-bottom:16px;width:100%}.badges-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;padding:4px 0 8px}.badge-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 6px;border-radius:var(--radius-md);border:2px solid var(--color-border);text-align:center;transition:transform .15s ease,box-shadow .15s ease}.badge-item.unlocked{background:var(--color-surface);box-shadow:var(--shadow-hard);border-color:var(--ink)}.badge-item.locked{background:var(--color-bg);opacity:.35;filter:grayscale(1)}.badge-icon{font-size:28px;line-height:1}.badge-name{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted)}.badge-item.unlocked .badge-name{color:var(--color-text)}.rating-btn{background:var(--color-bg);border:2px solid var(--color-border);border-radius:var(--radius-sm);width:32px;height:32px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .1s ease,box-shadow .1s ease}.rating-btn:not(:disabled):hover{transform:translateY(-2px);box-shadow:var(--shadow-hard)}.rating-btn.active{background:var(--color-primary);border-color:var(--ink);box-shadow:var(--shadow-hard)}.rating-btn:disabled{cursor:default;opacity:.5}.form-select{height:48px;padding:0 16px;background:var(--color-surface-alt);border:2px solid var(--ink);border-radius:var(--radius-md);font-size:16px;color:var(--color-text);font-family:var(--font-body);outline:none;width:100%}.form-select:focus{box-shadow:3px 3px 0 var(--ink)}
