.town-page{padding-top:8px;padding-bottom:40px;}
.town-h1{text-align:center;color:#e8456e;font-size:26px;margin:6px 0 2px;text-shadow:2px 2px 0 #222;}
.town-lead{text-align:center;font-size:13px;color:#666;margin:0 0 12px;}

.town-stage{position:relative;max-width:640px;margin:0 auto;border:5px solid #222;border-radius:14px;
  overflow:hidden;box-shadow:6px 6px 0 #222;background:#93c66e;}
#townCanvas{display:block;width:100%;height:auto;image-rendering:auto;touch-action:none;background:#93c66e;}
.town-hud{position:absolute;top:8px;left:8px;background:rgba(0,0,0,.55);color:#fff;
  font-size:12px;font-weight:bold;padding:4px 12px;border-radius:14px;pointer-events:none;}
.town-loading{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:#93c66e;color:#fff;font-weight:bold;}

/* モバイルD-pad */
.town-pad{display:none;justify-content:center;margin:14px auto 0;}
.town-pad .dpad{display:grid;grid-template-columns:repeat(3,58px);grid-template-rows:repeat(3,58px);gap:5px;touch-action:none;}
.town-pad .dpad button{background:#333;color:#fff;border:3px solid #888;border-radius:10px;font-size:22px;
  font-family:inherit;cursor:pointer;touch-action:none;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;}
.town-pad .dpad .ul{grid-column:1;grid-row:1;background:#1a1a1a;font-size:16px;}
.town-pad .dpad .up{grid-column:2;grid-row:1;}
.town-pad .dpad .ur{grid-column:3;grid-row:1;background:#1a1a1a;font-size:16px;}
.town-pad .dpad .left{grid-column:1;grid-row:2;}
.town-pad .dpad .mid{grid-column:2;grid-row:2;background:transparent;border:none;pointer-events:none;}
.town-pad .dpad .right{grid-column:3;grid-row:2;}
.town-pad .dpad .dl{grid-column:1;grid-row:3;background:#1a1a1a;font-size:16px;}
.town-pad .dpad .down{grid-column:2;grid-row:3;}
.town-pad .dpad .dr{grid-column:3;grid-row:3;background:#1a1a1a;font-size:16px;}
@media (pointer:coarse), (max-width:760px){ .town-pad{display:flex;} }

.town-help{font-size:12px;color:#888;text-align:center;margin-top:12px;line-height:1.7;}
.town-help b{color:#e8456e;}

/* 住人になるパネル */
.town-join{max-width:520px;margin:26px auto 0;background:#fff;border:3px solid #222;border-radius:14px;
  box-shadow:5px 5px 0 #222;padding:20px;}
.town-join h2{margin:0 0 8px;font-size:18px;color:#e8456e;}
.tj-note{font-size:12px;color:#666;line-height:1.7;margin:0 0 12px;}
.tj-form label{display:block;font-size:12px;font-weight:bold;color:#333;margin:10px 0 4px;}
.tj-form .req{color:#e8456e;font-size:10px;} .tj-form .opt{color:#888;font-size:10px;}
.tj-form input[type=text]{width:100%;padding:10px 12px;font-size:15px;border:2px solid #222;border-radius:8px;font-family:inherit;}
.cam-wrap{margin:14px 0;}
.cam-btn{background:#3b6fe0;color:#fff;border:3px solid #222;border-radius:30px;padding:9px 18px;font-weight:bold;
  font-size:14px;cursor:pointer;font-family:inherit;box-shadow:3px 3px 0 #222;}
.cam-btn.ghost{background:#888;}
.cam-area{display:none;margin-top:12px;text-align:center;}
.cam-area.show{display:block;}
.cam-box{position:relative;width:240px;max-width:100%;aspect-ratio:1/1;margin:0 auto;border:3px solid #222;
  border-radius:12px;overflow:hidden;background:#000;}
#camVideo{width:100%;height:100%;object-fit:cover;transform:scaleX(-1);}
.face-guide{position:absolute;inset:0;pointer-events:none;}
.face-guide svg{width:100%;height:100%;}
.face-guide .guide-label{position:absolute;bottom:6px;left:0;right:0;text-align:center;color:#ffd700;font-size:11px;font-weight:bold;}
.cam-area .preview{display:none;width:150px;height:200px;object-fit:contain;margin:0 auto;background:#cfe;border:3px solid #222;border-radius:12px;}
.cam-area .preview.show{display:block;}
.cam-controls{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-top:12px;}
.cam-msg{font-size:12px;color:#555;margin-top:8px;min-height:16px;}
.mine-box{margin-top:18px;border-top:2px dashed #ddd;padding-top:14px;}
.mine-box h3{margin:0 0 8px;font-size:14px;color:#333;}
.mine-row{display:flex;align-items:center;justify-content:space-between;gap:10px;background:#f7f7f7;
  border:2px solid #222;border-radius:8px;padding:8px 12px;margin:6px 0;}
.mine-nm{font-weight:bold;font-size:13px;}
.mine-del{background:#e8456e;color:#fff;border:2px solid #222;border-radius:16px;padding:4px 14px;font-weight:bold;font-size:12px;cursor:pointer;font-family:inherit;}
.mine-note{font-size:11px;color:#999;margin:6px 0 0;}
.tj-submit{width:100%;margin-top:16px;background:#e8456e;color:#fff;border:3px solid #222;border-radius:30px;
  padding:12px;font-weight:900;font-size:16px;cursor:pointer;font-family:inherit;box-shadow:4px 4px 0 #222;}
.tj-submit:disabled{background:#bbb;cursor:not-allowed;box-shadow:none;}
.tj-result{margin-top:12px;font-size:13px;font-weight:bold;text-align:center;min-height:18px;}
.tj-result.ok{color:#2e9d5b;} .tj-result.err{color:#e8456e;}

.tj-warn{color:#c0392b;}

/* 乗車ボタン */
.ride-btn{position:absolute;bottom:12px;left:50%;transform:translateX(-50%);z-index:5;
  background:#ffd24a;color:#8a1846;border:3px solid #222;border-radius:30px;
  padding:10px 22px;font-weight:900;font-size:15px;cursor:pointer;font-family:inherit;
  box-shadow:3px 3px 0 #222;white-space:nowrap;}
.ride-btn:active{transform:translateX(-50%) translateY(2px);box-shadow:1px 1px 0 #222;}
