Shuo/client/css/style.css

580 lines
10 KiB
CSS

@import url(
http://fonts.googleapis.com/css?family=Lato:400,700
);
@font-face {
font-family: "Octicons";
src: url("fonts/octicons.svg") format("svg"), url("fonts/octicons.woff") format("woff");
}
html,
body {
height: 100%;
}
body {
background: #fff;
color: #222;
font: 16px Lato, sans-serif;
margin: 0;
}
a {
transition: opacity .2s;
}
a:hover {
text-decoration: none;
opacity: .8;
}
h1,
h2 {
font: inherit;
line-height: inherit;
margin: 0;
}
input {
outline: 0;
}
button {
border: none;
background: none;
margin: 0;
outline: none;
padding: 0;
}
.btn {
border: 2px solid #95a5a6;
border: 2px solid #84d1ff;
border-radius: 5px;
color: #95a5a6;
color: #84d1ff;
display: inline-block;
font: bold 12px Lato, sans-serif;
letter-spacing: 1px;
margin-bottom: 10px;
padding: 9px 17px;
text-transform: uppercase;
transition: background .2s, border-color .2s, color .2s;
word-spacing: 3px;
}
.btn:disabled,
.btn:hover {
background: #95a5a6;
background: #84d1ff;
color: #fff;
}
.btn:active {
box-shadow: none;
opacity: .8;
}
.btn:disabled {
opacity: .6;
}
.container {
margin: 10% auto;
max-width: 420px;
overflow: hidden;
overflow-y: auto;
-webkit-overflow-scrolling: touch;
padding: 0 30px;
}
::-moz-placeholder {
color: rgba(0, 0, 0, .5);
opacity: 1;
}
::-webkit-input-placeholder {
color: rgba(0, 0, 0, .5);
}
:-ms-input-placeholder {
color: rgba(0, 0, 0, .5) !important;
}
#wrap {
height: 100%;
overflow: hidden;
}
#viewport {
height: 100%;
transition: all .4s;
-webkit-transform: translateZ(0);
transform: translateZ(0);
-webkit-perspective: 1000;
perspective: 1000;
}
#sidebar {
background: #262c36;
bottom: 0;
color: #fff;
left: 0;
overflow: hidden;
overflow-y: auto;
-webkit-overflow-scrolling: touch;
position: absolute;
top: 0;
width: 220px;
z-index: 2;
}
#sidebar button {
border: 1px solid transparent;
border-radius: 2px;
color: #7c838d;
font-size: 14px;
}
#sidebar button:hover,
#sidebar .active {
background: #2a303a;
border-color: rgba(255, 255, 255, .025);
}
#sidebar button.active {
background: #323841;
color: #fff;
}
#sidebar .networks {
min-height: 100%;
padding: 25px 40px 80px;
}
#sidebar .network + .network {
margin-top: 30px;
}
#sidebar .empty {
color: #7c838d;
line-height: 1.6;
font-size: 12px;
text-align: center;
width: 140px;
}
#sidebar .empty:before {
content: "\f085";
display: block;
margin-top: 20px;
font: 64px Octicons;
opacity: .4;
margin-bottom: 24px;
text-align: center;
}
#sidebar .chan {
display: block;
margin: 1px -10px;
padding: 6px 10px 8px;
position: relative;
text-align: left;
transition: all .2s;
width: 160px;
}
#sidebar .chan:first-child {
color: #84d1ff;
font-size: 15px;
font-weight: bold;
}
#sidebar .chan:hover .badge {
opacity: 0;
}
#sidebar .chan:hover .close {
opacity: .2;
}
#sidebar .badge {
background: rgba(255, 255, 255, .06);
border-radius: 3px;
color: #afb6c0;
font-size: 10px;
margin-top: 1px;
padding: 3px 6px;
position: absolute;
right: 10px;
transition: all .2s;
}
#sidebar .badge.highlight {
background: #fff;
color: #49505a;
}
#sidebar .badge:empty {
display: none;
}
#sidebar .close {
background: no-repeat url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTYiIGhlaWdodD0iMTYiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+DQogPGc+DQogIDx0aXRsZT5MYXllciAxPC90aXRsZT4NCiAgPHBhdGggZmlsbD0iI2ZmZmZmZiIgaWQ9InN2Z18xIiBkPSJtMTIuODcyLDEuNTYyYzAuMTk1MDAxLDAuMTk0IDAuMTk1MDAxLDAuNTEzIDAsMC43MDdsLTMuODg5LDMuODkxYy0wLjE5MywwLjE5NCAtMC4xOTMsMC41MTMgMCwwLjcwOGwzLjg4NywzLjg5MmMwLjE5NSwwLjE5NCAwLjE5NSwwLjUxMyAwLDAuNzA3bC0xLjQxNTk5OSwxLjQxM2MtMC4xOTMwMDEsMC4xOTQgLTAuNTEyLDAuMTk0IC0wLjcwNzAwMSwwbC0zLjg4NSwtMy44OTJjLTAuMTk0LC0wLjE5NCAtMC41MTMsLTAuMTk0IC0wLjcwNywwbC0zLjg4OSwzLjg4OWMtMC4xOTQsMC4xOTUgLTAuNTEzLDAuMTk1IC0wLjcwNywwbC0xLjQxNCwtMS40MTU5OTljLTAuMTk0LC0wLjE5MzAwMSAtMC4xOTQsLTAuNTEyIDAsLTAuNzA3MDAxbDMuODksLTMuODg5YzAuMTk0LC0wLjE5NCAwLjE5NCwtMC41MTMgMCwtMC43MDhsLTMuODg3LC0zLjg5MWMtMC4xOTQsLTAuMTk1IC0wLjE5NCwtMC41MTMgMCwtMC43MDdsMS40MTUsLTEuNDE0YzAuMTk0LC0wLjE5NCAwLjUxMywtMC4xOTQgMC43MDcsMGwzLjg4NSwzLjg5MWMwLjE5NCwwLjE5NSAwLjUxMywwLjE5NSAwLjcwNywwLjAwMWwzLjg4OCwtMy44OWMwLjE5NSwtMC4xOTMgMC41MTQsLTAuMTkzIDAuNzA3LDBsMS40MTUsMS40MTV6Ii8+DQogPC9nPg0KPC9zdmc+);
background-size: 50%;
background-position: 5px 6px;
border-radius: 3px;
height: 18px;
margin-top: 1px;
margin-right: 10px;
opacity: 0;
position: absolute;
right: 0;
transition: all .2s;
width: 18px;
}
#sidebar .close:hover {
background-color: rgba(0, 0, 0, .2);
opacity: .7 !important;
}
#footer {
height: 80px;
line-height: 80px;
margin-top: -80px;
text-align: center;
width: 220px;
}
#footer button {
font: 18px Octicons;
line-height: 34px;
padding: 0px 12px;
}
#footer .connect:before {
content: "\f085";
}
#footer .settings:before {
content: "\f02f";
}
#main {
bottom: 0;
left: 220px;
position: absolute;
right: 0;
top: 0;
}
#header {
border-bottom: 1px solid #e9ecef;
display: none;
height: 40px;
position: absolute;
top: 0;
width: 100%;
}
#header h1 {
color: #222;
font-size: 15px;
line-height: 40px;
text-align: center;
}
#header button {
color: #666;
font: 16px Octicons;
height: 32px;
opacity: .5;
position: absolute;
top: 4px;
transition: opacity .2s;
padding: 0 10px;
width: 64px;
}
#header button:hover {
opacity: 1;
}
#header #lt {
left: 4px;
text-align: left;
}
#header #rt {
display: none;
right: 4px;
text-align: right;
}
#header #lt:before {
content: "\f05e";
}
#header #rt:before {
content: "\f037";
}
#windows {
bottom: 40px;
position: absolute;
top: 0px;
width: 100%;
}
#windows .chan,
#windows .window {
background: #fff;
bottom: 0;
display: none;
left: 0;
position: absolute;
right: 0;
top: 0;
}
#windows .window {
overflow-y: auto;
}
#windows .window h1 {
font: 36px Lato;
}
#windows .window input {
border: 2px solid #e9ecef;
border-radius: 4px;
color: #222;
font-size: 14px;
margin: 2px 0;
outline: 0;
padding: 8px 10px;
transition: border-color .2s;
-webkit-appearance: none;
width: 100%;
}
#windows .window input:hover,
#windows .window input:focus {
border-color: #bdc3c7;
}
#windows .active {
display: block;
}
#chat {
bottom: 0;
font: 13px Consolas, monospace;
left: 0;
position: absolute;
right: 0;
top: 0;
}
#chat button:hover {
opacity: .6;
}
#chat .chat {
bottom: 0;
left: 0;
overflow: auto;
-webkit-overflow-scrolling: touch;
position: absolute;
right: 180px;
top: 0;
}
#chat .sidebar {
background: #fff;
border-left: 1px solid #e9ecef;
bottom: 0;
position: absolute;
right: 0;
top: 0;
width: 180px;
}
#chat .sidebar button {
color: #33b0f7;
}
#chat .messages {
display: table;
height: 100%;
width: 100%;
}
#chat .msg {
display: table-row;
word-wrap: break-word;
}
#chat .msg:last-child {
height: 100%;
}
#chat .msg:last-child .text {
padding-bottom: 5px;
}
#chat .msg .type {
color: #ccc;
display: none;
}
#chat .time,
#chat .from,
#chat .text {
display: table-cell;
padding: 5px 0 0;
}
#chat .time {
background: #f9f9f9;
color: #ddd;
text-align: right;
width: 46px;
}
#chat .from {
background: #f9f9f9;
border-right: 1px solid #f4f4f4;
color: #ddd;
padding-right: 10px;
text-align: right;
width: 134px;
}
#chat a,
#chat .from button {
color: #33b0f7;
}
#chat .text {
padding-left: 10px;
padding-right: 6px;
}
#chat .text a {
word-break: break-all;
}
#chat .join .type,
#chat .part .type,
#chat .mode .type,
#chat .nick .type,
#chat .kick .type,
#chat .quit .type,
#chat .quit .type,
#chat .notice .type,
#chat .topic .type {
display: inline;
}
#chat .error,
#chat .error .user,
#chat .highlight,
#chat .highlight .user {
color: #f00;
}
#chat .meta {
height: 80px;
padding: 25px 0 0 20px;
}
#chat .meta h1 {
color: #222;
font-size: 15px;
}
#chat .meta .type {
color: #ccc;
text-transform: capitalize;
}
#chat .count {
background: #f9f9f9;
border-top: 1px dashed #e9ecef;
border-bottom: 1px solid #e9ecef;
height: 40px;
left: 0;
position: absolute;
right: 0;
top: 80px;
}
#chat .count:before {
color: #eee;
font: 16px Octicons;
content: "\f02e";
position: absolute;
right: 18px;
line-height: 40px;
transition: color .2s;
z-index: 0;
}
#chat .search {
color: #222;
border: 0;
background: none;
font: inherit;
outline: 0;
padding: 12px 20px;
position: relative;
width: 100%;
}
#chat .names {
bottom: 0;
overflow: auto;
overflow-x: hidden;
-webkit-overflow-scrolling: touch;
padding: 15px 20px;
position: absolute;
top: 120px;
width: 100%;
}
#chat .names button {
display: block;
line-height: 1.6em;
}
#connect input {
width: 100%;
}
#connect label {
display: block;
margin-top: 10px;
}
#connect .title {
margin-bottom: 10px;
}
#connect .port:before {
content: ":";
margin: 28px 0 0 -17px;
position: absolute;
}
#connect .btn {
margin-top: 30px;
}
#form {
bottom: 0;
height: 40px;
left: 0;
position: absolute;
right: 0px;
z-index: 1;
}
#form input {
border: 0;
border-top: 1px solid #e9ecef;
font: 13px Consolas, monospace;
height: 100%;
outline: none;
padding: 0 12px;
-webkit-appearance: none;
width: 100%;
}
#form #submit {
height: 0;
margin-left: -9999px;
position: absolute;
width: 0;
}
@media (max-width: 768px) {
#viewport.rt {
-webkit-transform: translate3d(-180px, 0, 0);
transform: translate3d(-180px, 0, 0);
}
#header {
display: block;
}
#header #lt {
display: none;
}
#windows {
top: 40px;
}
#chat .chat {
right: 0;
}
#chat .sidebar {
bottom: -40px;
right: -180px;
top: -40px;
}
}
@media (max-width: 480px) {
#viewport.lt {
-webkit-transform: translate3d(220px, 0, 0);
transform: translate3d(220px, 0, 0);
}
#header #lt {
display: inherit;
}
#sidebar {
left: -220px;
}
#sidebar .empty:before {
margin-top: 0;
}
#main {
left: 0;
}
#chat .messages {
display: block;
padding: 5px 10px;
}
#chat .msg {
display: block;
padding: 2px 0;
}
#chat .msg:last-child {
height: auto;
}
#chat .from,
#chat .text {
background: none;
border: 0;
display: inline;
padding: 0;
}
#chat .time {
display: none;
}
#windows .title {
display: none;
}
}