@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: 959px) {
      #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: -30px;
    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;
    padding-top: 61px;
    padding-bottom: 15px; }
    #header nav li.has-child ul::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 nav li.has-child ul.has-child_sugu::before {
      background-image: url("../img/header/suguaru-logo.png");
      width: 80px;
      height: 40px;
      right: 55px;
      top: 25px; }
    #header nav li.has-child ul.has-child_photo::before {
      background-image: url("../img/header/photobook-logo.png");
      width: 95px;
      height: 40px;
      right: 39px;
      top: 20px; }
    #header nav li.has-child ul.has-child_light::before {
      background-image: url("../img/header/lightbook-logo.png");
      width: 70px;
      height: 60px; }
    #header nav li.has-child ul.has-child_plus::before {
      background-image: url("../img/header/lightbookplus-logo.png");
      width: 70px;
      height: 60px; }
    #header nav li.has-child ul.has-child_plus::before {
      background-image: url("../img/header/lightbookplus-logo.png");
      width: 70px;
      height: 60px; }
    #header nav li.has-child ul.has-child_zine::before {
      background-image: url("../img/header/photozine-logo.png");
      width: 80px;
      top: 20px; }
  #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_photo {
    left: -25px !important; }
  #header .has-child_light {
    left: -20px !important; }
  #header .has-child_plus {
    width: 220px !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: 959px) {
    #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(../img/header/suguaru-logo.png);
    top: 14px;
    left: -5px; }
  #header .spnav-section_photo::before {
    width: 80px;
    height: 50px;
    left: -3px;
    top: 9px;
    background-image: url("../img/header/photobook-logo.png"); }
  #header .spnav-section_light::before {
    width: 50px;
    height: 50px;
    top: 10px;
    background-image: url("../img/header/lightbook-logo.png"); }
  #header .spnav-section_plus::before {
    width: 50px;
    height: 50px;
    top: 10px;
    background-image: url("../img/header/lightbookplus-logo.png"); }
  #header .spnav-section_zine::before {
    width: 80px;
    height: 20px;
    top: 6px;
    background-image: url("../img/header/photozine-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: 959px) {
    #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 {
  margin: 0 calc(50% - 50vw);
  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;
  background-color: var(--color-bg-lighter); }

footer .icon_link {
  width: 12px;
  height: auto; }

footer a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  color: #222;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 0 3px; }

footer a:hover {
  opacity: 0.6;
  -webkit-transition: .3s;
  transition: .3s; }

/* サイトマップ */
.footer_wrap {
  width: 90%;
  max-width: 1000px;
  margin: auto;
  padding: 48px 0;
  font-size: 100%; }
  @media screen and (max-width: 768px) {
    .footer_wrap {
      padding: 25px 0px;
      position: relative; } }
  @media screen and (max-width: 768px) {
    .footer_wrap::after {
      border-bottom: solid 10px #f3f3f3;
      content: "";
      display: block;
      width: 100vw;
      left: 50%;
      -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
      transform: translateX(-50%);
      position: absolute;
      bottom: 0px; } }

.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_inner_top {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 2%; }
  @media screen and (max-width: 768px) {
    .footer_inner_top {
      -webkit-box-orient: vertical;
      -webkit-box-direction: normal;
      -ms-flex-direction: column;
      flex-direction: column;
      gap: 15px 0px;
      -webkit-box-align: center;
      -ms-flex-align: center;
      align-items: center; } }

.footer_inner_top > ul {
  width: 25%; }
  @media screen and (max-width: 768px) {
    .footer_inner_top > ul {
      width: auto; } }

.footer_inner_top > ul > li {
  margin-bottom: 12px; }

.f_menu_header_en {
  display: block;
  font-size: 60%;
  color: var(--color-silver);
  margin-bottom: -3px;
  font-weight: 700;
  width: 100%; }

.f_menu_header {
  font-weight: 500; }

.f_category_wrap li ul,
.f_brand_wrap li ul {
  margin-top: 8px;
  margin-left: 6px;
  font-weight: 400; }

.f_category_wrap li ul li,
.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: 80%;
  position: relative; }

.f_category_wrap li ul li:before,
.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; }

.f_category_wrap li ul li a,
.f_brand_wrap li ul li a {
  width: 100%; }

.footer_inner_top > ul:nth-child(3) .f_menu_header {
  font-size: 90%; }

.payment {
  margin-top: 24px;
  width: 200%;
  font-weight: 400;
  font-size: 90%; }

.payment span {
  position: relative; }

.payment span::after {
  border-bottom: 3px dotted #fff;
  content: '';
  width: 220px;
  height: 2px;
  display: inline-block;
  position: absolute;
  bottom: -12px;
  left: calc(50% - 45px); }

.payment p {
  font-size: 80%;
  line-height: 1.8;
  margin-left: 2px;
  margin-top: 12px;
  width: 50%; }

.payment_wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap; }

.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; }

.rakuten {
  width: 85%;
  height: auto; }

/* .paypay {
  width: 18%;
} */
.f_store_wrap {
  width: 18%;
  font-weight: 400;
  font-size: 90%; }

.f_store_wrap div li {
  margin-bottom: 8px; }

/* 運営  */
.footer_inner_bottom {
  background-color: #f3fdff;
  padding: 16px 0 0;
  font-weight: 400;
  font-size: 90%; }
  @media screen and (max-width: 768px) {
    .footer_inner_bottom {
      background: #fff; } }

.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; }
  @media screen and (max-width: 959px) {
    .f_company_wrap {
      -ms-flex-wrap: wrap;
      flex-wrap: wrap;
      text-align: center;
      -webkit-box-pack: center;
      -ms-flex-pack: center;
      justify-content: center;
      gap: 0px;
      padding: 10px 0px; } }

.f_company_wrap > ul {
  width: 25%;
  margin-top: auto;
  padding: 24px 0 16px;
  font-size: 12px; }
  @media screen and (max-width: 768px) {
    .f_company_wrap > ul {
      padding: 0px; } }

@media screen and (max-width: 959px) {
  .f_company_wrap ul:first-child {
    width: 100%;
    max-width: 100%; } }

@media screen and (max-width: 768px) {
  .f_company_wrap ul:first-child {
    margin-bottom: 15px; } }

@media screen and (max-width: 959px) {
  .f_company_wrap ul:first-child a {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center; } }

.f_company_wrap ul:first-child li img {
  width: 70%;
  margin: 0px -10px -10px; }
  @media screen and (max-width: 959px) {
    .f_company_wrap ul:first-child li img {
      width: 59%; } }

.f_company_wrap ul:nth-child(2) {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 15%; }
  @media screen and (max-width: 959px) {
    .f_company_wrap ul:nth-child(2) {
      width: 50%; } }
  @media screen and (max-width: 768px) {
    .f_company_wrap ul:nth-child(2) {
      -webkit-box-pack: center;
      -ms-flex-pack: center;
      justify-content: center;
      gap: 0px;
      width: 100%;
      max-width: 100%;
      margin-bottom: 10px; } }
  @media screen and (max-width: 768px) {
    .f_company_wrap ul:nth-child(2) li {
      border-left: solid 1px rgba(34, 34, 34, 0.4);
      -webkit-box-sizing: border-box;
      box-sizing: border-box;
      padding: 0px 1em; } }
  @media screen and (max-width: 768px) {
    .f_company_wrap ul:nth-child(2) li:last-child {
      border-right: solid 1px rgba(34, 34, 34, 0.4); } }

.f_company_wrap > ul:nth-child(3) {
  width: 40%;
  text-align: end;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end; }
  @media screen and (max-width: 959px) {
    .f_company_wrap > ul:nth-child(3) {
      width: 50%; } }
  @media screen and (max-width: 768px) {
    .f_company_wrap > ul:nth-child(3) {
      -webkit-box-pack: center;
      -ms-flex-pack: center;
      justify-content: center;
      width: 100%;
      max-width: 100%; } }

.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%; }

.sns_wrap img {
  width: 30px;
  height: auto; }

small {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-size: 10px;
  padding: 12px 0;
  width: 90%;
  max-width: 1000px;
  margin: auto; }
  @media screen and (max-width: 768px) {
    small {
      background: #fff;
      width: 100%;
      max-width: 100%;
      -webkit-box-pack: center;
      -ms-flex-pack: center;
      justify-content: center; } }

/*------------------- SP ------------------ */
