Apple keyboard made using CSS flexbox. It’s just the design and the keyboard is not interactive just has a simple click effect.
Made by Olex.
Related Posts
The Html Code
<!DOCTYPE html>
<html lang="en" >
<head>
<title>CSS Flexbox Apple Keyboard</title>
</head>
<body>
<div class="container">
<h1 class="title">CSS Flexbox Apple Keyboard by <a href="//olex.co/">Olex</a></h1>
<div class="keyboard">
<div class="keyboard-row thin">
<div class="key lowercase">Esc</div>
<div class="key function lo-bright"><span>f1</span></div>
<div class="key function hi-bright"><span>f2</span></div>
<div class="key function expose"><span>f3</span></div>
<div class="key function tilez"><span>f4</span></div>
<div class="key function"><span>f5</span></div>
<div class="key function"><span>f6</span></div>
<div class="key function rewind"><span>f7</span></div>
<div class="key function play-pause"><span>f8</span></div>
<div class="key function ffwd"><span>f9</span></div>
<div class="key function mute"><span>f10</span></div>
<div class="key function lo-vol"><span>f11</span></div>
<div class="key function hi-vol"><span>f12</span></div>
<div class="key eject"></div>
</div>
<div class="keyboard-row">
<div class="key"><span>~<br/>`</span></div>
<div class="key"><span>!<br/>1</span></div>
<div class="key"><span>@<br/>2</span></div>
<div class="key"><span>#<br/>3</span></div>
<div class="key"><span>$<br/>4</span></div>
<div class="key"><span>%<br/>5</span></div>
<div class="key"><span>^<br/>6</span></div>
<div class="key"><span>&<br/>7</span></div>
<div class="key"><span>*<br/>8</span></div>
<div class="key"><span>(<br/>9</span></div>
<div class="key"><span>)<br/>0</span></div>
<div class="key"><span>_<br/>-</span></div>
<div class="key"><span>+<br/>=</span></div>
<div class="key extra-size lowercase lower-right"><span class="lower-row-text">delete</span></div>
</div>
<div class="keyboard-row">
<div class="key extra-size lowercase lower-left"><span class="lower-row-text">tab</span></div>
<div class="key">Q</div>
<div class="key">W</div>
<div class="key">E</div>
<div class="key">R</div>
<div class="key">T</div>
<div class="key">Y</div>
<div class="key">U</div>
<div class="key">I</div>
<div class="key">O</div>
<div class="key">P</div>
<div class="key"><span>{<br/>[</span></div>
<div class="key"><span>}<br/>]</span></div>
<div class="key"><span>|<br/>\</span></div>
</div>
<div class="keyboard-row">
<div class="key lowercase lower-left extra-size-two"><span class="lower-row-text">caps lock</span><span class="absolute-left caps-dot">•</span></div>
<div class="key">A</div>
<div class="key">S</div>
<div class="key">D</div>
<div class="key">F</div>
<div class="key">G</div>
<div class="key">H</div>
<div class="key">J</div>
<div class="key">K</div>
<div class="key">L</div>
<div class="key"><span>:<br/>;</span></div>
<div class="key"><span>"<br/>'</span></div>
<div class="key extra-size-two lowercase lower-right"><span class="lower-row-text">return</span><span class="absolute-right">enter</span></div>
</div>
<div class="keyboard-row">
<div class="key double-size lowercase lower-left"><span class="lower-row-text">shift</span></div>
<div class="key">Z</div>
<div class="key">X</div>
<div class="key">C</div>
<div class="key">V</div>
<div class="key">B</div>
<div class="key">N</div>
<div class="key">M</div>
<div class="key"><span><<br/>,</span></div>
<div class="key"><span>><br/>.</span></div>
<div class="key"><span>?<br/>/</span></div>
<div class="key double-size lowercase lower-right"><span class="lower-row-text">shift</span></div>
</div>
<div class="keyboard-row bottom-row">
<div class="key lower-left lowercase"><span class="lower-row-text">fn</span></div>
<div class="key lower-left lowercase"><span class="lower-row-text">control</span></div>
<div class="key lower-left lowercase"><span class="lower-row-text">option</span><span class="absolute-left">alt</span></div>
<div class="key lower-center lowercase extra-size-two"><span class="lower-row-text">command</span><span class="absolute-right icon">⌘</span></div>
<div class="key space-bar"></div>
<div class="key lower-center lowercase extra-size-two"><span class="lower-row-text">command</span><span class="absolute-left icon">⌘</span></div>
<div class="key lower-right lowercase"><span class="lower-row-text">option</span><span class="absolute-right">alt</span></div>
<div class="arrows">
<div class="key">◄</div>
<div class="up-down">
<div class="key">▲</div>
<div class="key">▼</div>
</div>
<div class="key">►</div>
</div>
</div>
</div>
</div>
</div>
</body>
</html>
The CSS Code
* {
box-sizing: inherit;
}
body {
box-sizing: border-box;
background-color: #404049;
font-family: 'VAG Rounded W01 Thin';
}
.container {
max-width: 816px;
padding: 30px 8px 8px;
margin: 60px auto;
box-shadow: inset 1px 1px 0px #f1f1f1, 3px 3px 6px 3px #303038;
background-color: #e3e3e3;
border-radius: 1px 1px 7px 7px;
}
h1 {
position: relative;
top: -23px;
left: 3px;
height: 0;
font-size: 12px;
}
h1 a {
color: inherit;
text-decoration: none;
letter-spacing: 0.5px;
}
h1 a:hover {
color: #ff8855;
border-bottom: 1px solid;
}
.keyboard-row {
display: flex;
}
.key {
position: relative;
display: inline-block;
vertical-align: middle;
text-align: center;
padding: 3px 2px;
height: 30px;
margin: 4px;
letter-spacing: 0.5px;
color: #3a3a3a;
background-color: #f7f7f7;
flex: 1;
box-shadow: inset 0 -2px 0 #aaaaaa, inset 0px 1px 1px -1px #fff, 0px 1px 1px 0px #7a7a7a;
border-radius: 3px;
text-transform: uppercase;
font-size: 14px;
line-height: 1.3;
white-space: nowrap;
overflow: hidden;
user-select: none;
transition: transform 0.08s ease, background-color 0.08s ease, box-shadow 0.08s ease;
cursor: pointer;
}
.key:hover {
background-color: #fbfbfb;
}
.key:active {
transform: translateY(1.5px);
box-shadow: inset 0 -0.5px 0 #aaaaaa, inset 0px -1px 1px -1px #fff, 0px 0.5px 0.75px 0px #999;
}
.key span {
display: inline-block;
vertical-align: middle;
}
.key::before {
display: inline-block;
vertical-align: middle;
height: 100%;
content: '';
}
.keyboard-row.thin .key {
height: 20px;
}
.keyboard-row.bottom-row .key {
height: 24px;
}
@media (min-width: 640px) {
.key {
height: 48px;
}
.keyboard-row.thin .key {
height: 28px;
}
.keyboard-row.bottom-row .key {
height: 55px;
}
}
.key.extra-size {
flex: 1.25;
}
.key.extra-size-two {
flex: 1.625;
}
.key.double-size {
flex: 2.125;
}
.key.lowercase {
font-size: 11px;
text-transform: lowercase;
}
.key.function {
font-size: 8px;
text-align: right;
}
.key.function span {
vertical-align: bottom;
}
.key.lower-right {
vertical-align: bottom;
text-align: right;
padding-right: 5px;
}
.key.lower-left {
vertical-align: bottom;
text-align: left;
padding-left: 5px;
}
.key.lower-center {
vertical-align: bottom;
}
.key.space-bar {
flex: 7.2;
}
.key .lower-row-text {
vertical-align: bottom;
padding-bottom: 2px;
}
.key .absolute-left,
.key .absolute-right {
position: absolute;
top: 5px;
font-size: 9px;
}
.key .absolute-left.icon,
.key .absolute-right.icon {
font-size: 12px;
}
.key .absolute-right {
right: 5px;
}
.key .absolute-left {
left: 5px;
}
.key .absolute-left.caps-dot {
top: 3px;
left: 4px;
}
.bottom-row .arrows {
display: flex;
flex: 4;
justify-content: justify;
align-items: flex-end;
padding-bottom: 4px;
}
.bottom-row .arrows .up-down {
flex: 1.2;
height: 54px;
display: flex;
flex-direction: column;
margin-left: 4px;
margin-right: 4px;
}
.bottom-row .arrows .up-down .key {
margin: 0;
}
.bottom-row .arrows .up-down .key:first-child {
box-shadow: inset 0 -5px 4px -4px #aaaaaa, inset 0px 1px 1px -1px #fff, 0px 1px 1px 0px #7a7a7a;
border-bottom-left-radius: 1px;
border-bottom-right-radius: 1px;
}
.bottom-row .arrows .up-down .key + .key {
border-top-left-radius: 1px;
border-top-right-radius: 1px;
}
.bottom-row .arrows .key {
flex: 1;
font-size: 7px;
margin: 0 4px;
height: 27px;
font-family: "Georgia", sans-serif;
color: #555;
}
/* function row icons */
.fn-row-icon {
background-size: auto 60%;
background-position: 50% 45%;
background-repeat: no-repeat;
}
.eject,
.lo-bright,
.hi-bright,
.expose,
.tilez,
.rewind,
.ffwd,
.play-pause,
.mute,
.lo-vol,
.hi-vol,
.eject {
background-size: auto 60%;
background-position: 50% 45%;
background-repeat: no-repeat;
}
.eject {
background-image: url(//s3-us-west-2.amazonaws.com/s.cdpn.io/8533/apple-icons-01_1.svg);
}
.lo-bright {
background-image: url(//s3-us-west-2.amazonaws.com/s.cdpn.io/8533/apple-icons-10_1.svg);
}
.hi-bright {
background-image: url(//s3-us-west-2.amazonaws.com/s.cdpn.io/8533/apple-icons-09_1.svg);
}
.expose {
background-image: url(//s3-us-west-2.amazonaws.com/s.cdpn.io/8533/apple-icons-08_1.svg);
}
.tilez {
background-image: url(//s3-us-west-2.amazonaws.com/s.cdpn.io/8533/apple-icons-07_1.svg);
}
.rewind {
background-image: url(//s3-us-west-2.amazonaws.com/s.cdpn.io/8533/apple-icons-06_1.svg);
}
.ffwd {
background-image: url(//s3-us-west-2.amazonaws.com/s.cdpn.io/8533/apple-icons-04_1.svg);
}
.play-pause {
background-image: url(//s3-us-west-2.amazonaws.com/s.cdpn.io/8533/apple-icons-05_1.svg);
}
.mute {
background-image: url(//s3-us-west-2.amazonaws.com/s.cdpn.io/8533/apple-icons-11.svg);
}
.lo-vol {
background-image: url(//s3-us-west-2.amazonaws.com/s.cdpn.io/8533/apple-icons-03_1.svg);
}
.hi-vol {
background-image: url(//s3-us-west-2.amazonaws.com/s.cdpn.io/8533/apple-icons-02_1.svg);
}
.eject {
background-image: url(//s3-us-west-2.amazonaws.com/s.cdpn.io/8533/apple-icons-01_1.svg);
}
The Complete Code
<!DOCTYPE html>
<html lang="en" >
<head>
<title>CSS Flexbox Apple Keyboard</title>
<style>
* {
box-sizing: inherit;
}
body {
box-sizing: border-box;
background-color: #404049;
font-family: 'VAG Rounded W01 Thin';
}
.container {
max-width: 816px;
padding: 30px 8px 8px;
margin: 60px auto;
box-shadow: inset 1px 1px 0px #f1f1f1, 3px 3px 6px 3px #303038;
background-color: #e3e3e3;
border-radius: 1px 1px 7px 7px;
}
h1 {
position: relative;
top: -23px;
left: 3px;
height: 0;
font-size: 12px;
}
h1 a {
color: inherit;
text-decoration: none;
letter-spacing: 0.5px;
}
h1 a:hover {
color: #ff8855;
border-bottom: 1px solid;
}
.keyboard-row {
display: flex;
}
.key {
position: relative;
display: inline-block;
vertical-align: middle;
text-align: center;
padding: 3px 2px;
height: 30px;
margin: 4px;
letter-spacing: 0.5px;
color: #3a3a3a;
background-color: #f7f7f7;
flex: 1;
box-shadow: inset 0 -2px 0 #aaaaaa, inset 0px 1px 1px -1px #fff, 0px 1px 1px 0px #7a7a7a;
border-radius: 3px;
text-transform: uppercase;
font-size: 14px;
line-height: 1.3;
white-space: nowrap;
overflow: hidden;
user-select: none;
transition: transform 0.08s ease, background-color 0.08s ease, box-shadow 0.08s ease;
cursor: pointer;
}
.key:hover {
background-color: #fbfbfb;
}
.key:active {
transform: translateY(1.5px);
box-shadow: inset 0 -0.5px 0 #aaaaaa, inset 0px -1px 1px -1px #fff, 0px 0.5px 0.75px 0px #999;
}
.key span {
display: inline-block;
vertical-align: middle;
}
.key::before {
display: inline-block;
vertical-align: middle;
height: 100%;
content: '';
}
.keyboard-row.thin .key {
height: 20px;
}
.keyboard-row.bottom-row .key {
height: 24px;
}
@media (min-width: 640px) {
.key {
height: 48px;
}
.keyboard-row.thin .key {
height: 28px;
}
.keyboard-row.bottom-row .key {
height: 55px;
}
}
.key.extra-size {
flex: 1.25;
}
.key.extra-size-two {
flex: 1.625;
}
.key.double-size {
flex: 2.125;
}
.key.lowercase {
font-size: 11px;
text-transform: lowercase;
}
.key.function {
font-size: 8px;
text-align: right;
}
.key.function span {
vertical-align: bottom;
}
.key.lower-right {
vertical-align: bottom;
text-align: right;
padding-right: 5px;
}
.key.lower-left {
vertical-align: bottom;
text-align: left;
padding-left: 5px;
}
.key.lower-center {
vertical-align: bottom;
}
.key.space-bar {
flex: 7.2;
}
.key .lower-row-text {
vertical-align: bottom;
padding-bottom: 2px;
}
.key .absolute-left,
.key .absolute-right {
position: absolute;
top: 5px;
font-size: 9px;
}
.key .absolute-left.icon,
.key .absolute-right.icon {
font-size: 12px;
}
.key .absolute-right {
right: 5px;
}
.key .absolute-left {
left: 5px;
}
.key .absolute-left.caps-dot {
top: 3px;
left: 4px;
}
.bottom-row .arrows {
display: flex;
flex: 4;
justify-content: justify;
align-items: flex-end;
padding-bottom: 4px;
}
.bottom-row .arrows .up-down {
flex: 1.2;
height: 54px;
display: flex;
flex-direction: column;
margin-left: 4px;
margin-right: 4px;
}
.bottom-row .arrows .up-down .key {
margin: 0;
}
.bottom-row .arrows .up-down .key:first-child {
box-shadow: inset 0 -5px 4px -4px #aaaaaa, inset 0px 1px 1px -1px #fff, 0px 1px 1px 0px #7a7a7a;
border-bottom-left-radius: 1px;
border-bottom-right-radius: 1px;
}
.bottom-row .arrows .up-down .key + .key {
border-top-left-radius: 1px;
border-top-right-radius: 1px;
}
.bottom-row .arrows .key {
flex: 1;
font-size: 7px;
margin: 0 4px;
height: 27px;
font-family: "Georgia", sans-serif;
color: #555;
}
/* function row icons */
.fn-row-icon {
background-size: auto 60%;
background-position: 50% 45%;
background-repeat: no-repeat;
}
.eject,
.lo-bright,
.hi-bright,
.expose,
.tilez,
.rewind,
.ffwd,
.play-pause,
.mute,
.lo-vol,
.hi-vol,
.eject {
background-size: auto 60%;
background-position: 50% 45%;
background-repeat: no-repeat;
}
.eject {
background-image: url(//s3-us-west-2.amazonaws.com/s.cdpn.io/8533/apple-icons-01_1.svg);
}
.lo-bright {
background-image: url(//s3-us-west-2.amazonaws.com/s.cdpn.io/8533/apple-icons-10_1.svg);
}
.hi-bright {
background-image: url(//s3-us-west-2.amazonaws.com/s.cdpn.io/8533/apple-icons-09_1.svg);
}
.expose {
background-image: url(//s3-us-west-2.amazonaws.com/s.cdpn.io/8533/apple-icons-08_1.svg);
}
.tilez {
background-image: url(//s3-us-west-2.amazonaws.com/s.cdpn.io/8533/apple-icons-07_1.svg);
}
.rewind {
background-image: url(//s3-us-west-2.amazonaws.com/s.cdpn.io/8533/apple-icons-06_1.svg);
}
.ffwd {
background-image: url(//s3-us-west-2.amazonaws.com/s.cdpn.io/8533/apple-icons-04_1.svg);
}
.play-pause {
background-image: url(//s3-us-west-2.amazonaws.com/s.cdpn.io/8533/apple-icons-05_1.svg);
}
.mute {
background-image: url(//s3-us-west-2.amazonaws.com/s.cdpn.io/8533/apple-icons-11.svg);
}
.lo-vol {
background-image: url(//s3-us-west-2.amazonaws.com/s.cdpn.io/8533/apple-icons-03_1.svg);
}
.hi-vol {
background-image: url(//s3-us-west-2.amazonaws.com/s.cdpn.io/8533/apple-icons-02_1.svg);
}
.eject {
background-image: url(//s3-us-west-2.amazonaws.com/s.cdpn.io/8533/apple-icons-01_1.svg);
}
</style>
</head>
<body>
<div class="container">
<h1 class="title">CSS Flexbox Apple Keyboard by <a href="//olex.co/">Olex</a></h1>
<div class="keyboard">
<div class="keyboard-row thin">
<div class="key lowercase">Esc</div>
<div class="key function lo-bright"><span>f1</span></div>
<div class="key function hi-bright"><span>f2</span></div>
<div class="key function expose"><span>f3</span></div>
<div class="key function tilez"><span>f4</span></div>
<div class="key function"><span>f5</span></div>
<div class="key function"><span>f6</span></div>
<div class="key function rewind"><span>f7</span></div>
<div class="key function play-pause"><span>f8</span></div>
<div class="key function ffwd"><span>f9</span></div>
<div class="key function mute"><span>f10</span></div>
<div class="key function lo-vol"><span>f11</span></div>
<div class="key function hi-vol"><span>f12</span></div>
<div class="key eject"></div>
</div>
<div class="keyboard-row">
<div class="key"><span>~<br/>`</span></div>
<div class="key"><span>!<br/>1</span></div>
<div class="key"><span>@<br/>2</span></div>
<div class="key"><span>#<br/>3</span></div>
<div class="key"><span>$<br/>4</span></div>
<div class="key"><span>%<br/>5</span></div>
<div class="key"><span>^<br/>6</span></div>
<div class="key"><span>&<br/>7</span></div>
<div class="key"><span>*<br/>8</span></div>
<div class="key"><span>(<br/>9</span></div>
<div class="key"><span>)<br/>0</span></div>
<div class="key"><span>_<br/>-</span></div>
<div class="key"><span>+<br/>=</span></div>
<div class="key extra-size lowercase lower-right"><span class="lower-row-text">delete</span></div>
</div>
<div class="keyboard-row">
<div class="key extra-size lowercase lower-left"><span class="lower-row-text">tab</span></div>
<div class="key">Q</div>
<div class="key">W</div>
<div class="key">E</div>
<div class="key">R</div>
<div class="key">T</div>
<div class="key">Y</div>
<div class="key">U</div>
<div class="key">I</div>
<div class="key">O</div>
<div class="key">P</div>
<div class="key"><span>{<br/>[</span></div>
<div class="key"><span>}<br/>]</span></div>
<div class="key"><span>|<br/>\</span></div>
</div>
<div class="keyboard-row">
<div class="key lowercase lower-left extra-size-two"><span class="lower-row-text">caps lock</span><span class="absolute-left caps-dot">•</span></div>
<div class="key">A</div>
<div class="key">S</div>
<div class="key">D</div>
<div class="key">F</div>
<div class="key">G</div>
<div class="key">H</div>
<div class="key">J</div>
<div class="key">K</div>
<div class="key">L</div>
<div class="key"><span>:<br/>;</span></div>
<div class="key"><span>"<br/>'</span></div>
<div class="key extra-size-two lowercase lower-right"><span class="lower-row-text">return</span><span class="absolute-right">enter</span></div>
</div>
<div class="keyboard-row">
<div class="key double-size lowercase lower-left"><span class="lower-row-text">shift</span></div>
<div class="key">Z</div>
<div class="key">X</div>
<div class="key">C</div>
<div class="key">V</div>
<div class="key">B</div>
<div class="key">N</div>
<div class="key">M</div>
<div class="key"><span><<br/>,</span></div>
<div class="key"><span>><br/>.</span></div>
<div class="key"><span>?<br/>/</span></div>
<div class="key double-size lowercase lower-right"><span class="lower-row-text">shift</span></div>
</div>
<div class="keyboard-row bottom-row">
<div class="key lower-left lowercase"><span class="lower-row-text">fn</span></div>
<div class="key lower-left lowercase"><span class="lower-row-text">control</span></div>
<div class="key lower-left lowercase"><span class="lower-row-text">option</span><span class="absolute-left">alt</span></div>
<div class="key lower-center lowercase extra-size-two"><span class="lower-row-text">command</span><span class="absolute-right icon">⌘</span></div>
<div class="key space-bar"></div>
<div class="key lower-center lowercase extra-size-two"><span class="lower-row-text">command</span><span class="absolute-left icon">⌘</span></div>
<div class="key lower-right lowercase"><span class="lower-row-text">option</span><span class="absolute-right">alt</span></div>
<div class="arrows">
<div class="key">◄</div>
<div class="up-down">
<div class="key">▲</div>
<div class="key">▼</div>
</div>
<div class="key">►</div>
</div>
</div>
</div>
</div>
</div>
</body>
</html>