@charset "UTF-8";
/* CSS Document */
:root {
  --easing: cubic-bezier(0.2, 1, 0.2, 1);
  --transition: 0.8s var(--easing);
  --box-shadow2: 0.8rem 0.8rem 1.2rem rgba(0, 0, 0, 0.05), -0.8rem -0.8rem 1.2rem #fff;
  --box-shadow3: 0rem 0.2rem 0.3rem rgba(133, 133, 133, 0.05);
  --color-text: #47474b;
  --color-text-accent: #00aaca;
  --color-bg: #c5edf1;
  --color-bg-lighter: #d6f5f9;
  --color-bg-transparent: #e8ffff;
  --color-bg-brands: #5cd0e0;
  --color-bg-footer: #ddfaf9;
  --color-accent: #5cd0e0;
  --color-icon-on2: #bf8ec8;
  --color-store: #fd3d85;
  --color-white: #ffffff;
  --color-gray: #63636d;
  --color-silver: #627186;
  --color-icon-off: #E6E0D1;
  --color-shop: #E189D6;
  --margin40: 40px;
  --margin8: 8px;
  --margin24: 24px;
  --color-pink-lighter: #f6e9f8;
  --color-blue: #93a6cb;
  --color-sugu: #dbf0f6;
  --color-photo: #E2EFEF;
  --color-lightbook: #F2F3DB;
  --color-lightbookplus: #ffb281; }

.nav_reset {
  /*! destyle.css v3.0.2 | MIT License | https://github.com/nicolas-cusan/destyle.css */
  /* Reset box-model and set borders */
  /* ============================================ */
  /* Document */
  /* ============================================ */
  /**
  * 1. Correct the line height in all browsers.
  * 2. Prevent adjustments of font size after orientation changes in iOS.
  * 3. Remove gray overlay on links for iOS.
  */
  line-height: 1.15;
  /* 1 */
  -webkit-text-size-adjust: 100%;
  /* 2 */
  -webkit-tap-highlight-color: transparent;
  /* 3*/
  /* Sections */
  /* ============================================ */
  /**
  * Remove the margin in all browsers.
  */
  /**
  * Render the `main` element consistently in IE.
  */
  /* Vertical rhythm */
  /* ============================================ */
  /* Headings */
  /* ============================================ */
  /* Lists (enumeration) */
  /* ============================================ */
  /* Lists (definition) */
  /* ============================================ */
  /* Grouping content */
  /* ============================================ */
  /**
  * 1. Add the correct box sizing in Firefox.
  * 2. Show the overflow in Edge and IE.
  */
  /**
  * 1. Correct the inheritance and scaling of font size in all browsers.
  * 2. Correct the odd `em` font sizing in all browsers.
  */
  /* Text-level semantics */
  /* ============================================ */
  /**
  * Remove the gray background on active links in IE 10.
  */
  /**
  * 1. Remove the bottom border in Chrome 57-
  * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
  */
  /**
  * Add the correct font weight in Chrome, Edge, and Safari.
  */
  /**
  * 1. Correct the inheritance and scaling of font size in all browsers.
  * 2. Correct the odd `em` font sizing in all browsers.
  */
  /**
  * Add the correct font size in all browsers.
  */
  /**
  * Prevent `sub` and `sup` elements from affecting the line height in
  * all browsers.
  */
  /* Replaced content */
  /* ============================================ */
  /**
  * Prevent vertical alignment issues.
  */
  /* Forms */
  /* ============================================ */
  /**
  * Reset form fields to make them styleable.
  * 1. Make form elements stylable across systems iOS especially.
  * 2. Inherit text-transform from parent.
  */
  /**
  * Reset radio and checkbox appearance to preserve their look in iOS.
  */
  /**
  * Correct cursors for clickable elements.
  */
  /**
  * Improve outlines for Firefox and unify style with input elements & buttons.
  */
  /**
  * Remove padding
  */
  /**
  * Reset to invisible
  */
  /**
  * Add the correct vertical alignment in Chrome, Firefox, and Opera.
  */
  /**
  * Remove the default vertical scrollbar in IE 10+.
  */
  /**
  * Correct the cursor style of increment and decrement buttons in Chrome.
  */
  /**
  * 1. Correct the outline style in Safari.
  */
  /**
  * Remove the inner padding in Chrome and Safari on macOS.
  */
  /**
  * 1. Correct the inability to style clickable types in iOS and Safari.
  * 2. Fix font inheritance.
  */
  /**
  * Clickable labels
  */
  /* Interactive */
  /* ============================================ */
  /*
  * Add the correct display in Edge, IE 10+, and Firefox.
  */
  /*
  * Add the correct display in all browsers.
  */
  /*
  * Remove outline for editable content.
  */
  /* Tables */
  /* ============================================ */
  /**
  1. Correct table border color inheritance in all Chrome and Safari.
  */ }
  .nav_reset *,
  .nav_reset ::before,
  .nav_reset ::after {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    border-style: solid;
    border-width: 0; }
  .nav_reset p,
  .nav_reset table,
  .nav_reset blockquote,
  .nav_reset address,
  .nav_reset pre,
  .nav_reset iframe,
  .nav_reset form,
  .nav_reset figure,
  .nav_reset dl {
    margin: 0; }
  .nav_reset h1,
  .nav_reset h2,
  .nav_reset h3,
  .nav_reset h4,
  .nav_reset h5,
  .nav_reset h6 {
    font-size: inherit;
    font-weight: inherit;
    margin: 0; }
  .nav_reset ul,
  .nav_reset ol {
    margin: 0;
    padding: 0;
    list-style: none; }
  .nav_reset dt {
    font-weight: bold; }
  .nav_reset dd {
    margin-left: 0; }
  .nav_reset hr {
    -webkit-box-sizing: content-box;
    box-sizing: content-box;
    /* 1 */
    height: 0;
    /* 1 */
    overflow: visible;
    /* 2 */
    border-top-width: 1px;
    margin: 0;
    clear: both;
    color: inherit; }
  .nav_reset pre {
    font-family: monospace, monospace;
    /* 1 */
    font-size: inherit;
    /* 2 */ }
  .nav_reset address {
    font-style: inherit; }
  .nav_reset a {
    background-color: transparent;
    text-decoration: none;
    color: inherit; }
  .nav_reset abbr[title] {
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted;
    /* 2 */ }
  .nav_reset b,
  .nav_reset strong {
    font-weight: bolder; }
  .nav_reset code,
  .nav_reset kbd,
  .nav_reset samp {
    font-family: monospace, monospace;
    /* 1 */
    font-size: inherit;
    /* 2 */ }
  .nav_reset small {
    font-size: 80%; }
  .nav_reset sub,
  .nav_reset sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline; }
  .nav_reset sub {
    bottom: -0.25em; }
  .nav_reset sup {
    top: -0.5em; }
  .nav_reset svg,
  .nav_reset img,
  .nav_reset embed,
  .nav_reset object,
  .nav_reset iframe {
    vertical-align: bottom; }
  .nav_reset button,
  .nav_reset input,
  .nav_reset optgroup,
  .nav_reset select,
  .nav_reset textarea {
    -webkit-appearance: none;
    /* 1 */
    -moz-appearance: none;
    appearance: none;
    vertical-align: middle;
    color: inherit;
    font: inherit;
    background: transparent;
    padding: 0;
    margin: 0;
    border-radius: 0;
    text-align: inherit;
    text-transform: inherit;
    /* 2 */ }
  .nav_reset [type="checkbox"] {
    -webkit-appearance: checkbox;
    -moz-appearance: checkbox;
    appearance: checkbox; }
  .nav_reset [type="radio"] {
    -webkit-appearance: radio;
    -moz-appearance: radio;
    appearance: radio; }
  .nav_reset button,
  .nav_reset [type="button"],
  .nav_reset [type="reset"],
  .nav_reset [type="submit"] {
    cursor: pointer; }
  .nav_reset button:disabled,
  .nav_reset [type="button"]:disabled,
  .nav_reset [type="reset"]:disabled,
  .nav_reset [type="submit"]:disabled {
    cursor: default; }
  .nav_reset :-moz-focusring {
    outline: auto; }
  .nav_reset select:disabled {
    opacity: inherit; }
  .nav_reset option {
    padding: 0; }
  .nav_reset fieldset {
    margin: 0;
    padding: 0;
    min-width: 0; }
  .nav_reset legend {
    padding: 0; }
  .nav_reset progress {
    vertical-align: baseline; }
  .nav_reset textarea {
    overflow: auto; }
  .nav_reset [type="number"]::-webkit-inner-spin-button,
  .nav_reset [type="number"]::-webkit-outer-spin-button {
    height: auto; }
  .nav_reset [type="search"] {
    outline-offset: -2px;
    /* 1 */ }
  .nav_reset [type="search"]::-webkit-search-decoration {
    -webkit-appearance: none; }
  .nav_reset ::-webkit-file-upload-button {
    -webkit-appearance: button;
    /* 1 */
    font: inherit;
    /* 2 */ }
  .nav_reset label[for] {
    cursor: pointer; }
  .nav_reset details {
    display: block; }
  .nav_reset summary {
    display: list-item; }
  .nav_reset [contenteditable]:focus {
    outline: auto; }
  .nav_reset table {
    border-color: inherit;
    /* 1 */
    border-collapse: collapse; }
  .nav_reset caption {
    text-align: left; }
  .nav_reset td,
  .nav_reset th {
    vertical-align: top;
    padding: 0; }
  .nav_reset th {
    text-align: left;
    /*font-weight: bold;/*/ }

/*------------------------------------
header
-------------------------------------*/
#header {
  font-size: 62.5%;
  background-color: #FFF;
  font-family: 'Quicksand', 'Arial', 'Noto Sans JP', "游ゴシック", "Yu Gothic", sans-serif;
  /*------------------------------------
  SPメニュー
  -------------------------------------*/ }
  #header + * {
    padding-top: 70px; }
    @media screen and (max-width: 768px) {
      #header + * {
        padding-top: 0px;
        margin-top: -60px; } }
  #header .nav-container {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: right;
    -ms-flex-pack: right;
    justify-content: right;
    position: fixed;
    width: 100%;
    z-index: 999;
    background-color: #fff;
    border-bottom: solid 0.1px #efefef;
    height: 70px; }
  #header .shop-search {
    color: #fff;
    font-size: 1.6rem; }
  #header .shop-search_box {
    background-color: var(--color-store);
    padding: 15px 10px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    margin-left: 20px; }
  #header .has-child_sugu li img {
    display: block;
    width: 60px;
    height: 50px;
    -o-object-fit: contain;
    object-fit: contain;
    margin: 0 auto; }
  #header nav ul li a img {
    width: 60px;
    height: 60px;
    -o-object-fit: contain;
    object-fit: contain;
    margin: 0 auto 5px;
    display: block; }
  #header nav ul li a img:first-child {
    height: 30px; }
  #header nav h1 {
    display: block;
    font-size: 24px;
    margin-bottom: 25px;
    color: #C5A35A;
    font-weight: bold;
    z-index: 99999; }
  #header nav h1 img {
    display: block;
    width: 180px;
    position: relative;
    top: 16px;
    padding: 5px 5px 5px 30px; }
  #header .pc-navbox {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    position: fixed;
    z-index: 99999; }
  #header nav {
    background: #fff;
    text-align: center;
    position: relative; }
  #header nav ul {
    list-style: none;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center; }
  #header nav ul ul {
    display: block; }
  #header nav ul li {
    position: relative; }
  #header nav ul li a {
    display: block;
    text-decoration: none;
    color: var(--color-text);
    padding: 27px 25px 6px;
    -webkit-transition: all .3s;
    transition: all .3s;
    font-size: 1.4rem !important;
    font-weight: 500; }
  #header nav ul li li a {
    padding: 3px 35px; }
  #header nav ul li a:hover {
    color: var(--color-store); }
  #header nav ul li.has-child::before {
    content: '';
    position: absolute;
    right: 5px;
    bottom: 31px;
    width: 6px;
    height: 6px;
    border-top: 2px solid var(--color-store);
    border-right: 2px solid var(--color-store);
    -webkit-transform: rotate(135deg);
    -ms-transform: rotate(135deg);
    transform: rotate(135deg); }
  #header nav li.has-child ul {
    position: absolute;
    left: 0px;
    top: 63px;
    z-index: 4;
    background: white;
    border: solid 3px #E6E0D1;
    -webkit-box-shadow: 6px 6px 6px 0px rgba(0, 0, 0, 0.3);
    box-shadow: 6px 6px 6px 0px rgba(0, 0, 0, 0.3);
    width: 180px;
    visibility: hidden;
    opacity: 0;
    -webkit-transition: all .8s;
    transition: all .8s; }
  #header nav li.has-child ul::after {
    content: "";
    display: inline-block;
    position: absolute;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0 20px 20px 20px;
    border-color: transparent transparent #E6E0D1 transparent;
    top: -22px;
    left: 50%;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%); }
  #header nav li.has-child {
    text-align: left; }
  #header .has-child_sugu, #header .has-child_photo, #header .has-child_light, #header .has-child_plus,#header .has-child_zine {
    padding-top: 61px;
    position: relative;
    padding-bottom: 15px; }
  #header .has-child_sugu {
    left: -30px !important; }
  #header .has-child_photo {
    left: -30px !important; }
  #header .has-child_light {
    left: -30px !important; }
  #header .has-child_plus {
    left: -30px !important;
    width: 220px !important; }
  #header .has-child_sugu::before, #header .has-child_photo::before, #header .has-child_light::before, #header .has-child_plus::before,#header .has-child_zine::before {
    content: "";
    display: inline-block;
    background-size: contain;
    background-repeat: no-repeat;
    width: 50px;
    height: 40px;
    position: absolute;
    top: 10px;
    left: 50%;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%); }
  #header .has-child_sugu::before {
    background-image: url("../../images/common/header/suguaru-logo.png");
    width: 80px;
    height: 40px;
    right: 55px;
    top: 25px; }
  #header .has-child_photo::before {
    background-image: url("../../images/common/header/photobook-logo.png");
    width: 95px;
    height: 40px;
    right: 39px;
    top: 20px; }
  #header .has-child_light::before {
    background-image: url("../../images/common/header/lightbook-logo.png");
    width: 70px;
    height: 60px; }
  #header .has-child_plus::before {
    background-image: url("../../images/common/header/lightbookplus-logo.png");
    width: 70px;
    height: 60px; }
  #header .has-child_zine::before {
    background-image: url("../../images/common/header/photozine-logo.png");
    width: 95px;
    height: 60px;
    top: 20px; }
  #header .has-child_photo {
    left: -25px !important; }
  #header .has-child_light {
    left: -20px !important; }
  #header nav li.has-child:hover > ul,
  #header nav li.has-child ul li:hover > ul,
  #header nav li.has-child:active > ul,
  #header nav li.has-child ul li:active > ul {
    visibility: visible;
    opacity: 1; }
  #header nav li.has-child ul li a {
    color: var(--color-text);
    border-bottom: dotted 1px rgba(255, 255, 255, 0.6);
    padding-left: 50px;
    white-space: nowrap; }
  #header .arrow_s {
    position: relative;
    display: inline-block;
    padding-left: 12px;
    color: var(--color-text);
    text-decoration: none; }
  #header .arrow_s:before {
    content: '';
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 4px 0 4px 5px;
    border-color: transparent transparent transparent var(--color-text);
    position: absolute;
    top: 50%;
    left: 30px;
    margin-top: -4px; }
  #header nav li.has-child ul li:last-child a {
    border-bottom: none; }
  #header nav li.has-child ul li a:hover,
  #header nav li.has-child ul li a:active, #header .arrow_s:hover {
    color: var(--color-store); }
  #header .arrow_s:before:hover {
    border-color: transparent transparent transparent var(--color-store); }
  #header .nav_en {
    display: block;
    font-size: 0.8rem;
    color: #C5A35A;
    margin-top: -3px;
    margin-left: 2px;
    opacity: 0.5; }
  #header .nav_en1 {
    margin-left: 7px; }
  #header .nav_en2 {
    margin-left: 15px; }
  #header .nav_en3 {
    margin-left: 19px; }
  #header .nav_en4 {
    margin-left: 23px; }
  #header nav .now {
    color: var(--color-store) !important; }
  #header nav .now:hover {
    opacity: 0.8 !important; }
  #header #g-nav {
    display: none; }
  #header .sp-logo {
    display: none; }
  @media screen and (max-width: 850px) {
    #header nav ul li a {
      padding: 27px 15px 6px; }
    #header nav ul li.has-child::before {
      right: 1px; } }
  @media screen and (max-width: 768px) {
    #header nav {
      padding: 0; }
    #header nav ul {
      display: block; }
    #header nav ul li.has-child::before {
      left: 20px; }
    #header nav ul ul li.has-child::before {
      -webkit-transform: rotate(135deg);
      -ms-transform: rotate(135deg);
      transform: rotate(135deg);
      left: 20px; }
    #header nav ul li.has-child.active::before {
      -webkit-transform: rotate(-45deg);
      -ms-transform: rotate(-45deg);
      transform: rotate(-45deg); } }
  #header #g-nav {
    background: #fff;
    color: var(--color-text);
    text-align: center;
    display: block;
    position: fixed;
    z-index: 999;
    top: 0;
    right: -120%;
    width: 100%;
    -webkit-transition: all 0.6s;
    transition: all 0.6s; }
  #header #g-nav-list .accordion-area_spnav {
    list-style: none;
    width: 100%;
    max-width: 900px;
    margin: 20% auto; }
  #header #g-nav-list .accordion-area_spnav li {
    margin: 15px 0; }
  #header #g-nav-list .accordion-area_spnav section {
    border-bottom: 1px solid #ccc;
    text-align: left;
    margin: 0 40px; }
  #header #g-nav-list .spnav-section {
    position: relative; }
  #header #g-nav-list .spnav-section::before {
    content: "";
    display: inline-block;
    position: absolute;
    background-repeat: no-repeat;
    background-size: contain; }
  #header .spnav-section_sugu::before {
    width: 65px;
    height: 40px;
    background-image: url(../../images/common/header/suguaru-logo.png);
    top: 14px;
    left: -5px; }
  #header .spnav-section_photo::before {
    width: 80px;
    height: 50px;
    left: -3px;
    top: 9px;
    background-image: url("../../images/common/header/photobook-logo.png"); }
  #header .spnav-section_light::before {
    width: 50px;
    height: 50px;
    top: 10px;
    background-image: url("../../images/common/header/lightbook-logo.png"); }
  #header .spnav-section_plus::before {
    width: 50px;
    height: 50px;
    top: 10px;
    background-image: url("../../images/common/header/lightbookplus-logo.png"); }
  #header #g-nav-list .title_spnav {
    position: relative;
    cursor: pointer;
    font-size: 1.6rem;
    font-weight: normal;
    padding: 10px 15px 10px 110px;
    -webkit-transition: all .5s ease;
    transition: all .5s ease; }
  #header #g-nav-list .box_spnav p a {
    margin-left: 72px;
    display: block;
    text-decoration: none;
    padding: 10px 0px 10px 30px;
    -webkit-transition: all .3s;
    transition: all .3s;
    text-align: left;
    font-weight: 500;
    border-top: dotted 0.5px #AFB0B2;
    position: relative; }
  #header #g-nav-list .box_spnav p a::before {
    content: "";
    display: inline-block;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 4px 0 4px 5px;
    border-color: transparent transparent transparent var(--color-store);
    position: absolute;
    top: 50%;
    left: 10px;
    margin-top: -4px; }
  #header #g-nav-list .title_spnav::before,
  #header #g-nav-list .title_spnav::after {
    position: absolute;
    content: '';
    width: 9px;
    height: 2px;
    background-color: var(--color-store); }
  #header #g-nav-list .title_spnav::before {
    top: 48%;
    right: 15px;
    -webkit-transform: rotate(0deg);
    -ms-transform: rotate(0deg);
    transform: rotate(0deg); }
  #header #g-nav-list .title_spnav::after {
    top: 48%;
    right: 15px;
    -webkit-transform: rotate(90deg);
    -ms-transform: rotate(90deg);
    transform: rotate(90deg); }
  #header #g-nav-list .title_spnav.close::before {
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg); }
  #header #g-nav-list .title_spnav.close::after {
    -webkit-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg); }
  #header #g-nav-list .box_spnav {
    display: none;
    margin: 0 3% 3% 3%;
    padding: 0; }
  #header #g-nav-list .g-nav-shoplink {
    display: inline-block;
    text-decoration: none;
    color: #fff !important;
    padding: 4px 40px !important;
    -webkit-transition: all .3s;
    transition: all .3s;
    text-align: center !important;
    margin-left: 0px !important;
    background-color: var(--color-store);
    border-radius: 20px;
    margin-top: 20px;
    font-size: 1.6rem;
    font-weight: 500; }
  #header #g-nav-list .g-nav-shoplink:hover {
    opacity: 0.7;
    color: #fff !important; }
  @media screen and (max-width: 768px) {
    #header {
      /*========= ボタン===============*/ }
      #header .sp-logo {
        z-index: 1;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        position: relative;
        height: 60px;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center; }
      #header .sp-logo img {
        display: block;
        width: 40%;
        padding: 13px 0px 0px;
        margin: auto; }
      #header #pc-nav {
        display: none; }
      #header #g-nav {
        display: block;
        position: fixed;
        z-index: 999;
        top: 0;
        right: -120%;
        width: 100%;
        height: 100vh;
        background: #fff;
        -webkit-transition: all 0.6s;
        transition: all 0.6s; }
      #header #g-nav.panelactive {
        right: 0; }
      #header #g-nav.panelactive #g-nav-list {
        position: fixed;
        z-index: 999;
        width: 100%;
        height: 100vh;
        overflow: auto;
        -webkit-overflow-scrolling: touch; }
      #header .openbtn {
        position: fixed;
        z-index: 9999;
        top: 10px;
        right: 10px;
        cursor: pointer;
        width: 50px;
        height: 50px; }
      #header .openbtn span {
        display: inline-block;
        -webkit-transition: all .4s;
        transition: all .4s;
        position: absolute;
        left: 14px;
        height: 3px;
        border-radius: 2px;
        background-color: #666;
        width: 45%; }
      #header .openbtn span:nth-of-type(1) {
        top: 15px; }
      #header .openbtn span:nth-of-type(2) {
        top: 23px;
        width: 33%; }
      #header .openbtn span:nth-of-type(3) {
        top: 31px; }
      #header .openbtn.active span:nth-of-type(1) {
        top: 18px;
        left: 18px;
        -webkit-transform: translateY(6px) rotate(-45deg);
        -ms-transform: translateY(6px) rotate(-45deg);
        transform: translateY(6px) rotate(-45deg);
        width: 30%; }
      #header .openbtn.active span:nth-of-type(2) {
        opacity: 0; }
      #header .openbtn.active span:nth-of-type(3) {
        top: 30px;
        left: 18px;
        -webkit-transform: translateY(-6px) rotate(45deg);
        -ms-transform: translateY(-6px) rotate(45deg);
        transform: translateY(-6px) rotate(45deg);
        width: 30%; } }

/*====================================================================
Footer
====================================================================*/
#footer {
  /*------------------- SP ------------------ */
  /*------------------- PC ------------------ */ }
  #footer {
    margin: 0 calc(50% - 50vw);
    font-size: clamp(0.813rem, 0.744rem + 0.34vw, 1rem)!important;
    text-align: left;
    font-family: "Quicksand", "Arial", "Noto Sans JP", "游ゴシック", "Yu Gothic", sans-serif !important;
    line-height: 1.875 !important;
    -webkit-font-feature-settings: "palt" !important;
    font-feature-settings: "palt" !important;
    letter-spacing: 0.05em !important; }
  #footer .icon_link {
    width: 12px;
    height: auto; }
  #footer a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 3px;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center; }
  #footer .footer_inner_bottom {
    background-color: var(--color-bg-transparent); }
  @media (max-width: 768px) {
    #footer {
      /* 共通 footer  */ }
      #footer {
        background: var(--color-white); }
      #footer img {
        max-width: 300px; }
      #footer .footer_wrap {
        display: none; }
      #footer .sp_footer_wrap {
        padding: 48px 0 24px;
        background-color: var(--color-bg-footer);
        text-align: center; }
      #footer .sp_footer_wrap .title_en {
        text-align: center;
        font-size: 280%;
        padding-bottom: 8px;
        margin-top: -24px;
        font-weight: 700;
        color: var(--color-silver); }
      #footer .storewrap {
        padding: 12px 0 24px; }
      #footer .storewrap a {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        gap: 16px;
        width: 65%;
        margin: auto;
        border-radius: 50px;
        padding: 16px 20px;
        background-color: var(--color-store);
        color: var(--color-white); }
      #footer .arrow2::before,
      #footer .arrow2::after {
        left: 70%; }
      #footer .arrow2_in::before {
        width: 24px;
        height: 24px;
        border-radius: 50%;
        background-color: var(--color-white); }
      #footer .arrow2_in::after {
        left: 72.5%;
        width: 8px;
        height: 8px;
        border-top: 2px solid #fd3d85;
        border-right: 2px solid #fd3d85;
        -webkit-transform: rotate(45deg);
        -ms-transform: rotate(45deg);
        transform: rotate(45deg); }
      #footer .sp_footer_bottom {
        width: 70%;
        margin: auto;
        font-size: 85%;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        -webkit-box-pack: space-evenly;
        -ms-flex-pack: space-evenly;
        justify-content: space-evenly;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        gap: 12px;
        padding: 24px 0;
        background-image: linear-gradient(to right, white 2px, transparent 2px);
        background-size: 10px 2px;
        background-repeat: repeat-x; }
      #footer .rakuten_p {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        padding: 24px 0 12px;
        background-image: linear-gradient(to right, white 2px, transparent 2px);
        background-size: 10px 2px;
        background-repeat: repeat-x;
        width: 60%;
        margin: auto; }
      #footer .rakuten_p img {
        width: 80%;
        height: auto;
        margin: auto; }
      #footer .footer_inner_bottom {
        background-color: var(--color-white);
        padding-top: 48px;
        padding-bottom: 6px; }
      #footer .f_company_wrap {
        width: 90%;
        font-size: 70%;
        text-align: center;
        padding: 12px;
        padding-bottom: 6px;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        margin: auto; }
      #footer .f_company_wrap ul {
        padding: 2px 0;
        margin: auto;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center; }
      #footer .f_company_wrap ul:first-child {
        width: 100%; }
      #footer .f_company_wrap ul:first-child a {
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center; }
      #footer .f_company_wrap ul:first-child img {
        width: 70%;
        width: 59%;
        margin: -10px -10px 0px; }
      #footer .f_company_wrap ul:nth-child(2) {
        width: 100%;
        max-width: 100%;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        margin-bottom: 32px; }
        #footer .f_company_wrap ul:nth-child(2) li {
          display: block; }
          #footer .f_company_wrap ul:nth-child(2) li a {
            display: block; }
            #footer .f_company_wrap ul:nth-child(2) li a img {
              width: 160px;
              height: auto; }
      #footer .footer_logo {
        width: 30px;
        height: 30px;
        display: block; }
      #footer .sns_wrap {
        width: 30%;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
        gap: 6px; }
      #footer .sns_wrap img {
        width: 28px;
        height: auto;
        padding: 0 3px; }
      #footer small {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        padding: 32px 4px;
        font-size: 10px;
        background-color: var(--color-bg-footer); } }
  @media (min-width: 769px) {
    #footer {
      /* .paypay {
      width: 18%;
    } */
      /* 共通 footer  */ }
      #footer {
        background-color: var(--color-bg-lighter); }
      #footer .footer_wrap_sp {
        display: none; }
      #footer a {
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        gap: 0 3px; }
      #footer a:hover {
        opacity: 0.6;
        -webkit-transition: .3s;
        transition: .3s; }
      #footer .footer_wrap {
        width: 90%;
        max-width: 1000px;
        margin: auto;
        padding: 48px 0;
        font-size: 100%; }
      #footer .f_brand_wrap > li > ul > li > a {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        gap: 8px;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center; }
      #footer .footer_inner_top {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        gap: 2%; }
      #footer .footer_inner_top > ul {
        width: 25%; }
      #footer .footer_inner_top > ul > li {
        margin-bottom: 12px; }
      #footer .f_menu_header_en {
        display: block;
        font-size: 10px;
        color: var(--color-silver);
        margin-bottom: -3px;
        font-weight: 700;
        width: 100%; }
      #footer .f_menu_header {
        font-weight: 500;
        font-size: 14px; }
      #footer .f_category_wrap li ul,
      #footer .f_brand_wrap li ul {
        margin-top: 8px;
        margin-left: 6px;
        font-weight: 400; }
      #footer .f_category_wrap li ul li,
      #footer .f_brand_wrap li ul li {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        padding-left: 10px;
        margin-top: 6px;
        font-size: 13px;
        position: relative; }
      #footer .f_category_wrap li ul li:before,
      #footer .f_brand_wrap li ul li:before {
        content: '';
        width: 0;
        height: 0;
        border-style: solid;
        border-width: 3px 0 3px 4px;
        border-color: transparent transparent transparent #272343;
        position: absolute;
        top: 50%;
        left: 2px;
        margin-top: -3px; }
      #footer .f_category_wrap li ul li a,
      #footer .f_brand_wrap li ul li a {
        width: 100%; }
      #footer .footer_inner_top > ul:nth-child(3) .f_menu_header {
        font-size: 14px; }
      #footer .payment {
        margin-top: 24px;
        width: 200%;
        font-weight: 400;
        font-size: 90%; }
      #footer .payment span {
        position: relative; }
      #footer .payment span::after {
        border-bottom: 3px dotted #fff;
        content: '';
        width: 220px;
        height: 2px;
        display: inline-block;
        position: absolute;
        bottom: -12px;
        left: calc(50% - 45px); }
      #footer .payment p {
        font-size: 80%;
        line-height: 1.8;
        margin-left: 2px;
        margin-top: 12px;
        width: 50%; }
      #footer .payment_wrap {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: nowrap;
        flex-wrap: nowrap; }
      #footer .rakuten_paypay {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        gap: 8px;
        background-color: var(--color-white);
        width: 50%;
        padding: 0 10px; }
      #footer .rakuten {
        width: 85%;
        height: auto; }
      #footer .f_store_wrap {
        width: 18%;
        font-weight: 400;
        font-size: 90%; }
      #footer .f_store_wrap div li {
        margin-bottom: 8px; }
      #footer .footer_inner_bottom {
        background-color: #f3fdff;
        padding: 16px 0 0;
        font-weight: 400;
        font-size: 90%; }
      #footer .f_company_wrap {
        width: 90%;
        max-width: 1000px;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: start;
        -ms-flex-pack: start;
        justify-content: flex-start;
        gap: 2%;
        margin: auto; }
      #footer .f_company_wrap > ul {
        width: 25%;
        margin-top: auto;
        padding: 24px 0 16px;
        font-size: 12px; }
      #footer .f_company_wrap ul:first-child li img {
        width: 70%;
        margin: 0px -10px -10px; }
      #footer .f_company_wrap ul:nth-child(2) li {
        display: block;
        width: 130px; }
        #footer .f_company_wrap ul:nth-child(2) li a {
          padding-bottom: 10px; }
        #footer .f_company_wrap ul:nth-child(2) li img {
          vertical-align: top; }
      #footer .f_company_wrap > ul:nth-child(3) {
        width: 40%;
        text-align: end;
        -webkit-box-pack: end;
        -ms-flex-pack: end;
        justify-content: flex-end; }
      #footer .sns_wrap {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        gap: 5%; }
      #footer .sns_wrap img {
        width: 30px;
        height: auto;
        padding: 0 3px; }
      #footer small {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        font-size: 10px;
        padding: 12px 0;
        width: 90%;
        max-width: 1000px;
        margin: auto; }
      #footer .sp_footer_wrap {
        display: none; } }
