/** * Solo - A small and beautiful blogging system written in Java. * Copyright (c) 2010-2019, b3log.org & hacpai.com * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see . */ /* * skin style * * @author Liyuan Li * @version 0.1.0.0, Mar 26, 2019 */ @import "../../../scss/reset"; @import "../../../scss/usite"; @import "../../../scss/toc"; @import "../../../scss/function"; @import "../../../scss/nprogress"; @import "vditor/src/assets/scss/classic"; $fade-lighter: rgba(255, 255, 255, .8) !default; $gray: #738a94 !default; $black: #15171a !default; $black-bg: #090a0b !default; $link: #26a8ed !default; body { background-color: #f4f8fb; } ::selection { text-shadow: none; background-color: #cbeafb; } a { color: $link; } .ft__a { color: $gray; &:hover { color: rgba($gray, .8); } } .wrapper { max-width: 1040px; margin: 0 auto; padding: 0 10px; } .header { color: #fff; position: relative; &--index { &:before { content: ""; height: 100%; position: absolute; background: url("../images/header-bg.jpg") no-repeat center center; width: 100%; top: 0; background-size: cover; filter: brightness(38%); } } &--article { background-color: $black-bg; height: 64px; .header__title { display: none; } .header__nav a { margin-bottom: 0; line-height: 64px; } } &--other { height: 407px; .header__title { display: none; } &:before { content: ""; height: 100%; position: absolute; background: url("../images/header-bg.jpg") no-repeat center center; width: 100%; top: 0; background-size: cover; filter: brightness(38%); } .header__nav a { margin-bottom: 0; line-height: 64px; } } &__title { position: relative; text-align: center; } &__h1 { font-size: 30px; padding-top: 140px; font-weight: normal; img { height: 32px; width: 32px; margin-right: 10px; } a { color: #fff; &:hover { text-decoration: none; color: $fade-lighter; } } } &__h2 { font-size: 20px; font-weight: 300; margin: 5px 0 70px; color: $fade-lighter; } &__nav { position: relative; a { font-size: 13px; float: left; line-height: 24px; color: $fade-lighter; margin: 0 20px 90px 0; &:hover { color: #fff; text-decoration: none; } } img { height: 14px; width: 14px; margin-right: 5px; } svg { margin-top: 5px; } } } .footer { font-size: 13px; padding: 20px 0; background-color: $black-bg; color: #fff; a { color: $fade-lighter; &:hover { text-decoration: none; color: #fff; } } .fn__right { text-align: right; } } .articles { top: -70px; position: relative; display: flex; flex-wrap: wrap; margin: 0 -20px; .item { flex: 1 1 300px; overflow: hidden; margin: 0 20px 40px; min-height: 300px; border-radius: 5px; box-shadow: 8px 14px 38px rgba(39, 44, 49, .06), 1px 3px 8px rgba(39, 44, 49, .03); transition: all .3s ease; display: flex; flex-direction: column; background-color: #fff; &--large { flex-direction: row; flex: 1 1 100%; .item__cover { flex: 1; height: auto; } .item__main { padding: 30px 40px; width: 357px; flex: unset; } } &:hover { box-shadow: 8px 28px 50px rgba(39, 44, 49, .07), 1px 6px 12px rgba(39, 44, 49, .04); transform: translate3D(0, -1px, 0) scale(1.02); } &__cover { background-size: cover; background-position: center center; height: 200px; } &__main { padding: 25px; box-sizing: border-box; display: flex; flex-direction: column; flex: 1; } &__tag { display: inline-block; margin-bottom: 4px; color: $gray; font-size: 12px; line-height: 14px; font-weight: 500; letter-spacing: .5px; text-transform: uppercase; &:hover { text-decoration: none; color: rgba($gray, 0.8); } } &__title { margin-bottom: 10px; a { color: $black; font-size: 18px; line-height: 24px; &:hover { text-decoration: none; color: rgba($black, 0.8); } } sup { font-size: 12px; font-weight: normal; color: rgba($gray, 0.8); } } &__abstract { line-height: 24px; color: $black; flex: 1; &:hover { text-decoration: none; color: rgba($black, 0.8); } } &__meta { float: right; margin-top: 18px; color: $gray; &:hover { text-decoration: none; color: rgba($gray, 0.8); } } &__avatar { margin-top: 10px; float: left; img { height: 32px; width: 32px; } } } } .pagination { text-align: center; margin-top: -70px; &__item { width: 30px; height: 30px; background: $black; border-radius: 50%; display: inline-block; color: #fff; line-height: 30px; font-size: 12px; margin: 0 5px 40px; &:hover { opacity: 0.8; text-decoration: none; } &--active { background: $black-bg; &:hover { opacity: 1; } } &--omit { background-color: transparent; color: $black; } } } .article { background-color: #fff; &__bottom { background-color: #fff; position: relative; .fn__flex { margin: 0 -20px; } .item { position: relative; flex: 1; margin: 40px 20px; box-shadow: 8px 14px 38px rgba(39, 44, 49, .06), 1px 3px 8px rgba(39, 44, 49, .03); border-radius: 5px; padding: 40px; overflow: hidden; text-align: center; &:before { content: ""; position: absolute; height: 100%; top: 0; left: 0; width: 100%; background: url(../images/header-bg.jpg) no-repeat center center; background-size: cover; filter: brightness(38%); } h3 { color: #fff; position: relative; margin-bottom: 20px; } ul { padding-left: 0; position: relative; list-style: none; } a { display: block; border-bottom: 1px solid rgba($gray, .8); padding: 10px 0; color: #fff; margin: 0 20px; } } } &__top { position: fixed; width: 100%; top: -61px; background-color: rgba(255, 255, 255, 0.9); border-bottom: 1px solid rgba($gray, 0.1); height: 60px; transition: all .3s ease; z-index: 1; .title { float: left; margin-left: 20px; line-height: 60px; font-size: 22px; } } &__share { float: right; position: relative; .item { height: 60px; width: 60px; float: left; text-align: center; padding: 20px 0; box-sizing: border-box; color: #fdc200; cursor: pointer; transition: all .3s ease; svg { height: 20px; width: 20px; } &[data-type="wechat"] { color: #3caf36; &:hover { background-color: #3caf36; } } &[data-type="twitter"] { color: #18a3fa; &:hover { background-color: #18a3fa; } } &[data-type="weibo"] { color: #f93; &:hover { background-color: #f93; } } &:hover { color: #fff; background-color: #fdc200; } &__qr { position: absolute; top: 61px; left: 60px; } } } &__progress { position: absolute; right: 0; bottom: -1px; left: 0; width: 100%; height: 2px; border: none; background: transparent; -webkit-appearance: none; &::-webkit-progress-value { background-color: $link; } &::-webkit-progress-bar { background-color: transparent; } } .item { &__meta { padding-top: 76px; font-size: 14px; text-transform: uppercase; color: rgba($gray, .8); a { color: $gray; } } &__title { font-size: 28px; margin-bottom: 40px; sup { font-size: 14px; font-weight: normal; color: rgba($gray, .8); } } &__cover { height: 800px; background-size: cover; } &__content { padding: 70px 100px 0; box-sizing: border-box; background-color: #fff; &--article { margin-top: -164px; } } &__tip { margin-bottom: 40px; border-radius: 5px; box-shadow: 8px 14px 38px rgba(39, 44, 49, .06), 1px 3px 8px rgba(39, 44, 49, .03); transition: all .3s ease; padding: 20px 0; text-align: center; background: #f4f8fb; cursor: pointer; font-size: 18px; &:hover { box-shadow: 8px 28px 50px rgba(39, 44, 49, .07), 1px 6px 12px rgba(39, 44, 49, .04); transform: translate3D(0, -1px, 0) scale(1.02); } } } } .post__toc { display: none; position: fixed; top: 84px; bottom: 80px; overflow: auto; padding-left: 3px; &::-webkit-scrollbar { display: none; } .article__toc { overflow: initial; border-left: 1px solid rgba($gray, 0.28); margin: 0; font-size: 14px; line-height: 24px; li.current a, a:hover { color: $link; } a { display: block; margin-top: -24px; color: $gray; } } li { &:before { position: relative; top: -2px; left: -4px; display: inline-block; width: 7px; height: 7px; content: ''; border-radius: 50%; } &.current:before { background-color: $link; } } } .comment { background-color: #f4f8fb; position: relative; &__wrapper { margin: 0 auto; padding: 0 100px 0.1px; box-sizing: border-box; } &-body-ref { position: absolute; left: 80px; width: 76%; } &__title { text-align: center; padding: 40px 0; color: $gray; } .item { margin-bottom: 40px; border: 1px solid $fade-lighter; border-radius: 5px; background: #fff; box-shadow: 0 1px 4px rgba(0, 0, 0, .04); list-style: none; padding: 20px; &__meta { color: rgba($gray, .8); font-size: 12px; } &__avatar { float: left; height: 40px; width: 40px; border-radius: 20px; border: 1px solid rgba(0, 0, 0, .04); margin: 0 20px 20px 0; background-size: cover; background-position: center center; } &__name { color: rgba($gray, .8); float: left; line-height: 40px; a { color: $gray; &:hover { color: rgba($gray, .8); } } } &:hover { .item__reply { display: block; } } } #comments { position: relative; } #comment { position: relative; margin-bottom: 30px; padding: 20px; border-radius: 3px; background: #fff; box-shadow: 0 1px 4px rgba(0, 0, 0, 0.04); border: 0; resize: none; cursor: pointer; width: 100%; box-sizing: border-box; } } .other { position: relative; &__title { margin: -220px 0 5px; color: #fff; font-size: 28px; text-align: center; font-weight: 400; } &__meta { color: #fff; font-size: 14px; text-align: center; &--list { margin-bottom: 154px; } } &__content { background-color: #fff; padding: 70px 100px; margin: 77px auto 40px; box-shadow: 8px 14px 38px rgba(39, 44, 49, 0.06), 1px 3px 8px rgba(39, 44, 49, 0.03); border-radius: 5px; } &__item { line-height: 20px; margin: 10px; white-space: nowrap; display: block; &--archive { width: 187px; display: inline-block; } span, div { color: $gray; font-size: 12px; } } }