@charset "utf-8";


/* --------------------------------------------------------------------------------
タグ
-------------------------------------------------------------------------------- */
html {
	padding: 180px 0 0;
}
body {
	margin: 0;
	padding: 0;
	min-width: 1200px;
	line-height: 1.5;
	text-size-adjust: 100%;
	font-size: 16px;
	font-family: "M PLUS 1", sans-serif;
	font-weight: 400;
	font-style: normal;
	color: #1e1e14;
}

img {
	max-width: 100%;
	height: auto;
	vertical-align: bottom;
}

address {
	font-style: normal;
}


/* --------------------------------------------------------------------------------
	共通
-------------------------------------------------------------------------------- */
.common {
	text-align: left;
	font-size: 14px;
}

.common * {
	margin: 0;
	padding: 0;
	
	font-family: "M PLUS 1", sans-serif;
	font-weight: 400;
	font-style: normal;
}

.common h1,
.common h2,
.common h3,
.common h4,
.common h5,
.common h6 {
	font-size: 1em;
}
.common ol,
.common ul {
	list-style: none;
}
.common table {
	border-collapse: collapse;
	border-spacing: 0;
	font-size: 1em;
}
.common a,
.common a:link,
.common a:visited {
	text-decoration: none;
	color: #1e1e14;
	-webkit-tap-highlight-color: rgba(0,0,0,0.1);
	tap-highlight-color: rgba(0,0,0,0.8);
}
.common a:hover,
.common a:active {
	text-decoration: underline;
}

input,
select,
textarea {
	outline: none !important;
	box-shadow: none !important;
}


/* --------------------------------------------------------------------------------
共通クラス
-------------------------------------------------------------------------------- */
.clear {
	clear:both;
}
br.clear {
	display: block;
	margin: 0;
	padding: 0;
	clear: both;
	height: 0;
	border: none;
	visibility: hidden;
	font-size: 0;
}
.clearfix::after {
	content: ".";
	display: block;
	clear: both;
	height: 0;
	visibility: hidden;
}
.clearfix {
	min-height:1%;
}
* html .clearfix {
	height:1%;
	/*\*//*/
	height:auto;
	overflow:hidden;
	/**/
}


/* ----------------------------------------
★共通文字色
---------------------------------------- */
.color-orange {
	color: #e65000;
}
.color-green {
	color: #87b900;
}
.color-pink {
	color: #e66464;
}
.color-blue {
	color: #6db2b6;
}
.color-gray {
	color: #1e1e14;
}


/* --------------------------------------------------------------------------------
デバイスごとの表示・非表示
-------------------------------------------------------------------------------- */
.device-sp{
	display: none;
}
.device-sp-inline {
	display: none;
}
.device-pc {
	display: block;
}
.device-pc-inline {
	display: inline;
}







/* ----------------------------------------
スライダー共通
---------------------------------------- */
.item-slider-parts {
}

/* 次へ・前へ */
.item-slider-parts .slick-arrow{
	display: block;
	
	position: absolute;
	top: 50%;
	margin: -20px 0 0;
	
	width: 40px;
	height: 40px;
	border:none;
	text-indent: -9999px;
	overflow: hidden;
	z-index: 2;
}
.item-slider-parts .slick-arrow.slick-prev {
	left: 10px;
	background: url("../images/common-2025/slide-arrow-left.svg") no-repeat 0 0;
	background-size: 100% 100%;
	opacity: 0.7;
}
.item-slider-parts .slick-arrow.slick-next {
	right: 10px;
	background: url("../images/common-2025/slide-arrow-right.svg") no-repeat 0 0;
	background-size: 100% 100%;
	opacity: 0.7;
}


/********** スライダーの本体 **********/
.item-slider-parts .slick-list {
	margin: 0 28px;
	font-size: 16px;
}

/* スライダーの各項目 */
.item-slider-parts .slick-list .slick-slide .slide-item {
	margin: 0 12px;
}

/* a */
.item-slider-parts .slick-list .slick-slide .slide-item a {
	position: relative;
	
	display: block;
	text-decoration: none;
}

/* サムネイル */
.item-slider-parts .slick-list .slick-slide .slide-item a .thumb {
	padding: 0 0 10px;
}
.item-slider-parts .slick-list .slick-slide .slide-item a .thumb img {
	display: block;
}

/* 商品名 */
.item-slider-parts .slick-list .slick-slide .slide-item a .item-name {
	padding: 0 0 1px;
}

/* 価格 */
.item-slider-parts .slick-list .slick-slide .slide-item a .price {
	color: #e65000;
}



/* ----------------------------------------
main-contents-inner
---------------------------------------- */
.main-contents-inner {
	width: 1080px;
	margin: 0 auto;
}


/* --------------------------------------------------------------------------------
container
-------------------------------------------------------------------------------- */
#container {
}


/* --------------------------------------------------------------------------------
header
-------------------------------------------------------------------------------- */
#header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 100;
}

/* ----------------------------------------
header-outer
---------------------------------------- */
#header .header-outer {
	background: #f7de66;
}

/* ----------------------------------------
header-inner
---------------------------------------- */
#header .header-inner {
	width: 1080px;
	margin: 0 auto;
}

/* ----------------------------------------
site-catch
---------------------------------------- */
#header .site-catch {
	padding: 7px 0 15px;
	font-size: 12px;
}

/* ----------------------------------------
ヘッダーコンテンツ
---------------------------------------- */
#header .h-contents {
}

#header .h-contents .h-contents-box {
	display: flex;
	justify-content: space-between;
	
	width: 100%;
}

/********** ロゴ **********/
#header .h-logo {
	width: 336px;
	margin: 0 0 0 0;
}
#header .h-logo a {
	display: block;
}
#header .h-logo a img {
	display: block;
}


/* ----------------------------------------
常連さんメニュー & カートボタン
---------------------------------------- */
#header .h-menu-btn-cart {
	display: flex;
	justify-content: space-between;
	
	width: 376px;
}


/********** 常連さんメニュー **********/
#header .h-menu-btn-cart .h-customer-menu {
	width: 276px;
}
#header .h-menu-btn-cart .h-customer-menu .h-customer-menu-box {
	border-radius: 10px;
	padding: 5px 6px;
	background: #faf5dc;
}
#header .h-menu-btn-cart .h-customer-menu .heading {
	padding: 0 0 1px;
	text-align: center;
}
#header .h-menu-btn-cart .h-customer-menu .heading i {
	padding: 0 8px;
	font-size: 15px;
	color: #e65000;
}
#header .h-menu-btn-cart .h-customer-menu ul {
	display: flex;
	justify-content: space-between;
	
	width: 100%;
}
#header .h-menu-btn-cart .h-customer-menu ul li {
	width: 130px;
}
#header .h-menu-btn-cart .h-customer-menu ul li a {
	display: flex;
	align-items: center;
	
	width: 130px;
	height: 36px;
	padding: 0 0 0 44px;
	border-radius: 8px;
	text-decoration: none;
	color: #fff;
}

/* ログイン */
#header .h-menu-btn-cart .h-customer-menu ul li.h-btn-login a {
	background: #6db2b6 url("../images/common-2025/h-icon-login.svg") no-repeat 8px 50%;
}

/* マイページ */
#header .h-menu-btn-cart .h-customer-menu ul li.h-btn-my a {
	background: #e66464 url("../images/common-2025/h-icon-mypage.svg") no-repeat 8px 50%;
}


/********** ショッピングカートボタン **********/
#header .h-menu-btn-cart .h-customer-menu .h-btn-cart {
	width: 70px;
}
#header .h-menu-btn-cart .h-customer-menu .h-btn-cart a {
	display: block;
}
#header .h-menu-btn-cart .h-customer-menu .h-btn-cart a img {
	display: block;
}


/* ----------------------------------------
ナビゲーション
---------------------------------------- */
#header .h-nav {
	background: #e65000;
}
#header .h-nav nav {
	width: 1080px;
	margin: 0 auto;
}
#header .h-nav .h-nav-box {
	display: flex;
	
	width: 100%;
	padding: 6px 0;
}


/* ----------------------------------------
ナビゲーションボタンリスト
---------------------------------------- */
#header .h-nav-list {
	display: flex;
	align-items: center;
	
	width: 690px;
}
#header .h-nav-list .h-nav-list-box {
}
#header .h-nav-list ul {
	display: flex;
	
	color: #fff;
}
#header .h-nav-list ul li {
	margin: 0 25px 0 0;
	font-size: 16px;
	color: #fff;
}
#header .h-nav-list ul li:last-child {
	margin-right: 0;
}
#header .h-nav-list > .h-nav-list-box > ul > li > a {
	display: block;
	color: #fff;
	cursor: pointer;
	padding: 1px 14px 3px 27px;
}

/* トップページ */
#header .h-nav-list ul li.h-nav-list-top a {
	background: url("../images/common-2025/h-navi-home.svg") no-repeat 0 50%;
}

/* 商品一覧 */
#header .h-nav-list ul li.h-nav-list-itemlist {
	position: relative;
	padding-right: 20px;
}
#header .h-nav-list ul li.h-nav-list-itemlist .h-btn-itemlist-open-close {
	padding: 1px 14px 3px 27px;
	background: url("../images/common-2025/h-navi-item.svg") no-repeat 0 50%, url("../images/common-2025/h-navi-arrow.svg") no-repeat calc(100% - 14px) 50%;
	cursor: pointer;
}
/* 商品一覧：メガメニューを開いている時（アクティブ時） */
body.h-mega-active #header .h-nav-list ul li.h-nav-list-itemlist .h-btn-itemlist-open-close {
	background: none;
}
body.h-mega-active #header .h-nav-list ul li.h-nav-list-itemlist .h-btn-itemlist-open-close .h-btn-itemlist-open-close-box {
	position: relative;
	z-index: 2;
	color: #1e1e14;
}
body.h-mega-active #header .h-nav-list ul li.h-nav-list-itemlist .h-btn-itemlist-open-close::after {
	content: '';
	display: block;
	
	position: absolute;
	z-index: 1;
	top: -5px;
	left: -9px;
	
	width: 130px;
	height: 35px;
	border-radius: 10px 10px 0 0;
	background: #faf5dc url("../images/common-2025/h-navi-item-close.svg") no-repeat 9px 50%;
}


/* お支払・送料 */
#header .h-nav-list ul li.h-nav-list-payment a {
	background: url("../images/common-2025/h-navi-payment.svg") no-repeat 0 50%;
}


/* ----------------------------------------
検索
---------------------------------------- */
#header .search {
	width: 390px;
}
#header .search form .search-box {
	display: flex;
	justify-content: space-between;
	width: 100%;
}
#header .search form .search-box input[type="text"] {
	display: flex;
	align-items: center;
	
	width: 320px;
	border-radius: 35px 0 0 35px;
	border: none;
	
	height: 35px;
	padding: 0 20px 0 35px;
	line-height: 1;
	font-size: 13px;
	background: #fff url("../images/common-2025/h-icon-search.svg") no-repeat 15px 50%;
}
#header .search form .search-box input[type="submit"] {
	display: flex;
	align-items: center;
	
	width: 70px;
	height: 35px;
	border-radius: 0 35px 35px 0;
	padding: 0 0 0 18px;
	border: none;
	text-align: left;
	font-size: 15px;
	color: #fff;
	background: #1e1e14;
	
	cursor: pointer;
}


/* ----------------------------------------
メガメニュー
---------------------------------------- */
#header .h-mega {
	position: relative;
	z-index: 999;
	
	width: 1080px;
	margin: 0 auto;
}
#header .h-mega .h-mega-unit {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	
	/* 最初はメニューを非表示に */
	display: none;
}
#header .h-mega .h-mega-wrapper {
	position: relative;
	z-index: 1;
	margin: -7px 0 0;
	padding: 20px 0 10px 30px;
	border-radius: 10px;
	background: #faf5dc;
}

/* タブボタン */
#header .btn-tab ul {
	display: flex;
}
#header .btn-tab ul li {
	width: 340px;
	height: 50px;
	
	margin: 0 19px 0 0;
	padding: 3px 0 0;
	text-align: center;
	font-size: 20px;
	background: url("../images/common-2025/h-btn-bg-frame-off.png") no-repeat 0 0;
	
	cursor: pointer;
}

/* アクティブ（フォーカス時） */
#header .btn-tab ul li.h-mega-active {
	color: #fff;
	background: url("../images/common-2025/h-btn-bg-frame-on.png") no-repeat 0 0;
}

/* ■お菓子の種類 */
#header .btn-tab ul li.h-mega-tab-btn-kind {
	padding-left: 15px;
}



/* h-mega-box */
#header .h-mega .h-mega-box {
	padding: 6px 10px;
}


#header .h-mega .h-mega-list {
	display: flex;
	flex-wrap: wrap;
	
	width: 100%;
}
#header .h-mega .h-mega-list .h-mega-list-box {
	width: 220px;
	margin: 0 40px 10px 0;
}
#header .h-mega .h-mega-list .h-mega-list-box:nth-of-type(4n) {
	margin-right: 0;
}

#header .h-mega .h-mega-list .heading {
	margin: 0 0 16px;
	padding: 0 0 5px;
	border-bottom: solid 1px #e65000;
	font-size: 16px;
	color: #e65000;
}
#header .h-mega .h-mega-list .heading a {
	display: block;
	color: #e65000;
	text-decoration: none;
	background: url("../images/common-2025/menu-arrow.png") no-repeat 100% 50%;
	background-size: 6px 10px;
}
#header .h-mega .h-mega-cat-food .h-mega-list .h-mega-list-box {
	width: 190px;
	margin: 0 25px 10px 0;
}
#header .h-mega .h-mega-cat-cosme .h-mega-list .h-mega-list-box {
	width: 220px;
	margin: 0 60px 10px 0;
}
#header .h-mega .h-mega-cat-food .h-mega-list .h-mega-list-box:nth-of-type(5n) {
	margin-right: 0;
}
#header .h-mega .h-mega-cat-cosme .h-mega-list .h-mega-list-box:nth-of-type(4n) {
	margin-right: 0;
}
#header .h-mega .h-mega-list ul li {
	margin: 0 0 11px;
}
#header .h-mega .h-mega-list ul li a {
	display: block;
	line-height: 1;
	font-size: 14px;
}
/* h-mega-box */
#header .h-mega .tabs .tabs-box {
	display: none;
}
#header .h-mega .tabs .h-tab-active {
	display: block;
}



/* --------------------------------------------------------------------------------
footer
-------------------------------------------------------------------------------- */
#footer {
	padding: 110px 0 0;
	position: relative;
}
#footer::before {
	content: '';
	
	position: absolute;
	
	width: 100%;
	height: 20px;
	margin: -20px 0 0;
	background: url("../images/common-2025/bg-zigzag.svg") repeat-x 0 0;
	background-size: 1920px auto;
}

/********** footer-outer **********/
#footer .footer-outer {
	padding: 50px 0 0;
	background: #fff;
}

/********** footer-inner **********/
#footer .footer-inner {
	width: 1080px;
	margin: 0 auto;
}


/* ----------------------------------------
その他
---------------------------------------- */
#footer .f-menu-contact {
}


#footer .f-menu-contact .btn-contact-list {
	padding: 0 0 0;
}
#footer .f-menu-contact .btn-contact-list ul {
	display: flex;
	justify-content: space-between;
	
	width: 100%;
}
#footer .f-menu-contact .btn-contact-list ul li {
	width: 340px;
	height: 90px;
	margin: 0 0 30px;
}
#footer .f-menu-contact .btn-contact-list ul li a {
	display: block;
	text-decoration: none;
}
#footer .f-menu-contact .btn-contact-list ul li .btn-unit {
	display: block;
	height: 90px;
	padding: 16px 0 0;
	border-radius: 10px;
	line-height: 1;
	color: #fff;
	background: #e65000;
}
#footer .f-menu-contact .btn-contact-list ul li .btn-unit .label {
	display: flex;
	align-items: center;
	
	min-height: 35px;
	margin: 0 0 6px;
	padding: 0 0 0 77px;
	font-size: 30px;
	font-weight: 900;
}

/* 電話 */
#footer .f-menu-contact .btn-contact-list ul li.btn-list-tel .label {
	background: url("../images/common-2025/f-icon-tel.svg") no-repeat 37px 50%;
	background-size: 30px auto;
}
/* FAX */
#footer .f-menu-contact .btn-contact-list ul li.btn-list-fax .label {
	background: url("../images/common-2025/f-icon-fax.svg") no-repeat 36px 50%;
	background-size: 30px auto;
}
/* お問合わせフォーム */
#footer .f-menu-contact .btn-contact-list ul li .btn-unit {
	
}
#footer .f-menu-contact .btn-contact-list ul li.btn-list-mail .btn-unit {
	margin: 0 0 7px;
	padding: 15px 0 0;
}
#footer .f-menu-contact .btn-contact-list ul li.btn-list-mail .label {
	padding: 0 0 0 73px;
	background: url("../images/common-2025/f-icon-mail.svg") no-repeat 33px 50%;
	background-size: 30px auto;
	font-size: 26px;
}
#footer .f-menu-contact .btn-contact-list ul li .btn-unit .notes {
	text-align: center;
	font-size: 18px;
}

/********** その他のボタン **********/
#footer .f-menu-contact .list-other {
	padding: 0 0 55px;
}
#footer .f-menu-contact .list-other ul {
	display: flex;
	justify-content: space-between;
	
	width: 100%;
}
#footer .f-menu-contact .list-other ul li {
	width: 525px;
	padding: 0 0 0;
}
#footer .f-menu-contact .list-other ul li a {
	display: flex;
	align-items: center;
	
	height: 60px;
	border-radius: 10vw;
	line-height: 1;
	text-decoration: none;
	font-size: 24px;
	color: #fff;
}
#footer .f-menu-contact .list-other ul li.btn-list-newsletter a {
	padding: 0 0 0 147px;
	background: #87b900 url("../images/common-2025/f-icon-mag.svg") no-repeat 115px 50%;
	background-size: 24px auto;
}
#footer .f-menu-contact .list-other ul li.btn-list-instagram a {
	padding: 0 0 0 98px;
	background: #6db2b6 url("../images/common-2025/f-icon-Instagram.svg") no-repeat 67px 50%;
	background-size: 24px auto;
}






/********** footer-contents **********/
#footer .footer-contents {
}

/********** フッターコンテンツ **********/
#footer .f-cols {
	display: flex;
	
	width: 100%;
	padding: 0 0 31px;
}
#footer .f-cols .col {
	width: 340px;
}
#footer .f-cols .col-1 {
	margin: 0 30px 0 0;
}
#footer .f-cols .col-2 {
	margin: 0 60px 0 0;
}
#footer .f-cols .col-3 {
	width: 310px;
}


/* ----------------------------------------
★.f-cols内 共通
---------------------------------------- */
#footer .f-cols .sheading {
	margin: 0 0 8px;
	padding: 0 0 4px;
	border-bottom: solid 1px #e65000;
	font-size: 15px;
	color: #e65000;
}
#footer .f-cols .txt {
	margin: 0 0 13px;
}
#footer .f-cols .txt.txt-1 {
	margin: 0 0 13px;
}
#footer .f-cols .txt.txt-2 {
	margin: 0 0 9px;
}
#footer .f-cols .btn-details {
}
#footer .f-cols .btn-details a {
	display: inline-block;
	color: #e65000;
}


/* ----------------------------------------
お支払について
---------------------------------------- */
#footer .f-col-payment {
	padding: 0 0 35px;
}
#footer .f-col-payment .icon-credit {
	padding: 0 0 17px;
}


/* ----------------------------------------
配送・送料について
---------------------------------------- */
#footer .f-col-shipping {
}
#footer .f-col-shipping .time-table {
	padding: 12px 0 11px;
}


/* ----------------------------------------
会社概要・その他
うえだがしドットコム
---------------------------------------- */
#footer .f-col-other {
}
#footer .f-col-other .company-heading {
	position: relative;
	margin: -4px 0 7px;
	
	min-height: 61px;
	padding: 11px 0 0 64px;
	background: url("../images/common-2025/f-img-shop.png") no-repeat 5px 0;
	background-size: 51px auto;
}
#footer .f-col-other .company-heading .label-shopname {
	font-size: 18px;
	font-weight: 900;
}
#footer .f-col-other .company-heading .label-company {
	font-size: 14px;
}

/********** txt-att **********/
#footer .f-col-other .txt.txt-1 {
	margin: 0 0 8px;
}
#footer .f-col-other p.txt-att {
	padding: 2px 0 0;
	line-height: 1.35;
	font-size: 13px;
}


/* ----------------------------------------
営業日カレンダー
---------------------------------------- */
#footer .f-col-other .calendar {
	width: 100%;
	padding: 0 0 11px;
}
#footer .f-col-other .calendar .calendar-wrapper {
	display: flex;
	justify-content: space-between;
}
/* カレンダー外枠 */
#footer .f-col-other .calendar .f-calendar-box {
	display: flex;
	justify-content: space-between;
	
	width: 100%;
}
#footer .f-col-other .calendar .calendar-box {
	width: 137px;
	padding: 0 0 5px;
}
/* 営業日カレンダー */
#footer .f-col-other .calendar table {
	width: 100%;
	line-height: 1.25;
	font-size: 12px;
	text-align: center;
	border: 1px solid #f88827;
	border-collapse: collapse;
	color: #000;
	background: #fffdf8;
}
/* 月名 */
#footer .f-col-other .calendar caption {
	padding: 3px;
	text-align: center;
	font-size: 12px;
}
#footer .f-col-other .calendar caption span {
}
/* 曜日 */
#footer .f-col-other .calendar th {
	padding: 3px 0;
	width: calc(100% / 7);
	border: 1px solid #f88827;
	font-weight: 400;
	background: #f0ebef;
}
#footer .f-col-other .calendar th.sunday {
}
#footer .f-col-other .calendar th.saturday {
}
#footer .f-col-other .calendar th span {
}
/* 日付の枠 */
#footer .f-col-other .calendar td {
	padding: 3px 0;
	width: calc(100% / 7);
	border: 1px solid #f88827;
	font-weight: 700;
}
#footer .f-col-other .calendar td.sunday {
}
#footer .f-col-other .calendar td.saturday {
}
#footer .f-col-other .calendar td.close {
	background: #ece7ca;
}



/********** 営業・休業 **********/
#footer .f-col-other .calendar .cal-txt {
	display: flex;
	
	width: 100%;
	font-size: 12px;
}

/* 営業 */
#footer .f-col-other .calendar .mark-day {
	display: flex;
	align-items: center;
	margin: 0 30px 3px 0;
}
#footer .f-col-other .calendar .mark-day::before {
	content: '';
	display: block;
	
	width: 12px;
	height: 16px;
	margin: 0 5px 0 0;
	border: solid 1px #f88827;
}

/* 休業 */
#footer .f-col-other .calendar .mark-close {
	display: flex;
	align-items: center;
}
#footer .f-col-other .calendar .mark-close::before {
	content: '';
	display: block;
	
	width: 12px;
	height: 16px;
	margin: 0 5px 0 0;
	border: solid 1px #f88827;
	background: #ece7ca;
}


/* カレンダーの文言 */
#footer .f-col-other .calendar .txt-close {
	font-size: 12px;
}


/********** バナー **********/
#footer .bnrs {
	padding: 0 0 11px;
}
#footer .bnrs ul li {
	padding: 0 0 5px;
}
#footer .bnrs ul li a {
	display: block;
	width: 180px;
}
#footer .bnrs ul li img {
	display: block;
	height: auto;
}


/********** リンクリスト **********/
#footer .link-list {
	padding: 0 0 10px;
}
#footer .link-list ul li {
	padding: 0 0 3px;
	line-height: 1.2;
}
#footer .link-list ul li a {
	display: block;
	padding: 1px 0 1px 11px;
	font-size: 14px;
	background: url("../images/common-2025/menu-arrow.svg") no-repeat 0 5px;
	background-size: 6px auto;
}


/********** PAGE TOP **********/
#footer .f-btn-pagetop {
	position: fixed;
	z-index: 100;
	right: 20px;
	bottom: 10px;
	
	padding: 0 0 5px;
}
#footer .f-btn-pagetop a {
	display: block;
}
#footer .f-btn-pagetop img {
	display: block;
	width: 94px;
	height: auto;
}




/********** コピーライト **********/
#footer .copyright {
	padding: 0 0 12px;
	text-align: center;
}
#footer .copyright small {
	font-size: 12px;
}





