@charset "UTF-8";
/* ========================================================================== Base styles: opinionated defaults ========================================================================== */
html { color: #222; font-size: 1em; line-height: 1.4; }

/* Remove text-shadow in selection highlight: https://twitter.com/miketaylr/status/12228805301  These selection rule sets have to be separate. Customize the background color to match your design. */
::-moz-selection { background: #b3d4fc; text-shadow: none; }

::selection { background: #b3d4fc; text-shadow: none; }

/* A better looking default horizontal rule */
hr { display: block; height: 1px; border: 0; border-top: 1px solid #ccc; margin: 1em 0; padding: 0; }

/* Remove the gap between audio, canvas, iframes, images, videos and the bottom of their containers: https://github.com/h5bp/html5-boilerplate/issues/440 */
audio, canvas, iframe, img, svg, video { vertical-align: middle; }

/* Remove default fieldset styles. */
fieldset { border: 0; margin: 0; padding: 0; }

/* Allow only vertical resizing of textareas. */
textarea { resize: vertical; }

/* ========================================================================== Browser Upgrade Prompt ========================================================================== */
.browserupgrade { margin: 0.2em 0; background: #ccc; color: #000; padding: 0.2em 0; }

/* Make the entire page show a busy cursor */
.nprogress-busy body { cursor: wait; }

.fade { -webkit-transition: all 300ms linear 700ms; transition: all 300ms linear 700ms; -webkit-transform: translate3d(0, 0, 0); -ms-transform: translate3d(0, 0, 0); transform: translate3d(0, 0, 0); opacity: 1; }

.fade.out { opacity: 0; }

/* ========================================================================== Author's custom styles ========================================================================== */
body { background-color: #000; font-family: "游ゴシック", YuGothic, "Droid Sans", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; position: relative; }

.loading { position: absolute; top: 0; left: 0; right: 0; bottom: 0; margin: auto; }

.container { background-image: url("../img/bground-top@2x.jpg"), url("../img/bground-bottom@2x.jpg"); background-repeat: no-repeat; background-size: 100% auto, 50% auto; background-position: left top, right bottom; background-color: #000; padding: 0 10px; }
@media only screen and (min-width: 756px) { .container { background-size: 75% auto, 50% auto; } }

.page { width: 100%; margin: 0 auto; }

#site-header { width: 100%; padding-top: 65px; padding-bottom: 65px; }
@media only screen and (min-width: 960px) { #site-header { padding-top: 100px; padding-bottom: 70px; } }

.logo-royalcos { display: none !important; margin: 0 auto; padding: 0; width: 72px; font-size: 1em; line-height: 1; }
.logo-royalcos > img { width: 72px; }
@media only screen and (min-width: 960px) { .logo-royalcos { width: 112px; }
  .logo-royalcos > img { width: 112px; } }

.hero { position: relative; margin-bottom: 52px; padding-top: 366px; width: 100%; }
.hero:before, .hero:after { content: " "; display: table; }
.hero:after { clear: both; }
@media only screen and (min-width: 756px) { .hero { width: 736px; margin-left: auto; margin-right: auto; margin-bottom: 0; padding-top: 80px; } }
@media only screen and (min-width: 960px) { .hero { width: 960px; padding-top: 0; } }

.hero__catchphrase { position: absolute; top: 306px; left: 0; right: 0; margin: 0; padding: 0; font-size: 1em; line-height: 1; text-align: center; z-index: 1; }
.hero__catchphrase img { width: 291px; }
@media only screen and (min-width: 756px) { .hero__catchphrase { top: 0; } }
@media only screen and (min-width: 960px) { .hero__catchphrase { position: static; margin-bottom: 75px; }
  .hero__catchphrase img { width: 416px; } }

.ss-soap { width: 104px; height: 225px; background-image: url("../img/ss_soap__mirror--hero@2x.png"); background-repeat: no-repeat; background-position: 0 106px; background-size: 104px auto; }
.ss-soap .img { width: 104px; }
@media only screen and (min-width: 960px) { .ss-soap { width: 160px; height: 318px; background-size: 160px auto; background-position: 0 159px; }
  .ss-soap .img { width: 160px; } }

.ss-foam { width: 88px; height: 352px; background-image: url("../img/ss_foam__mirror--hero@2x.png"); background-repeat: no-repeat; background-position: 10px 226px; background-size: 67.5px auto; }
.ss-foam .img { width: 88px; }
@media only screen and (min-width: 960px) { .ss-foam { width: 135px; height: 690px; background-size: 101px auto; background-position: 15px 345px; }
  .ss-foam .img { width: 135px; } }

.ss-cream { width: 68px; height: 366px; background-image: url("../img/ss_cream__mirror--hero@2x.png?=v220522"); background-repeat: no-repeat; background-position: 1px 216px; background-size: 60px auto; }
.ss-cream .img { width: 62px; }
@media only screen and (min-width: 960px) { .ss-cream { width: 104px; height: 730px; background-size: 92px auto; background-position: 2px 334px; }
  .ss-cream .img { width: 96px; } }

.ss-lotion { width: 64px; height: 341px; background-image: url("../img/ss_lotion__mirror--hero@2x.png?=v220522"); background-repeat: no-repeat; background-position: 0 198px; background-size: 60px auto; }
.ss-lotion .img { width: 60px; }
@media only screen and (min-width: 960px) { .ss-lotion { width: 98px; height: 654px; background-size: 92px auto; background-position: 0 304px; }
  .ss-lotion .img { width: 92px; } }

.hero__products { position: absolute; top: 0; left: 0; right: 0; width: 300px; margin: 0 auto; }
.hero__products .inner { position: relative; width: 300px; height: 366px; }
@media only screen and (min-width: 960px) { .hero__products .inner { width: 460px; height: 485px; } }
.hero__products .inner .ss-cream { position: absolute; top: 20px; right: 73px; }
@media only screen and (min-width: 960px) { .hero__products .inner .ss-cream { top: 28px; right: 112px; } }
.hero__products .inner .ss-lotion { position: absolute; top: 38px; right: 0; }
@media only screen and (min-width: 960px) { .hero__products .inner .ss-lotion { top: 60px; } }
.hero__products .inner .ss-foam { position: absolute; top: 14px; left: 67px; }
@media only screen and (min-width: 960px) { .hero__products .inner .ss-foam { top: 20px; left: 103px; } }
.hero__products .inner .ss-soap { position: absolute; top: 140px; left: 0px; }
@media only screen and (min-width: 960px) { .hero__products .inner .ss-soap { top: 216px; } }
@media only screen and (min-width: 756px) { .hero__products { position: static; float: left; width: 300px; height: 300px; margin-left: 53px; } }
@media only screen and (min-width: 960px) { .hero__products { width: 460px; height: 485px; margin-left: 0; } }

.hero__body p { font-size: 14px; line-height: 1.6; color: #fff; font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "メイリオ", Meiryo, serif; }
.hero__body .members-only { text-align: center; }
.hero__body .members-only span { display: inline-block; margin-top: 1em; padding: 5px 6px 6px 6px; border: 1px solid #fff; font-family: "游ゴシック", YuGothic, "Droid Sans", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif; font-size: 10px; line-height: 1; }
@media only screen and (max-width: 756px) { .hero__body br { display: none !important; } }
@media only screen and (min-width: 756px) { .hero__body { float: right; width: 353px; }
  .hero__body p { font-size: 12px; text-align: center; } }
@media only screen and (min-width: 960px) { .hero__body { width: 460px; margin-top: 45px; }
  .hero__body p { font-size: 14px; line-height: 2; }
  .hero__body .members-only span { font-size: 12px; } }

.logo-ss { margin: 0 auto 35px auto; padding: 0; width: 52px; font-size: 1em; line-height: 1; }
.logo-ss > img { width: 52px; }
@media only screen and (min-width: 960px) { .logo-ss { width: 80px; }
  .logo-ss > img { width: 80px; } }

.product-section:before, .product-section:after { content: " "; display: table; }
.product-section:after { clear: both; }
@media only screen and (min-width: 756px) { .product-section { width: 736px; margin: 0 auto; } }
@media only screen and (min-width: 960px) { .product-section { width: 960px; } }

.product { position: relative; width: 100%; height: 370px; margin-bottom: 30px; background: -webkit-linear-gradient(90deg, #0a0a0a 0%, #131313 100%); background: linear-gradient(0deg, #0a0a0a 0%, #131313 100%); overflow: hidden; }
@media only screen and (min-width: 756px) { .product { width: 353px; float: left; }
  .product:nth-child(even) { margin-left: 30px; } }
@media only screen and (min-width: 960px) { .product { float: left; width: 460px; height: 460px; margin-bottom: 40px; }
  .product:nth-child(even) { margin-left: 40px; } }

#product-soap.product { height: 300px; }
@media only screen and (min-width: 756px) { #product-soap.product { height: 370px; } }
@media only screen and (min-width: 960px) { #product-soap.product { height: 460px; background: -webkit-linear-gradient(90deg, #131313 0%, #0a0a0a 100%); background: linear-gradient(0deg, #131313 0%, #0a0a0a 100%); } }

@media only screen and (min-width: 960px) { #product-foam.product { background: -webkit-linear-gradient(90deg, #131313 0%, #0a0a0a 100%); background: linear-gradient(0deg, #131313 0%, #0a0a0a 100%); } }

.product-image { position: absolute; left: 0; right: 0; margin: auto; }
.product-image.ss-cream { top: 36px; background-image: url("../img/ss_cream__mirror@2x.png?=v220522"); }
@media only screen and (min-width: 960px) { .product-image.ss-cream { top: 55px; right: 20px; } }
.product-image.ss-lotion { top: 60px; background-image: url("../img/ss_lotion__mirror@2x.png?=v220522"); }
@media only screen and (min-width: 960px) { .product-image.ss-lotion { top: 93px; right: 40px; } }
.product-image.ss-foam { top: 49px; background-image: url("../img/ss_foam__mirror@2x.png"); }
@media only screen and (min-width: 960px) { .product-image.ss-foam { top: 76px; } }
.product-image.ss-soap { top: 98px; background-image: url("../img/ss_soap__mirror@2x.png"); }
@media only screen and (min-width: 960px) { .product-image.ss-soap { top: 151px; } }

.product-category { position: absolute; top: 26px; left: 19px; margin: 0; padding: 0; font-size: 1em; line-height: 1; }
@media only screen and (min-width: 960px) { .product-category { top: 40px; left: 30px; } }
#product-cream .product-category > img { width: 76px; }
@media only screen and (min-width: 960px) { #product-cream .product-category > img { width: 117px; } }
#product-lotion .product-category > img { width: 80px; }
@media only screen and (min-width: 960px) { #product-lotion .product-category > img { width: 122px; } }
#product-foam .product-category > img { width: 65px; }
@media only screen and (min-width: 960px) { #product-foam .product-category > img { width: 99px; } }
#product-soap .product-category > img { width: 58px; }
@media only screen and (min-width: 960px) { #product-soap .product-category > img { width: 89px; } }

.product-info { position: absolute; left: 0; right: 0; bottom: 8px; width: 300px; margin-left: auto; margin-right: auto; color: #fff; text-align: center; }
.product-info h2, .product-info dt, .product-info dd { font-size: 14px; line-height: 1.6; font-weight: normal; margin: 0; padding: 0; }
.product-info .tax { margin-left: 0.6em; font-size: 10px; }
.product-info h2 br { display: none; }
@media only screen and (min-width: 756px) { .product-info h2, .product-info dt, .product-info dd { font-size: 12px; } }
@media only screen and (min-width: 960px) { .product-info { left: auto; right: 30px; bottom: 0; text-align: right; margin-bottom: 2em; }
  .product-info h2 br { display: block; } }

.product-info__name, .product-info__amount, .product-info__price { display: none !important; }

@media only screen and (max-width: 960px) { .product-info__name-item, .product-info__name-item h2, .product-info__amount-item { display: inline; }
  .product-info__price-item { display: block; }
  .product-info__name-item:after { content: "/"; margin-left: .6em; margin-right: .3em; } }
#site-footer { clear: both; height: 90px; text-align: center; z-index: -2; }
#site-footer .copyright > img { width: 197px; }
@media only screen and (min-width: 960px) { #site-footer { height: 120px; }
  #site-footer .copyright > img { width: 248px; } }

/* ========================================================================== Helper classes ========================================================================== */
/* Hide from both screenreaders and browsers */
.is-hidden { display: none !important; }

/* Hide only visually, but have it available for screen readers */
.is-visually-hidden { position: absolute; width: 1px; height: 1px; margin: -1px; padding: 0; overflow: hidden; clip: rect(0 0 0 0); border: 0; }
.is-visually-hidden.focusable:active, .is-visually-hidden.focusable:focus { position: static; width: auto; height: auto; margin: 0; overflow: visible; clip: auto; }

/* Hide visually and from screen readers, but maintain layout */
.is-invisible { visibility: hidden; }

/* clearfix */
.cf:before, .cf:after, .clearfix:before, .clearfix:after, .group:before, .group:after { content: " "; display: table; }
.cf:after, .clearfix:after, .group:after { clear: both; }
