:root{--bg: #0f1115;--panel: #1a1d24;--panel-2: #232831;--line: #313845;--text: #e7ebf0;--muted: #8b95a5;--accent: #f6c343}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);overflow:hidden}.muted{color:var(--muted)}.error{color:#ff6b6b}.join-screen{height:100%;display:grid;place-items:center;padding:16px}.join-card{width:min(360px,100%);background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:24px;display:flex;flex-direction:column;gap:12px}.join-card h1{margin:0;font-size:22px}.join-card label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--muted)}.join-card input{background:var(--panel-2);border:1px solid var(--line);border-radius:8px;padding:10px 12px;color:var(--text);font-size:15px}.join-card button{margin-top:6px;background:var(--accent);color:#1a1300;border:0;border-radius:8px;padding:11px;font-weight:700;font-size:15px;cursor:pointer}.app{height:100%;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 14px;background:var(--panel);border-bottom:1px solid var(--line);flex-wrap:wrap}.topbar__left{display:flex;align-items:center;gap:10px}.pill{background:var(--panel-2);border:1px solid var(--line);border-radius:999px;padding:3px 10px;font-size:12px;color:var(--muted)}.status{font-size:12px;padding:3px 10px;border-radius:999px;background:var(--panel-2)}.status--open{color:#6ee7a8}.status--reconnecting,.status--connecting{color:var(--accent)}.status--closed{color:#ff6b6b}.topbar__players{display:flex;gap:12px;flex-wrap:wrap}.player{display:inline-flex;align-items:center;gap:6px;font-size:13px}.player__dot{width:10px;height:10px;border-radius:50%;display:inline-block}.play-area{flex:1;display:flex;flex-direction:column;min-height:0}.surface-wrap{flex:1;position:relative;overflow:hidden;min-height:0;touch-action:none;background:radial-gradient(circle at 50% 35%,#1b2230,#0f1115)}.surface{position:absolute;top:0;left:0;border-radius:8px;background-size:cover;background-position:center;box-shadow:0 10px 40px #00000080;touch-action:none}.surface-controls{position:absolute;top:10px;right:10px;display:flex;gap:6px;z-index:50}.surface-controls button{width:34px;height:34px;border-radius:8px;border:1px solid var(--line);background:var(--panel);color:var(--text);font-size:18px;cursor:pointer}.surface-controls button:hover{border-color:var(--accent)}.multi-bar{position:absolute;top:10px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:6px 10px;z-index:50;font-size:13px}.multi-bar button{background:var(--panel-2);color:var(--text);border:1px solid var(--line);border-radius:6px;padding:4px 8px;cursor:pointer}.multi-bar button:hover{border-color:var(--accent)}.piece{position:absolute;cursor:grab;-webkit-user-select:none;user-select:none;touch-action:none}.piece:active{cursor:grabbing}.piece.selected{outline:3px solid var(--accent);outline-offset:2px;border-radius:6px}.card-img{width:100%;height:100%;object-fit:contain;border-radius:6px;pointer-events:none;filter:drop-shadow(0 3px 5px rgba(0,0,0,.5))}.dice{width:100%;height:100%;border:3px solid #fff;border-radius:12px;background:#00000040;display:grid;place-items:center;overflow:hidden}.dice-img{width:100%;height:100%;object-fit:contain;pointer-events:none}.token{width:100%;height:100%;display:grid;place-items:center;color:#fff;font-weight:700;font-size:13px;text-shadow:0 1px 2px rgba(0,0,0,.6);border:2px solid rgba(255,255,255,.7);pointer-events:none}.token--circle{border-radius:50%}.token--square{border-radius:6px}.token--hex{clip-path:polygon(25% 5%,75% 5%,100% 50%,75% 95%,25% 95%,0% 50%)}.piece-toolbar{position:absolute;transform:translate(-50%,-100%);display:flex;gap:4px;background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:4px;z-index:100000;white-space:nowrap}.piece-toolbar button{background:var(--panel-2);color:var(--text);border:1px solid var(--line);border-radius:6px;padding:4px 8px;font-size:13px;cursor:pointer}.piece-toolbar button:hover{border-color:var(--accent)}.hand{background:var(--panel);border-top:1px solid var(--line);padding:8px 12px;min-height:120px}.hand__label{font-size:12px;color:var(--muted);margin-bottom:6px}.hand__other{margin-left:6px}.hand__cards{display:flex;gap:8px;overflow-x:auto;min-height:84px;align-items:center}.hand__card{height:84px;border-radius:6px;cursor:pointer;transition:transform .1s ease;box-shadow:0 2px 6px #0006}.hand__card:hover{transform:translateY(-6px)}.btn-primary{background:var(--accent);color:#1a1300;border:0;border-radius:8px;padding:8px 16px;font-weight:700;font-size:14px;cursor:pointer}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--panel-2);color:var(--text);border:1px solid var(--line);border-radius:8px;padding:7px 14px;font-size:14px;cursor:pointer}.btn-secondary:hover{border-color:var(--accent)}.btn-danger{background:transparent;color:#ff6b6b;border:1px solid #ff6b6b44;border-radius:8px;padding:7px 14px;font-size:14px;cursor:pointer}.btn-danger:hover{border-color:#ff6b6b}.btn-danger-sm{background:transparent;color:#ff6b6b;border:1px solid #ff6b6b44;border-radius:6px;padding:3px 8px;font-size:12px;cursor:pointer}.btn-danger-sm:hover{border-color:#ff6b6b}.btn-ghost{background:transparent;color:var(--muted);border:none;padding:6px 10px;font-size:14px;cursor:pointer}.btn-ghost:hover{color:var(--text)}.library-screen{height:100%;display:flex;flex-direction:column;padding:32px;overflow-y:auto}.library-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px}.library-header h1{margin:0;font-size:24px}.library-empty{margin-top:48px;text-align:center}.library-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}.library-card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:20px;display:flex;flex-direction:column;gap:10px}.library-card__name{font-size:17px;font-weight:600}.library-card__date{font-size:12px}.library-card__actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:4px}body.builder-open{overflow:auto}.builder-screen{height:100%;overflow-y:auto;display:flex;flex-direction:column;background:var(--bg)}.builder-topbar{position:sticky;top:0;z-index:10;display:flex;align-items:center;gap:16px;padding:12px 24px;background:var(--panel);border-bottom:1px solid var(--line)}.builder-topbar h2{margin:0;font-size:18px;flex:1}.builder-error{margin:12px 24px;padding:10px 14px;background:#ff6b6b22;border:1px solid #ff6b6b55;border-radius:8px;color:#ff6b6b;font-size:14px}.builder-body{padding:24px;display:flex;flex-direction:column;gap:24px;max-width:960px}.builder-section{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:20px;display:flex;flex-direction:column;gap:14px}.builder-section h3{margin:0;font-size:15px;color:var(--accent);text-transform:uppercase;letter-spacing:.05em}.section-header{display:flex;align-items:center;gap:12px}.section-header h3{flex:1}.builder-row{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end}.builder-row label{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--muted)}.builder-row input:not([type=checkbox]):not([type=color]),.builder-row select{background:var(--panel-2);border:1px solid var(--line);border-radius:6px;padding:7px 10px;color:var(--text);font-size:14px;min-width:80px}.builder-row input[type=color]{width:44px;height:34px;border:1px solid var(--line);border-radius:6px;cursor:pointer;background:none;padding:2px}.checkbox-label{flex-direction:row!important;align-items:center;gap:6px!important;color:var(--text)!important;font-size:14px!important;cursor:pointer}.builder-sublabel{margin:4px 0 0;font-size:12px;color:var(--muted)}.bg-preview{height:56px;border-radius:6px;object-fit:cover;border:1px solid var(--line)}.asset-grid{display:flex;flex-wrap:wrap;gap:10px;max-height:280px;overflow-y:auto;padding-bottom:4px}.asset-thumb{position:relative;width:72px;display:flex;flex-direction:column;align-items:center;gap:4px}.asset-thumb img{width:72px;height:72px;object-fit:cover;border-radius:6px;border:1px solid var(--line)}.asset-delete{position:absolute;top:2px;right:2px;width:18px;height:18px;background:#000000b3;color:#fff;border:none;border-radius:50%;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}.asset-name{font-size:10px;color:var(--muted);text-align:center;word-break:break-all}.asset-picker{display:flex;flex-wrap:wrap;gap:8px;padding:8px;background:var(--panel-2);border:1px solid var(--line);border-radius:8px;min-height:52px}.asset-pick{position:relative;width:56px;height:56px;border-radius:6px;overflow:hidden;cursor:pointer;border:2px solid transparent}.asset-pick img{width:100%;height:100%;object-fit:cover}.asset-pick--selected{border-color:var(--accent)}.asset-pick__check{position:absolute;bottom:1px;right:3px;font-size:13px;color:var(--accent);text-shadow:0 0 3px #000}.piece-form{background:var(--panel-2);border:1px solid var(--line);border-radius:10px;padding:14px;display:flex;flex-direction:column;gap:10px}.piece-form__header{display:flex;align-items:center;justify-content:space-between;font-size:14px}.join-back{align-self:flex-start;margin-bottom:4px}
