html {
    font-size: 10px;
    -webkit-tap-highlight-color: transparent;
}

body {
    line-height: 1.5;
    font-family: "Tahoma", "Helvetica Neue", "Lantinghei SC", Arial, "Microsoft Yahei", "Hiragino Sans GB", STXihei, Helvetica, sans-serif;
    font-size: 14px;
    color: #585858;
}

* {
    box-sizing: border-box;
}

img {
    vertical-align: middle;
}

a {
    color: #0066FF;
    text-decoration: none;
}

a:hover, a:focus {
    color: #0066FF;
    outline: none;
}

.clearfix:before, .clearfix:after {
    content: " ";
    display: table;
}

.clearfix:after {
    clear: both;
}

.pull-right {
    float: right !important;
}

.pull-left {
    float: left !important;
}

::selection {
    background: #0066FF;
    color: #fff;
}

::-moz-selection {
    background: #0066FF;
    color: #fff;
}

.wrapper {
    display: block;
    margin-left: auto;
    margin-right: auto;
    width: 1200px;
}

.error {
    position: absolute;
    top: 50%;
    left: 50%;
    margin-top: -300px;
    margin-left: -600px;
    width: 1200px;
    height: 500px;
}

.error .error-cartoon {
    height: 100%;
    width: 500px;
    background-position: top center;
    background-repeat: no-repeat;
    background-size: contain;
}

.error .error-cartoon.pull-left {
    width: 750px;
}

.error .error-desc {
    color: #2F2F4F;
}

.error .error-desc.pull-right {
    width: 420px;
}

.error .error-code {
    font-size: 120px;
    font-weight: 600;
    color: #697386;
}

.error h1 {
    padding-bottom: 20px;
    margin: 0;
    font-size: 24px;
}

.error p {
    margin: 0;
    padding-top: 20px;
    font-size: 16px;
    color: #697386;
    line-height: 2;
}

.error .error-tips {
    padding: 0;
}

.error a {
    display: block;
    font-size: 16px;
    margin: 20px 0;
}

.error a:hover {
    color: #297eff;
}

.error.fzfres {
    width: 100%;
    margin-left: -50%;
}

.error.fzfres .wave1,
.error.fzfres .wave2,
.error.fzfres .wave3 {
    position: absolute;
    left: 0;
    bottom: 10%;
    right: -100%;
    height: 70%;
    background-repeat: repeat no-repeat;
    background-size: 50% auto;
    background-position: left bottom;
    transform-origin: center bottom;
    transform: translateX(0) translateZ(0) scaleY(1);
}

.error.fzfres .wave1 {
    animation: move-wave 5s linear infinite;
    animation-delay: -1s;
    opacity: 0.8;
    background-image: url(../images/error/wave1.png);
}

.error.fzfres .wave2 {
    animation: move-wave 10s linear infinite;
    animation-delay: -3s;
    opacity: 0.9;
    background-image: url(../images/error/wave2.png);
}

.error.fzfres .wave3 {
    animation: move-wave 15s linear infinite;
    animation-delay: -5s;
    opacity: 0.9;
    background-image: url(../images/error/wave3.png);
}

@keyframes move-wave {
    0% {
        transform: translateX(0) translateZ(0) scaleY(1);
    }
    50% {
        transform: translateX(-25%) translateZ(0) scaleY(0.55);
    }
    100% {
        transform: translateX(-50%) translateZ(0) scaleY(1);
    }
}

@keyframes move-text {
    0% {
        transform: translateY(10%) translateZ(0);
    }
    50% {
        transform: translateY(0%) translateZ(0);
    }
    100% {
        transform: translateY(10%) translateZ(0);
    }
}

.error.fzfres .error-text {
    width: auto;
    height: 80%;
    animation: move-text 5s linear infinite;
}

.error.fzfres .error-desc {
    text-align: center;
}

.error.fzfres .error-cartoon {
    position: absolute;
    bottom: -120px;
    width: 100%;
    height: 256px;
    text-align: center;
    overflow: hidden;
}

.error.fzfres h1 {
    font-size: 48px;
}

.error.fzfres p {
    font-size: 24px;
}

.error .error-p {
    display: block;
}

.error .error-m {
    display: none;
}

.error .back-index {
    width: 100px;
    padding: 8px 0;
    text-align: center;
    color: #697386;
    border: 1px solid #E3E3E3;
    border-radius: 4px;
}

.error.errorcopy {
    height: 264px;
    margin-top: -132px;
}

.error.errorcopy h1 {
    padding: 16px 0 8px;
}

.error.errorcopy p {
    padding: 0;
}

.error.errorcopy .back-index {
    color: #fff;
    border-color: #0066FF;
    background-color: #0066FF;
}

.error.errorcopy .error-desc {
    padding-top: 30px;
}

@media screen and (max-width: 800px) {
    .error .error-cartoon.pull-left,
    .error .error-desc.pull-right {
        width: 100%;
        text-align: center;
    }
    .error .error-p {
        display: none;
    }
    .error .error-m {
        display: block;
    }
    .error {
        left: 0;
        width: 100%;
        height: 354px;
        margin-left: 0;
        margin-top: -177px;
    }
    .error .error-cartoon.pull-left {
        height: 200px;
        margin-bottom: 20px;
    }
    .error h1,
    .error.fzfres h1 {
        font-size: 20px;
    }
    .error p,
    .error.fzfres p {
        font-size: 14px;
        padding: 0;
    }
    .error .error-tips {
        position: fixed;
        bottom: 64px;
        left: 0;
        width: 100%;
        text-align: center;
    }
    .error .error-desc {
        padding: 0 40px;
        box-sizing: border-box;
    }
    .error.fzfres {
        margin-left: 0;
    }
    .error.fzfres .error-cartoon {
        position: relative;
        bottom: 0;
        height: 120px;
    }
    .error.errorcopy {
        height: 294px;
        margin-top: -142px;
    }
    .error.errorcopy .error-cartoon.pull-left {
        height: 100px;
    }
    .error.errorcopy .back-index {
        width: 126px;
        margin: auto;
        color: #0066FF;
        border-color: #0066FF;
        background-color: transparent;
        border-radius: 0;
    }
    .error.errorcopy p {
        padding-bottom: 20px;
    }
}
