/* 000.style.css */
:root{
--ge-container-width: 1500px;

--ge-sim-label-top: 110px;
--ge-sim-label-left: 150px;

--ge-sim-value-top: 130px;
--ge-sim-value-left: 150px;
}

html{
  overflow-y: scroll;
}

html, body{
margin: 0;
padding: 0;
}

body{
font-family: Arial, "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", sans-serif;
font-size: 18px;
line-height: 1.7;
color: #111;
background: #fff;
}

.ge-container{
width: var(--ge-container-width);
max-width: calc(100vw - 32px);
margin: 0 auto;
}

.ge-main{
padding: 22px 0 32px;
}

.ge-toprule{
padding: 0;
}

.ge-hr,
.ge-toprule hr{
border: 0;
border-top: 1px solid #ddd;
margin: 14px 0;
}

.ge-header{
padding: 18px 0 8px;
text-align: center;
}

.ge-brand{
font-size: 44px;
font-weight: 700;
letter-spacing: 0.3px;
}

.ge-tagline{
margin-top: 2px;
margin-bottom: 10px;
line-height: 0;
font-size: 16px;
color: #666;
}

main h1{
font-size: 30px;
margin: 0 0 12px;
}

main h2{
font-size: 24px;
margin: 22px 0 8px;
}

main p{
margin: 0 0 12px;
}

main ul{
margin: 0 0 12px 18px;
padding: 0;
}

main li{
margin: 4px 0;
}

.ge-hero{
margin-top: 0px;
margin-bottom: 50px;
}

.ge-hero-chart{
position: relative;
border:4px solid #31d2b2;
box-sizing: border-box;
}

.ge-hero-chart img{
display: block;
width: 100%;
height: auto;
}

.ge-hero-overlay{
position: absolute;
inset: 0;
display: flex;
align-items: center;
justify-content: center;
text-align: center;
padding: 16px;
}

.ge-hero-overlay-inner{
max-width: 90%;
}

.ge-sim-layer{
position: absolute;
inset: 0;
pointer-events: none;
}

.ge-sim-label{
position: absolute;
top: var(--ge-sim-label-top);
left: var(--ge-sim-label-left);
font-size: 16px;
font-weight: 700;
letter-spacing: 0.8px;
}

.ge-sim-value{
position: absolute;
top: var(--ge-sim-value-top);
left: var(--ge-sim-value-left);
font-size: 20px;
font-weight: 700;
}

.ge-hero-lead{
font-size: 36px;
margin: 0px;
}

.ge-hero-quote{
margin: 0px;
}

.ge-hero-quote-1{
font-size: 30px;
margin: 0px;
font-weight: 700;
}

.ge-hero-quote-2{
font-size: 30px;
margin: 0px;
font-weight: 700;
}

.ge-hero-p3{
font-size: 30px;
margin: 0;
}

.ge-hero-claim{
font-size: 30px;
margin: 0px;
}

.ge-footer{
text-align: center;
padding: 6px 0 28px;
}

.ge-footer-links{
font-size: 18px;
margin: 10px 0;
}

.ge-footer-links a{
color: #0b57d0;
text-decoration: none;
}

.ge-footer-links a:hover{
text-decoration: underline;
}

.ge-footer-links .sep{
margin: 0 10px;
color: #999;
}

.footer-current-page{
font-weight: 700;
color: #111;
}

.ge-footer-copy{
margin-top: 8px;
font-size: 16px;
color: #777;
}
