@charset "UTF-8";
@import url(http://fonts.googleapis.com/css?family=Roboto:300,600);
@import url(http://fonts.googleapis.com/css?family=Open+Sans:400,600);
@import url(http://fonts.googleapis.com/css?family=Montserrat:400,700);
.site-nav li, .site-nav ul, main ul.album-list, dl.menu dd, dl.profile dd { margin: 0; padding: 0; border: 0; font-size: 100%; font-style: normal; font-weight: normal; list-style: none; text-decoration: none; background: transparent; vertical-align: baseline; }

.layout-cols, .site-header, main ul.album-list { *zoom: 1; }

.layout-cols:after, .site-header:after, main ul.album-list:after { content: ''; display: block; clear: both; height: 0; }

@media print { .layout-cols:after, .site-header:after, main ul.album-list:after { height: 1px; margin-bottom: -1px; visibility: hidden; } }

.video-container { position: relative; padding-bottom: 56.25%; height: 0; overflow: hidden; }

.video-container.show-controll { padding-top: 30px; }

.video-container iframe, .video-container object, .video-container embed { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }

footer ul li, main ul li, article ul li, .dash-list li { list-style: none; position: relative; }

footer ul li:before, main ul li:before, article ul li:before, .dash-list li:before { content: '–'; width: 40px; display: block; text-align: right; position: absolute; left: -60px; color: #666; }

@media only screen and (max-width: 785px) { footer ul li:before, main ul li:before, article ul li:before, .dash-list li:before { content: '–'; width: 30px; left: -40px; } }

.layout-cols footer ul li, footer .layout-cols ul li, .layout-cols main ul li, main .layout-cols ul li, .layout-cols article ul li, article .layout-cols ul li, .layout-cols .dash-list li { margin-left: 20px; }

.layout-cols footer ul li:before, footer .layout-cols ul li:before, .layout-cols main ul li:before, main .layout-cols ul li:before, .layout-cols article ul li:before, article .layout-cols ul li:before, .layout-cols .dash-list li:before { width: 30px; left: -40px; }

#grid-overlay { display: block; position: absolute; width: 100%; height: 100%; top: 0; left: 0; right: 0; opacity: .3; }

#grid-overlay { height: 0; opacity: 0; background-image: linear-gradient(90deg, transparent 48px, rgba(255, 0, 0, 0.5) 24px), linear-gradient(rgba(255, 0, 0, 0.5) 32px, transparent 32px), linear-gradient(rgba(255, 0, 0, 0.8) 1px, transparent 1px); background-size: 72px 100%, 32px 64px, 100% 16px; background-position: 0 0, 0 32px, 0 -1px; transition: .3s; pointer-events: none; }

#grid-overlay.grid-overlay-show { opacity: .3; }

h1.site-id .logo, .site-logo { display: block; font-weight: normal; line-height: 1; text-indent: -9999px; background: url("../img/logo.png") left top no-repeat; -webkit-background-size: 100%; background-size: 100%; }

.subheading { width: 22.8571428571%; margin-left: -28.5714285714%; margin-top: .45em; float: left; text-align: right; text-transform: uppercase; color: #999; vertical-align: baseline; font-family: Roboto; letter-spacing: .05em; }

dl.menu dt, dl.profile dt { width: 14.2857142857%; color: #999; float: left; line-height: 1.5; padding-top: .25em; }

dl.menu dd, dl.profile dd { margin-left: 17.1428571429%; width: 74.2857142857%; }

.photo-stage { overflow-x: scroll; overflow: hidden; width: 840px; }

.photo-stage ul { width: 1680px; }

.photo-stage ul li { float: left; width: 840px; }

figure.photo img { width: 100%; }

main ul.album-list li { float: left; width: 48.5714285714%; margin-bottom: 32px; }

@media only screen and (max-width: 785px) { main ul.album-list li { float: none; width: 100%; } }

main ul.album-list li:nth-child(2n) { margin-left: 2.8571428571%; }

@media only screen and (max-width: 785px) { main ul.album-list li:nth-child(2n) { margin-left: 0; } }

main ul.album-list li a { display: block; padding: 15px; background-color: #fff; color: #444; text-decoration: none; box-shadow: 0 0 10px rgba(0, 0, 0, 0.1); }

main ul.album-list li a:hover { box-shadow: 0 0 10px rgba(0, 0, 0, 0.3); }

main ul.album-list li h3 { margin-top: 0; margin-bottom: 15px; height: 32px; overflow: hidden; }

main ul.album-list li figure { width: auto; line-height: 1.5; }

main ul.album-list li figure img { width: 100%; margin-bottom: 16px; }

main ul.album-list li:before { content: ''; }

.page-title-heading, main h1 { font-size: 2em; font-weight: normal; line-height: 1; margin: 32px 0 96px; }

@media only screen and (max-width: 420px) { .page-title-heading, main h1 { font-size: 1.5em; margin: 0px 0 32px; } }

body.home main h1 { text-transform: uppercase; letter-spacing: .12em; }

/*! normalize.css v1.1.3 | MIT License | git.io/normalize */
/* ========================================================================== HTML5 display definitions ========================================================================== */
/** Correct `block` display not defined in IE 6/7/8/9 and Firefox 3. */
article, aside, details, figcaption, figure, footer, header, hgroup, main, nav, section, summary { display: block; }

/** Correct `inline-block` display not defined in IE 6/7/8/9 and Firefox 3. */
audio, canvas, video { display: inline-block; *display: inline; *zoom: 1; }

/** Prevent modern browsers from displaying `audio` without controls. Remove excess height in iOS 5 devices. */
audio:not([controls]) { display: none; height: 0; }

/** Address styling not present in IE 7/8/9, Firefox 3, and Safari 4. Known issue: no IE 6 support. */
[hidden] { display: none; }

/* ========================================================================== Base ========================================================================== */
/** 1. Correct text resizing oddly in IE 6/7 when body `font-size` is set using `em` units. 2. Prevent iOS text size adjust after orientation change, without disabling user zoom. */
html { font-size: 100%; /* 1 */ -ms-text-size-adjust: 100%; /* 2 */ -webkit-text-size-adjust: 100%; /* 2 */ }

/** Address `font-family` inconsistency between `textarea` and other form elements. */
html, button, input, select, textarea { font-family: sans-serif; }

/** Address margins handled incorrectly in IE 6/7. */
body { margin: 0; }

/* ========================================================================== Links ========================================================================== */
/** Address `outline` inconsistency between Chrome and other browsers. */
a:focus { outline: thin dotted; }

/** Improve readability when focused and also mouse hovered in all browsers. */
a:active, a:hover { outline: 0; }

/* ========================================================================== Typography ========================================================================== */
/** Address font sizes and margins set differently in IE 6/7. Address font sizes within `section` and `article` in Firefox 4+, Safari 5, and Chrome. */
h1 { font-size: 2em; margin: 0.67em 0; }

h2 { font-size: 1.5em; margin: 0.83em 0; }

h3 { font-size: 1.17em; margin: 1em 0; }

h4 { font-size: 1em; margin: 1.33em 0; }

h5 { font-size: 0.83em; margin: 1.67em 0; }

h6 { font-size: 0.67em; margin: 2.33em 0; }

/** Address styling not present in IE 7/8/9, Safari 5, and Chrome. */
abbr[title] { border-bottom: 1px dotted; }

/** Address style set to `bolder` in Firefox 3+, Safari 4/5, and Chrome. */
b, strong { font-weight: bold; }

blockquote { margin: 1em 40px; }

/** Address styling not present in Safari 5 and Chrome. */
dfn { font-style: italic; }

/** Address differences between Firefox and other browsers. Known issue: no IE 6/7 normalization. */
hr { -moz-box-sizing: content-box; box-sizing: content-box; height: 0; }

/** Address styling not present in IE 6/7/8/9. */
mark { background: #ff0; color: #000; }

/** Address margins set differently in IE 6/7. */
p, pre { margin: 1em 0; }

/** Correct font family set oddly in IE 6, Safari 4/5, and Chrome. */
code, kbd, pre, samp { font-family: monospace, serif; _font-family: 'courier new', monospace; font-size: 1em; }

/** Improve readability of pre-formatted text in all browsers. */
pre { white-space: pre; white-space: pre-wrap; word-wrap: break-word; }

/** Address CSS quotes not supported in IE 6/7. */
q { quotes: none; }

/** Address `quotes` property not supported in Safari 4. */
q:before, q:after { content: ''; content: none; }

/** Address inconsistent and variable font size in all browsers. */
small { font-size: 80%; }

/** Prevent `sub` and `sup` affecting `line-height` in all browsers. */
sub, sup { font-size: 75%; line-height: 0; position: relative; vertical-align: baseline; }

sup { top: -0.5em; }

sub { bottom: -0.25em; }

/* ========================================================================== Lists ========================================================================== */
/** Address margins set differently in IE 6/7. */
dl, dl.profile, menu, ol, ul { margin: 1em 0; }

dd { margin: 0 0 0 40px; }

/** Address paddings set differently in IE 6/7. */
menu, ol, ul { padding: 0 0 0 40px; }

/** Correct list images handled incorrectly in IE 7. */
nav ul, nav ol { list-style: none; list-style-image: none; }

/* ========================================================================== Embedded content ========================================================================== */
/** 1. Remove border when inside `a` element in IE 6/7/8/9 and Firefox 3. 2. Improve image quality when scaled in IE 7. */
img { border: 0; /* 1 */ -ms-interpolation-mode: bicubic; /* 2 */ }

/** Correct overflow displayed oddly in IE 9. */
svg:not(:root) { overflow: hidden; }

/* ========================================================================== Figures ========================================================================== */
/** Address margin not present in IE 6/7/8/9, Safari 5, and Opera 11. */
figure { margin: 0; }

/* ========================================================================== Forms ========================================================================== */
/** Correct margin displayed oddly in IE 6/7. */
form { margin: 0; }

/** Define consistent border, margin, and padding. */
fieldset { border: 1px solid #c0c0c0; margin: 0 2px; padding: 0.35em 0.625em 0.75em; }

/** 1. Correct color not being inherited in IE 6/7/8/9. 2. Correct text not wrapping in Firefox 3. 3. Correct alignment displayed oddly in IE 6/7. */
legend { border: 0; /* 1 */ padding: 0; white-space: normal; /* 2 */ *margin-left: -7px; /* 3 */ }

/** 1. Correct font size not being inherited in all browsers. 2. Address margins set differently in IE 6/7, Firefox 3+, Safari 5, and Chrome. 3. Improve appearance and consistency in all browsers. */
button, input, select, textarea { font-size: 100%; /* 1 */ margin: 0; /* 2 */ vertical-align: baseline; /* 3 */ *vertical-align: middle; /* 3 */ }

/** Address Firefox 3+ setting `line-height` on `input` using `!important` in the UA stylesheet. */
button, input { line-height: normal; }

/** Address inconsistent `text-transform` inheritance for `button` and `select`. All other form control elements do not inherit `text-transform` values. Correct `button` style inheritance in Chrome, Safari 5+, and IE 6+. Correct `select` style inheritance in Firefox 4+ and Opera. */
button, select { text-transform: none; }

/** 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio` and `video` controls. 2. Correct inability to style clickable `input` types in iOS. 3. Improve usability and consistency of cursor style between image-type `input` and others. 4. Remove inner spacing in IE 7 without affecting normal text inputs. Known issue: inner spacing remains in IE 6. */
button, html input[type="button"], input[type="reset"], input[type="submit"] { -webkit-appearance: button; /* 2 */ cursor: pointer; /* 3 */ *overflow: visible; /* 4 */ }

/** Re-set default cursor for disabled elements. */
button[disabled], html input[disabled] { cursor: default; }

/** 1. Address box sizing set to content-box in IE 8/9. 2. Remove excess padding in IE 8/9. 3. Remove excess padding in IE 7. Known issue: excess padding remains in IE 6. */
input[type="checkbox"], input[type="radio"] { box-sizing: border-box; /* 1 */ padding: 0; /* 2 */ *height: 13px; /* 3 */ *width: 13px; /* 3 */ }

/** 1. Address `appearance` set to `searchfield` in Safari 5 and Chrome. 2. Address `box-sizing` set to `border-box` in Safari 5 and Chrome (include `-moz` to future-proof). */
input[type="search"] { -webkit-appearance: textfield; /* 1 */ -moz-box-sizing: content-box; -webkit-box-sizing: content-box; /* 2 */ box-sizing: content-box; }

/** Remove inner padding and search cancel button in Safari 5 and Chrome on OS X. */
input[type="search"]::-webkit-search-cancel-button, input[type="search"]::-webkit-search-decoration { -webkit-appearance: none; }

/** Remove inner padding and border in Firefox 3+. */
button::-moz-focus-inner, input::-moz-focus-inner { border: 0; padding: 0; }

/** 1. Remove default vertical scrollbar in IE 6/7/8/9. 2. Improve readability and alignment in all browsers. */
textarea { overflow: auto; /* 1 */ vertical-align: top; /* 2 */ }

/* ========================================================================== Tables ========================================================================== */
/** Remove most spacing between table cells. */
table { border-collapse: collapse; border-spacing: 0; }

/*! HTML5 Boilerplate v4.3.0 | MIT License | http://h5bp.com/ */
html, button, input, select, textarea { color: #222; }

html { font-size: 1em; line-height: 1.4; }

::-moz-selection { background: #ef4136; color: #fff; text-shadow: none; }

::selection { background: #ef4136; color: #fff; text-shadow: none; }

hr { display: block; height: 1px; border: 0; border-top: 1px solid #ccc; margin: 1em 0; padding: 0; }

audio, canvas, img, video { vertical-align: middle; }

fieldset { border: 0; margin: 0; padding: 0; }

textarea { resize: vertical; }

.browsehappy { margin: 0.2em 0; background: #ccc; color: #000; padding: 0.2em 0; }

/* ========================================================================== Author's custom styles ========================================================================== */
/* ========================================================================== Media Queries ========================================================================== */
/* ========================================================================== Helper classes ========================================================================== */
.ir { background-color: transparent; border: 0; overflow: hidden; *text-indent: -9999px; }

.ir:before { content: ""; display: block; width: 0; height: 150%; }

.hidden { display: none !important; visibility: hidden; }

.visuallyhidden { border: 0; clip: rect(0 0 0 0); height: 1px; margin: -1px; overflow: hidden; padding: 0; position: absolute; width: 1px; }

.visuallyhidden.focusable:active, .visuallyhidden.focusable:focus { clip: auto; height: auto; margin: 0; overflow: visible; position: static; width: auto; }

.invisible { visibility: hidden; }

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

.clearfix:after { clear: both; }

.clearfix { *zoom: 1; }

/* ========================================================================== Print styles ========================================================================== */
@media print { * { background: transparent !important; color: #000 !important; box-shadow: none !important; text-shadow: none !important; } a, a:visited { text-decoration: underline; } a[href]:after { content: " (" attr(href) ")"; } abbr[title]:after { content: " (" attr(title) ")"; } .ir a:after, a[href^="javascript:"]:after, a[href^="#"]:after { content: ""; } pre, blockquote { border: 1px solid #999; page-break-inside: avoid; } thead { display: table-header-group; } tr, img { page-break-inside: avoid; } img { max-width: 100% !important; } @page { margin: 0.5cm; } p, h2, h3 { orphans: 3; widows: 3; } h2, h3 { page-break-after: avoid; } }

* { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; }

html { margin: 0; padding: 0 30px; color: #444; background-color: #fafafa; overflow-y: scroll; -webkit-text-rendering: optimizeLegibility; text-rendering: optimizeLegibility; }

@media only screen and (max-width: 420px) { html { padding: 0 20px; } }

body { position: relative; max-width: 840px; font-weight: 400; padding: 0; margin: 0 auto; font-family: "Open Sans", "Noto Sans JP", sans-serif; font-size: 16px; line-height: 2; opacity: 1; transition: .2s; -webkit-transform: translateY(0); transform: translateY(0); }

a { color: #ef4136; text-decoration: none; }

a:hover { text-decoration: underline; }

main h2 a, main h3 a, main p a, main ul a, main dd a { color: #36a; text-decoration: underline; }

.site-header { height: 128px; color: #fff; }

.site-nav { float: right; font-size: 16px; }

@media only screen and (max-width: 420px) { .site-nav { font-size: 14px; } }

.site-nav ul { list-style-type: none; float: right; }

.site-nav li { display: block; float: left; margin-top: 32px; margin-left: 48px; }

@media only screen and (max-width: 420px) { .site-nav li { margin-left: 24px; margin-top: 21.312px; } }

.site-nav a { padding: 4px 0px 7px; border-bottom: 0px solid transparent; transition: .3s; }

.site-nav a.em, .site-nav a:hover, .home .site-nav a.home, .gallery .site-nav a.gallery, .articles .site-nav a.articles, .nikki .site-nav a.nikki, .about .site-nav a.about { text-decoration: none; border-bottom: 3px solid; padding-bottom: 5px; transition: .05s; }

h1.site-id { margin: 32px 0 32px; padding: 0; line-height: 1; float: left; font-weight: normal; }

@media only screen and (max-width: 420px) { h1.site-id { margin-top: 21.312px; } }

h1.site-id a.site-title { color: #999; }

h1.site-id a.site-title:hover { text-decoration: none; color: #444; }

h1.site-id .logo { width: 32px; height: 32px; float: left; margin-right: 10px; transition: 1s; }

h1.site-id .site-name { display: block; font-size: 18px; letter-spacing: .08em; margin-top: -1px; margin-bottom: 5px; text-transform: uppercase; }

.home h1.site-id .site-name { display: none; }

h1.site-id .tagline { display: block; font-size: 10px; letter-spacing: .0em; font-weight: 100; }

.home h1.site-id .tagline { display: none; }

.site-footer { margin: 112px 0 128px; }

.site-footer .site-logo { display: block; margin: 0 auto; width: 16px; height: 16px; }

.layout-col, .layout-col-12, .layout-col-11, .layout-col-10, .layout-col-9, .layout-col-8, .layout-col-7, .layout-col-6, body.home section.linksandupdates, body.home section.other, .layout-col-5, .layout-col-4, .layout-col-3, .layout-col-2, .layout-col-1 { float: left; margin-left: 2.8571428571%; }

.layout-col:first-child, .layout-col-12:first-child, .layout-col-11:first-child, .layout-col-10:first-child, .layout-col-9:first-child, .layout-col-8:first-child, .layout-col-7:first-child, .layout-col-6:first-child, body.home section.linksandupdates:first-child, body.home section.other:first-child, .layout-col-5:first-child, .layout-col-4:first-child, .layout-col-3:first-child, .layout-col-2:first-child, .layout-col-1:first-child { margin-left: 0; }

@media only screen and (max-width: 785px) { .layout-col, .layout-col-12, .layout-col-11, .layout-col-10, .layout-col-9, .layout-col-8, .layout-col-7, .layout-col-6, body.home section.linksandupdates, body.home section.other, .layout-col-5, .layout-col-4, .layout-col-3, .layout-col-2, .layout-col-1 { float: none; margin-left: 0; width: 100% !important; } }

.layout-col-1 { width: 5.7142857143%; }

.layout-push-1 { margin-left: 8.5714285714%; }

.layout-col-2 { width: 14.2857142857%; }

.layout-push-2 { margin-left: 17.1428571429%; }

.layout-col-3 { width: 22.8571428571%; }

.layout-push-3 { margin-left: 25.7142857143%; }

.layout-col-4 { width: 31.4285714286%; }

.layout-push-4 { margin-left: 34.2857142857%; }

.layout-col-5 { width: 40%; }

.layout-push-5 { margin-left: 42.8571428571%; }

.layout-col-6, body.home section.linksandupdates, body.home section.other { width: 48.5714285714%; }

.layout-push-6 { margin-left: 51.4285714286%; }

.layout-col-7 { width: 57.1428571429%; }

.layout-push-7 { margin-left: 60%; }

.layout-col-8 { width: 65.7142857143%; }

.layout-push-8 { margin-left: 68.5714285714%; }

.layout-col-9 { width: 74.2857142857%; }

.layout-push-9 { margin-left: 77.1428571429%; }

.layout-col-10 { width: 82.8571428571%; }

.layout-push-10 { margin-left: 85.7142857143%; }

.layout-col-11 { width: 91.4285714286%; }

.layout-push-11 { margin-left: 94.2857142857%; }

.layout-col-12 { width: 100%; }

.layout-push-12 { margin-left: 102.8571428571%; }

h1, h2, h3, .site-nav { font-family: 'Montserrat', sans-serif; }

main { opacity: 1; transition: .5s; }

.js.loading main { opacity: 0; }

main h2 { font-size: 1.5em; line-height: 1.3333333333; color: #999; font-weight: normal; margin: 64px 0 32px; }

main h3 { font-size: 1.25em; font-weight: normal; line-height: 1.6; margin: 32px 0 0px; }

main p { margin: 32px 0; line-height: 2; }

main p.meta { text-transform: uppercase; color: #999; }

h2 + main p.meta { margin: -64px 0 64px; }

main h3 .period { margin-left: .5em; position: relative; color: #999; text-transform: uppercase; font-size: 16px; }

main ul { margin: 0px 0; padding: 0; }

main li { margin: 0 0; }

@media only screen and (max-width: 785px) { .hitg { display: none; } }

/*# sourceMappingURL=style.css.map */