/* Base palette and shared layout */
:root{
  --bg:#ebe7de;
  --paper:#f8f5ef;
  --card:#fffdf9;
  --line:#ddd3c8;
  --text:#4d4036;
  --muted:#857669;
  --brown:#5b4733;
  --brown-dark:#453425;
  --accent:#8d2e27;
  --accent-soft:#d9b99e;
  --gold:#d8b47a;
  --shadow:0 1px 0 rgba(0,0,0,.03),0 8px 24px rgba(65,43,20,.06);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:"Hiragino Kaku Gothic ProN","Yu Gothic",Meiryo,"Microsoft YaHei","PingFang SC",Arial,sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.7;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button,input{font:inherit}

body::before,
body::after{
  content:"";
  position:fixed;
  width:128px;
  height:128px;
  border-radius:50%;
  background:radial-gradient(circle at 35% 35%, rgba(202,183,171,.33), rgba(202,183,171,.18) 66%, transparent 67%);
  z-index:0;
  pointer-events:none;
}
body::before{left:96px;top:88px}
body::after{right:88px;top:360px}

.page{position:relative;z-index:1}
.container{width:1000px;max-width:calc(100% - 32px);margin:0 auto}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* Header */
.topline{height:18px;background:#4f321e}
.mini-top{padding:8px 0 2px;font-size:11px;color:#695d54}
.mini-top .container,
.header-row,
.main-nav .container,
.utility-row,
.footer-links{
  display:flex;
  align-items:center;
}
.mini-top .container{justify-content:space-between;gap:16px}
.mini-top .right-side{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.right-links a{margin-left:12px;color:#77695d}
.right-links a:first-child{margin-left:0}

.lang-switcher{display:flex;align-items:center;gap:6px}
.lang-btn{
  border:1px solid #cabaa9;
  background:#fff8ef;
  color:#6c5e52;
  padding:4px 10px;
  border-radius:999px;
  cursor:pointer;
  font-size:11px;
  transition:.18s ease;
}
.lang-btn:hover{background:#f3ebdf}
.lang-btn.active{
  background:var(--accent);
  border-color:var(--accent);
  color:#fff;
  box-shadow:0 2px 8px rgba(141,46,39,.18);
}

.header{padding:4px 0 0}
.header-row{justify-content:space-between;align-items:flex-start;gap:24px}
.brand{display:flex;align-items:flex-start;gap:16px;padding-top:4px}
.logo-block{min-width:220px}
.logo-small{font-size:11px;color:#817568;letter-spacing:.08em}
.logo-main{font-size:44px;line-height:1;font-weight:700;letter-spacing:.08em;color:#25170f;margin-top:4px}
.logo-note{font-size:11px;color:#988d83;margin-top:8px}

.search-area{display:flex;align-items:center;gap:8px;padding-top:8px;flex-wrap:wrap}
.search-label{font-size:12px;color:#6f6257}
.search-area input{
  width:170px;
  height:30px;
  border:1px solid #c6b8a6;
  background:#fff;
  padding:0 10px;
  border-radius:2px;
}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:30px;
  padding:0 16px;
  border-radius:3px;
  border:1px solid rgba(0,0,0,.12);
  font-size:12px;
  white-space:nowrap;
}
.btn.red{background:#9b392f;color:#fff}
.btn.brown{background:#6a503a;color:#fff}
.search-area .btn.brown{min-width:124px;padding:0 18px}
.btn.ghost{background:#f6efe6;color:#6e5c4c}
.btn.outline{background:transparent;color:var(--accent);border-color:#c9a48f}

.main-nav{margin-top:10px;background:var(--brown);border-top:1px solid #6a5640;border-bottom:1px solid #483725}
.main-nav .container{justify-content:center;gap:0}
.main-nav a{
  min-width:108px;
  padding:12px 18px;
  color:#fff;
  font-size:13px;
  border-left:1px solid rgba(255,255,255,.08);
  text-align:center;
}
.main-nav a:last-child{border-right:1px solid rgba(255,255,255,.08)}
.main-nav a:hover,
.main-nav a.active{background:var(--brown-dark)}

/* Hero and cards */
.hero-wrap{background:#efece6;border-bottom:1px solid #ddd3c8}
.hero{
  position:relative;
  height:260px;
  overflow:hidden;
  background:
    linear-gradient(90deg, rgba(44,53,60,.06) 0 2%, transparent 2% 8%, rgba(52,70,85,.1) 8% 12%, transparent 12% 17%, rgba(37,20,31,.16) 17% 20%, transparent 20% 26%, rgba(46,78,52,.18) 26% 31%, transparent 31% 36%, rgba(89,76,121,.16) 36% 40%, transparent 40% 46%, rgba(39,66,51,.18) 46% 51%, transparent 51% 57%, rgba(58,56,73,.14) 57% 61%, transparent 61% 67%, rgba(72,93,64,.18) 67% 72%, transparent 72% 78%, rgba(38,54,80,.16) 78% 81%, transparent 81% 87%, rgba(72,47,58,.16) 87% 90%, transparent 90% 100%),
    linear-gradient(180deg,#c7bcb0 0,#efeae3 13%,#675864 15%,#2b2940 28%,#476450 58%,#253343 100%);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.34);
}
.hero::after{
  content:"";
  position:absolute;
  inset:auto 0 0;
  height:56px;
  background:linear-gradient(180deg, rgba(0,0,0,0), rgba(39,61,45,.58));
}
.hero-card{
  position:absolute;
  left:36px;
  top:22px;
  width:300px;
  padding:22px 24px;
  background:rgba(255,248,243,.9);
  box-shadow:var(--shadow);
}
.hero-card .sub{font-size:18px;color:#3b3027;margin-bottom:8px}
.hero-card .title{font-size:54px;line-height:1.04;font-weight:700;letter-spacing:.08em;color:#20130b}
.hero-card .meta{font-size:18px;color:#5a4d42;margin-top:10px}
.hero-card p{font-size:12px;color:#625448;margin:10px 0 14px}
.hero-link{
  position:absolute;
  right:14px;
  bottom:14px;
  background:#ddd3c8;
  color:#443529;
  padding:6px 10px;
  border-radius:2px;
  font-size:12px;
  z-index:1;
}

.product-strip{background:#f4f4f4;border-top:1px solid #e6e1db;border-bottom:1px solid #ddd7cf}
.product-strip .container{display:grid;grid-template-columns:repeat(10,1fr)}
.mini-product{
  position:relative;
  min-height:124px;
  padding:10px 8px 8px;
  text-align:center;
  border-right:1px dotted #d5cec5;
}
.mini-product:first-child{border-left:1px dotted #d5cec5}
.new-badge{
  position:absolute;
  left:8px;
  top:8px;
  background:#f0c6cf;
  color:#fff;
  font-size:10px;
  padding:2px 6px;
  border-radius:999px;
}
.pack{
  width:42px;
  height:60px;
  margin:10px auto 8px;
  border-radius:3px;
  box-shadow:0 2px 6px rgba(0,0,0,.12);
  border:1px solid rgba(0,0,0,.12);
  position:relative;
  overflow:hidden;
}
.pack::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg, rgba(255,255,255,.24), transparent 36%, rgba(0,0,0,.05) 100%)}
.pack::after{content:"";position:absolute;left:0;right:0;top:13px;height:2px;background:rgba(255,255,255,.58)}
.gold{background:linear-gradient(180deg,#9d7445,#6d4b2a)}
.black{background:linear-gradient(180deg,#202124,#4a413b)}
.yellow{background:linear-gradient(180deg,#bba652,#877128)}
.gray{background:linear-gradient(180deg,#98a9bd,#5e768f)}
.red{background:linear-gradient(180deg,#bb5448,#8b2f27)}
.blue{background:linear-gradient(180deg,#6483bf,#3b5a9a)}
.pink{background:linear-gradient(180deg,#e9a7ae,#bb5564)}
.mini-product .name{font-size:10px;line-height:1.4;color:#63574d;min-height:30px}
.mini-product .date{font-size:9px;color:#9b8e82;margin-top:6px}

/* Panels */
.content{padding:18px 0 28px}
.content-grid{display:grid;grid-template-columns:180px 1fr;gap:18px;align-items:start}
.panel,
.side-card,
.article-shell,
.category-shell,
.pagination,
.recommend-box,
.article-nav,
.article-related{background:var(--card);border:1px solid var(--line);box-shadow:var(--shadow)}
.side-title,.category-title{font-size:13px;color:#7d6f62;margin:10px 0 8px;font-weight:700}
.panel{padding:12px 14px;margin-bottom:14px}

.shopping-card{
  display:grid;
  grid-template-columns:88px minmax(0,1fr);
  align-items:stretch;
  padding:0;
  overflow:hidden;
}
.shopping-banner{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:100%;
  background:linear-gradient(135deg,#a5392f,#8c231f);
  color:#fff;
  padding:16px 10px;
  text-align:center;
  font-size:17px;
  line-height:1.5;
  letter-spacing:.12em;
}
.shopping-card .desc{
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:10px;
  min-height:116px;
  padding:14px 14px 14px 16px;
  font-size:11px;
  color:#584a40;
  background:#fffdf9;
}
.shopping-card .desc p{
  margin:0;
}
.shopping-card .desc a{
  display:inline-flex;
  align-items:center;
  align-self:flex-start;
  min-height:28px;
  padding:0 10px;
  border:1px solid #d7cabf;
  background:#f8f2e9;
  color:#6a5849;
  text-decoration:none;
  border-radius:2px;
}
.shopping-card .desc a:hover{
  background:#f1e8db;
}

.social-box{padding:10px;background:#f7f7fb;border:1px solid #c8d1e8;margin-bottom:10px}
.social-brand{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.icon{
  width:30px;
  height:30px;
  border-radius:4px;
  background:#3c5a98;
  color:#fff;
  font-size:20px;
  font-weight:700;
  display:flex;
  align-items:center;
  justify-content:center;
}
.label{font-size:12px;color:#495675;font-weight:700}
.small{font-size:10px;color:#6a6f82}
.tweet-box{
  padding:10px;
  background:#fafafa;
  border:1px solid var(--line);
  font-size:11px;
  color:#4f4a45;
  max-height:220px;
  overflow:auto;
}

.shop-list{display:flex;flex-direction:column;gap:8px}
.shop-item{display:grid;grid-template-columns:58px 1fr;gap:8px;padding:7px;border:1px solid #ddd5cb;background:#fffdfa}
.thumb,.content-thumb,.feature-thumb,.hero-photo,.recommend-thumb,.related-thumb{
  position:relative;
  overflow:hidden;
  background:linear-gradient(135deg,#b58a59,#7f5e3d 45%,#4d3c2c);
}
.thumb{height:48px;border-radius:2px}
.thumb::before,.thumb::after,
.content-thumb::before,.content-thumb::after,
.feature-thumb::before,.feature-thumb::after,
.hero-photo::before,.hero-photo::after,
.recommend-thumb::before,.recommend-thumb::after,
.related-thumb::before,.related-thumb::after{
  content:"";
  position:absolute;
}
.thumb::before,.content-thumb::before,.recommend-thumb::before,.related-thumb::before{width:100%;height:2px;top:14px;background:rgba(255,255,255,.4)}
.thumb::after,.content-thumb::after,.recommend-thumb::after,.related-thumb::after{width:32%;height:100%;right:8px;top:0;background:rgba(255,255,255,.18)}
.shop-item .txt{font-size:11px;color:#574a3e}

.news-panel{padding:10px 14px 12px}
.news-header{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  font-size:34px;
  font-weight:700;
  color:#523c2d;
  letter-spacing:.08em;
  margin:6px 0 8px;
}
.berry{width:12px;height:12px;border-radius:50%;background:#d5af7e;box-shadow:12px 0 0 #e5d19d}
.news-line{height:1px;background:#8d8177;margin:10px 0}
.news-scroll{max-height:130px;overflow:auto;padding-right:8px}
.news-item{font-size:12px;color:#3d2d25}
.news-item strong{display:block;font-size:11px;color:#6b5d52;margin-bottom:4px}

.section-title{display:flex;align-items:flex-end;justify-content:space-between;margin:6px 0 8px;padding:0 2px}
.section-title .left{font-size:14px;color:#6f6051;font-weight:700}
.section-title .left em{font-style:normal;color:#d66055;font-size:28px;font-family:Georgia,serif;font-weight:400;margin-right:4px;vertical-align:-3px}
.section-title .right{font-size:11px;color:#2d63ae}
.line-top{border-top:1px solid #dbcfc5;padding-top:8px}

.topic-grid,.category-grid,.content-list,.related-grid{display:grid;gap:12px}
.topic-grid{grid-template-columns:repeat(3,1fr)}
.topic-card{
  display:block;
  border:1px solid #dfd5ca;
  background:#fff;
  padding:10px;
}
.topic-thumb{
  height:86px;
  background:#e8e3dd;
  display:flex;
  align-items:center;
  justify-content:center;
}
.topic-thumb .pack{transform:scale(1.4)}
.topic-name{font-size:12px;color:#54473d;margin-top:8px;min-height:38px}

.like-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.like-card{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  border:1px solid #ddd2c7;
  background:linear-gradient(180deg,#fff,#f7f4ee);
  padding:10px 12px;
  min-height:66px;
}
.like-card .copy{font-size:12px;color:#54453c}
.like-card .accent{font-size:32px;font-style:italic;color:#f2c6cd;font-family:Georgia,serif;display:block;line-height:1;margin-top:2px}
.like-products{display:flex;gap:6px;align-items:flex-end}
.like-products .pack{width:24px;height:42px;margin:0}

.pickup-wrap{display:grid;grid-template-columns:1.3fr 1.1fr;border:1px solid #d8cec2;background:#fff}
.pickup-left{display:grid;grid-template-columns:1fr 1fr}
.pickup-photo{height:108px;position:relative}
.pickup-photo.one{background:linear-gradient(135deg,#1a2236,#25569a 40%,#43c7ff)}
.pickup-photo.two{background:linear-gradient(135deg,#20355f,#4d5ab6 48%,#172a4c)}
.pickup-photo::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.06),transparent 45%,rgba(255,255,255,.1))}
.pickup-text{padding:12px 14px;font-size:12px;color:#4c3f35;background:#fff}
.pickup-text .headline{font-size:18px;color:#4b6ca9;margin-bottom:6px;letter-spacing:.05em}

.category-grid{grid-template-columns:1fr 1fr;gap:14px 18px}
.category-card{border:1px solid #ddd1c7;background:#fffdfa;padding:12px 14px;min-height:142px}
.cat-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.cat-name{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:700;color:#54473d}
.cat-pack{width:10px;height:28px;border-radius:2px;background:linear-gradient(180deg,#5980c1,#3b5b99);box-shadow:0 0 0 1px rgba(0,0,0,.1)}
.cat-link{font-size:11px;color:#2d63ae}
.cat-list{display:grid;grid-template-columns:1fr 1fr;gap:8px 16px;padding-left:12px;margin:0}
.cat-list li{font-size:12px;color:#53463c}
.cat-list li::marker{color:#8b2b25}
.more-row{text-align:right;font-size:11px;color:#2d63ae;margin-top:8px}

.note{font-size:11px;color:#5d5045;margin-top:10px}

/* Inner pages */
.page-intro{padding:18px 0}
.breadcrumb{
  font-size:12px;
  color:#7b6e62;
  margin-bottom:12px;
}
.breadcrumb a{color:#6a594b}
.breadcrumb span{margin:0 6px;color:#aa998c}

.utility-row{justify-content:space-between;gap:16px;flex-wrap:wrap}
.page-title{font-size:30px;letter-spacing:.05em;color:#4c3b2d;margin:0}
.page-summary{font-size:13px;color:#6d5e51;margin:8px 0 0;max-width:720px}

.filter-tabs{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin:16px 0 18px;
}
.filter-tab{
  padding:8px 14px;
  background:#f4ede4;
  border:1px solid #d7cabf;
  color:#685748;
  font-size:12px;
  border-radius:999px;
  cursor:pointer;
}
.filter-tab.active{background:#8d2e27;color:#fff;border-color:#8d2e27}

.category-layout{display:grid;grid-template-columns:minmax(0,1fr) 280px;gap:18px}
.category-shell{padding:18px}
.content-list{grid-template-columns:repeat(3,1fr)}
.content-card{
  display:flex;
  flex-direction:column;
  border:1px solid #ddd2c8;
  background:#fff;
}
.content-thumb{height:148px;background:linear-gradient(135deg,#415f78,#7d8ca1 48%,#cab39a)}
.content-body{padding:12px}
.content-meta{font-size:11px;color:#8a7b6e;margin-bottom:8px}
.content-title{font-size:15px;color:#4b3b2d;line-height:1.5;margin:0 0 8px;min-height:46px}
.content-desc{font-size:12px;color:#67594d;flex:1}
.content-actions{padding:0 12px 12px}

.recommend-box{padding:16px}
.recommend-box h3,.article-related h3,.article-nav h3{font-size:16px;color:#5c4837;margin:0 0 12px}
.recommend-item,.related-item{
  display:grid;
  grid-template-columns:76px 1fr;
  gap:10px;
  padding:10px 0;
  border-top:1px solid #e3d8cc;
}
.recommend-item:first-of-type,.related-item:first-of-type{border-top:0;padding-top:0}
.recommend-thumb,.related-thumb{height:62px;border-radius:2px;background:linear-gradient(135deg,#86745e,#c1a078)}
.recommend-title,.related-title{font-size:13px;color:#4f4034;margin:0 0 4px}
.recommend-copy,.related-copy{font-size:11px;color:#7c6c5d}

.pagination{
  margin-top:16px;
  padding:14px 16px;
  display:flex;
  justify-content:center;
  gap:8px;
  flex-wrap:wrap;
}
.pagination a{
  min-width:34px;
  text-align:center;
  padding:7px 10px;
  border:1px solid #d7cbbe;
  background:#fff;
  color:#6a5849;
}
.pagination a.active{background:#8d2e27;border-color:#8d2e27;color:#fff}

.article-layout{display:grid;grid-template-columns:minmax(0,1fr) 260px;gap:18px}
.article-shell{padding:20px}
.article-meta{display:flex;gap:10px;align-items:center;flex-wrap:wrap;font-size:12px;color:#7f7165;margin:10px 0 18px}
.tag{
  display:inline-flex;
  align-items:center;
  padding:4px 10px;
  border-radius:999px;
  background:#f2e8de;
  border:1px solid #d8c8ba;
  color:#6a5748;
}
.hero-photo{
  height:280px;
  border:1px solid #d8ccbf;
  background:linear-gradient(135deg,#233448,#4f6980 42%,#bda88c);
  margin-bottom:18px;
}
.hero-photo::before{inset:0;background:linear-gradient(180deg,rgba(255,255,255,.14),transparent 42%,rgba(0,0,0,.12))}
.hero-photo::after{
  left:26px;
  bottom:22px;
  width:180px;
  height:88px;
  background:rgba(255,248,243,.9);
  box-shadow:var(--shadow);
}
.article-body h2{
  font-size:20px;
  color:#503d2d;
  margin:22px 0 8px;
  padding-bottom:6px;
  border-bottom:1px solid #dfd2c6;
}
.article-body p{font-size:14px;color:#514338;margin:0 0 14px}
.article-side-card{padding:16px}
.feature-thumb{height:140px;border-radius:2px;background:linear-gradient(135deg,#9f7d54,#d0b08c)}

.article-related,
.article-nav{padding:16px;margin-top:16px}
.related-grid{grid-template-columns:repeat(3,1fr)}
.related-item{grid-template-columns:1fr}
.related-thumb{height:110px}
.article-adjacent{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
.adjacent-link{
  display:block;
  padding:12px;
  border:1px solid #ddd1c7;
  background:#fff;
}
.adjacent-label{font-size:11px;color:#977763;margin-bottom:6px}
.adjacent-title{font-size:14px;color:#4c3c2d}

/* Product pages */
.products-layout,
.checkout-layout{display:grid;grid-template-columns:220px minmax(0,1fr);gap:18px}
.products-main,
.product-detail-shell,
.cart-shell,
.checkout-shell,
.confirm-shell{background:var(--card);border:1px solid var(--line);box-shadow:var(--shadow)}
.products-main,.product-detail-shell,.cart-shell,.checkout-shell,.confirm-shell{padding:18px}
.product-filter{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
  margin:14px 0 18px;
}
.filter-box{
  background:#f7f0e7;
  border:1px solid #dccfc3;
  padding:10px 12px;
}
.filter-box strong{display:block;font-size:12px;color:#6a5647;margin-bottom:6px}
.filter-box span{font-size:12px;color:#867364}
.product-category-nav{padding:16px}
.product-category-nav h3{margin:0 0 10px;font-size:16px;color:#5c4837}
.product-category-nav a{
  display:flex;
  justify-content:space-between;
  padding:10px 0;
  border-top:1px solid #e2d8ce;
  font-size:12px;
  color:#5f4f42;
}
.product-category-nav a:first-of-type{border-top:0;padding-top:0}
.product-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.product-card{display:flex;flex-direction:column;border:1px solid #ddd2c8;background:#fff}
.product-thumb{
  height:170px;
  display:block;
  background:linear-gradient(135deg,#5f6b7c,#b5a48b);
  position:relative;
  overflow:hidden;
}
.product-thumb::before,.cart-thumb::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(255,255,255,.18),transparent 40%,rgba(0,0,0,.12));
}
.product-body{padding:12px}
.product-tag{
  display:inline-block;
  padding:4px 8px;
  margin-bottom:8px;
  border-radius:999px;
  background:#f1e5d9;
  color:#7d5d48;
  font-size:10px;
}
.product-name{font-size:15px;color:#4b3b2d;margin:0 0 8px;line-height:1.5}
.product-copy{font-size:12px;color:#67584b;min-height:54px;margin:0 0 10px}
.product-price{font-size:18px;color:#8d2e27;font-weight:700}
.product-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:0 12px 12px}
.products-note{margin-top:16px;padding:14px;border:1px solid #dfd2c6;background:#faf6f1}
.products-note h3{margin:0 0 8px;font-size:16px;color:#5a4636}
.products-note p{margin:0;font-size:12px;color:#655547}

.detail-main{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
  margin-top:10px;
}
.detail-hero{
  min-height:360px;
  background:linear-gradient(135deg,#273546,#71839c 48%,#cfb39b);
  border:1px solid #dacdbf;
  position:relative;
}
.detail-hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(255,255,255,.12),transparent 40%,rgba(0,0,0,.12));
}
.detail-info h2{margin:0 0 8px;font-size:28px;color:#4d3a2b}
.detail-lead{font-size:13px;color:#6d5d4f;margin:8px 0 14px}
.detail-price{font-size:24px;color:#8d2e27;font-weight:700;margin-bottom:14px}
.detail-options{display:grid;gap:12px}
.option-row label{display:block;font-size:12px;color:#6d594a;margin-bottom:6px}
.option-row select,.option-row input,.checkout-form input,.checkout-form select,.checkout-form textarea{
  width:100%;
  padding:10px 12px;
  border:1px solid #d2c4b8;
  background:#fff;
  border-radius:2px;
}
.qty-control{
  display:inline-flex;
  align-items:center;
  border:1px solid #d8c9bb;
  background:#fff;
}
.qty-btn{
  width:32px;
  height:32px;
  border:0;
  background:#f1e7db;
  color:#5f4d40;
  cursor:pointer;
}
.qty-value{display:inline-flex;align-items:center;justify-content:center;width:38px;font-size:13px}
.detail-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}
.detail-sections{margin-top:22px}
.detail-sections section{margin-top:18px}
.detail-sections h3{font-size:18px;color:#4f3b2d;margin:0 0 8px;padding-bottom:6px;border-bottom:1px solid #dfd2c6}
.detail-sections p{font-size:13px;color:#56473b;margin:0}

.cart-item{
  display:grid;
  grid-template-columns:88px minmax(0,1.7fr) .8fr .9fr .8fr .6fr;
  gap:12px;
  align-items:center;
  padding:14px 0;
  border-top:1px solid #e2d7cc;
}
.cart-item:first-child{border-top:0;padding-top:0}
.cart-thumb{height:72px;display:block;background:linear-gradient(135deg,#6a7e93,#c5b08c)}
.cart-name{font-size:14px;color:#4c3b2d}
.cart-note{font-size:11px;color:#78695b;margin-top:4px}
.cart-price,.cart-subtotal,.cart-remove{font-size:12px;color:#5a493d}
.cart-remove{text-align:right}
.coupon-row{
  display:flex;
  gap:10px;
  margin-top:18px;
  padding-top:16px;
  border-top:1px solid #e2d7cc;
  flex-wrap:wrap;
}
.coupon-row label{font-size:12px;color:#6d594a;min-width:100px;padding-top:8px}
.coupon-row input{flex:1;min-width:220px;padding:10px 12px;border:1px solid #d2c4b8;background:#fff}
.cart-summary{
  margin-top:18px;
  margin-left:auto;
  width:320px;
  max-width:100%;
  padding:16px;
  border:1px solid #ddd2c6;
  background:#faf6f0;
}
.summary-line{
  display:flex;
  justify-content:space-between;
  gap:10px;
  padding:8px 0;
  border-top:1px solid #e1d7cd;
  font-size:12px;
}
.summary-line:first-child{border-top:0;padding-top:0}
.summary-line.total{font-size:16px;color:#8d2e27;font-weight:700}
.summary-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}

.checkout-form{display:grid;gap:12px}
.form-grid-two{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.radio-row{display:flex;gap:18px;flex-wrap:wrap;font-size:12px;color:#5e4d41}
.radio-row label{display:flex;align-items:center;gap:6px}
.checkout-side{padding:16px;border:1px solid #ddd2c6;background:#faf6f0}
.checkout-side h3,.confirm-shell h2{margin:0 0 12px;font-size:18px;color:#4f3c2e}
.confirm-banner{
  padding:18px;
  border:1px solid #d8c8ba;
  background:linear-gradient(180deg,#fff8f0,#f5ecdf);
  margin-bottom:18px;
}
.confirm-banner p{margin:6px 0 0;font-size:13px;color:#645444}
.confirm-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.confirm-card{padding:14px;border:1px solid #dfd2c6;background:#fff}
.confirm-card h3{margin:0 0 8px;font-size:14px;color:#5a4637}
.confirm-card ul{margin:0;padding-left:18px;font-size:12px;color:#625245}
.confirm-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}

/* Footer */
.footer-social{padding:18px 0 10px}
.footer-social .container{display:flex;align-items:center;gap:8px}
.sns{
  width:28px;
  height:28px;
  border-radius:4px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  font-weight:700;
}
.fb{background:#3f5b99}
.tw{background:#58a9de}
.cm{background:#d7ad59}
.footer{background:#f5f0ea;border-top:1px solid #d8d0c7;padding:12px 0 30px;text-align:center;font-size:11px;color:#8c8074}
.footer-links{justify-content:center;gap:16px;margin-bottom:8px;flex-wrap:wrap}

/* Responsive */
@media (max-width:980px){
  .product-strip .container,
  .content-list{grid-template-columns:repeat(2,1fr)}
  .content-grid,
  .category-layout,
  .article-layout,
  .products-layout,
  .checkout-layout,
  .pickup-wrap,
  .related-grid{grid-template-columns:1fr}
  .category-grid,
  .topic-grid,
  .like-grid{grid-template-columns:1fr}
  .product-grid,
  .detail-main,
  .confirm-grid{grid-template-columns:1fr}
  .header-row,
  .mini-top .container{flex-direction:column;align-items:flex-start}
  .main-nav .container{justify-content:flex-start;flex-wrap:wrap}
  .hero-card{width:min(300px,calc(100% - 70px))}
  .product-filter,
  .form-grid-two{grid-template-columns:1fr 1fr}
  .cart-item{grid-template-columns:88px 1fr 1fr;align-items:start}
}

@media (max-width:640px){
  body::before,body::after{display:none}
  .container{max-width:calc(100% - 20px)}
  .logo-main{font-size:34px}
  .page-title{font-size:24px}
  .hero{height:220px}
  .hero-card{left:14px;top:14px;width:calc(100% - 28px);padding:18px}
  .hero-card .title{font-size:38px}
  .product-strip .container{grid-template-columns:repeat(2,1fr)}
  .content-list{grid-template-columns:1fr}
  .article-adjacent{grid-template-columns:1fr}
  .product-filter,
  .form-grid-two{grid-template-columns:1fr}
  .cart-item{grid-template-columns:1fr}
  .cart-remove{text-align:left}
  .shopping-card{
    grid-template-columns:1fr;
  }
  .shopping-banner{
    min-height:0;
    padding:12px 14px;
    font-size:16px;
    line-height:1.4;
  }
  .shopping-card .desc{
    min-height:0;
    padding:12px 14px 14px;
  }
}

/* Mobile header fixes */
@media (max-width:768px){
  .mini-top{
    padding:10px 0 6px;
  }
  .mini-top .container{
    align-items:flex-start;
    gap:10px;
  }
  .mini-top .right-side{
    width:100%;
    flex-direction:column;
    align-items:flex-start;
    gap:10px;
  }
  .right-links{
    display:flex;
    flex-wrap:wrap;
    gap:8px 12px;
    width:100%;
  }
  .right-links a{
    margin-left:0;
    line-height:1.4;
  }
  .lang-switcher{
    flex-wrap:wrap;
    gap:8px;
    width:100%;
  }
  .lang-btn{
    min-width:72px;
    min-height:34px;
    padding:7px 12px;
    line-height:1;
    text-align:center;
  }

  .header{
    padding:10px 0 0;
  }
  .header-row{
    flex-direction:column;
    align-items:stretch;
    gap:14px;
  }
  .brand{
    width:100%;
    padding-top:0;
  }
  .logo-block{
    min-width:0;
    width:100%;
  }
  .logo-small{
    display:block;
    width:100%;
    line-height:1.5;
    word-break:break-word;
  }
  .logo-main{
    margin-top:6px;
    line-height:1.1;
    word-break:break-word;
  }
  .logo-note{
    margin-top:8px;
    line-height:1.6;
  }

  .search-area{
    width:100%;
    display:flex;
    flex-wrap:wrap;
    align-items:stretch;
    gap:10px;
    padding-top:0;
  }
  .search-label{
    width:100%;
    margin:0;
    line-height:1.4;
  }
  .search-area input{
    width:100%;
    max-width:100%;
    min-width:0;
    height:38px;
  }
  .search-area .btn{
    min-height:38px;
    height:38px;
    padding:0 14px;
    white-space:normal;
  }
  .search-area .btn.red{
    flex:1 1 150px;
  }
  .search-area .btn.brown{
    flex:1 1 100%;
  }

  .main-nav{
    margin-top:12px;
  }
  .main-nav .container{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:8px;
    padding:10px 0;
  }
  .main-nav a{
    min-height:40px;
    display:flex;
    align-items:center;
    justify-content:center;
    text-align:center;
    padding:10px 8px;
    border:0;
    background:rgba(255,255,255,.06);
    line-height:1.35;
  }
  .main-nav a:last-child{
    border-right:0;
  }
}

@media (max-width:480px){
  .mini-top{
    font-size:10px;
  }
  .container{
    max-width:calc(100% - 20px);
  }
  .logo-small{
    font-size:10px;
    letter-spacing:.04em;
  }
  .logo-main{
    font-size:30px;
    letter-spacing:.04em;
  }
  .logo-note{
    font-size:11px;
  }
  .lang-switcher{
    gap:6px;
  }
  .lang-btn{
    flex:0 1 auto;
    min-width:68px;
    font-size:11px;
    padding:7px 10px;
  }
  .search-area{
    gap:8px;
  }
  .search-area input,
  .search-area .btn{
    width:100%;
  }
  .search-area .btn.red,
  .search-area .btn.brown{
    flex:1 1 100%;
  }
  .main-nav .container{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:6px;
  }
  .main-nav a{
    min-height:38px;
    font-size:12px;
    padding:9px 6px;
  }
}

/* Compact mobile header refinement */
@media (max-width:768px){
  .mini-top{
    padding:6px 0 4px;
  }
  .mini-top .container{
    display:flex;
    flex-direction:row;
    justify-content:space-between;
    align-items:flex-start;
    gap:8px;
  }
  .mini-top .container > [data-i18n="miniTagline"]{
    flex:1 1 auto;
    min-width:0;
    font-size:10px;
    line-height:1.35;
    padding-top:2px;
  }
  .mini-top .right-side{
    width:auto;
    flex:0 0 auto;
    align-items:flex-end;
    gap:4px;
  }
  .right-links{
    justify-content:flex-end;
    gap:4px 8px;
    width:auto;
    font-size:10px;
    line-height:1.2;
  }
  .lang-switcher{
    width:auto;
    flex-wrap:nowrap;
    justify-content:flex-end;
    gap:6px;
  }
  .lang-btn{
    min-width:auto;
    min-height:32px;
    height:32px;
    padding:0 9px;
    font-size:12px;
    border-radius:999px;
    white-space:nowrap;
  }

  .header{
    padding:8px 0 0;
  }
  .header-row{
    display:grid;
    grid-template-columns:minmax(0,1fr) minmax(170px,42%);
    align-items:start;
    gap:10px;
  }
  .brand{
    width:auto;
    min-width:0;
  }
  .logo-block{
    width:auto;
  }
  .logo-small{
    font-size:10px;
    line-height:1.2;
    margin:0;
  }
  .logo-main{
    margin-top:3px;
    font-size:30px;
    line-height:1;
  }
  .logo-note{
    margin-top:4px;
    font-size:11px;
    line-height:1.35;
    max-width:none;
  }

  .search-area{
    width:100%;
    min-width:0;
    padding-top:0;
    display:grid;
    grid-template-columns:minmax(0,1fr) auto;
    grid-template-areas:
      "label label"
      "input search"
      "topic topic";
    gap:6px 8px;
    align-items:center;
  }
  .search-label{
    grid-area:label;
    width:auto;
    font-size:11px;
    line-height:1.2;
  }
  .search-area input{
    grid-area:input;
    width:100%;
    min-width:0;
    height:36px;
    font-size:13px;
    padding:0 12px;
  }
  .search-area .btn{
    min-height:36px;
    height:36px;
    padding:0 12px;
    font-size:12px;
    white-space:nowrap;
    justify-content:center;
  }
  .search-area .btn.red{
    grid-area:search;
    flex:none;
  }
  .search-area .btn.brown{
    grid-area:topic;
    width:100%;
    flex:none;
  }

  .main-nav{
    margin-top:10px;
  }
}

@media (max-width:480px){
  .mini-top{
    padding:5px 0 3px;
  }
  .mini-top .container > [data-i18n="miniTagline"]{
    font-size:9px;
    line-height:1.3;
  }
  .right-links{
    font-size:9px;
    gap:4px 6px;
  }
  .lang-switcher{
    gap:5px;
  }
  .lang-btn{
    height:30px;
    min-height:30px;
    padding:0 8px;
    font-size:11px;
  }

  .header{
    padding-top:6px;
  }
  .header-row{
    grid-template-columns:minmax(0,1fr) minmax(148px,44%);
    gap:8px;
  }
  .logo-small{
    font-size:9px;
  }
  .logo-main{
    font-size:26px;
  }
  .logo-note{
    font-size:10px;
    line-height:1.3;
  }

  .search-area{
    grid-template-columns:minmax(0,1fr) auto;
    gap:5px 6px;
  }
  .search-label{
    font-size:10px;
  }
  .search-area input{
    height:34px;
    font-size:12px;
    padding:0 10px;
  }
  .search-area .btn{
    height:34px;
    min-height:34px;
    padding:0 10px;
    font-size:11px;
  }

  .main-nav{
    margin-top:8px;
  }
}

.login-shell{
  padding:18px 0 32px;
}

.login-intro-card{
  background:linear-gradient(180deg,#fffaf3 0%,#f6ede1 100%);
  border:1px solid #dccdbf;
  border-radius:24px;
  box-shadow:0 14px 30px rgba(74,47,29,.08);
  padding:28px;
}

.login-note{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 14px;
  border-radius:999px;
  background:#efe1d0;
  color:#7b5a45;
  font-size:13px;
  letter-spacing:.04em;
}

.login-layout{
  display:grid;
  grid-template-columns:minmax(0,1.2fr) minmax(320px,.9fr);
  gap:24px;
  margin-top:22px;
}

.login-service-card,
.login-form-card,
.login-subcard{
  background:#fffdf9;
  border:1px solid #e2d5c9;
  border-radius:22px;
  box-shadow:0 10px 24px rgba(78,54,37,.06);
}

.login-service-card{
  padding:24px;
}

.section-title.compact{
  margin-bottom:12px;
}

.login-copy{
  margin:0;
  font-size:15px;
  line-height:1.9;
  color:#5f4c40;
}

.login-benefits{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
  margin-top:18px;
}

.login-benefit{
  padding:16px 18px;
  border-radius:18px;
  background:#f7efe4;
  border:1px solid #e6d9ce;
}

.login-benefit h3{
  margin:0 0 8px;
  font-size:18px;
  color:#4a3225;
}

.login-benefit p{
  margin:0;
  font-size:14px;
  line-height:1.8;
  color:#6b584b;
}

.login-subcards{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
  margin-top:18px;
}

.login-subcard{
  padding:18px;
}

.login-subcard h3{
  margin:0 0 8px;
  font-size:17px;
  color:#493124;
}

.login-subcard p{
  margin:0;
  font-size:14px;
  line-height:1.8;
  color:#6d5a4d;
}

.login-form-card{
  padding:24px;
  align-self:start;
  position:sticky;
  top:16px;
}

.login-form-header h2{
  margin:0;
  font-size:28px;
  color:#432c20;
}

.login-form-header p{
  margin:8px 0 0;
  font-size:14px;
  line-height:1.8;
  color:#6b5749;
}

.login-form{
  display:grid;
  gap:14px;
  margin-top:18px;
}

.login-form .field input{
  height:48px;
}

.login-remember{
  display:flex;
  align-items:center;
  gap:10px;
  font-size:14px;
  color:#624f42;
}

.login-submit{
  width:100%;
  justify-content:center;
  min-height:48px;
  font-size:16px;
}

.login-assist{
  margin-top:22px;
  padding-top:18px;
  border-top:1px solid #eaded3;
}

.login-assist h3{
  margin:0;
  font-size:18px;
  color:#493124;
}

.login-assist p{
  margin:8px 0 0;
  font-size:14px;
  line-height:1.8;
  color:#6c594b;
}

.login-assist-links{
  display:grid;
  gap:10px;
  margin-top:16px;
}

.login-assist-links .btn{
  justify-content:center;
  min-height:44px;
}

@media (max-width:980px){
  .login-layout{
    grid-template-columns:1fr;
  }

  .login-form-card{
    position:static;
  }
}

@media (max-width:640px){
  .login-intro-card{
    padding:18px;
    border-radius:20px;
  }

  .login-note{
    font-size:12px;
    line-height:1.5;
  }

  .login-benefits,
  .login-subcards{
    grid-template-columns:1fr;
  }

  .login-service-card,
  .login-form-card{
    padding:18px;
  }

  .login-form-header h2{
    font-size:24px;
  }
}

.jpencnwp-searchform{
  display:inline-flex;
}

.current-menu-item > a,
.current_page_item > a{
  background:#453425;
}

.footer-widgets{
  max-width:860px;
  margin:0 auto 12px;
}

.footer-widget{
  padding:12px;
  border:1px solid #ddd3c8;
  background:#fffdf8;
  margin-bottom:10px;
}

.widget-title{
  margin:0 0 8px;
  font-size:15px;
  color:#4b3b2d;
}
