body { overflow: hidden; }
.wrapper {filter:blur(12px);}
#loginModal label { display: block; font-size: 13px; font-weight: 600; color: #333; margin-bottom: 5px; }
#loginModal input {max-width:100%;}

.lm-overlay { position: fixed; inset: 0; background: rgba(0,0,0,.55); z-index: 30000; display: flex; align-items: center; justify-content: center; }
.lm-modal { position: absolute;top: 50%;transform: translateY(-50%);background: #fff; border-radius: 9px; width: 420px; max-width: calc(100vw - 32px); max-height: 90vh; overflow-y: auto; box-shadow: 0 8px 40px rgba(0,0,0,.18); box-sizing: border-box; padding: 14px 24px 16px; }
.lm-tabs { display: flex; padding: 0; border-bottom: 1px solid #eee; gap: 8px; }
.lm-tab { flex:1; background: none; border: none; cursor: pointer; padding: 10px 4px; font-size: 15px; font-weight: 600; color: #aaa; border-bottom: 2px solid transparent; margin-bottom: -1px; }
.lm-tab.active { color: #ff6b9d; border-bottom-color: #ff6b9d; }
.lm-body { padding-top: 20px; }
.lm-panel { display: none; }
.lm-panel.active { display: block; }
.lm-field { margin-bottom: 12px; }
.lm-field-row { display: flex; gap: 8px; }
.lm-field-row input { flex: 1; }
.lm-check-btn { white-space: nowrap; background: #555; color: #fff; border: none; border-radius: 8px; padding: 0 14px; font-size: 13px; cursor: pointer; flex-shrink: 0; }
.lm-hint { font-size: 12px; margin-top: 4px; display: none; }
.lm-hint.ok { color: #2a9d8f; display: block; }
.lm-hint.err { color: #e63946; display: block; }
.lm-submit { width: 100%; background: #ff6b9d; color: #fff; border: none; border-radius: 8px; padding: 13px; font-size: 15px; font-weight: 700; cursor: pointer; margin-top: 4px; }
.lm-submit.register { margin: 6px 0 4px; }
.lm-find { display: block; text-align: center; padding-top: 7px; font-size: 12px; color: #888; text-decoration: none; }
.lm-find.lg { padding-top:11px; }
.lm-error { background: #fff0f3; border: 1px solid #e63946; border-radius: 6px; padding: 10px 12px; font-size: 12px; color: #c1121f; margin-bottom: 14px; display: none; }
.lm-error.register { margin:-3px 0 6px; }
.lm-success { background: #d1f0eb; border: 1px solid #2a9d8f; border-radius: 6px; padding: 9px 12px; font-size: 13px; color: #1a6b63; margin-bottom: 14px; display: none; text-align: center; }
.lm-auth-box { border-radius: 12px; text-align: center; margin-bottom: 4px; padding: 20px 16px; background: #fff8fa; border: 1px solid #ffc0d5; }
.lm-auth-box p { font-size: 13px; color: #666; margin: 0 0 14px; line-height: 1.6; }
.lm-auth-btn { width: 100%; background: #ff6b9d; color: #fff; border: none; border-radius: 8px; padding: 13px; font-size: 15px; font-weight: 700; cursor: pointer; }
.lm-terms-box { border: 1px solid #ddd; border-radius: 8px; height: 90px; overflow-y: auto; padding: 10px 12px; font-size: 12px; color: #555; line-height: 1.6; background: #fafafa; margin-bottom: 8px; }
.lm-agree-row { display: flex; align-items: center; font-size: 13px; color: #333; margin-bottom: -4px; padding-top: 4px;}

/* 스피너 */
.lm-auth-loading { text-align: center; padding: 32px 16px; display: none; }
.lm-spinner { width: 38px; height: 38px; border: 4px solid #ffc0d5; border-top-color: #ff6b9d; border-radius: 50%; animation: lm-spin .75s linear infinite; margin: 0 auto 14px; }
@keyframes lm-spin { to { transform: rotate(360deg); } }
.lm-auth-loading p { font-size: 13px; color: #999; margin: 0; }

@media (max-width:799px) {
    label {font-size:11px;}
	.wrapper {transform:scale(1.1);}

    .lm-overlay { padding: 16px 0 24px; }
    .lm-modal { max-width: calc(100vw - 34px); max-height: 90%; border-radius: 12px; padding:12px 20px 13px;}
    .lm-tab { font-size: 13px; }
    .lm-find { font-size:11px; }
    .lm-find.lg { font-size:12px; padding-top:14px; }

    .lm-auth-box p {font-size:12px;}
    .lm-auth-btn {font-size:14px;}
}