<label for="user-id">아이디</label>
<input type="text" id="user-id" placeholder="특수 문자 포함 10자 이상">
input {
    padding: 0.5em;
    border: 2px solid blue;
    outline: none;
    outline-offset: 2px;
    transition: border-color 0.4s;
}

/* 포커스 시 점선 아웃라인 */
input:focus {
    outline: 1px dashed;
}

/* 플레이스홀더가 표시 중인 상태 */
input:placeholder-shown {
    border-color: red; /* 플레이스홀더 텍스트가 표시될 때 적용 */
}
실제 적용된 모습
:placeholder-shown {
    /* ... */
}
<label for="nickname">닉네임</label>
<input type="text" id="nickname" placeholder="15자 이내..." aria-describedby="nickname-required">
<span id="nickname-required" class="tooltip" aria-live="polite">*필수</span>
input {
    padding: 0.5em;
    border: 2px solid blue;
    outline: none;
    outline-offset: 2px;
    transition: border-color 0.4s;
}

/* 포커스 시 점선 아웃라인 */
input:focus {
    outline: 1px dashed;
}

/* 플레이스홀더가 표시 중인 상태 */
input:placeholder-shown {
    border-color: red; /* 플레이스홀더 텍스트가 표시될 때 적용 */
}

/* 툴팁 기본 스타일 */
.tooltip {
    display: none;
    color: red;
    font-size: 0.9em;
    margin-left: 0.5em;
}

/* 플레이스홀더 표시 시 툴팁 표시 */
input:placeholder-shown + .tooltip {
    display: inline;
}
실제 적용된 모습