.photoWrap{position:relative;display:inline-block;flex-shrink:0;line-height:0;vertical-align:middle}.photo{display:inline-flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:var(--gradient-brand);color:var(--text-inverse);flex-shrink:0;-webkit-user-select:none;user-select:none;font-family:var(--font-display);font-weight:800;letter-spacing:-.02em;box-shadow:0 2px 6px #0000004d;vertical-align:middle;width:100%;height:100%}.photo-circle{border-radius:50%}.photo-rounded{border-radius:var(--radius-md)}.photo img{width:100%;height:100%;object-fit:cover;display:block;border-radius:inherit}.photo-initials,.photo-fallback{display:flex;align-items:center;justify-content:center;width:100%;height:100%;line-height:1}.photo-gradient-0{background:var(--gradient-brand)}.photo-gradient-1{background:var(--gradient-cool)}.photo-gradient-2{background:var(--gradient-success)}.photo-gradient-3{background:linear-gradient(135deg,#ec4899,#f43f5e)}.photo-fallback{color:var(--text-inverse)}.photo-badge{position:absolute;z-index:3;pointer-events:none;line-height:1}.photo-badge-topLeft{top:-3px;left:-3px}.photo-badge-bottomRight{bottom:-3px;right:-3px}.gameCard-link{text-decoration:none;color:inherit;display:block;margin-bottom:12px;border-radius:var(--radius-lg)}.gameCard{padding:0;display:flex;flex-direction:column;overflow:hidden;isolation:isolate}.gameCard-hero{position:relative;height:150px;background:var(--surface-2);isolation:isolate}.gameCard-heroImg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;display:block;z-index:0}.gameCard-heroImg-fallback{display:none}.gameCard-heroOverlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#0000002e,#0000000d 35%,#000000c7);z-index:1;pointer-events:none}.gameCard-heroTop{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;gap:8px;padding:12px 14px 0}.gameCard-heroStatus{display:inline-flex;align-items:center;gap:6px;flex-wrap:wrap}.gameCard-heroPill{flex-shrink:0;display:inline-flex;align-items:center;background:linear-gradient(135deg,#16a34a,#22c55e);color:#fff;font-family:var(--font-mono);font-variant-numeric:tabular-nums;font-size:12px;font-weight:800;padding:4px 10px;border-radius:10px;box-shadow:0 2px 8px #16a34a66,0 0 0 1px #ffffff1f inset;letter-spacing:.02em}.gameCard-heroBody{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:12px 14px;color:#fff;display:flex;flex-direction:column-reverse;gap:4px}.gameCard-heroTitle{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-display);font-size:19px;font-weight:800;line-height:1.1;letter-spacing:-.02em;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.55)}.gameCard-heroTitleIcon{color:#fffffff2;font-size:16px}.gameCard-heroMeta{display:flex;flex-direction:column;gap:2px;color:#ffffffd9;font-size:11px;font-weight:500;text-shadow:0 1px 4px rgba(0,0,0,.4)}.gameCard-heroMeta span{display:inline-flex;align-items:center;gap:5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gameCard-heroMeta i{color:#ffffffbf;flex-shrink:0}.badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:var(--radius-pill);font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;flex-shrink:0;background:#00000059;color:#fff;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);box-shadow:0 0 0 1px #ffffff14 inset}.badge-dot{width:6px;height:6px;border-radius:50%;background:currentColor;box-shadow:0 0 8px currentColor}.badge-open{color:#34d399}.badge-full{color:#fbbf24}.badge-cancelled{color:#f87171}.badge-finished{color:#ffffffb3}.closedPill{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:var(--radius-pill);font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;background:#0006;color:#fff;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);box-shadow:0 0 0 1px #ffffff14 inset}.gameCard-info{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 14px 12px}.gameCard-playersRow{display:flex;align-items:center;flex:1;min-width:0}.gameCard-playersRow .photoWrap{margin-right:-8px;position:relative;z-index:0}.gameCard-playersRow .photoWrap .photo{box-shadow:0 0 0 2px var(--surface-1)}.gameCard-playersRow .photoWrap:nth-of-type(1){z-index:1}.gameCard-playersRow .photoWrap:nth-of-type(2){z-index:2}.gameCard-playersRow .photoWrap:nth-of-type(3){z-index:3}.gameCard-playersRow .photoWrap:nth-of-type(4){z-index:4}.gameCard-playersRow .photoWrap:nth-of-type(5){z-index:5}.gameCard-playersMore{margin-left:14px;font-size:11px;font-weight:700;color:var(--text-tertiary);font-variant-numeric:tabular-nums;letter-spacing:.02em}.gameCard-hostSub{font-size:11px;color:var(--text-tertiary);font-weight:500;text-align:right;line-height:1.3;white-space:nowrap}.gameCard-hostSub strong{color:var(--text-primary);font-weight:700;font-variant-numeric:tabular-nums}.gameCard-capacityFree{color:var(--success);font-weight:600}.gameCard-right{display:flex;flex-direction:column;align-items:flex-end;gap:3px;flex-shrink:0;max-width:50%}.gameCard-tags{display:flex;gap:4px;flex-wrap:wrap;justify-content:flex-end}.gameCard-price{text-align:right;line-height:1.05;display:inline-flex;align-items:baseline;gap:3px;white-space:nowrap}.gameCard-priceValue{font-size:15px;font-weight:800;font-family:var(--font-mono);color:var(--brand);letter-spacing:-.02em;font-variant-numeric:tabular-nums}.gameCard-priceLabel{font-size:10px;color:var(--text-tertiary);font-weight:600;text-transform:lowercase;letter-spacing:.02em}.gameCard-urgent{display:inline-flex;align-items:center;gap:4px;margin:0 14px 12px;padding:4px 10px;background:var(--warning-soft);color:var(--warning);border-radius:var(--radius-pill);font-size:11px;font-weight:600;letter-spacing:.02em;align-self:flex-start;border:1px solid rgba(245,158,11,.3)}.home{display:flex;flex-direction:column}.home-hero{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-bottom:24px;padding:20px 18px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-xl);position:relative;overflow:hidden}.home-hero:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.14) 50%,transparent 100%)}.home-hero:after{content:"";position:absolute;top:-40px;right:-40px;width:200px;height:200px;background:var(--gradient-brand-subtle);filter:blur(40px);pointer-events:none;z-index:0}.home-hero-text{flex:1;min-width:0;position:relative;z-index:1}.home-hero-eyebrow{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;color:var(--brand-300);background:var(--brand-soft);padding:4px 10px;border-radius:var(--radius-pill);margin-bottom:10px;letter-spacing:.02em}.home-hero-title{font-size:26px;line-height:1.15;font-weight:800;margin:0 0 6px;color:var(--text-primary)}.home-hero-title .wave{display:inline-block;transform-origin:70% 70%;animation:wave 2.4s var(--ease-out) infinite;margin-left:4px}.home-hero-sub{color:var(--text-tertiary);font-size:13px;margin:0;font-weight:500;line-height:1.4}.home-hero-mascot{position:relative;width:88px;height:88px;flex-shrink:0;z-index:1}.mascot-glow{position:absolute;top:-10px;right:-10px;bottom:-10px;left:-10px;background:var(--gradient-brand);filter:blur(20px);opacity:.4;border-radius:50%;z-index:0;animation:float 4s ease-in-out infinite}.mascot-orbit{position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border:1.5px dashed rgba(255,182,39,.25);border-radius:50%;z-index:1;animation:orbit 18s linear infinite}.mascot-img{position:relative;z-index:2;width:88px;height:88px;object-fit:contain;filter:drop-shadow(0 6px 18px rgba(0,0,0,.5));animation:float 3.6s ease-in-out infinite}.hero-cta{width:100%;display:flex;align-items:center;justify-content:space-between;background:var(--gradient-brand);color:var(--text-inverse);border:none;border-radius:var(--radius-lg);padding:16px 18px;margin-bottom:16px;cursor:pointer;font-family:var(--font-display);position:relative;overflow:hidden;box-shadow:var(--shadow-md),var(--shadow-glow),var(--shadow-inner);transition:transform var(--dur-instant) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out),filter var(--dur-fast) var(--ease-out)}.hero-cta:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:linear-gradient(180deg,rgba(255,255,255,.18) 0%,transparent 50%);pointer-events:none}.hero-cta:hover{transform:translateY(-1px);filter:brightness(1.04);box-shadow:var(--shadow-lg),var(--shadow-glow-strong),var(--shadow-inner)}.hero-cta:active{transform:scale(.98);filter:brightness(.95);transition-duration:var(--dur-instant)}.hero-cta-content{display:flex;align-items:center;gap:14px;position:relative;z-index:1}.hero-cta-icon{width:40px;height:40px;border-radius:12px;background:#0a0f1c33;color:var(--text-inverse);display:flex;align-items:center;justify-content:center}.hero-cta-title{font-size:16px;font-weight:700;text-align:left;line-height:1.2;letter-spacing:-.01em}.hero-cta-sub{font-size:12px;font-weight:500;text-align:left;opacity:.75;margin-top:2px}.hero-cta-arrow{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:#0a0f1c26;color:var(--text-inverse);position:relative;z-index:1;flex-shrink:0}.stat-strip{display:flex;align-items:stretch;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 8px;margin-bottom:24px;box-shadow:var(--shadow-inner)}.stat{flex:1;text-align:center;padding:0 4px;position:relative}.stat-value{font-size:22px;font-weight:800;font-family:var(--font-display);color:var(--text-primary);letter-spacing:-.03em;font-variant-numeric:tabular-nums;line-height:1.1;margin-bottom:2px}.stat-label{font-size:11px;color:var(--text-tertiary);font-weight:500;text-transform:uppercase;letter-spacing:.04em}.stat-divider{width:1px;background:var(--border);margin:4px 0}.home-hero-avatar{flex-shrink:0;position:relative;z-index:1}.home-hero-avatar:before{content:"";position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px;background:var(--gradient-brand);filter:blur(20px);opacity:.4;border-radius:50%;z-index:-1}.home-onboardBanner{display:flex;align-items:center;gap:12px;padding:14px 16px;width:100%;background:var(--brand-soft);border:1.5px solid var(--brand);border-radius:var(--radius-lg);text-align:left;font-family:inherit;color:var(--text-primary);cursor:pointer;box-shadow:0 4px 16px var(--brand-glow);animation:onboard-pulse 2.4s ease-in-out infinite;transition:transform var(--dur-fast) var(--ease-out);margin-bottom:16px}.home-onboardBanner:hover{transform:translateY(-1px)}.home-onboardBanner:active{transform:scale(.99)}@keyframes onboard-pulse{0%,to{box-shadow:0 4px 16px var(--brand-glow)}50%{box-shadow:0 6px 24px var(--brand-glow)}}.home-onboardBanner-icon{width:36px;height:36px;border-radius:var(--radius-sm);background:var(--gradient-brand);color:var(--text-inverse);display:flex;align-items:center;justify-content:center;flex-shrink:0}.home-onboardBanner-text{flex:1;min-width:0}.home-onboardBanner-title{font-size:14px;font-weight:700;font-family:var(--font-display);color:var(--text-primary);margin-bottom:2px}.home-onboardBanner-sub{font-size:12px;color:var(--text-tertiary);font-weight:500}.home-onboardBanner i{color:var(--text-tertiary)}.home-hero-titleRow{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:6px}.home-hero-titleRow .home-hero-title{margin:0}.home-hero-adminPill{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;font-size:11px;font-weight:700;font-family:var(--font-display);letter-spacing:.02em;border-radius:var(--radius-pill);background:linear-gradient(135deg,#f59e0b,#ef4444);color:#fff;box-shadow:0 2px 8px #ef444459;text-transform:uppercase;white-space:nowrap}.home-hero-skillPick{display:inline-flex;align-items:center;gap:6px;margin-top:2px;margin-bottom:8px;padding:6px 12px;font-family:inherit;font-size:12px;font-weight:700;background:var(--brand-soft);color:var(--brand-300);border:1px dashed var(--brand);border-radius:var(--radius-pill);cursor:pointer;transition:background var(--dur-fast) var(--ease-out),transform var(--dur-instant) var(--ease-out)}.home-hero-skillPick:hover{background:var(--surface-2)}.home-hero-skillPick:active{transform:scale(.98)}.home-hero-skill{display:inline-flex;align-items:center;gap:6px;margin-top:2px;margin-bottom:8px;background:transparent;border:0;padding:4px 6px;margin-left:-6px;border-radius:12px;cursor:pointer;transition:background var(--dur-fast) var(--ease-out)}.home-hero-skill:hover{background:var(--surface-1)}.home-hero-skill:active{transform:scale(.98)}.home-hero-skill-edit{color:var(--text-tertiary);opacity:0;transition:opacity var(--dur-fast) var(--ease-out)}.home-hero-skill:hover .home-hero-skill-edit,.home-hero-skill:focus-visible .home-hero-skill-edit{opacity:1}.home-hero-photoWrap{position:relative;display:inline-block;flex-shrink:0;z-index:1}.home-hero-photoWrap:before{content:"";position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px;background:var(--gradient-brand);filter:blur(20px);opacity:.4;border-radius:50%;z-index:-1}.home-hero-locateBtn{background:transparent;border:1px solid var(--border-subtle);color:var(--text-secondary);width:22px;height:22px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;padding:0}.home-hero-locateBtn:hover{background:var(--surface-2);color:var(--brand)}.hero-cta-secondary{background:var(--surface-1)}.hero-cta-secondary .hero-cta-icon{background:var(--gradient-cool)}.gamesPage{display:flex;flex-direction:column}.gamesHeader{display:flex;align-items:center;gap:14px;padding:18px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-xl);margin-bottom:20px;position:relative;overflow:hidden}.gamesHeader:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.12) 50%,transparent 100%)}.gamesHeader:after{content:"";position:absolute;top:-30px;right:-30px;width:140px;height:140px;background:var(--gradient-cool);filter:blur(50px);opacity:.12;border-radius:50%;pointer-events:none}.gamesHeader-icon{width:44px;height:44px;border-radius:14px;background:var(--brand-soft);color:var(--brand-300);display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;z-index:1}.gamesHeader-title{font-size:20px;font-weight:700;font-family:var(--font-display);color:var(--text-primary);margin:0 0 2px;letter-spacing:-.02em;position:relative;z-index:1}.gamesHeader-sub{font-size:12px;color:var(--text-tertiary);font-weight:500;margin:0;position:relative;z-index:1}.skillChips{display:flex;gap:8px;margin-bottom:20px;overflow-x:auto;padding:4px 2px 12px;scrollbar-width:none;scroll-snap-type:x proximity}.skillChips::-webkit-scrollbar{display:none}.chip{flex-shrink:0;display:inline-flex;align-items:center;gap:6px;padding:10px 14px;border-radius:var(--radius-pill);background:var(--surface-1);border:1px solid var(--border);color:var(--text-secondary);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--dur-fast) var(--ease-out);min-height:40px;scroll-snap-align:start}.chip:hover{background:var(--surface-2);border-color:var(--border-strong);color:var(--text-primary);transform:translateY(-1px)}.chip:active{transform:scale(.96);transition-duration:var(--dur-instant)}.chip i{color:var(--text-tertiary);transition:color var(--dur-fast) var(--ease-out)}.chip:hover i{color:var(--text-secondary)}.chip-active{background:var(--gradient-brand);color:var(--text-inverse);border-color:transparent;box-shadow:var(--shadow-md),var(--shadow-glow)}.chip-active i{color:var(--text-inverse)}.chip-active:hover{filter:brightness(1.05);transform:translateY(-1px);background:var(--gradient-brand)}.chip-check{display:inline-flex;align-items:center;justify-content:center;margin-left:2px;animation:chip-pop var(--dur-base) var(--ease-spring)}@keyframes chip-pop{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.gamesFilters{padding:14px;display:flex;flex-direction:column;gap:10px;margin-bottom:14px}.btn-icon{width:36px;height:36px;min-height:36px;padding:0;flex:0 0 36px}.inviteSearch{position:relative;display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:12px}.inviteSearch-icon{color:var(--text-tertiary);flex-shrink:0}.inviteSearch-input{flex:1;background:transparent;border:none;outline:none;color:var(--text-primary);font-family:var(--font-display);font-size:15px;min-width:0}.inviteSearch-input::placeholder{color:var(--text-tertiary)}.inviteSearch-clear{flex-shrink:0;width:22px;height:22px;color:var(--text-tertiary)}.inviteList{display:flex;flex-direction:column;gap:6px;max-height:360px;overflow-y:auto;padding:2px 2px 8px}.inviteRow{display:grid;grid-template-columns:36px minmax(0,1fr) 36px;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-md);background:var(--surface-1);border:1px solid var(--border-subtle);transition:background var(--dur-fast) var(--ease-out)}.inviteRow:hover{background:var(--surface-hover)}.inviteRow-body{display:flex;flex-direction:column;gap:2px;min-width:0}.inviteRow-name{font-weight:600;font-size:14px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.inviteRow-sub{display:flex;align-items:center;gap:8px;color:var(--text-tertiary);font-size:12px;font-weight:500}.inviteAdd{width:36px;height:36px;border-radius:50%;background:var(--gradient-brand);color:var(--text-inverse);border:none;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;box-shadow:var(--shadow-sm);transition:transform var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out),opacity var(--dur-fast) var(--ease-out)}.inviteAdd:hover:not(:disabled){transform:scale(1.05);box-shadow:var(--shadow-md),var(--shadow-glow)}.inviteAdd:active:not(:disabled){transform:scale(.95)}.inviteAdd:disabled{cursor:not-allowed;opacity:.55;background:var(--surface-3);color:var(--text-tertiary);box-shadow:none}.inviteEmpty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:24px 12px;color:var(--text-tertiary);text-align:center}.inviteEmpty p{margin:0;font-size:13px}.detailCard{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px;margin-bottom:12px;position:relative;overflow:hidden}.detailCard:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.12) 50%,transparent 100%)}.detailCard h3{margin:0 0 14px;font-size:18px;font-weight:700;font-family:var(--font-display);display:flex;align-items:center;gap:8px}.detailCard-players{padding:18px 18px 14px}.detailPlayers-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.detailPlayers-header h3{margin:0}.detailPlayers-count{font-family:var(--font-mono);font-variant-numeric:tabular-nums;font-weight:700;color:var(--brand-300);font-size:13px;padding:3px 10px;border-radius:999px;background:var(--brand-soft);border:1px solid var(--border-subtle)}.detailPlayers-subheader{margin-top:14px;margin-bottom:8px;font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-tertiary);display:flex;align-items:center;gap:8px}.detailPlayers-subheader:before,.detailPlayers-subheader:after{content:"";flex:1;height:1px;background:var(--border-subtle)}.detailPlayers-spots{display:grid;grid-template-columns:repeat(auto-fill,minmax(44px,1fr));gap:8px}.detailPlayers-spotSlot{aspect-ratio:1 / 1;border-radius:var(--radius-md);border:1px dashed var(--border-subtle);background:var(--surface-2);color:var(--text-tertiary);display:flex;align-items:center;justify-content:center}.detailPlayerList{list-style:none;margin:0;padding:0}.detailPlayer{display:grid;grid-template-columns:44px minmax(0,1fr) 36px;align-items:center;gap:12px;padding:10px 0;color:var(--text-secondary);font-size:14px;font-weight:500;border-bottom:1px solid var(--border-subtle)}.detailPlayer:last-of-type{border-bottom:none}.detailPlayer-body{display:flex;flex-direction:column;gap:2px;min-width:0}.detailPlayer-name{display:flex;align-items:center;gap:6px;min-width:0}.detailPlayer-nameText{font-weight:600;color:var(--text-primary);font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.detailPlayer-sub{display:flex;align-items:center;gap:6px;color:var(--text-tertiary);font-size:12px;font-weight:500;flex-wrap:wrap}.detailPlayer-sub .detailPlayer-tag-host+.skillBadge{margin-left:2px}.detailPlayer-tag{display:inline-flex;align-items:center;font-family:var(--font-display);font-size:10px;font-weight:800;letter-spacing:.06em;padding:2px 6px;border-radius:999px;text-transform:uppercase;line-height:1}.detailPlayer-tag-host{background:var(--brand-soft);color:var(--brand-300)}.detailPlayer-tag-you{background:var(--surface-3);color:var(--text-secondary);border:1px solid var(--border-subtle)}.detailPlayer-empty{padding:12px 0 4px;text-align:center;font-size:13px;color:var(--text-tertiary)}.detailPlayer-menu{position:relative;display:flex;justify-content:flex-end}.detailPlayer-menuBtn{color:var(--text-tertiary);font-family:var(--font-display)}.detailPlayer-menuBtn:hover{color:var(--text-primary);background:var(--surface-hover)}.detailPlayer-menuDots{font-size:22px;line-height:1;letter-spacing:-2px;font-weight:700;display:inline-block;transform:translateY(1px)}.detailPlayer-menuPop{position:absolute;top:100%;right:0;margin-top:4px;min-width:140px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);z-index:20;overflow:hidden}.detailPlayer-menuItem{display:flex;align-items:center;gap:8px;width:100%;padding:10px 12px;background:transparent;border:none;color:var(--text-primary);font-size:14px;font-weight:500;text-align:left;cursor:pointer;font-family:var(--font-display)}.detailPlayer-menuItem:hover{background:var(--surface-hover)}.detailActions{display:grid;grid-template-columns:1fr 1fr;gap:6px;align-items:stretch;margin-top:4px}.detailActions-full{grid-column:1 / -1}.detailActions-primary{height:100%}.detailActions-secondary{height:100%;border:1px solid var(--border-subtle)!important;background:var(--surface-1)!important;color:var(--text-primary)!important;box-shadow:none!important}.detailActions-secondary:hover{background:var(--surface-hover)!important}.detailActions-danger{height:100%;background:transparent!important;color:#ef4444!important;border:1px solid rgba(239,68,68,.3)!important;box-shadow:none!important}.detailActions-danger:hover{background:#ef444414!important}.detailHero{position:relative;height:190px;border-radius:var(--radius-lg);overflow:hidden;background:var(--surface-2);margin-bottom:16px;isolation:isolate}.detailHero-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;display:block;z-index:0}.detailHero-img-fallback{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-elevated) 0%,var(--bg-deep) 100%);color:var(--text-tertiary)}.detailHero-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#0000,#0000000d 35%,#000000c7);z-index:1}.detailHero-body{position:relative;z-index:2;height:100%;display:flex;flex-direction:column;justify-content:flex-end;padding:18px 20px;color:var(--text-inverse)}.detailHero-top{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin-bottom:10px}.detailHero-title{margin:0;font-family:var(--font-display);font-size:26px;font-weight:800;line-height:1.1;letter-spacing:-.02em;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.4);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.detailHero-pill{flex-shrink:0;display:inline-flex;align-items:center;background:linear-gradient(135deg,#16a34a,#22c55e);color:#fff;font-family:var(--font-mono);font-variant-numeric:tabular-nums;font-size:14px;font-weight:800;padding:6px 12px;border-radius:14px;box-shadow:0 2px 8px #16a34a66,0 0 0 1px #ffffff1f inset;letter-spacing:.02em}.detailHero-meta{display:flex;flex-direction:column;gap:4px;color:#ffffffd9;font-size:13px;font-weight:500}.detailHero-meta span{display:inline-flex;align-items:center;gap:6px}.detailHero-meta i{color:#ffffffb3}.detailTabs{display:grid;grid-template-columns:1fr 1fr;gap:0;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-md);padding:4px;margin-bottom:16px}.detailTab{display:inline-flex;align-items:center;justify-content:center;gap:6px;background:transparent;border:none;padding:9px 12px;border-radius:calc(var(--radius-md) - 4px);color:var(--text-tertiary);font-family:var(--font-display);font-size:14px;font-weight:700;cursor:pointer;transition:background var(--dur-fast) var(--ease-out),color var(--dur-fast) var(--ease-out)}.detailTab:hover{color:var(--text-primary)}.detailTab.isActive{background:var(--gradient-brand);color:var(--text-inverse);box-shadow:var(--shadow-sm)}.detailTab.isActive i{color:var(--text-inverse)}.detailCard-info{display:flex;flex-direction:column;gap:12px;padding:18px}.detailInfo-row{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--text-secondary);line-height:1.45}.detailInfo-row i{color:var(--brand-300);margin-top:2px}.detailInfo-row strong{color:var(--text-primary);font-weight:700;margin-right:4px}.detailInfo-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.detailInfo-notes{margin-top:4px;padding:10px 12px;border-radius:var(--radius-md);background:var(--surface-2);border:1px solid var(--border-subtle);color:var(--text-primary);font-size:14px;line-height:1.5}.detailInfo-notes i{color:var(--brand-300);margin-right:6px}.detailMap{background:linear-gradient(135deg,var(--bg-elevated) 0%,var(--bg-deep) 100%);border-radius:var(--radius-lg);height:200px;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);border:1px solid var(--border);margin-bottom:12px;font-family:var(--font-mono);font-size:12px;position:relative;overflow:hidden}.detailMap:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 300px 200px at 70% 30%,var(--brand-glow) 0%,transparent 60%);opacity:.25}.detailMap i{position:relative;z-index:1;font-size:32px;color:var(--brand-300);margin-right:10px}.detailMap span{position:relative;z-index:1;color:var(--text-secondary);font-weight:600}.paymentsSummary{background:linear-gradient(135deg,var(--surface-2) 0%,var(--surface-1) 100%);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:14px 16px;margin-bottom:16px;display:flex;flex-direction:column;gap:8px}.paymentsSummary-row{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:14px}.paymentsSummary-row-accent .paymentsSummary-value{color:var(--brand-300);font-size:16px}.paymentsSummary-label{color:var(--text-tertiary);font-weight:600}.paymentsSummary-value{font-family:var(--font-mono);font-variant-numeric:tabular-nums;color:var(--text-primary);font-weight:700}.paymentsList{display:flex;flex-direction:column;gap:6px;max-height:360px;overflow-y:auto;padding:2px}.paymentsList-header{display:flex;align-items:center;justify-content:space-between;padding:6px 10px 4px;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--text-tertiary)}.paymentsList-header>:last-child{margin-right:44px}.paymentsList-row{display:grid;grid-template-columns:32px minmax(0,1fr) auto 36px;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-md);background:var(--surface-1);border:1px solid var(--border-subtle)}.paymentsList-row.isPaid{border-color:#22c55e59;background:linear-gradient(180deg,rgba(34,197,94,.06) 0%,var(--surface-1) 100%)}.paymentsList-row.isUnpaid{border-color:#ef444440;background:linear-gradient(180deg,rgba(239,68,68,.04) 0%,var(--surface-1) 100%)}.paymentsList-name{font-weight:600;font-size:14px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.paymentsList-toggle{width:36px;height:36px;color:var(--text-tertiary)}.paymentsList-toggle:hover{color:var(--text-primary);background:var(--surface-hover)}.paymentsList-row.isPaid .paymentsList-toggle{color:#ef4444}.paymentsList-row.isPaid .paymentsList-toggle:hover{background:#ef44441a}.paymentsList-row.isUnpaid .paymentsList-toggle{color:#16a34a}.paymentsList-row.isUnpaid .paymentsList-toggle:hover{background:#16a34a1a}.createForm{display:flex;flex-direction:column;gap:24px;padding-bottom:8px}.createHeader{display:flex;align-items:center;gap:14px;padding:18px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-xl);position:relative;overflow:hidden}.createHeader:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.12) 50%,transparent 100%)}.createHeader:after{content:"";position:absolute;top:-30px;right:-30px;width:140px;height:140px;background:var(--gradient-brand);filter:blur(50px);opacity:.12;border-radius:50%;pointer-events:none}.createHeader-icon{width:44px;height:44px;border-radius:14px;background:var(--brand-soft);color:var(--brand-300);display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;z-index:1}.createHeader-title{font-size:20px;font-weight:700;font-family:var(--font-display);color:var(--text-primary);margin:0 0 2px;letter-spacing:-.02em;position:relative;z-index:1}.createHeader-sub{font-size:12px;color:var(--text-tertiary);font-weight:500;margin:0;position:relative;z-index:1}.formSection-num{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:var(--brand-soft);color:var(--brand-300);font-size:11px;font-weight:800;font-family:var(--font-display);letter-spacing:0}.field-row{display:flex;flex-wrap:wrap;gap:10px;align-items:stretch}.field-row .field{flex:1 1 140px;min-width:0}.field-row .field-duration{flex:0 0 96px;max-width:110px}.venueSelected{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-md);margin-top:8px}.venueSelected-icon{width:40px;height:40px;border-radius:12px;background:var(--gradient-brand);color:var(--text-inverse);display:flex;align-items:center;justify-content:center;flex-shrink:0}.venueSelected-info{flex:1;min-width:0}.venueSelected-name{font-size:14px;font-weight:600;color:var(--text-primary);font-family:var(--font-display);margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.venueSelected-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.venueSelected-price{font-size:12px;font-weight:700;color:var(--brand-300);font-family:var(--font-mono);margin-left:auto}.spotsStepper{display:flex;align-items:stretch;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;height:48px;transition:border-color var(--dur-fast) var(--ease-out)}.spotsStepper:focus-within{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}.stepperBtn{width:48px;display:flex;align-items:center;justify-content:center;background:var(--surface-2);border:none;color:var(--text-secondary);cursor:pointer;transition:all var(--dur-fast) var(--ease-out)}.stepperBtn:hover{background:var(--surface-3);color:var(--text-primary)}.stepperBtn:active{transform:scale(.92);background:var(--brand-soft);color:var(--brand-300)}.stepperInput{flex:1;background:transparent;border:none;color:var(--text-primary);font-size:18px;font-weight:700;font-family:var(--font-mono);text-align:center;font-variant-numeric:tabular-nums;min-width:0;padding:0;-moz-appearance:textfield}.stepperInput::-webkit-outer-spin-button,.stepperInput::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.costSummary{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px 14px;display:flex;flex-direction:column;gap:8px;margin-top:4px}.costSummary-row{display:flex;justify-content:space-between;align-items:center;font-size:13px}.costSummary-label{color:var(--text-tertiary);font-weight:500}.costSummary-value{color:var(--text-primary);font-weight:700;font-family:var(--font-mono);font-variant-numeric:tabular-nums}.costSummary-row-total{padding-top:8px;border-top:1px solid var(--border-subtle)}.paidBadge{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:var(--radius-pill);font-size:13px;font-weight:600;margin-top:10px;border:1px solid transparent}.paidBadge-paid{background:var(--brand-soft);color:var(--brand-300);border-color:#ffa50033}.paidBadge-free{background:var(--surface-2);color:var(--text-secondary);border-color:var(--border)}.venuePicker{display:flex;flex-direction:column;gap:8px;margin-top:6px}.venuePicker-item{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:var(--radius-md);background:var(--surface-1);border:1px solid var(--border);cursor:pointer;transition:border-color var(--dur-fast) var(--ease-out),background var(--dur-fast) var(--ease-out);text-align:left;width:100%;font:inherit;color:inherit}.venuePicker-item:hover{border-color:var(--brand);background:var(--surface-2)}.venuePicker-item.isActive{border-color:var(--brand);background:var(--brand-soft)}.venuePicker-icon{flex:0 0 36px;width:36px;height:36px;border-radius:10px;background:var(--surface-2);display:inline-flex;align-items:center;justify-content:center;color:var(--brand-300)}.venuePicker-info{flex:1;min-width:0}.playTypePicker{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.playTypePicker-option{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:12px 8px;background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-secondary);font-family:var(--font-display);font-size:13px;font-weight:700;cursor:pointer;transition:background var(--dur-fast) var(--ease-out),border-color var(--dur-fast) var(--ease-out),color var(--dur-fast) var(--ease-out)}.playTypePicker-option i{color:var(--brand-300);font-size:18px}.playTypePicker-option:hover{border-color:var(--border);background:var(--surface-hover)}.playTypePicker-option.isActive{background:var(--gradient-brand);border-color:transparent;color:var(--text-inverse);box-shadow:var(--shadow-sm),var(--shadow-glow)}.playTypePicker-option.isActive i{color:var(--text-inverse)}.venuePicker-name{font-weight:600;font-size:14px;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.venuePicker-meta{font-size:12px;color:var(--text-tertiary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.venuePicker-price{flex:0 0 auto;font-size:12px;color:var(--brand-300);font-weight:600}.venuePicker-empty{padding:12px;border-radius:var(--radius-md);background:var(--surface-2);color:var(--text-tertiary);font-size:13px;text-align:center}.venuesPage{display:flex;flex-direction:column}.venueCard{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;margin-bottom:12px;position:relative;overflow:hidden;transition:transform var(--dur-fast) var(--ease-out),border-color var(--dur-fast) var(--ease-out),background var(--dur-fast) var(--ease-out)}.venueCard:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.12) 50%,transparent 100%)}.venueCard:hover{background:var(--surface-2);border-color:var(--border-strong);transform:translateY(-1px)}.venueCard h3{margin:0 0 8px;font-size:17px;font-weight:700;font-family:var(--font-display);color:var(--text-primary);letter-spacing:-.015em}.venueRow{display:flex;justify-content:space-between;align-items:center;color:var(--text-tertiary);font-size:13px;margin-top:6px;gap:12px;font-weight:500}.venueRow strong{color:var(--brand-300);font-weight:700;font-family:var(--font-mono);font-variant-numeric:tabular-nums}.venueRow i{color:var(--brand-300);margin-right:4px}.profilePage{display:flex;flex-direction:column;gap:24px;padding-bottom:8px}.profileHero{display:flex;align-items:center;gap:16px;padding:20px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-xl);position:relative;overflow:hidden}.profileHero:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.12) 50%,transparent 100%)}.profileHero:after{content:"";position:absolute;top:-30px;right:-30px;width:160px;height:160px;background:var(--gradient-cool);filter:blur(50px);opacity:.18;border-radius:50%;pointer-events:none}.profileAvatar{width:64px;height:64px;border-radius:50%;background:var(--gradient-brand);color:var(--text-inverse);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:800;font-family:var(--font-display);flex-shrink:0;position:relative;z-index:1;box-shadow:0 4px 16px var(--brand-glow);letter-spacing:-.02em}.profileHero-info{flex:1;min-width:0;position:relative;z-index:1}.profileHero-name{font-size:20px;font-weight:700;font-family:var(--font-display);color:var(--text-primary);margin:0 0 4px;letter-spacing:-.02em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profileHero-username{display:inline-flex;align-items:center;font-size:13px;color:var(--text-tertiary);font-weight:500}.profileHero-username i{color:var(--brand-300);margin-right:4px}.profileHero-skill{display:inline-flex;align-items:center;gap:6px;padding:3px 10px 3px 6px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-pill);font-size:12px;font-weight:700;color:var(--text-primary);font-family:var(--font-display);letter-spacing:.01em}.profileHero-skillBig{display:inline-flex;align-items:center;gap:6px;background:transparent;border:0;padding:4px 8px 4px 4px;margin:4px 0 8px -4px;border-radius:12px;cursor:pointer;transition:background var(--dur-fast) var(--ease-out)}.profileHero-skillBig:hover{background:var(--surface-1)}.profileHero-skillBig:active{transform:scale(.98)}.profileHero-skillBig-edit{color:var(--text-tertiary);opacity:0;transition:opacity var(--dur-fast) var(--ease-out)}.profileHero-skillBig:hover .profileHero-skillBig-edit,.profileHero-skillBig:focus-visible .profileHero-skillBig-edit{opacity:1}.profileHero-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.profileHero-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:999px;font-size:11px;font-weight:700;font-family:var(--font-display);letter-spacing:.02em;text-transform:uppercase}.profileHero-badge-admin{background:linear-gradient(135deg,#f59e0b,#ef4444);color:#fff;box-shadow:0 2px 8px #f59e0b66}.formSection{display:flex;flex-direction:column;gap:12px}.formSection-title{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700;font-family:var(--font-body);text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);margin:0;padding:0 4px}.formSection-num{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:var(--brand-soft);color:var(--brand-300);font-family:var(--font-display)}.formSection-num-admin{background:linear-gradient(135deg,#f59e0b,#ef4444);color:#fff}.formSection-hint{font-size:12px;color:var(--text-muted);font-weight:500;margin:-4px 0 0 4px}.profileCard{display:flex;flex-direction:column;padding:16px}.field-label{display:inline-flex;align-items:center;gap:5px}.field-label i{color:var(--text-muted);margin-right:0}.skillGrid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.skillCard{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:16px 8px;background:var(--surface-1);border:1.5px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);font-size:12px;font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--dur-fast) var(--ease-out);min-height:76px}.skillCard i{color:var(--text-tertiary);transition:color var(--dur-fast) var(--ease-out)}.skillCard:hover{border-color:var(--border-strong);background:var(--surface-2);color:var(--text-primary);transform:translateY(-1px)}.skillCard:hover i{color:var(--text-secondary)}.skillCard:active{transform:scale(.97);transition-duration:var(--dur-instant)}.skillCard-active{background:var(--brand-soft);border-color:var(--brand);color:var(--brand-300);box-shadow:0 4px 16px var(--brand-glow)}.skillCard-active i{color:var(--brand-300)}.skillCard-num{position:absolute;top:8px;right:8px;font-size:10px;font-weight:800;color:var(--text-muted);font-family:var(--font-display)}.skillCard{position:relative}.skillCard-label{font-size:12px;line-height:1.2;text-align:center}.skillDescription{display:flex;align-items:flex-start;gap:8px;padding:12px 14px;background:var(--brand-soft);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-md);font-size:12px;color:var(--text-secondary);line-height:1.5;font-weight:500;margin-top:4px;animation:chip-pop var(--dur-base) var(--ease-spring)}.skillDescription i{color:var(--brand-300);flex-shrink:0;margin-top:2px}.reminderList{display:flex;flex-direction:column;gap:8px}.reminderOption{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--surface-1);border:1.5px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--dur-fast) var(--ease-out);text-align:left;font-family:inherit;color:var(--text-primary);width:100%}.reminderOption:hover{background:var(--surface-2);border-color:var(--border-strong);transform:translateY(-1px)}.reminderOption:active{transform:scale(.99);transition-duration:var(--dur-instant)}.reminderOption-icon{width:40px;height:40px;border-radius:12px;background:var(--surface-2);color:var(--text-tertiary);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--dur-fast) var(--ease-out)}.reminderOption-text{flex:1;min-width:0}.reminderOption-label{font-size:14px;font-weight:600;font-family:var(--font-display);margin-bottom:2px}.reminderOption-desc{font-size:12px;color:var(--text-tertiary);font-weight:500}.reminderOption-radio{width:20px;height:20px;border-radius:50%;border:2px solid var(--border-strong);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--dur-fast) var(--ease-out)}.radio-dot{width:0;height:0;border-radius:50%;background:var(--brand);transition:all var(--dur-fast) var(--ease-spring)}.reminderOption-active{background:var(--brand-soft);border-color:var(--brand);box-shadow:0 4px 16px var(--brand-glow)}.reminderOption-active .reminderOption-icon{background:var(--gradient-brand);color:var(--text-inverse)}.reminderOption-active .reminderOption-label{color:var(--brand-300)}.reminderOption-active .reminderOption-radio{border-color:var(--brand)}.reminderOption-active .radio-dot{width:10px;height:10px;box-shadow:0 0 8px var(--brand-glow)}.success-banner{display:flex;align-items:center;gap:8px;padding:12px 14px;background:var(--success-soft);color:var(--success);border-radius:var(--radius-md);border:1px solid rgba(16,185,129,.3);font-size:13px;font-weight:600;animation:chip-pop var(--dur-base) var(--ease-spring)}@keyframes chip-pop{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.profileAdminSection{margin-top:12px;padding-top:20px;border-top:1px dashed var(--border)}.adminPanelLink{display:flex;align-items:center;gap:14px;padding:16px;background:linear-gradient(135deg,#f59e0b1f,#ef444414);border:1.5px solid rgba(245,158,11,.3);border-radius:var(--radius-md);text-decoration:none;color:var(--text-primary);transition:all var(--dur-fast) var(--ease-out);font-family:inherit;text-align:left;cursor:pointer}.adminPanelLink:hover{background:linear-gradient(135deg,#f59e0b2e,#ef44441f);border-color:#f59e0b80;transform:translateY(-1px)}.adminPanelLink-icon{width:44px;height:44px;border-radius:var(--radius-sm);background:linear-gradient(135deg,#f59e0b,#ef4444);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 12px #f59e0b66}.adminPanelLink-text{flex:1;min-width:0}.adminPanelLink-title{font-size:15px;font-weight:700;font-family:var(--font-display);color:var(--text-primary);margin-bottom:2px}.adminPanelLink-desc{font-size:12px;color:var(--text-tertiary);font-weight:500}.adminPanelLink i{color:var(--text-tertiary)}.profileLogout{margin-top:4px;background:var(--surface-2);color:var(--text-secondary);box-shadow:none}.profileLogout:hover{background:var(--surface-3);color:var(--text-primary);box-shadow:none}.langGrid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.langOption{display:flex;align-items:center;gap:10px;padding:12px 14px;border:1px solid var(--border-subtle);border-radius:12px;background:var(--surface-1);color:var(--text-primary);cursor:pointer;transition:all .12s;font-size:14px;font-weight:500}.langOption:hover{background:var(--surface-2)}.langOption-active{background:var(--brand-soft);border-color:var(--brand);color:var(--brand)}.langOption-flag{font-size:22px;line-height:1}.langOption-label{font-weight:600}.profileHero-eval{display:flex;align-items:center;margin-top:8px}.profilePhotoStatus{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:999px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;box-shadow:0 2px 8px #00000047;border:1px solid rgba(255,255,255,.18)}.cityRow{display:flex;gap:8px;align-items:stretch}.cityRow-input{flex:1;min-width:0}.cityRow-locateBtn{flex:0 0 auto;width:44px;min-height:44px;height:44px;padding:0;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface-1);color:var(--brand-300);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background var(--dur-fast) var(--ease-out),transform var(--dur-instant) var(--ease-out)}.cityRow-locateBtn:hover{background:var(--brand-soft)}.cityRow-locateBtn:active{transform:scale(.96)}.formSection-collapsible>.formSection-body{display:none}.formSection-collapsible.isOpen>.formSection-body{display:block}.formSection-toggle{display:inline-flex;align-items:center;gap:6px;background:none;border:none;padding:0;cursor:pointer;color:var(--text-tertiary);font-size:12px;font-weight:500}.formSection-toggle:hover{color:var(--brand-300)}.reminderSummary{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:var(--radius-pill);background:var(--surface-2);border:1px solid var(--border);font-size:13px;font-weight:500;color:var(--text-primary);margin-top:8px;cursor:pointer;transition:background var(--dur-fast) var(--ease-out)}.reminderSummary:hover{background:var(--brand-soft)}.reminderSummary-icon{color:var(--brand-300);display:inline-flex}.welcome{min-height:100vh;padding:24px 20px calc(120px + env(safe-area-inset-bottom));display:flex;flex-direction:column;animation:page-fade-in var(--dur-base) var(--ease-out)}.welcome-backBtn{position:absolute;top:16px;left:16px;display:inline-flex;align-items:center;gap:4px;padding:6px 10px;border-radius:999px;background:var(--surface-1);border:1px solid var(--border-subtle);color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:background var(--dur-fast) var(--ease-out)}.welcome-backBtn:hover{background:var(--surface-2);color:var(--text-primary)}.welcome-progress{display:flex;gap:6px;justify-content:center;margin-bottom:28px}.welcome-dot{width:8px;height:8px;border-radius:50%;background:var(--surface-2);transition:all var(--dur-base) var(--ease-out)}.welcome-dot-active{background:var(--brand);width:24px;border-radius:4px;box-shadow:0 0 8px var(--brand-glow)}.welcome-step{flex:1;display:flex;flex-direction:column}.welcome-fadeIn{animation:welcome-fadeIn var(--dur-base) var(--ease-out)}@keyframes welcome-fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.welcome-hero{text-align:center;margin-bottom:32px;display:flex;flex-direction:column;align-items:center}.welcome-avatar{position:relative;width:88px;height:88px;margin-bottom:16px}.welcome-avatarGlow{position:absolute;top:-10px;right:-10px;bottom:-10px;left:-10px;background:var(--gradient-brand);filter:blur(24px);opacity:.4;border-radius:50%;z-index:-1;animation:float 4s ease-in-out infinite}.welcome-title{font-size:28px;font-weight:800;font-family:var(--font-display);color:var(--text-primary);margin:0 0 8px;letter-spacing:-.025em;line-height:1.15}.welcome-sub{font-size:14px;color:var(--text-tertiary);font-weight:500;line-height:1.55;max-width:320px;margin:0 auto}.welcome-features{display:flex;flex-direction:column;gap:10px;margin-bottom:32px}.welcome-feature{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-md)}.welcome-featureIcon{width:36px;height:36px;border-radius:var(--radius-sm);background:var(--brand-soft);color:var(--brand-300);display:flex;align-items:center;justify-content:center;flex-shrink:0}.welcome-featureTitle{font-size:14px;font-weight:600;color:var(--text-primary);font-family:var(--font-display);margin-bottom:2px}.welcome-featureDesc{font-size:12px;color:var(--text-tertiary);font-weight:500;line-height:1.4}.welcome-cta{margin-top:auto}.welcome-foot{text-align:center;font-size:12px;color:var(--text-muted);font-weight:500;margin-top:12px}.welcome-skillHeader{margin-bottom:20px;text-align:center}.welcome-skillHeader .welcome-title{font-size:24px}.welcome-skillHeader .welcome-sub{text-align:left;max-width:none;margin:0}.welcome-levelList{display:flex;flex-direction:column;gap:8px;margin-bottom:24px}.welcome-level{width:100%;background:var(--surface-1);border:1.5px solid var(--border);border-radius:var(--radius-md);padding:12px 14px;cursor:pointer;text-align:left;font-family:inherit;color:var(--text-primary);transition:all var(--dur-fast) var(--ease-out)}.welcome-level:hover{background:var(--surface-2);border-color:var(--border-strong)}.welcome-level:active{transform:scale(.99)}.welcome-level-active{background:var(--brand-soft);border-color:var(--brand);box-shadow:0 4px 16px var(--brand-glow)}.welcome-levelRow{display:flex;align-items:center;gap:12px}.welcome-levelNum{width:26px;height:26px;border-radius:50%;background:var(--surface-2);color:var(--text-tertiary);font-size:12px;font-weight:800;font-family:var(--font-display);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--dur-fast) var(--ease-out)}.welcome-level-active .welcome-levelNum{background:var(--gradient-brand);color:var(--text-inverse)}.welcome-levelIcon{width:36px;height:36px;border-radius:var(--radius-sm);background:var(--surface-2);color:var(--text-tertiary);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--dur-fast) var(--ease-out)}.welcome-level-active .welcome-levelIcon{background:var(--gradient-brand);color:var(--text-inverse)}.welcome-levelText{flex:1;min-width:0}.welcome-levelLabel{font-size:15px;font-weight:600;font-family:var(--font-display);letter-spacing:-.01em}.welcome-levelInfo{width:32px;height:32px;border-radius:50%;background:var(--surface-2);border:none;color:var(--text-tertiary);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all var(--dur-fast) var(--ease-out)}.welcome-levelInfo:hover{background:var(--surface-3);color:var(--text-secondary)}.welcome-levelDesc{margin-top:12px;padding-top:12px;border-top:1px solid var(--border-subtle);font-size:12px;color:var(--text-secondary);line-height:1.5;font-weight:500;animation:welcome-fadeIn var(--dur-fast) var(--ease-out)}.welcome-actions{margin-top:auto}.welcome-done{align-items:center;justify-content:center;text-align:center;padding-top:80px}.welcome-doneCheck{position:relative;width:112px;height:112px;border-radius:50%;background:linear-gradient(135deg,#10b981,#059669);color:#fff;display:flex;align-items:center;justify-content:center;margin-bottom:24px;box-shadow:var(--shadow-glow-strong),0 12px 40px #00000073;animation:welcome-pop var(--dur-slow) var(--ease-spring)}.welcome-doneCheck:before{content:"";position:absolute;top:-10px;right:-10px;bottom:-10px;left:-10px;border-radius:50%;background:linear-gradient(135deg,#10b981,#059669);filter:blur(24px);opacity:.45;z-index:-1}.welcome-doneCheck .hgi-stroke{font-size:60px;line-height:1;filter:drop-shadow(0 2px 4px rgba(0,0,0,.35))}@keyframes welcome-pop{0%{transform:scale(0);opacity:0}60%{transform:scale(1.1);opacity:1}to{transform:scale(1);opacity:1}}.adminPage{display:flex;flex-direction:column;gap:20px;padding-bottom:16px}.adminHeader{display:flex;align-items:center;gap:14px;padding:18px;background:linear-gradient(135deg,#f59e0b1f,#ef444414);border:1px solid rgba(245,158,11,.3);border-radius:var(--radius-xl);position:relative;overflow:hidden}.adminHeader:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(245,158,11,.4),transparent)}.adminHeader-icon{width:44px;height:44px;border-radius:var(--radius-sm);background:linear-gradient(135deg,#f59e0b,#ef4444);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 12px #f59e0b66}.adminHeader-title{font-size:20px;font-weight:800;font-family:var(--font-display);margin:0 0 2px;letter-spacing:-.02em}.adminHeader-sub{font-size:12px;color:var(--text-tertiary);font-weight:500;margin:0}.adminTabs{display:flex;gap:4px;padding:4px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-md);overflow-x:auto;scrollbar-width:none}.adminTabs::-webkit-scrollbar{display:none}.adminTab{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-tertiary);font-size:12px;font-weight:600;font-family:inherit;cursor:pointer;white-space:nowrap;transition:all var(--dur-fast) var(--ease-out)}.adminTab:hover{color:var(--text-secondary);background:var(--surface-2)}.adminTab-active{background:var(--gradient-brand);color:var(--text-inverse);box-shadow:0 2px 8px var(--brand-glow)}.statsGrid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.statCard{position:relative;padding:18px 16px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.statCard:before{content:"";position:absolute;top:-30px;right:-30px;width:100px;height:100px;border-radius:50%;filter:blur(40px);opacity:.3}.statCard-brand:before{background:var(--gradient-brand)}.statCard-cool:before{background:var(--gradient-cool)}.statCard-success:before{background:var(--gradient-success)}.statCard-warn:before{background:linear-gradient(135deg,#f59e0b,#ef4444)}.statCard-icon{width:32px;height:32px;border-radius:var(--radius-sm);background:var(--surface-2);color:var(--brand-300);display:flex;align-items:center;justify-content:center;margin-bottom:10px}.statCard-cool .statCard-icon{color:#38bdf8}.statCard-success .statCard-icon{color:var(--success)}.statCard-warn .statCard-icon{color:#f59e0b}.statCard-value{font-size:28px;font-weight:800;font-family:var(--font-display);color:var(--text-primary);letter-spacing:-.025em;line-height:1;margin-bottom:4px}.statCard-label{font-size:12px;color:var(--text-tertiary);font-weight:600;text-transform:uppercase;letter-spacing:.04em}.adminList{display:flex;flex-direction:column;gap:12px}.adminList-search{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-tertiary);transition:all var(--dur-fast) var(--ease-out)}.adminList-search:focus-within{border-color:var(--brand);background:var(--surface-2);box-shadow:0 0 0 3px var(--brand-glow)}.adminList-search input{flex:1;background:transparent;border:none;outline:none;color:var(--text-primary);font-size:14px;font-family:inherit}.adminList-search input::placeholder{color:var(--text-muted)}.adminList-meta{font-size:12px;color:var(--text-tertiary);font-weight:600;padding:0 4px;text-transform:uppercase;letter-spacing:.04em}.adminItems{display:flex;flex-direction:column;gap:8px}.adminItem{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-md);transition:all var(--dur-fast) var(--ease-out)}.adminItem:hover{background:var(--surface-2);border-color:var(--border-strong)}.adminItem-icon{width:40px;height:40px;border-radius:var(--radius-sm);background:var(--surface-2);color:var(--text-tertiary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.adminItem-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.adminItem-title{font-size:14px;font-weight:700;font-family:var(--font-display);color:var(--text-primary);display:flex;align-items:center;gap:6px;flex-wrap:wrap}.adminItem-sub{font-size:12px;color:var(--text-tertiary);font-weight:500;display:flex;align-items:center;gap:6px;flex-wrap:wrap}.adminItem-meta{font-size:10px;color:var(--text-muted);font-family:var(--font-mono);font-weight:500;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.adminItem-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 6px;border-radius:999px;font-size:9px;font-weight:700;font-family:var(--font-display);text-transform:uppercase;letter-spacing:.04em}.adminItem-badge-admin{background:linear-gradient(135deg,#f59e0b,#ef4444);color:#fff}.adminItem-badge-warn{background:#f59e0b26;color:#fbbf24;border:1px solid rgba(245,158,11,.3)}.adminItem-tag{display:inline-block;padding:1px 6px;border-radius:4px;background:var(--surface-2);font-size:10px;font-weight:600;font-family:var(--font-mono);color:var(--text-tertiary)}.adminItem-statusBadge{width:40px;height:40px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:800;font-family:var(--font-display);text-align:center;line-height:1;flex-shrink:0}.adminItem-statusBadge-full{background:var(--brand-soft);color:var(--brand-300)}.adminItem-statusBadge-cancelled{background:#ef44441f;color:#fca5a5}.adminItem-statusBadge-finished{background:var(--surface-2);color:var(--text-muted)}.adminItem-actions{display:flex;gap:4px;flex-shrink:0}.adminItem-btn{width:32px;height:32px;border-radius:var(--radius-sm);background:var(--surface-2);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--dur-fast) var(--ease-out)}.adminItem-btn:hover{background:var(--surface-3);color:var(--text-primary);border-color:var(--border-strong)}.adminItem-btn:active{transform:scale(.94)}.adminItem-btn:disabled{opacity:.5;cursor:not-allowed}.adminItem-btn-danger:hover{background:#ef444426;color:#fca5a5;border-color:#ef444466}.adminItem-btn-warn:hover{background:#f59e0b26;color:#fbbf24;border-color:#f59e0b66}.adminItem-target{color:var(--text-muted);font-weight:500}.adminItem-audit{font-family:var(--font-mono)}.adminList-filters{display:flex;gap:6px;margin-bottom:10px;flex-wrap:wrap}.adminItem-heatmap .adminItem-meta{font-variant-numeric:tabular-nums}.adminItem-badge-danger{background:var(--danger-soft);color:var(--danger)}.adminItem-statusBadge-open{background:var(--success-soft);color:var(--success)}.adminItem-statusBadge-finished{background:var(--brand-soft);color:var(--brand)}.adminItem-statusBadge-cancelled{background:var(--danger-soft);color:var(--danger)}.adminItem-statusBadge-full{background:var(--warning-soft);color:var(--warning)}.adminIndex{display:flex;flex-direction:column;gap:10px;margin-top:12px}.adminIndexCard{display:flex;align-items:center;gap:14px;padding:16px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-md);text-decoration:none;color:var(--text-primary);font-family:inherit;text-align:left;cursor:pointer;transition:background var(--dur-fast) var(--ease-out),border-color var(--dur-fast) var(--ease-out),transform var(--dur-instant) var(--ease-out)}.adminIndexCard:hover{background:var(--surface-2);border-color:var(--border-strong);transform:translateY(-1px)}.adminIndexCard:active{transform:scale(.99)}.adminIndexCard-icon{width:44px;height:44px;border-radius:14px;background:var(--brand-soft);color:var(--brand-300);display:flex;align-items:center;justify-content:center;flex-shrink:0}.adminIndexCard-text{flex:1;min-width:0}.adminIndexCard-title{font-size:15px;font-weight:700;font-family:var(--font-display);color:var(--text-primary);margin-bottom:2px}.adminIndexCard-desc{font-size:12px;color:var(--text-tertiary);font-weight:500}.adminIndexCard-arrow{color:var(--text-tertiary);flex-shrink:0}.inviteBanner{position:fixed;left:12px;right:12px;bottom:calc(72px + env(safe-area-inset-bottom));z-index:50;display:grid;grid-template-columns:48px minmax(0,1fr) auto;align-items:center;gap:10px;padding:10px 12px;background:linear-gradient(135deg,var(--surface-2) 0%,var(--surface-1) 100%);border:1px solid var(--brand-300);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);animation:inviteBanner-slide-in .28s var(--ease-out)}@keyframes inviteBanner-slide-in{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.inviteBanner-photo{position:relative;background:transparent;border:none;padding:0;cursor:pointer;width:48px;height:48px;display:inline-flex;align-items:center;justify-content:center}.inviteBanner-badge{position:absolute;right:-2px;bottom:-2px;width:20px;height:20px;border-radius:50%;background:var(--gradient-brand);color:var(--text-inverse);display:inline-flex;align-items:center;justify-content:center;box-shadow:0 0 0 2px var(--surface-1)}.inviteBanner-body{background:transparent;border:none;padding:0;text-align:left;cursor:pointer;display:flex;flex-direction:column;gap:2px;min-width:0;font-family:var(--font-display)}.inviteBanner-title{font-weight:700;font-size:13px;color:var(--text-primary)}.inviteBanner-meta{font-size:12px;color:var(--text-tertiary);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;max-width:100%}.inviteBanner-venue,.inviteBanner-when{color:var(--text-secondary);font-weight:600}.inviteBanner-actions{display:flex;align-items:center;gap:4px}.inviteBanner-btn{width:32px;height:32px;border-radius:50%;border:none;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;background:var(--surface-3);color:var(--text-secondary);flex-shrink:0;transition:background var(--dur-fast) var(--ease-out),color var(--dur-fast) var(--ease-out),transform var(--dur-instant) var(--ease-out)}.inviteBanner-btn:hover:not(:disabled){background:var(--surface-hover);color:var(--text-primary);transform:scale(1.05)}.inviteBanner-btn:active:not(:disabled){transform:scale(.95)}.inviteBanner-btn:disabled{opacity:.5;cursor:not-allowed}.inviteBanner-btn-accept{background:var(--gradient-brand);color:var(--text-inverse);box-shadow:var(--shadow-sm),var(--shadow-glow)}.inviteBanner-btn-accept:hover:not(:disabled){color:var(--text-inverse);filter:brightness(1.05);box-shadow:var(--shadow-md),var(--shadow-glow)}.inviteBanner-btn-decline{color:var(--text-tertiary)}.inviteBanner-btn-close{background:transparent;color:var(--text-tertiary)}.inviteBanner-btn-close:hover:not(:disabled){background:#ef44441f;color:#ef4444}:root{--bg-0: #050810;--bg-1: #0a0f1c;--bg-2: #111827;--bg-3: #1a2236;--surface-1: #131a2c;--surface-2: #1c2540;--surface-3: #283154;--surface-hover: #1f2a48;--border-subtle: rgba(255, 255, 255, .05);--border: rgba(255, 255, 255, .08);--border-strong: rgba(255, 255, 255, .14);--text-primary: #ffffff;--text-secondary: #c2c9d6;--text-tertiary: #8b94a8;--text-muted: #5d6679;--text-inverse: #0a0f1c;--brand-50: #fff8e6;--brand-100: #ffeec0;--brand-200: #ffdf85;--brand-300: #ffd04a;--brand-400: #ffc52a;--brand: #ffb627;--brand-600: #e89e0e;--brand-700: #c4820a;--brand-soft: rgba(255, 182, 39, .14);--brand-glow: rgba(255, 182, 39, .4);--brand-soft-glow: rgba(255, 182, 39, .08);--gradient-brand: linear-gradient(135deg, #fb923c 0%, #ffb627 50%, #fde047 100%);--gradient-brand-subtle: linear-gradient(135deg, rgba(251, 146, 60, .15), rgba(253, 224, 71, .05));--gradient-cool: linear-gradient(135deg, #3b82f6 0%, #6366f1 100%);--gradient-success: linear-gradient(135deg, #10b981 0%, #34d399 100%);--gradient-bg-orb: radial-gradient(circle at 20% 0%, rgba(255, 182, 39, .12) 0%, transparent 50%), radial-gradient(circle at 80% 100%, rgba(99, 102, 241, .08) 0%, transparent 50%);--success: #10b981;--success-soft: rgba(16, 185, 129, .15);--warning: #f59e0b;--warning-soft: rgba(245, 158, 11, .15);--danger: #ef4444;--danger-soft: rgba(239, 68, 68, .15);--info: #3b82f6;--info-soft: rgba(59, 130, 246, .15);--radius-xs: 6px;--radius-sm: 10px;--radius-md: 14px;--radius-lg: 20px;--radius-xl: 24px;--radius-pill: 999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .2);--shadow-md: 0 4px 12px rgba(0, 0, 0, .25), 0 1px 3px rgba(0, 0, 0, .15);--shadow-lg: 0 12px 32px rgba(0, 0, 0, .35);--shadow-glow: 0 4px 24px rgba(255, 182, 39, .3);--shadow-glow-strong: 0 8px 32px rgba(255, 182, 39, .45);--shadow-inner: inset 0 1px 0 rgba(255, 255, 255, .04);--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--ease-in-out: cubic-bezier(.65, 0, .35, 1);--dur-instant: .1s;--dur-fast: .18s;--dur-base: .24s;--dur-slow: .4s;--font-display: "Outfit", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;font-family:var(--font-body);color-scheme:dark;-webkit-tap-highlight-color:transparent}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%;margin:0;padding:0}body{background:var(--bg-0);background-image:var(--gradient-bg-orb);background-attachment:fixed;color:var(--text-primary);font-family:var(--font-body);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;letter-spacing:-.005em;overscroll-behavior-y:none}h1,h2,h3,h4,h5{font-family:var(--font-display);font-weight:700;letter-spacing:-.025em;margin:0;color:var(--text-primary)}p{margin:0}button{font-family:inherit}::selection{background:var(--brand);color:var(--text-inverse)}::-webkit-scrollbar{width:0;height:0}:focus{outline:none}:focus-visible{outline:2px solid var(--brand);outline-offset:2px;border-radius:var(--radius-xs)}.app-container{max-width:480px;margin:0 auto;padding:16px;padding-top:calc(48px + env(safe-area-inset-top));padding-bottom:calc(100px + env(safe-area-inset-bottom));animation:page-fade-in var(--dur-base) var(--ease-out)}body.keyboard-open .bottom-nav{display:none}body.keyboard-open .app-container{padding-bottom:calc(16px + env(safe-area-inset-bottom))}.app-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;padding:4px 0}.app-header h1{font-size:22px;font-weight:700;margin:0}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.field-label{color:var(--text-tertiary);font-size:12px;font-weight:600;letter-spacing:.01em;text-transform:none}.field-hint{color:var(--text-muted);font-size:12px;margin-top:4px}.field input,.field select,.field textarea{background:var(--surface-1);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px 16px;font-size:16px;width:100%;font-family:inherit;transition:border-color var(--dur-fast) var(--ease-out),background-color var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out)}.field input::placeholder,.field textarea::placeholder{color:var(--text-muted)}.field input:hover,.field select:hover,.field textarea:hover{border-color:var(--border-strong)}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--brand);background:var(--surface-2);box-shadow:0 0 0 3px var(--brand-soft)}.tag{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-pill);background:var(--surface-2);font-size:11px;font-weight:600;color:var(--text-secondary);letter-spacing:.01em;border:1px solid var(--border-subtle)}.tag.accent{background:var(--brand-soft);color:var(--brand-300);border-color:#ffb62740}.tag.success{background:var(--success-soft);color:var(--success);border-color:#10b98140}.tag.warning{background:var(--warning-soft);color:var(--warning);border-color:#f59e0b40}.tag.danger{background:var(--danger-soft);color:var(--danger);border-color:#ef444440}.tag.info{background:var(--info-soft);color:#93c5fd;border-color:#3b82f640}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--gradient-brand);color:var(--text-inverse);border:none;border-radius:var(--radius-md);padding:14px 20px;font-weight:700;font-size:15px;font-family:var(--font-display);letter-spacing:-.01em;cursor:pointer;width:100%;min-height:48px;position:relative;overflow:hidden;box-shadow:var(--shadow-md),var(--shadow-glow),var(--shadow-inner);transition:transform var(--dur-instant) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out),filter var(--dur-fast) var(--ease-out)}.btn:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:linear-gradient(180deg,rgba(255,255,255,.15) 0%,transparent 50%);pointer-events:none}.btn:hover:not(:disabled){filter:brightness(1.05);transform:translateY(-1px);box-shadow:var(--shadow-lg),var(--shadow-glow-strong),var(--shadow-inner)}.btn:active:not(:disabled){transform:scale(.98) translateY(0);filter:brightness(.95);transition-duration:var(--dur-instant)}.btn:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}.btn.secondary{background:var(--surface-2);color:var(--text-primary);box-shadow:var(--shadow-sm)}.btn.secondary:hover:not(:disabled){background:var(--surface-hover);box-shadow:var(--shadow-md)}.btn.danger{background:linear-gradient(135deg,#ef4444,#f87171);color:#fff;box-shadow:var(--shadow-md),0 4px 24px #ef44444d}.btn-ghost{background:transparent;color:var(--brand-300);border:none;padding:8px 12px;font-weight:600;font-size:14px;cursor:pointer;border-radius:var(--radius-sm);transition:background var(--dur-fast) var(--ease-out)}.btn-ghost:hover{background:var(--brand-soft)}.btn-ghost:active{transform:scale(.97)}.btn-icon,.btn.btn-icon{width:auto;min-height:0;padding:0;flex:0 0 36px;width:36px;height:36px}.btn-icon:after{display:none}.btn-icon-dot{position:absolute;top:6px;right:6px;width:8px;height:8px;border-radius:50%;background:var(--brand);box-shadow:0 0 0 2px var(--surface-1);pointer-events:none}.btn.btn-sm,.btn-sm.btn{padding:9px 14px;min-height:36px;font-size:13px;border-radius:var(--radius-md)}.btn.btn-sm.btn-ghost,.btn-sm.btn.btn-ghost{padding:9px 14px;min-height:36px}.icon-inline{margin-right:6px;vertical-align:-2px}.icon-stacked{display:block;margin:0 auto}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center;background:var(--surface-1);border-radius:var(--radius-lg);border:1px dashed var(--border)}.empty-state-icon{width:56px;height:56px;border-radius:50%;background:var(--surface-2);display:flex;align-items:center;justify-content:center;color:var(--text-muted);margin-bottom:16px}.empty-state-title{color:var(--text-primary);font-weight:600;font-size:15px;margin-bottom:4px;font-family:var(--font-display)}.empty-state-text{color:var(--text-tertiary);font-size:13px;max-width:280px;line-height:1.5}.error{color:var(--danger);font-size:13px;margin-top:8px;padding:12px 14px;background:var(--danger-soft);border-radius:var(--radius-md);border:1px solid rgba(239,68,68,.25);display:flex;align-items:center;gap:8px}.bottom-nav{position:fixed;left:0;right:0;bottom:0;background:#0a0f1cc7;backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);border-top:1px solid var(--border);display:flex;padding:10px 12px calc(10px + env(safe-area-inset-bottom));z-index:50;gap:4px;transition:opacity .12s var(--ease-out)}.bottom-nav a{flex:1;text-align:center;color:var(--text-muted);text-decoration:none;font-size:11px;font-weight:600;letter-spacing:.01em;padding:8px 4px;display:flex;flex-direction:column;align-items:center;gap:4px;min-height:52px;position:relative;border-radius:var(--radius-md);transition:color var(--dur-fast) var(--ease-out),background var(--dur-fast) var(--ease-out)}.bottom-nav a:hover{color:var(--text-secondary)}.bottom-nav a.active{color:var(--brand);background:var(--brand-soft)}.bottom-nav a .nav-icon{width:32px;height:32px;border-radius:var(--radius-pill);display:flex;align-items:center;justify-content:center;transition:background var(--dur-base) var(--ease-out),transform var(--dur-base) var(--ease-spring)}.bottom-nav a.active .nav-icon{background:#ffb6272e;transform:scale(1.08)}.bottom-nav a:active .nav-icon{transform:scale(.92)}.section{margin-bottom:24px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;padding:0 2px}.section-title{display:flex;align-items:center;gap:8px;font-size:17px;font-weight:700;color:var(--text-primary);font-family:var(--font-display);letter-spacing:-.015em}.section-title-icon{width:28px;height:28px;border-radius:var(--radius-sm);background:var(--brand-soft);color:var(--brand-300);display:flex;align-items:center;justify-content:center;font-size:16px}.section-action{background:none;border:none;color:var(--brand-300);cursor:pointer;font-size:13px;font-weight:600;padding:6px 10px;border-radius:var(--radius-sm);transition:background var(--dur-fast) var(--ease-out),transform var(--dur-fast) var(--ease-out);display:inline-flex;align-items:center;gap:4px}.section-action:hover{background:var(--brand-soft)}.section-action:active{transform:scale(.97)}.card{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px;position:relative;overflow:hidden;transition:transform var(--dur-fast) var(--ease-out),border-color var(--dur-fast) var(--ease-out),background var(--dur-fast) var(--ease-out);box-shadow:var(--shadow-inner)}.card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.12) 50%,transparent 100%);pointer-events:none}.card-hover:hover{border-color:var(--border-strong);background:var(--surface-2);transform:translateY(-1px)}.card-hover:active{transform:scale(.99) translateY(0);transition-duration:var(--dur-instant)}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--border-subtle)}.card-title{font-size:16px;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:8px;font-family:var(--font-display)}@keyframes page-fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes wave{0%,60%,to{transform:rotate(0)}10%,30%{transform:rotate(14deg)}20%{transform:rotate(-8deg)}40%{transform:rotate(-4deg)}50%{transform:rotate(10deg)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes orbit{0%,to{transform:rotate(0) scale(1)}50%{transform:rotate(180deg) scale(1.1)}}.skeleton{background:linear-gradient(90deg,var(--surface-1) 0%,var(--surface-2) 50%,var(--surface-1) 100%);background-size:200% 100%;animation:shimmer 1.6s ease-in-out infinite;border-radius:var(--radius-sm)}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.skillBadge{display:inline-flex;align-items:center;justify-content:center;gap:4px;border-radius:999px;padding:3px 8px;font-weight:700;font-size:11px;line-height:1;background:var(--surface-2);color:var(--text-primary);border:1px solid var(--border-subtle);letter-spacing:.02em;white-space:nowrap}.skillBadge-sm{padding:2px 6px;font-size:10px}.skillBadge-md{padding:3px 8px;font-size:11px}.skillBadge-lg{padding:6px 12px;font-size:14px}.skillBadge-xl{padding:8px 14px;font-size:16px;gap:8px;border-radius:999px;font-weight:800;box-shadow:0 4px 16px #0006}.skillBadge-num{font-variant-numeric:tabular-nums}.skillBadge-label{font-weight:500;color:var(--text-tertiary);margin-left:4px}.skillBadge-level_1{background:linear-gradient(135deg,#94a3b833,#64748b1a);color:#cbd5e1}.skillBadge-level_2{background:linear-gradient(135deg,#3b82f633,#6366f11a);color:#93c5fd}.skillBadge-level_3{background:linear-gradient(135deg,#10b98133,#22c55e1a);color:#86efac}.skillBadge-level_4{background:linear-gradient(135deg,#f59e0b33,#eab3081a);color:#fcd34d}.skillBadge-level_5{background:linear-gradient(135deg,#f9731640,#fb923c1a);color:#fdba74}.skillBadge-level_6{background:var(--gradient-brand);color:#1a1207;border-color:transparent}.skillBadge-empty{color:var(--text-muted)}.page-header{display:flex;align-items:center;gap:12px;margin-bottom:18px;padding-top:4px}.page-header-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:var(--gradient-brand-subtle);color:var(--brand);border:1px solid var(--border-subtle);flex-shrink:0}.page-header-title{font-size:22px;font-weight:700;margin:0;font-family:var(--font-display);letter-spacing:-.01em}.page-header-sub{font-size:13px;color:var(--text-tertiary);margin:2px 0 0}.calendarPage{padding:0}.calendarList{display:flex;flex-direction:column;gap:18px}.calendarDay{display:flex;flex-direction:column;gap:8px}.calendarDay-head{display:flex;align-items:center;justify-content:space-between;gap:8px;position:sticky;top:0;background:var(--bg-1);padding:4px 0;z-index:1}.calendarDay-pill{font-size:11px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em}.calendarDay-pill.isToday{background:var(--gradient-brand);color:#1a1207;padding:4px 10px;border-radius:999px;font-size:10px;text-transform:none;letter-spacing:0}.calendarDay-count{font-size:11px;color:var(--text-muted);background:var(--surface-2);border-radius:999px;padding:2px 8px;border:1px solid var(--border-subtle)}.calendarDay-empty{color:var(--text-muted);font-size:12px;padding:8px 4px}.calendarDay-games{display:flex;flex-direction:column;gap:8px}.calendarGame{display:grid;grid-template-columns:56px 36px 1fr;align-items:center;gap:10px;padding:12px 14px;background:var(--surface-1);border:1px solid var(--border-subtle);border-radius:var(--radius-md, 12px);text-decoration:none;color:var(--text-primary);transition:all .12s var(--ease-out)}.calendarGame:hover{background:var(--surface-2);border-color:var(--border-strong)}.calendarGame-time{font-weight:700;font-size:14px;font-variant-numeric:tabular-nums}.calendarGame-skill{display:inline-flex;align-items:center;justify-content:center;gap:4px;border-radius:8px;padding:4px 6px;font-weight:700;font-size:12px;width:36px}.calendarGame-info{display:flex;flex-direction:column;gap:2px;min-width:0}.calendarGame-venue{font-weight:600;font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.calendarGame-meta{font-size:12px;color:var(--text-tertiary)}.blacklistList{display:flex;flex-direction:column;gap:10px;margin-top:14px}.blacklistItem{display:grid;grid-template-columns:44px 1fr auto;align-items:center;gap:12px;background:var(--surface-1);border:1px solid var(--border-subtle);border-radius:12px;padding:10px 12px}.blacklistItem-info{min-width:0}.blacklistItem-name{font-weight:600;font-size:14px;display:flex;gap:6px;align-items:center}.blacklistItem-handle{font-size:12px;color:var(--text-muted);font-weight:400}.blacklistItem-meta{display:flex;gap:8px;align-items:center;margin-top:4px;flex-wrap:wrap}.blacklistItem-reason{font-size:12px;color:var(--text-tertiary);background:var(--surface-2);padding:2px 8px;border-radius:999px}.invitationsList{display:flex;flex-direction:column;gap:10px}.invitationItem{padding:14px}.invitationItem-meta{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.invitationItem-when{font-weight:700;font-size:15px}.invitationItem-venue{font-size:13px;color:var(--text-secondary)}.invitationItem-from{font-size:12px;color:var(--text-tertiary)}.invitationItem-actions{display:flex;gap:8px;flex-wrap:wrap}.paymentsList{display:flex;flex-direction:column;gap:8px;margin-top:14px}.paymentItem{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;padding:10px 14px;background:var(--surface-1);border:1px solid var(--border-subtle);border-radius:12px}.paymentItem-pill{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:3px 8px;border-radius:999px}.paymentItem-pill.isPaid{background:var(--success-soft);color:var(--success)}.paymentItem-pill.isUnpaid{background:var(--warning-soft);color:var(--warning)}.paymentItem-info{display:flex;flex-direction:column;min-width:0}.paymentItem-venue{font-weight:600;font-size:14px}.paymentItem-meta{font-size:12px;color:var(--text-tertiary)}.paymentsUnpaid{border-color:var(--warning)!important;margin-bottom:16px}.paymentsUnpaid-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-top:1px solid var(--border-subtle);text-decoration:none;color:inherit}.paymentsUnpaid-amount{font-weight:700;color:var(--warning);min-width:64px}.paymentsUnpaid-info{display:flex;flex-direction:column}.paymentsUnpaid-venue{font-weight:600}.paymentsUnpaid-when{font-size:12px;color:var(--text-tertiary)}.modalBackdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:100;display:flex;align-items:flex-end;justify-content:center;animation:page-fade-in .18s var(--ease-out)}.modal{background:var(--bg-2);border-top-left-radius:24px;border-top-right-radius:24px;border-top:1px solid var(--border);width:100%;max-width:540px;padding:20px 18px calc(20px + env(safe-area-inset-bottom));max-height:85vh;overflow-y:auto;animation:modal-slide-up .22s var(--ease-out)}@keyframes modal-slide-up{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.modal-title{font-size:18px;font-weight:700;margin:0}.modal-close{background:transparent;border:1px solid var(--border);border-radius:10px;padding:6px;cursor:pointer;color:var(--text-secondary)}.modal-actions{display:flex;gap:8px;margin-top:16px}.modal-actions .btn{flex:1}.optionList{display:flex;flex-direction:column;gap:8px}.optionItem{display:flex;align-items:center;gap:10px;padding:12px 14px;border:1px solid var(--border-subtle);border-radius:12px;background:var(--surface-1);cursor:pointer;transition:all .12s}.optionItem:hover{background:var(--surface-2)}.optionItem.isSelected{border-color:var(--brand);background:var(--brand-soft)}.skillChipGrid{display:grid;grid-template-columns:repeat(6,1fr);gap:6px}.skillChip{display:flex;flex-direction:column;align-items:center;gap:2px;padding:10px 4px;border-radius:10px;background:var(--surface-1);border:1px solid var(--border-subtle);cursor:pointer;transition:all .12s}.skillChip:hover{background:var(--surface-2)}.skillChip.isActive{background:var(--brand-soft);border-color:var(--brand)}.skillChip-num{font-weight:700;font-size:13px}.skillChip-icon{color:var(--text-tertiary)}.skillChip.isActive .skillChip-icon{color:var(--brand)}.toggle{position:relative;display:inline-flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none}.toggle input{position:absolute;opacity:0;pointer-events:none}.toggle-track{width:40px;height:22px;border-radius:999px;background:var(--surface-3);position:relative;transition:background .15s}.toggle-track:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;background:#fff;border-radius:50%;transition:transform .15s}.toggle input:checked+.toggle-track{background:var(--gradient-brand)}.toggle input:checked+.toggle-track:after{transform:translate(18px)}.toggle-label{font-size:13px}.costRow{display:flex;justify-content:space-between;align-items:baseline;font-size:14px;padding:4px 0}.costRow strong{font-variant-numeric:tabular-nums;font-weight:700}.costInput-row{display:flex;align-items:center;gap:6px}.costInput-row input{flex:1}.costInput-currency{background:var(--surface-2);border:1px solid var(--border-subtle);color:var(--text-primary);border-radius:10px;padding:10px 12px;font-size:14px}.coverPreview{position:relative;width:100%;aspect-ratio:16 / 9;border-radius:14px;overflow:hidden;background:var(--surface-2);border:1px solid var(--border-subtle)}.coverPreview img{width:100%;height:100%;object-fit:cover;display:block}.coverPreview-empty{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-muted);font-size:12px;gap:6px}.closedPill{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;background:var(--surface-3);border-radius:999px;font-size:11px;color:var(--text-secondary);font-weight:600}.requestBanner{background:var(--surface-2);border:1px solid var(--border);padding:10px 12px;border-radius:12px;display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary);margin:10px 0}.profileLinks{display:flex;flex-direction:column;gap:6px;margin-top:16px}.profileLink{display:flex;align-items:center;gap:10px;padding:14px;background:var(--surface-1);border:1px solid var(--border-subtle);border-radius:12px;text-decoration:none;color:var(--text-primary);font-weight:600;font-size:14px;transition:all .12s}.profileLink:hover{background:var(--surface-2);border-color:var(--border-strong)}.profileLink-icon{width:32px;height:32px;border-radius:8px;background:var(--gradient-brand-subtle);display:flex;align-items:center;justify-content:center;color:var(--brand)}.profileLink-arrow{margin-left:auto;color:var(--text-tertiary)}.skillBadge-on-photo{position:absolute;bottom:-3px;right:-3px;z-index:3;box-shadow:0 2px 8px #0000008c;border:2px solid var(--surface-1)}.profileHero-photoWrap{position:relative;display:inline-block}.spotsWrap{display:flex;flex-direction:column;gap:12px}.venuePicker-price{flex:0 0 18px;display:inline-flex;align-items:center;justify-content:center}.profilePhotoStatus{display:inline-flex;align-items:center;gap:4px;justify-content:center;width:20px;height:20px;padding:0;border-radius:999px;font-size:10px;font-weight:700;box-shadow:0 2px 8px #00000047;border:1px solid rgba(255,255,255,.18)}.profilePhotoStatus-admin{background:linear-gradient(135deg,#f59e0b,#ef4444);color:#fff}
