@charset "utf-8";

/* Suggested order:
 * display
 * list-style
 * position
 * float
 * clear
 * width
 * height
 * margin
 * padding
 * border
 * background
 * color
 * font
 * text-decoration
 * text-align
 * vertical-align
 * white-space
 * other text
 * content
 *
 */

@import url("base.css");
@import url('https://fonts.googleapis.com/css2?family="Noto Serif JP", serif:wght@400;500;600;700;900&display=swap');
@import url('https://use.fontawesome.com/releases/v6.7.2/css/all.css');

/* ==============================================================
SP
============================================================== */


* {
    font-family: "Noto Serif JP", serif;
    font-weight: 400;
}

body {
    font-size: 1.6rem;
    color: #222222;
    background-color: #222222;
}

header {
    position: fixed;
    display: block;
    height: 82px;
    width: 100%;
    top: 0;
    background-color: #222222;
    border-bottom: 1px solid #999999;
    z-index:
}
h1#sitename {
    padding-top: 1%;
    font-size: 1.2rem;
    text-align: center;
    color: #cccccc;
}

main {
    margin-top: 84px;
}
img#logo {
    width: 200px;
}

main ul.sp {}
main ul.sp li {
    display: none;
}
main ul.sp li:first-of-type {
    display: block;

    padding-top: 1.5%;
    padding-bottom: 1.5%;
}
main ul.sp li:first-of-type img {
    width: 95%;
    margin-left: auto;
    margin-right: auto;
    border: 1px solid #cccccc;
}

.inner {
    width: 98%;
}

a {
    text-decoration: underline;
}
a:hover {
    color: #999999;
    text-decoration: none;
}

p.indent {
    text-indent: 1em;
}

.commoncontent {
    padding-top: 5%;
    padding-bottom: 15%;
}


h2#maincol {
  font-size: 1.6rem;
  font-weight: 600;
  color: #333333;
  position: relative;
  text-align: center;
  padding: 1.0% 20%; /* 上下のpaddingを維持し、左右のpaddingを調整 */
}

h2#maincol:before,
h2#maincol:after {
  content: '';
  position: absolute;
  top: 50%;
  width: 15%; /* 線の長さを調整 */
  height: 1px; /* 線の太さを固定値（px）にする */
  background: #333333; /* グラデーションを単色にするか、グラデーションを調整 */
}

h2#maincol:before {
  left: 0;
  /* 左側のグラデーションを調整 */
  background: linear-gradient(to right, transparent, #333333 50%, #333333);
}

h2#maincol:after {
  right: 0;
  /* 右側のグラデーションを調整 */
  background: linear-gradient(to right, #333333, #333333 50%, transparent);
}


.subcol {
    margin-top: 15%;
}
.subcol h2 {
    padding: 2.5%;
    color: #ffffff;
    font-size: 1.6rem;
    background-image: linear-gradient(0deg, #333333 5%, #000000);
    border-top: 5px double #ffffff;
    border-bottom: 5px double #ffffff;
}



#mv {
    background-color: #111111;
    border-bottom: 1px solid #000000;
}
#mv .inner {
    width: 100%;
}
.pc {
    display: none;
}
.sp {
    display: block;
}


main {
    background-color: #f5f5f5;
}

#pankuzu {
    border-bottom: 1px solid #cccccc;
}
#pankuzu p {
    font-size: 1.2rem;
    padding-bottom: 0.5%;
}


.shopinfo956 {
    margin-top: 8%;
}

.shopinfo956 h3 {
    font-size: 2.2rem;
    font-weight: 600;
}

.shopinfo956 img {}

.shopinfo956 table {
    width: 100%;
}
.shopinfo956 table th, td {
    width: 25%;
    padding-top: 1.2%;
    padding-bottom: 1.2%;
    border: 1px solid #cccccc;
    font-size: 1.6rem;
    vertical-align: middle;
    text-align: center;
}
.shopinfo956 table th {
    background-image: linear-gradient(0deg, #333333 5%, #000000);
    color: #f5f5f5;
}
.shopinfo956 table td {}
.shopinfo956 i {
    color: #cccccc
}
.shopinfo956 ul {
    font-size:0;
}
.shopinfo956 ul li {
    width: 19.56%;
    display: inline-block;
    margin-left: 0.55%;
}
 .shopinfo956 ul li:first-child {
    margin-left: 0;
}
.shopinfo956 p {
    padding: 1.2%;
    border-top: 1px dotted #666666;
    border-bottom: 1px dotted #666666;
    background-color: #f1f1f1;
}


.explan {
    width: 90%;
    margin-left: auto;
    margin-right: auto;
}

.explan h3 {
    background-color: #333333;
    padding: 3%;
    text-align: center;
    color: #f5f5f5;
    font-weight: 900;
    border: 2px solid #ffffff;
}
.explan h4 {
    width: 90%;
    margin-left: auto;
    margin-right: auto;
    padding-top: 2%;
    padding-bottom: 2%;
    border-top: 1px solid #999999;
    border-bottom: 1px solid #999999;
    text-align: center;
    font-weight: 600;
}
.explan li.check {
  position: relative;
  padding-left: 15px;
  list-style: none;
  line-height: 200%;
}
.explan li.check:before {
  content: "";
  position: absolute;
  top: 0.8em;
  left: 0;
  -webkit-transform: rotate(50deg);
  -ms-transform: rotate(50deg);
  transform: rotate(50deg);
  width: 5px;
  height: 10px;
  border-right: 3px solid #333;
  border-bottom: 3px solid #333;
}
.explan ol.num li {
  position: relative;
  line-height: 200%;
  list-style-type: decimal;
}

.explan p.notice {
    padding: 3%;
    border: 1px dotted #999999;
    font-size: 1.4rem;
    background-color: #cccccc;

}

.kflinkbanner h3 {
    padding-top: 1.5%;
    padding-bottom: 1.5%;
    border-top: 1px solid #999999;
    border-bottom: 1px solid #999999;
    font-weight: 600;
}

.kflinkbanner #kfban468 {
    width: 100%;
}
.kflinkbanner #kfban320 {
    width: 320px;
}
.kflinkbanner #kfban200 {
    width: 200px;
}
.kflinkbanner #kfban88 {
    width: 88px;
}


footer {
    height: 42%;
    padding-top: 3.6%;
    padding-bottom: 16%;
    border-top: 10px double #ffffff;
    color: #cccccc;
    background-image: linear-gradient(0deg, #222222 1%, #000000);
}

.no-scroll {
   overflow: hidden;
}


#excellentshops ul#excellentshop,
#recommendedshops ul#recommendedshop {
    margin-left: auto;
    margin-right: auto;
    font-size:0;
}
#excellentshops ul#excellentshop li,
#recommendedshops ul#recommendedshop li {
    width: 48.5%;
    display: inline-block;
    margin-top: 1.5%;
    margin-left: 1.5%;
   font-size: 1.6rem;
}
#recommendedshops {
    margin-top: 5%;
}

nav#permanent {
    position: fixed;
    bottom: 0px;
    z-index: 200;
    width: 100%;
    height: 8%;
    padding-top: 3.2%;
    padding-bottom: 1.0%;
    border-top: solid 1px #999999;
    border-bottom: solid 1px #999999;
    background: rgba(0,0,0, 0.5);
}
nav#permanent ul {
    position: relative;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
    font-size:0;
    z-index: 210;
    text-align: center;
}
nav#permanent ul li {
    display: inline-block;
    width: 95%;
    vertical-align: top;
    border: 1px solid #cccccc;
}

nav#pgtop {
    display: block;
    position: fixed;
    width: 48px;
    height: 48px;
    bottom: 12%;
    color: #cccccc;
    text-align: center;
    right: 3%;
    border: 2px solid #cccccc;
    border-radius: 5px;
    z-index: 300;
}
nav#pgtop p {
    font-size: 3.2rem;
}

.aboutdeli {
    border-top: solid 1px #999999;
}
.bgcol-01 {
    display: block;
    height: 100%;
    background-color: #dddddd;
    padding-bottom: 10%;
}


nav#drawer-bg {
    display: block;
    position: absolute;
    width: 48px;
    height: 43px;
    top: 26px;
    right: 4px;
    border: 1px solid #666666;
    border-radius: 2px;
    background-color: #333333;
    z-index: 300;
}
nav#drawer {
    display: block;
    position: absolute;
    width: 35px;
    height: 45px;
    top: 26px;
    right: 11px;
    cursor: pointer;
    z-index: 310;
}
nav#drawer .line {
    display: block;
    position: relative;
    top: 0;
    left: 0;
    width: 35px;
    height: 4px;
    background-color: #999999;
    border-radius: 1px;
}
nav#drawer .line-1 {top: 8px;}
nav#drawer .line-2 {top: 14px;}
nav#drawer .line-3 {top: 20px;}

nav#close {
    display: none;
    position: absolute;
    width: 40px;
    height: 45px;
    margin-right: 65%;
    top: 39%;
    right: 0px;
    cursor: pointer;
    z-index: 295;
}
nav#close .line {
    display: block;
    position: relative;
    top: 0;
    left: 0;
    width: 40px;
    height: 4px;
    border-radius: 1px;
}

nav#close .line-1 {
  top: 20px;
  transform: rotate(45deg);
  background-color: #f5f5f5;
  border-radius: 3px;
}
nav#close .line-2 {
  opacity: 0;
}
nav#close .line-3 {
  top: 12px;
  transform: rotate(135deg);
  background-color: #f5f5f5;
  border-radius: 3px;
}


h2.common {
    padding: 1.0%;
    color: #ffffff;
    font-size: 1.8rem;
    background-image: linear-gradient(0deg, #333333 5%, #000000);
    border-top: 5px double #ffffff;
    border-bottom: 5px double #ffffff;
    text-align: center;
}

#topics {
    width: 100%;
    height: 130px;
    padding: 3%;
    overflow: auto;
    border: 2px ridge #cccccc;
    margin-bottom: 5%;
      background-color: #dddddd;

    color: #222222;
}
#topics::-webkit-scrollbar {
    width: 15px;
}
#topics::-webkit-scrollbar-track {
    background: rgba(98, 80, 46, 0.2);
}
#topics::-webkit-scrollbar-thumb {
    background: #62502e;
}
#topics ul li {
    display: inline-block;
    border-bottom: 1px dotted #666666;
}
#topics h3 em {
    display: inline-block;
    vertical-align: top;
    margin-right: 3%;
    margin-bottom: 1.5%;
    background: rgba(98, 80, 46, 1); /* #62502e */
    padding: 3px 6px;
    border-radius: 2px;
    font-size: 1.4rem;
    font-style: normal;
    font-weight: 600;
    color: rgba(255, 255, 255, 1);
}
#topics h3 {
    display: block;
    margin-bottom: 2%;
    font-size: 1.6rem;
    font-weight: 600;
}
#topics p.update {
    padding: 0;
    font-size: 1.4rem;
    border: none;
    color: #999999;
    text-align: right;
}
#topics .article img {
    display: inline-block;
    max-width: 42%;
    margin-right: 3%;
    margin-bottom: 1.2%;
}
#topics .article p {
    font-size: 1.4rem;
    padding-bottom: 1.8%;
}




p.dspcode {
    font-family: "Noto Serif JP", serif;
    border: 2px ridge #cccccc;
    padding: 1.6%;
    background-color: #eeeeee;

}




table.common {
    width: 100%;
}
table.common th, td {
    padding-top: 1.2%;
    padding-bottom: 1.2%;
    border: 1px solid #cccccc;
    font-size: 1.6rem;
    vertical-align: middle;
    text-align: center;
}
table.common th {
    background-image: linear-gradient(0deg, #333333 5%, #000000);
    color: #f5f5f5;
}
table.common td {}
table.common td.w1 {
    width: 60%;
}
table.common i {
    color: #cccccc
}


ul.common li {
    margin-left: 5%;
    line-height: 180%;
  list-style-type: disc; /* または circle, square など */
}

.commoncontent h3 {
    padding-top: 1.5%;
    padding-bottom: 1.5%;
    border-top: 1px solid #999999;
    border-bottom: 1px solid #999999;
    font-weight: 600;
}


#permanent li {
    visibility: hidden;
}
#permanent li:first-of-type {
    visibility: visible;
}

.shopinfo956 h3 a {
    display: block;
}


/* ==============================================================
PC
============================================================== */
@media all and (min-width: 1166px) {

    body {
        font-size: 1.8rem;
    }

    header {
        height: 112px;
        z-index: 500;

    }
    img#logo {
        width: 300px;
    }
    main {
        margin-top: 112px;
    }
    .inner {
        width: 60.72%;
        margin-left: auto;
        margin-right: auto;
    }

    #mv .inner {
        width: 60.72%;
    }


h1#sitename {
    text-align: right;
}


h2#maincol {
    font-size: 2.2rem;
    font-weight: 600;
    padding-top: 1.0%;
    padding-bottom: 1.0%;
    color: #333333;
}

.pc {
    display: block;
}
.sp {
    display: none;
}

    h1 {}




.shopinfo956 {
    margin-top: 5%;
}

.shopinfo956 h3 {
    font-size: 2.6rem;
}



    .subcol {
        margin-top: 0;
    }
    .subcol h2 {
        padding: 5%;
        color: #ffffff;
        background-image: linear-gradient(0deg, #333333 5%, #000000);
        border-top: 5px double #ffffff;
        border-bottom: 5px double #ffffff;
    }


    #excellentshops ul#excellentshop li,
    #recommendedshops ul#recommendedshop li {
        width: 100%;
        display: block;
        margin: 0;
        margin-top: 5%;
    }

    .explan {
        width: 100%;
    }






    main {
        
    }


.explan h3 {
    padding: 1.5%;
}

    nav#drawer-bg {
        display: none;
    }

    nav#drawer {
        display: none;
    }

    nav#main {
        position: relative;
        display: block;
        width: 100%;
        height: 48px;
        margin: 0;
        border: none;
        border-top: 2px solid #474625;
        border-bottom: 2px solid #474625;
        background-image: url(../images/nav-main-bg.gif);
        background-repeat: repeat-x;
        overflow: hidden;
    }
    nav#main img#sp-nav-logo {
        display: none;
    }
    nav#main ul {
        margin: 0;
        font-size: 0; /* https://qiita.com/BEMU/items/0f500e0306471073ed63 */
        width: 100%;
    }
    nav#main ul li {
        display: inline-block;
        width: 20%;
        height: 48px;
        padding: 0;
        padding-top: 4px;
        text-align: center;
        font-size: 1.7rem;
        font-weight: 600;
        border: none;
        border-left: 1px solid #474625;
        background-image: url(../images/nav-main-item-bg.gif);
        background-repeat: no-repeat;
        text-shadow: 2px 1px 2px #000000;
    }
    nav#main ul li:last-of-type {
        border-right: 1px solid #474625;
    }
    nav#main ul li a {
        display: block;
        height: 48px;
        padding: 0;
        font-weight: 600;
        color: #ffffff;
    }
    nav#main ul li a:hover {}
    nav#main ul li .sf {
        font-size: 1.2rem;
    }
    nav#main ul li.label {
        display: none;
    }
    nav#main p.shop-info {
        display: none;
    }



    nav#bottom {
        width: 50%;
        margin-top: 10%;
        margin-left: auto;
        margin-right: auto;
    }
    nav#bottom ul li {
        font-size: 1.4rem;
    }
    nav#bottom ul li a {
        width: 20%;
        color: #86833d;
    }
    
    nav#bottom ul li:first-of-type,
    nav#bottom ul li:nth-of-type(2),
    nav#bottom ul li:nth-of-type(3),
    nav#bottom ul li:nth-of-type(4),
    nav#bottom ul li:nth-of-type(5)
    {
        width: 468px;

    }
    nav#bottom ul li:first-of-type {
        border: none;
    }

    nav#perm-bottom {
        display: none;
        bottom: 2%;
    }
    nav#perm-bottom ul {
        padding: 0.2%;
    }
    nav#perm-bottom ul li {
        font-size: 1.6rem;
    }
    nav#perm-bottom li .lf {
        display: block;
        padding-top: 0.5%;
        font-weight: 600;
    }


    footer {
        height: 10%;
    }





    p#copyright {
        padding-top: 2%;
        font-size: 1.6rem;
        color: #cccccc;
    }
    
    
    
    
.kflinkbanner #kfban468 {
    width: 468px;
}    

nav#permanent {
    padding-top: 1%;
    height: 11%;
}

#permanent li:first-of-type,
#permanent li:nth-of-type(2) {
    visibility: visible;
}

nav#permanent ul li {
    display: inline-block;
    width: 468px;
    vertical-align: top;
    color: #cccccc;
}
#permanent li:nth-of-type(2) {
    margin-left: 5%;
}

#permanent img {
   max-width : 468px;
}

#topics h3 {
    margin-bottom: 2%;
    font-size: 2.0rem;
    font-weight: 600;
}
#topics h3 em {
    margin-right: 1.5%;
}




.ladiesimages .luminous img {
   max-width : 400px;
}

header ul {}
header ul li {
    visibility: hidden;
}
header ul li:first-of-type {
    visibility: visible;
    padding-top: 0.25%;
    padding-bottom: 0.25%;

}
header ul li:first-of-type img {
    width : 468px;
    margin-left: auto;
    margin-right: 0;
    border: 1px solid #999999;
}

}