Set line-height
to a value that lets (at least) two lines fit into the allocated height. A suitable value might be 1.5
in this case. You also need to fix the font: 13px bpg arial;
line, apparently by removing bpg
to make it work. Note that you may still run into trouble if a heading requires more space that two lines, but that’s a different issue.
If you want the text to be vertically centered when there is just one line (this was not specified in the question but this seems to be intent of setting such a large line height), you can e.g. set vertical alignment to middle
and (to make that apply) display: table-cell
.
.newstitle {
width: 486px;
height: 41px;
overflow: hidden;
background: #0a70a5;
background: url(…EiIGhlaWdodD0iMSIgZmlsbD0idXJsKCNncmFkLXVjZ2ctZ2VuZXJhdGVkKSIgLz4KPC9zdmc+);
background: -moz-linear-gradient(top, #0a70a5 0%, #006092 100%);
background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#0a70a5), color-stop(100%,#006092));
background: -webkit-linear-gradient(top, #0a70a5 0%,#006092 100%);
background: -o-linear-gradient(top, #0a70a5 0%,#006092 100%);
background: -ms-linear-gradient(top, #0a70a5 0%,#006092 100%);
background: linear-gradient(to bottom, #0a70a5 0%,#006092 100%);
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#0a70a5', endColorstr='#006092',GradientType=0 );
}
* {
margin: 0;
padding: 0;
outline: none;
position: relative;
}
h1 {
font: 13px arial;
color: #fff;
text-shadow: 0 1px 0 rgba(0,0,0,.15);
line-height: 1.5;
width: 476px;
padding: 0 5px;
height: 41px;
vertical-align: middle;
display: table-cell;
}
<div class="news">
<div class="newstitle" style="line-height: 20px;">
<h1>bla bla bla fcking bla bla blaa more bla bla bla and more bla bla bla second bla bla bla fcking bla bla blaa more bla bla bla and more bla bla bla</h1></div>
</div>
And then an example with a short text:
<div class="news">
<div class="newstitle" style="line-height: 20px;">
<h1>White Christmas expected!</h1></div>
</div>