:root{--bg:#0f172a;--paper:#1e293b;--ink:#f1f5f9;--muted:#94a3b8;--accent:#84a98c;--line:#334155;--danger:#f87171;--danger-bg:#2d1515;--success-bg:#0f2318}*{box-sizing:border-box}:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}body{font-family:var(--font-sans,"Inter", "Segoe UI", sans-serif);background:radial-gradient(circle at 20% 10%, #1a2744 0%, var(--bg) 55%);color:var(--ink);-webkit-font-smoothing:antialiased;margin:0}h1{font-family:var(--font-sans,"Inter", "Segoe UI", sans-serif);font-optical-sizing:auto;letter-spacing:-.03em;margin:0;font-weight:700}h2{font-family:var(--font-sans,"Inter", "Segoe UI", sans-serif);letter-spacing:-.02em;margin:0;font-weight:600}h3{letter-spacing:-.01em;margin:0;font-weight:600}p{color:var(--muted);margin:0;line-height:1.6}input,select,textarea,button{font:inherit}label{color:var(--ink);letter-spacing:.01em;gap:6px;font-size:.875rem;font-weight:600;display:grid}.page{place-items:center;min-height:100vh;padding:24px;display:grid}.dashboard-page{min-height:100vh;padding:24px}.card{background:var(--paper);border:1px solid var(--line);border-radius:18px;width:min(780px,100%);padding:32px;box-shadow:0 1px 3px #00000040,0 6px 20px #00000073}.hero h1,.auth-card h1{font-size:clamp(2rem,6vw,3rem);line-height:1.05}.eyebrow{text-transform:uppercase;letter-spacing:.09em;color:var(--muted);margin:0 0 8px;font-size:.7rem;font-weight:700}.row{flex-wrap:wrap;gap:12px;margin-top:16px;display:flex}.button{cursor:pointer;border:1px solid #0000;border-radius:12px;align-items:center;gap:6px;padding:10px 16px;font-size:.9rem;font-weight:600;text-decoration:none;transition:transform .12s,box-shadow .12s,background-color .12s,border-color .12s,color .12s;display:inline-flex}.button:hover{transform:translateY(-1px)}.button:disabled{opacity:.45;cursor:not-allowed;pointer-events:none;transform:none}.button-primary{background:var(--accent);color:#0f172a}.button-primary:hover{box-shadow:0 4px 14px #84a98c59}.button-ghost{border-color:var(--line);color:var(--ink);background:0 0}.button-ghost:hover{border-color:var(--accent);color:var(--accent)}.button.danger{color:var(--danger);border-color:#0000}.button.danger:hover{background:var(--danger-bg);border-color:var(--danger)}input,select,textarea{border:1px solid var(--line);background:var(--bg);color:var(--ink);border-radius:12px;width:100%;padding:10px 12px;font-size:.95rem;transition:border-color .15s,box-shadow .15s}input:focus,select:focus,textarea:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #84a98c26}input.error,select.error,textarea.error{border-color:var(--danger);background:var(--danger-bg)}input.success,select.success,textarea.success{border-color:var(--accent);background:var(--success-bg)}.field-error{color:var(--danger);margin-top:2px;font-size:.8rem;font-weight:500}textarea{resize:vertical;min-height:88px}.auth-form{gap:10px;display:grid}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:16px;display:grid}.compact-form{margin-top:20px}.full-width{grid-column:1/-1}.oauth-buttons{flex-wrap:wrap;gap:12px;margin-top:12px;display:flex}.status{color:var(--muted);margin-top:14px;font-size:.875rem}.status-ok{color:var(--accent);font-weight:500}.status-error{color:var(--danger);font-weight:500}.dashboard-header{justify-content:space-between;align-items:flex-end;gap:16px;width:min(1200px,100%);margin:0 auto 20px;display:flex}.dashboard-grid{grid-template-columns:360px 1fr;gap:20px;width:min(1200px,100%);margin:0 auto;display:grid}.dashboard-profile{width:min(1200px,100%);margin:20px auto 0}.game-night-banner{align-items:stretch;gap:0;width:min(1200px,100%);margin:0 auto 20px;padding:0;display:flex;overflow:hidden}.gnb-cta{flex-shrink:0;align-items:flex-start;gap:16px;padding:22px 28px;display:flex}.gnb-cta-icon{color:var(--accent);flex-shrink:0;margin-top:2px}.gnb-cta-heading{color:var(--ink);margin:0 0 4px;font-size:1.05rem;font-weight:700}.gnb-cta-desc{color:var(--muted);max-width:220px;margin:0;font-size:.82rem;line-height:1.4}.gnb-cta-actions{flex-direction:column;align-items:flex-start;gap:8px;margin-top:14px;display:flex}.gnb-start-btn{padding:7px 16px!important;font-size:.85rem!important}.gnb-view-link{color:var(--accent);font-size:.8rem;text-decoration:none}.gnb-view-link:hover{text-decoration:underline}.gnb-divider{background:var(--line);flex-shrink:0;align-self:stretch;width:1px}.gnb-col{flex-direction:column;flex:1;gap:10px;min-width:0;padding:22px 24px;display:flex}.gnb-col-label{letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin:0;font-size:.72rem;font-weight:700}.gnb-col-label-row{justify-content:space-between;align-items:center;display:flex}.gnb-view-all{color:var(--muted);font-size:.76rem;text-decoration:none}.gnb-view-all:hover{color:var(--ink)}.gnb-night-card{border:1px solid var(--line);background:#ffffff08;border-radius:8px;align-items:center;gap:12px;padding:10px 12px;text-decoration:none;transition:background .15s;display:flex}.gnb-night-card:hover{background:#ffffff12}.gnb-night-art{background:linear-gradient(135deg, var(--accent) 0%, #84a98c40 100%);border-radius:6px;flex-shrink:0;width:52px;height:52px}.gnb-night-info{flex-direction:column;gap:3px;min-width:0;display:flex}.gnb-night-title{color:var(--ink);white-space:nowrap;text-overflow:ellipsis;font-size:.88rem;font-weight:600;overflow:hidden}.gnb-night-date{color:var(--muted);font-size:.76rem}.gnb-status-badge{border-radius:10px;width:fit-content;padding:2px 7px;font-size:.7rem;font-weight:600;display:inline-block}.gnb-status-badge--active{color:#f59e0b;background:#f59e0b26}.section-card{width:100%}.section-heading{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.dashboard-status{width:min(1200px,100%);margin:16px auto 0}.bgg-search-block{border:1px solid var(--line);background:#ffffff0a;border-radius:14px;margin-bottom:20px;padding:14px}.small-label{color:var(--muted);text-transform:uppercase;letter-spacing:.07em;margin:0 0 8px;font-size:.75rem;font-weight:700;display:block}.search-hint{color:var(--muted);margin-top:6px;font-size:.8rem;display:block}.search-results{gap:6px;max-height:220px;margin-top:10px;display:grid;overflow-y:auto}.search-result-item{background:var(--bg);border:1px solid var(--line);border-radius:10px;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;display:flex}.search-result-art{background:#ffffff0d;border-radius:8px;flex-shrink:0;place-items:center;width:44px;height:44px;display:grid;overflow:hidden}.search-result-art img{object-fit:cover;width:100%;height:100%}.search-result-item p{margin:2px 0 0;font-size:.85rem}.import-options-row{flex-wrap:wrap;align-items:center;gap:12px;margin:8px 0 16px;display:flex}.import-option{color:var(--muted);align-items:center;gap:6px;font-size:.8rem;font-weight:600;display:inline-flex}.import-option input{width:auto}.inline-actions{flex-wrap:wrap;align-items:center;gap:8px;margin-top:10px;display:flex}.inline-actions input{flex:1;min-width:220px}.inline-editor{border-top:1px solid var(--line);gap:10px;margin-top:14px;padding-top:14px;display:grid}.collection-grid,.ranked-list{gap:8px;margin-top:18px;display:grid}.collection-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.ranked-list{grid-template-columns:1fr}.game-card,.ranked-item{border:1px solid var(--line);background:#ffffff0a;border-radius:14px;gap:14px;padding:14px;transition:box-shadow .15s,transform .15s;display:grid}.game-card:hover,.ranked-item:hover{transform:translateY(-1px);box-shadow:0 3px 14px #00000059}.game-card{cursor:pointer;grid-template-columns:1fr;align-content:start}.game-card.in-top-list{border-color:var(--accent);box-shadow:0 0 0 1px #84a98c73}.game-card.selected{border-color:var(--accent);box-shadow:0 0 0 2px #84a98c33}.game-card[draggable=true]:not(.in-top-list){cursor:grab}.game-card[draggable=true]:not(.in-top-list):active{cursor:grabbing}.game-card.dragging{opacity:.45;transform:scale(.97)}.shelf-card-body{gap:8px;display:grid}.shelf-filter-row{flex-wrap:wrap;gap:6px;margin-top:10px;display:flex}.shelf-filter-button{border:1px solid var(--line);color:var(--muted);cursor:pointer;background:0 0;border-radius:999px;padding:4px 10px;font-size:.72rem}.shelf-filter-button.active{border-color:var(--accent);color:var(--accent);background:#84a98c1f}.shelf-card-title{font-size:.86rem;line-height:1.35}.shelf-status-pill{border:1px solid var(--line);text-transform:uppercase;letter-spacing:.04em;color:var(--muted);border-radius:999px;justify-self:start;padding:2px 8px;font-size:.64rem;display:inline-flex}.shelf-status-pill.status-owned{color:#bfd8c6;border-color:#84a98c73}.shelf-status-pill.status-wishlist{color:#bfdbfe;border-color:#60a5fa80}.shelf-status-pill.status-played{color:#fbcfe8;border-color:#f472b680}.in-top-list-pill{color:#c7e8ce;letter-spacing:.03em;text-transform:uppercase;background:#84a98c2e;border:1px solid #84a98c99;border-radius:999px;justify-self:start;align-items:center;padding:2px 8px;font-size:.68rem;display:inline-flex}.shelf-card-actions{opacity:0;pointer-events:none;gap:6px;transition:opacity .14s;display:flex}.game-card:hover .shelf-card-actions,.game-card:focus-within .shelf-card-actions{opacity:1;pointer-events:auto}.shelf-card-actions .button{border-radius:8px;padding:5px 10px;font-size:.75rem}.game-card>div:last-child{min-width:0}.game-art{aspect-ratio:1;background:linear-gradient(135deg, var(--accent) 0%, #6b9e78 100%);color:#0f172a;width:100%;font-family:var(--font-sans,"Inter", "Segoe UI", sans-serif);font-optical-sizing:auto;letter-spacing:-.02em;border-radius:12px;flex-shrink:0;place-items:center;font-size:1.75rem;font-weight:700;display:grid;overflow:hidden}.game-art img{object-fit:cover;width:100%;height:100%}.ranked-item{grid-template-columns:46px 58px 1fr;align-items:start;gap:10px;padding:10px;position:relative}.ranked-item>div:last-child{gap:4px;display:grid}.ranked-item-empty{opacity:.9;border-style:dashed}.ranked-item-empty.drop-empty{border-color:var(--accent);box-shadow:0 0 0 2px #84a98c38}.ranked-art-empty{color:#c7e8ce;background:#84a98c1f;border:1px dashed #84a98c73}.empty-slot-title{color:var(--ink);font-size:.95rem}.ranked-item.dragging-source{opacity:.35}.ranked-item.drop-before,.ranked-item.drop-after{position:relative}.ranked-item.drop-before:before,.ranked-item.drop-after:after{content:"";background:var(--accent);pointer-events:none;z-index:1;border-radius:2px;height:3px;position:absolute;left:8px;right:8px}.ranked-item.drop-before:before{top:-2px}.ranked-item.drop-after:after{bottom:-2px}.rank-badge{background:var(--accent);color:#0f172a;border-radius:999px;flex-shrink:0;place-items:center;width:36px;height:36px;font-size:.76rem;font-weight:700;display:grid}.ranked-art{background:linear-gradient(135deg, var(--accent) 0%, #6b9e78 100%);color:#0f172a;border-radius:8px;place-items:center;width:58px;height:58px;font-size:1.05rem;font-weight:700;display:grid;overflow:hidden}.ranked-item h3{font-size:.92rem;line-height:1.28}.ranked-item p{font-size:.82rem;line-height:1.42}.ranked-art img{object-fit:cover;width:100%;height:100%}.top-note-button{color:var(--text);text-align:left;cursor:pointer;opacity:.9;white-space:nowrap;text-overflow:ellipsis;background:0 0;border:0;padding:0;font-size:.82rem;line-height:1.2;overflow:hidden}.top-note-button:hover{opacity:1;color:var(--accent)}.top-note-editor{border:1px solid var(--line);background:var(--bg);width:100%;min-height:56px;color:var(--text);resize:vertical;border-radius:8px;padding:6px 8px}.top-remove{color:#fca5a5;cursor:pointer;opacity:0;background:0 0;border:0;justify-self:start;padding:0;transition:opacity .14s}.top-remove-icon{background:#f8717114;border-radius:999px;place-items:center;width:18px;height:18px;font-size:.72rem;line-height:1;display:grid;position:absolute;top:6px;right:8px}.top-remove-icon:hover{background:#f8717133}.ranked-item:hover .top-remove,.ranked-item:focus-within .top-remove{opacity:1}.profile-inline-list{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.profile-inline-item{gap:6px;display:grid}.profile-inline-trigger{text-align:left;border:1px solid var(--line);background:var(--bg);width:100%;color:var(--ink);cursor:pointer;border-radius:12px;padding:10px 12px}.profile-inline-trigger:hover{border-color:var(--accent)}.profile-inline-trigger-bio{min-height:88px}.empty-state{border:1px dashed var(--line);text-align:center;color:var(--muted);border-radius:14px;padding:24px 16px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton{background:linear-gradient(90deg, var(--line) 25%, #263348 50%, var(--line) 75%);background-size:200% 100%;border-radius:8px;animation:1.5s ease-in-out infinite shimmer}.skeleton-card{border:1px solid var(--line);border-radius:14px;grid-template-columns:84px 1fr;gap:14px;padding:14px;display:grid}.skeleton-art{border-radius:12px;width:84px;height:84px}.skeleton-lines{align-content:start;gap:8px;padding-top:6px;display:grid}.skeleton-line{border-radius:6px;height:13px}.skeleton-line.short{width:60%}.skeleton-line.xshort{width:35%}.page:has(.public-profile-card){align-items:start;padding-top:40px}.public-profile-card{gap:12px;width:min(960px,100%);display:grid}.public-handle{color:var(--muted);margin-top:-2px;font-size:.95rem}.public-hero{align-items:center;gap:20px;margin-bottom:4px;display:flex}.public-avatar{background:linear-gradient(135deg, var(--accent) 0%, #6b9e78 100%);color:#0f172a;letter-spacing:-.02em;border-radius:999px;flex-shrink:0;place-items:center;width:72px;height:72px;font-size:1.75rem;font-weight:700;display:grid}.public-content-grid{grid-template-columns:1fr 1fr;gap:28px;margin-top:20px;display:grid}.public-section-title{text-transform:uppercase;letter-spacing:.07em;color:var(--muted);margin-bottom:12px;font-size:1rem;font-weight:700}.public-bio{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.public-share-row{align-items:center;margin-top:4px}.public-ranked-list{margin-bottom:8px}.public-collection-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.public-collection-card{gap:8px;display:grid}.public-collection-card h3{font-size:.9rem;line-height:1.3}.public-collection-art{aspect-ratio:1;background:linear-gradient(135deg, var(--accent) 0%, #6b9e78 100%);color:#0f172a;border-radius:10px;place-items:center;width:100%;font-size:1.25rem;font-weight:700;display:grid;overflow:hidden}.public-collection-art img{object-fit:cover;width:100%;height:100%}.legal-page{padding:40px 24px 80px}.legal-content{width:min(720px,100%);margin:0 auto}.legal-back{color:var(--muted);margin-bottom:24px;font-size:.875rem;font-weight:600;text-decoration:none;transition:color .12s;display:inline-block}.legal-back:hover{color:var(--accent)}.legal-updated{color:var(--muted);margin:4px 0 32px;font-size:.8rem}.legal-section{margin-bottom:28px}.legal-section h2{margin-bottom:8px;font-size:1.1rem}.legal-section p,.legal-section ul{margin-bottom:8px}.legal-section ul{color:var(--muted);padding-left:20px;line-height:1.6}.legal-section li{margin-bottom:4px}.legal-section a{color:var(--accent);text-decoration:none}.legal-section a:hover{text-decoration:underline}.legal-danger-zone{border-top:2px solid var(--line);gap:16px;margin-top:32px;padding-top:28px;display:grid}.legal-danger-zone>h2{font-size:1.1rem}.legal-danger-action{border:1px solid var(--line);background:#ffffff0a;border-radius:12px;justify-content:space-between;align-items:flex-start;gap:20px;padding:16px;display:flex}.legal-danger-label{color:var(--ink);margin:0 0 4px;font-size:.9rem;font-weight:700}.legal-danger-desc{color:var(--muted);margin:0;font-size:.825rem}.legal-confirm-row{flex-wrap:wrap;flex-shrink:0;align-items:center;gap:8px;display:flex}.legal-confirm-text{color:var(--danger);font-size:.825rem;font-weight:500}.site-footer{color:var(--muted);border-top:1px solid var(--line);align-items:center;gap:16px;padding:16px 24px;font-size:.8rem;display:flex}.site-footer a{color:var(--muted);text-decoration:none;transition:color .12s}.site-footer a:hover{color:var(--accent)}.admin-page{padding:40px 24px 80px}.admin-content{width:min(720px,100%);margin:0 auto}.admin-title{margin-bottom:32px;font-size:2rem}.admin-section{margin-bottom:32px}.admin-section-label{color:var(--muted);text-transform:uppercase;letter-spacing:.09em;margin-bottom:12px;font-size:.7rem;font-weight:700}.admin-stat-grid{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.admin-stat{background:var(--paper);border:1px solid var(--line);border-radius:14px;gap:6px;padding:20px 16px;display:grid}.admin-stat-value{letter-spacing:-.03em;color:var(--ink);font-size:2rem;font-weight:700}.admin-stat-label{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-size:.72rem;font-weight:600}.admin-quality-grid{background:var(--paper);border:1px solid var(--line);border-radius:14px;overflow:hidden}.admin-quality-row{border-bottom:1px solid var(--line);align-items:center;gap:12px;padding:12px 16px;display:flex}.admin-quality-row:last-child{border-bottom:none}.admin-quality-label{color:var(--ink);flex:1;font-size:.875rem}.admin-quality-count{color:var(--muted);font-variant-numeric:tabular-nums;font-size:.875rem}.admin-quality-pct{text-align:right;min-width:40px;font-size:.8rem;font-weight:700}.admin-quality-pct.ok{color:var(--accent)}.admin-quality-pct.warn{color:var(--danger)}@media (max-width:640px){.card{padding:20px 16px}.admin-stat-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:900px){.dashboard-grid{grid-template-columns:1fr}.collection-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.dashboard-header{flex-direction:column;align-items:start}.game-night-banner{flex-direction:column}.gnb-divider{width:auto;height:1px}}@media (max-width:720px){.form-grid,.profile-inline-list{grid-template-columns:1fr}.public-collection-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.collection-grid,.ranked-item{grid-template-columns:1fr}.game-art{border-radius:10px;width:100%;height:180px}}@media (max-width:700px){.public-content-grid{grid-template-columns:1fr}}@media (hover:none){.shelf-card-actions{opacity:1;pointer-events:auto}}.paste-list-textarea{border:1px solid var(--line);background:var(--bg);width:100%;color:var(--ink);resize:vertical;border-radius:10px;padding:10px 12px;font-family:inherit;font-size:.9rem;transition:border-color .15s}.paste-list-textarea:focus{border-color:var(--accent);outline:none}.paste-list-results{flex-direction:column;gap:8px;display:flex}.paste-list-row{background:var(--bg);border:1px solid var(--line);border-radius:10px;grid-template-columns:44px 1fr auto auto;align-items:center;gap:10px;padding:8px 10px;display:grid}.paste-list-row--found{border-color:var(--accent)}.paste-list-row--not-found{opacity:.5}.paste-list-art{background:var(--line);width:44px;height:44px;color:var(--muted);border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;font-size:1.2rem;display:flex;overflow:hidden}.paste-list-art img{object-fit:cover;width:100%;height:100%}.paste-list-info{flex-direction:column;gap:2px;min-width:0;display:flex}.paste-list-input-title{color:var(--ink);white-space:nowrap;text-overflow:ellipsis;font-size:.875rem;font-weight:600;overflow:hidden}.paste-list-match-name{color:var(--accent);font-size:.8rem}.paste-list-no-match,.paste-list-pending{color:var(--muted);font-size:.8rem}.paste-list-status-select{border-radius:8px;width:auto;padding:5px 8px;font-size:.8rem}.gn-list-page{gap:28px;width:min(1200px,100%);margin:20px auto 0;display:grid}.gn-section-label{text-transform:uppercase;letter-spacing:.09em;color:var(--muted);margin:0 0 10px;font-size:.7rem;font-weight:700}.gn-list{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.gn-card{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:18px 20px;text-decoration:none;transition:box-shadow .15s,transform .15s,border-color .15s;display:block}.gn-card:hover{border-color:#84a98c66;transform:translateY(-1px);box-shadow:0 4px 18px #0006}.gn-card-main{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.gn-card-body{gap:4px;min-width:0;display:grid}.gn-card-role{text-transform:uppercase;letter-spacing:.07em;color:var(--muted);margin:0;font-size:.68rem;font-weight:700}.gn-card-title{color:var(--ink);letter-spacing:-.01em;white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:1.05rem;font-weight:600;overflow:hidden}.gn-card-meta{color:var(--muted);margin:0;font-size:.82rem}.gn-card-theme{color:var(--muted);margin:0;font-size:.8rem;font-style:italic}.gn-status-badge{text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;border-radius:999px;flex-shrink:0;align-items:center;padding:3px 10px;font-size:.68rem;font-weight:700;display:inline-flex}.gn-status-planning{border:1px solid var(--line);color:var(--muted);background:0 0}.gn-status-voting{color:#bfdbfe;background:#60a5fa14;border:1px solid #60a5fa80}.gn-status-confirmed{color:#c7e8ce;background:#84a98c1f;border:1px solid #84a98c99}.gn-status-completed{border:1px solid var(--line);color:#475569;background:0 0}.gn-new-card{width:min(900px,100%)}.gn-back-link{color:var(--muted);margin-bottom:16px;font-size:.82rem;font-weight:600;text-decoration:none;transition:color .12s;display:inline-block}.gn-back-link:hover{color:var(--accent)}.gn-optional{color:var(--muted);font-size:.8em;font-weight:400}.gn-form{gap:20px;margin-top:20px;display:grid}.gn-form-actions{justify-content:flex-end;gap:12px;margin-top:8px;display:flex}.gn-participants-section{gap:12px;padding-top:4px;display:grid}.gn-handle-search{align-items:center;gap:8px;display:flex}.gn-handle-search input{flex:1}.gn-search-result{border:1px solid var(--line);background:var(--bg);border-radius:12px;justify-content:space-between;align-items:center;gap:12px;margin-top:8px;padding:10px 12px;display:flex}.gn-search-name{color:var(--ink);margin:0;font-size:.95rem;font-weight:600}.gn-participant-list{gap:0;margin:8px 0 0;padding:0;list-style:none;display:grid}.gn-participant-row{border-bottom:1px solid var(--line);align-items:center;gap:12px;padding:10px 0;display:flex}.gn-participant-row:last-child{border-bottom:none}.gn-participant-avatar{background:linear-gradient(135deg, var(--accent) 0%, #6b9e78 100%);color:#0f172a;border-radius:999px;flex-shrink:0;place-items:center;width:32px;height:32px;font-size:.8rem;font-weight:700;display:grid}.gn-avatar-organizer{box-shadow:0 0 0 2px #84a98c80}.gn-participant-name{color:var(--ink);flex:1;margin:0;font-size:.9rem;font-weight:600}.gn-ptcpt-status{text-transform:uppercase;letter-spacing:.04em;border-radius:999px;flex-shrink:0;padding:2px 8px;font-size:.68rem;font-weight:700}.gn-ptcpt-status-invited{border:1px solid var(--line);color:var(--muted)}.gn-ptcpt-status-confirmed{color:#c7e8ce;background:#84a98c1a;border:1px solid #84a98c80}.gn-ptcpt-status-declined{color:#fca5a5;background:#f871710f;border:1px solid #f8717166}.gn-add-participant{border-top:1px solid var(--line);gap:10px;margin-top:16px;padding-top:16px;display:grid}.gn-header-top{align-items:center;gap:12px;margin-bottom:8px;display:flex}.gn-meta-row{flex-wrap:wrap;gap:6px 20px;margin-top:6px;display:flex}.gn-meta-row p{color:var(--muted);margin:0;font-size:.88rem}.gn-edit-form{flex-direction:column;gap:12px;margin-top:4px;display:flex}.gn-edit-title{border:none;border-bottom:1px solid var(--line);color:var(--ink);background:0 0;outline:none;width:100%;padding:4px 0;font-size:1.6rem;font-weight:700}.gn-edit-title:focus{border-bottom-color:var(--accent)}.gn-edit-fields{grid-template-columns:1fr 1fr;gap:10px 20px;display:grid}.gn-edit-label{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;flex-direction:column;gap:4px;font-size:.78rem;display:flex}.gn-edit-label input,.gn-edit-label select{color:var(--ink);background:var(--bg);border:1px solid var(--line);border-radius:6px;padding:6px 8px;font-size:.9rem}.gn-edit-label select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2394a3b8' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;padding-right:28px}@media (max-width:600px){.gn-edit-fields{grid-template-columns:1fr}}.gn-auto-add-banner{background:#84a98c12;border:1px solid #84a98c66;border-radius:12px;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;padding:12px 14px;display:flex}.gn-auto-add-banner p{color:var(--ink);margin:0;font-size:.875rem}.gn-candidate-list{gap:6px;margin:8px 0;padding:0;list-style:none;display:grid}.gn-pool-card{width:min(1200px,100%);margin:20px auto 0}.gn-pool-search{margin:12px 0}.gn-pool-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:8px;margin:12px 0 0;padding:0;list-style:none;display:grid}.gn-pool-item{border:1px solid var(--line);background:#ffffff08;border-radius:12px;align-items:center;gap:10px;padding:8px 10px;transition:border-color .12s;display:flex}.gn-pool-item-candidate{border-color:var(--accent);background:#84a98c0f}.gn-pool-art{background:linear-gradient(135deg, var(--accent) 0%, #6b9e78 100%);color:#0f172a;border-radius:8px;flex-shrink:0;place-items:center;width:52px;height:52px;font-size:.9rem;font-weight:700;display:grid;overflow:hidden}.gn-pool-art img{object-fit:cover;width:100%;height:100%}.gn-pool-info{flex:1;gap:2px;min-width:0;display:grid}.gn-pool-name{color:var(--ink);white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:.87rem;font-weight:600;overflow:hidden}.gn-pool-check{width:18px;height:18px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}.gn-pool-meta-row{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.gn-bgg-badge{color:#fbbf24;white-space:nowrap;background:#fbbf241f;border:1px solid #fbbf2447;border-radius:6px;align-items:center;padding:1px 6px;font-size:.68rem;font-weight:700;display:inline-flex}.gn-owner-avatars{flex-direction:row;flex-shrink:0;display:flex}.gn-owner-avatar{color:#e2f0e6;border:2px solid var(--paper);background:linear-gradient(135deg,#4a7c59 0%,#3d6b4a 100%);border-radius:999px;flex-shrink:0;place-items:center;width:30px;height:30px;margin-left:-7px;font-size:.7rem;font-weight:700;display:grid}.gn-owner-avatar:first-child{margin-left:0}.gn-play-online{border:1px solid var(--line);color:var(--muted);white-space:nowrap;border-radius:8px;flex-shrink:0;align-items:center;gap:4px;padding:3px 8px;font-size:.72rem;font-weight:600;text-decoration:none;transition:border-color .12s,color .12s;display:inline-flex}.gn-play-online:hover{border-color:var(--accent);color:var(--accent)}.gn-chip-online.gn-chip-active{border-color:var(--accent);color:var(--accent);background:#84a98c1a}.gn-pool-context{color:var(--muted);margin:2px 0 0;font-size:.78rem}.gn-pool-tags{flex-wrap:wrap;gap:4px;margin-top:5px;display:flex}.gn-pool-tag{color:#7fbf9a;white-space:nowrap;background:#1e3a2e;border-radius:999px;padding:2px 7px;font-size:.68rem}.gn-pool-tag-mechanic{color:#7fb3bf;background:#1e2d3a}.gn-selection-hint{color:var(--muted);margin:0 0 12px;font-size:.82rem}.gn-selection-hint:has(+.gn-pool-chips){margin-bottom:8px}.gn-pool-chips{flex-wrap:wrap;gap:8px;margin:12px 0 4px;display:flex}.gn-chip{border:1px solid var(--line);color:var(--muted);cursor:pointer;white-space:nowrap;background:0 0;border-radius:999px;align-items:center;padding:5px 12px;font-size:.75rem;font-weight:600;transition:border-color .12s,color .12s,background .12s;display:inline-flex}.gn-chip:hover{color:var(--ink);border-color:#84a98c66}.gn-chip-active{border-color:var(--accent);color:var(--accent);background:#84a98c14}.gn-next-steps{border:1px solid var(--line);background:#ffffff05;border-radius:12px;margin-top:16px;padding:12px 14px}.gn-next-steps-label{text-transform:uppercase;letter-spacing:.07em;color:var(--muted);margin:0 0 6px;font-size:.68rem;font-weight:700}.gn-next-steps p{color:var(--muted);margin:0;font-size:.82rem}.gn-create-page{box-sizing:border-box;width:100%;min-height:100svh;padding:20px}.gn-create-layout{border:1px solid var(--line);border-radius:20px;grid-template-columns:300px 1fr 260px;max-width:1400px;min-height:calc(100svh - 40px);margin:0 auto;display:grid;overflow:hidden}.gn-create-left{background:var(--paper);border-right:1px solid var(--line);flex-direction:column;padding:24px 20px;display:flex;overflow-y:auto}.gn-create-center{background:var(--bg);padding:24px 20px;overflow-y:auto}.gn-create-right{background:var(--paper);border-left:1px solid var(--line);flex-direction:column;gap:20px;padding:24px 20px;display:flex;overflow-y:auto}.gn-panel-section{flex-direction:column;gap:12px;padding:16px 0;display:flex}.gn-panel-divider{background:var(--line);flex-shrink:0;height:1px}.gn-panel-step-row{align-items:center;gap:10px;display:flex}.gn-panel-step{background:var(--accent);color:#0f172a;border-radius:999px;flex-shrink:0;place-items:center;width:24px;height:24px;font-size:.72rem;font-weight:700;display:grid}.gn-panel-heading{color:var(--ink);margin:0;font-size:1rem;font-weight:600}.gn-left-form{gap:14px;display:grid}.gn-participant-info{flex:1;min-width:0}.gn-create-error{margin-bottom:12px}.gn-create-center-header{margin-bottom:4px}.gn-pool-item-clickable{cursor:pointer;-webkit-user-select:none;user-select:none}.gn-pool-item-clickable:hover{border-color:#84a98c80}.gn-summary-heading{color:var(--ink);margin:0;font-size:1rem;font-weight:600}.gn-summary-section{flex-direction:column;gap:8px;display:flex}.gn-summary-label{text-transform:uppercase;letter-spacing:.07em;color:var(--muted);margin:0;font-size:.7rem;font-weight:700}.gn-summary-avatars{flex-wrap:wrap;gap:6px;display:flex}.gn-summary-avatar{background:linear-gradient(135deg, var(--accent) 0%, #6b9e78 100%);color:#0f172a;border-radius:999px;flex-shrink:0;place-items:center;width:36px;height:36px;font-size:.82rem;font-weight:700;display:grid}.gn-summary-thumbs{flex-wrap:wrap;gap:6px;display:flex}.gn-summary-thumb{background:linear-gradient(135deg, var(--accent) 0%, #6b9e78 100%);color:#0f172a;border-radius:8px;flex-shrink:0;place-items:center;width:42px;height:42px;font-size:.72rem;font-weight:700;display:grid;overflow:hidden}.gn-summary-thumb img{object-fit:cover;width:100%;height:100%}.gn-summary-thumb-more{background:var(--bg);border:1px solid var(--line);color:var(--muted);font-size:.68rem}.gn-summary-event-title{color:var(--ink);margin:0;font-size:.95rem;font-weight:600}.gn-summary-actions{flex-direction:column;gap:8px;margin-top:auto;display:flex}.gn-summary-actions .button{text-align:center;width:100%}@media (max-width:900px){.gn-list{grid-template-columns:1fr}}@media (max-width:1000px){.gn-create-layout{min-height:unset;border-radius:16px;grid-template-columns:1fr}.gn-create-left{border-right:none;border-bottom:1px solid var(--line)}.gn-create-right{border-left:none;border-top:1px solid var(--line)}.gn-summary-actions{flex-direction:row;margin-top:0}}@media (max-width:640px){.gn-pool-grid{grid-template-columns:1fr}.gn-auto-add-banner{flex-direction:column;align-items:flex-start}}.ag-overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:1000;background:#000000a6;justify-content:center;align-items:flex-start;padding:20px;display:flex;position:fixed;inset:0;overflow-y:auto}.ag-modal{background:var(--paper);border:1px solid var(--line);border-radius:18px;flex-direction:column;width:min(860px,100%);margin:auto;display:flex;box-shadow:0 4px 16px #0006,0 20px 60px #00000080}.ag-modal-header{flex-shrink:0;justify-content:space-between;align-items:flex-start;gap:16px;padding:28px 28px 20px;display:flex}.ag-close{flex-shrink:0;padding:8px 18px}.ag-tabs{border-bottom:1px solid var(--line);scrollbar-width:none;flex-shrink:0;gap:0;padding:0 28px;display:flex;overflow-x:auto}.ag-tabs::-webkit-scrollbar{display:none}.ag-tab{color:var(--muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:7px;margin-bottom:-1px;padding:10px 18px;font-size:.875rem;font-weight:600;transition:color .12s,border-color .12s;display:flex}.ag-tab:hover{color:var(--ink)}.ag-tab-active{color:var(--ink);border-bottom-color:var(--accent)}.ag-tab-icon{font-size:.95rem}.ag-body{padding:24px 28px}.ag-footer{border-top:1px solid var(--line);flex-shrink:0;padding:12px 28px}@media (max-width:600px){.ag-modal-header{padding:20px 16px 14px}.ag-tabs{padding:0 16px}.ag-body{padding:16px}.ag-tab{padding:10px 12px;font-size:.8rem}.ag-tab-icon{display:none}}.bbt-dropzone{border:2px dashed var(--line);text-align:center;cursor:pointer;-webkit-user-select:none;user-select:none;background:0 0;border-radius:10px;padding:28px 24px;transition:border-color .12s,background .12s,padding .2s}.bbt-dropzone-active{border-color:var(--accent);background:#84a98c0f}.bbt-grid{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.bbt-grid-dragging{outline:2px dashed var(--accent);outline-offset:4px;border-radius:10px}.bbt-plus-slot{aspect-ratio:1;border:2px dashed var(--line);cursor:pointer;background:0 0;border-radius:8px;justify-content:center;align-items:center;width:100%;transition:border-color .12s,background .12s;display:flex}.bbt-plus-slot:hover{border-color:var(--accent);background:#84a98c0f}.bbt-plus-icon{color:var(--muted);font-size:2rem;line-height:1;transition:color .12s}.bbt-plus-slot:hover .bbt-plus-icon{color:var(--accent)}.bbt-slot-wrap{flex-direction:column;gap:5px;min-width:0;display:flex}.bbt-slot{aspect-ratio:1;background-color:var(--line);isolation:isolate;border-radius:8px;position:relative;overflow:hidden}.bbt-slot:before{content:"";background-image:var(--slot-img);filter:blur(12px)brightness(.45);z-index:0;background-position:50%;background-size:cover;position:absolute;inset:-8%}.bbt-slot:after{content:"";background-image:var(--slot-img);z-index:1;background-position:50%;background-repeat:no-repeat;background-size:contain;position:absolute;inset:0}.bbt-slot-top{z-index:2;position:absolute;top:6px;left:6px;right:36px}.bbt-badge{letter-spacing:.02em;white-space:nowrap;border-radius:20px;padding:2px 7px;font-size:.68rem;font-weight:700;display:inline-block}.bbt-badge-pending,.bbt-badge-matching{color:#fff;background:#00000073}.bbt-badge-matched{color:#fff;background:#4caf50d9}.bbt-badge-needs_review{color:#fff;background:#ffa000d9}.bbt-badge-no_match{color:#fff;background:#d32f2fd9}.bbt-badge-duplicate{color:#fff;background:#6464ffd9}.bbt-slot-actions{opacity:0;z-index:2;flex-direction:column;gap:4px;transition:opacity .12s;display:flex;position:absolute;top:6px;right:6px}.bbt-slot:hover .bbt-slot-actions{opacity:1}.bbt-action-btn{color:#fff;cursor:pointer;background:#000000a6;border:1.5px solid #ffffff59;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;font-size:.9rem;line-height:1;transition:background .1s,border-color .1s;display:flex}.bbt-action-btn:hover{background:#000000e0;border-color:#fff9}.bbt-action-btn-match{background:#388e3cd9;border-color:#ffffff80}.bbt-action-btn-match:hover{background:#388e3c}@media (hover:none){.bbt-slot-actions{opacity:1}}.bbt-title-input{width:100%;color:var(--ink);background:var(--bg);border:1px solid var(--line);box-sizing:border-box;border-radius:5px;min-width:0;padding:4px 7px;font-size:.75rem;font-weight:600}.bbt-title-input:focus{border-color:var(--accent);outline:none}.bbt-title-input:disabled{opacity:.5}.bbt-debug{color:var(--muted);flex-direction:column;gap:1px;font-size:.65rem;line-height:1.3;display:flex;overflow:hidden}.bbt-debug span{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}@media (max-width:640px){.bbt-grid{grid-template-columns:repeat(2,1fr)}.bbt-title-input{font-size:.7rem}}.crm-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:1100;background:#000000bf;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.crm-modal{background:var(--paper);border:1px solid var(--line);border-radius:16px;flex-direction:column;width:min(580px,100%);max-height:95vh;display:flex;overflow-y:auto;box-shadow:0 8px 40px #00000080}.crm-header{border-bottom:1px solid var(--line);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.crm-close{padding:6px 14px;font-size:.85rem}.crm-preview-wrap{flex-direction:column;align-items:center;gap:8px;padding:16px 20px 8px;display:flex}.crm-preview{-webkit-user-select:none;user-select:none;touch-action:none;max-width:100%;display:inline-block;position:relative}.crm-preview-crosshair{cursor:crosshair}.crm-img{object-fit:contain;border:1px solid var(--line);pointer-events:none;border-radius:8px;width:100%;max-width:520px;max-height:calc(95vh - 160px);display:block}.crm-crop-rect{border:2px solid var(--accent);pointer-events:none;background:#84a98c2e;border-radius:3px;position:absolute}.crm-hint{color:var(--muted);text-align:center;margin:0;font-size:.78rem}.crm-controls{border-top:1px solid var(--line);flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:center;gap:8px;padding:12px 20px 16px;display:flex}.crm-rotate-btns{flex-wrap:wrap;gap:8px;display:flex}.game-detail-popover{z-index:900;background:var(--paper);border:1px solid var(--line);pointer-events:auto;border-radius:14px;padding:14px;animation:.12s both gdp-in;position:fixed;box-shadow:0 12px 40px #00000073}@keyframes gdp-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.gdp-cover{aspect-ratio:1;object-fit:cover;border-radius:8px;width:100%;margin-bottom:10px;display:block}.gdp-title{color:var(--ink);margin-bottom:2px;font-size:.95rem;font-weight:700;line-height:1.25}.gdp-year{color:var(--muted);margin-bottom:8px;font-size:.75rem}.gdp-stats{flex-wrap:wrap;gap:6px;margin-bottom:8px;display:flex}.gdp-stat{color:var(--ink);border:1px solid var(--line);background:#ffffff0d;border-radius:6px;align-items:center;gap:3px;padding:2px 7px;font-size:.75rem;display:inline-flex}.gdp-stat-complexity{color:var(--muted)}.gdp-personal{align-items:center;gap:8px;margin-bottom:8px;display:flex}.gdp-personal-rating{color:var(--muted);font-size:.72rem}.gdp-tags{flex-wrap:wrap;gap:4px;margin-bottom:5px;display:flex}.gdp-tag{letter-spacing:.02em;border-radius:4px;padding:2px 6px;font-size:.65rem;font-weight:600}.gdp-tag-category{color:var(--accent);background:#84a98c1f;border:1px solid #84a98c40}.gdp-tag-mechanic{color:var(--muted);border:1px solid var(--line);background:#94a3b814}.gdp-description{color:var(--muted);margin-top:8px;font-size:.72rem;line-height:1.5}.gdp-loading{opacity:.5;font-style:italic}.gdp-play-online{border:1px solid var(--line);color:var(--muted);text-align:center;border-radius:8px;margin-top:10px;padding:6px 10px;font-size:.72rem;font-weight:600;text-decoration:none;transition:border-color .12s,color .12s;display:block}.gdp-play-online:hover{border-color:var(--accent);color:var(--accent)}
