/* xdoga login / upload pages — matched to the site theme (bg #0f0f0f, accent #ff2d55, panel #1a1a1a). */
.page-h1 { max-width: 680px; margin: 14px auto 4px; padding: 0 16px; font-size: 22px; font-weight: 800; color: #fff; }
.page-h2 { max-width: 1100px; margin: 26px auto 10px; padding: 0 4px; font-size: 16px; font-weight: 800; color: #fff; }

.authcard { max-width: 420px; margin: 18px auto; padding: 20px 18px 18px; background: #1a1a1a; border: 1px solid #262626; border-radius: 16px; }
.authtabs { display: flex; gap: 8px; margin-bottom: 16px; }
.authtab { flex: 1 1 0; font-size: 14px; font-weight: 700; color: #bbb; background: #232323; border: 1px solid #2e2e2e; border-radius: 12px; padding: 9px 0; cursor: pointer; }
.authtab.on { color: #fff; background: #ff2d55; border-color: #ff2d55; }

.fld { display: block; margin: 0 0 14px; }
.fld span { display: block; font-size: 12.5px; font-weight: 700; color: #cfcfcf; margin: 0 0 6px; }
.fld input { width: 100%; font-size: 16px; color: #f1f1f1; background: #121212; border: 1px solid #333; border-radius: 10px; padding: 11px 12px; outline: none; }
.fld input:focus { border-color: #ff2d55; }
.fld input[type="file"] { padding: 9px; font-size: 13px; }
/* clear (✕) button inside a text field — quickly wipe a prefilled value (e.g. the email-derived handle) */
.fld-x { position: relative; display: block; }
.fld-x input { padding-right: 38px; }
.fld-clear { position: absolute; right: 6px; top: 50%; transform: translateY(-50%); width: 28px; height: 28px; display: flex; align-items: center; justify-content: center; background: none; border: 0; color: #9a9a9a; font-size: 15px; line-height: 1; cursor: pointer; }
.fld-clear:active { color: #fff; }

.hint { margin: -6px 0 12px; font-size: 12px; color: #9a9a9a; }
.authbtn { display: block; width: 100%; box-sizing: border-box; text-align: center; font-size: 15px; font-weight: 800; color: #fff; background: #ff2d55; border: 0; border-radius: 12px; padding: 12px 0; cursor: pointer; text-decoration: none; }
.authbtn:active { background: #e02950; }
.authbtn[disabled] { opacity: .6; cursor: default; }
.msg { min-height: 18px; margin: 10px 0 0; font-size: 13px; color: #ff8aa3; text-align: center; }
.msg a { color: #ff5d7d; font-weight: 700; }
.authnote { margin: 14px 0 0; font-size: 11.5px; line-height: 1.6; color: #9a9a9a; }
.authnote a { color: #ff5d7d; }
.linkbtn { background: none; border: 0; padding: 0; font: inherit; color: #ff5d7d; font-weight: 700; cursor: pointer; }
.linkbtn:disabled { color: #9a9a9a; cursor: default; }
#code { letter-spacing: 10px; text-align: center; font-size: 22px; }
.hint.ok { color: #57d28a; }
.hint.bad { color: #ff8aa3; }
/* mypage */
.mp-head { display: flex; align-items: center; gap: 14px; margin: 0 0 8px; }
.mp-avatar { position: relative; width: 72px; height: 72px; flex: 0 0 auto; }
.mp-avatar img { width: 72px; height: 72px; border-radius: 50%; object-fit: cover; background: #222; display: block; }
.mp-letter { width: 72px; height: 72px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 34px; font-weight: 800; color: #fff; }
.mp-avbtn { position: absolute; right: -4px; bottom: -4px; font-size: 11px; font-weight: 700; color: #fff; background: #ff2d55; border: 2px solid #0f0f0f; border-radius: 999px; padding: 3px 8px; cursor: pointer; }
.mp-id { min-width: 0; }
.mp-name { font-size: 18px; font-weight: 800; color: #f1f1f1; word-break: break-all; }
.mp-email { font-size: 12.5px; color: #9a9a9a; word-break: break-all; }
.authnote strong { color: #fff; }

.bar { height: 8px; margin: 12px 0 0; background: #232323; border-radius: 6px; overflow: hidden; }
.barfill { height: 100%; width: 0; background: #ff2d55; transition: width .15s linear; }
