/* ===== ハスの中村 共通スタイル（和モダン・上品） ===== */
:root{
  --washi:#F7F2E8;
  --washi-deep:#EFE7D6;
  --card:#FFFFFF;
  --sumi:#2A2622;
  --sumi-soft:#5C544B;
  --beni:#A85A6E;       /* 蓮の淡紅 */
  --beni-deep:#8E4658;
  --kin:#B49A5E;        /* 金・真鍮の細線 */
  --matcha:#56654A;     /* 蓮の葉 */
  --line:#E2D8C5;
  --maxw:1080px;
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:"Noto Sans JP",sans-serif;
  color:var(--sumi);
  background:var(--washi);
  line-height:1.9;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
}
.mincho{font-family:"Noto Serif JP",serif;}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px;}
.center{text-align:center;}

/* ---- 見本の注意帯（本番では非表示） ---- */
.demo-note{ display:none; }

/* ---- 上部ユーティリティ ---- */
.utility{background:var(--washi-deep);border-bottom:1px solid var(--line);}
.utility .wrap{display:flex;align-items:center;justify-content:space-between;height:56px;gap:16px;flex-wrap:wrap;}
.util-left{font-size:13px;color:var(--sumi-soft);letter-spacing:.05em;}
.util-right{display:flex;align-items:center;gap:18px;}
.tel{display:flex;align-items:baseline;gap:8px;}
.tel .label{font-size:12px;color:var(--sumi-soft);}
.tel .num{font-family:"Noto Serif JP",serif;font-size:23px;font-weight:600;color:var(--beni-deep);letter-spacing:.04em;}
.util-cart{font-size:14px;border:1px solid var(--kin);border-radius:999px;padding:7px 18px;color:var(--sumi);}

/* ---- ヘッダー ---- */
header.site{background:var(--washi);position:sticky;top:0;z-index:50;border-bottom:1px solid var(--line);}
header.site .wrap{display:flex;align-items:center;justify-content:space-between;height:104px;}
.logo{display:flex;align-items:center;}
.logo-img{height:88px;width:auto;display:block;}
.logo .mark{
  width:46px;height:46px;border-radius:50%;border:1.5px solid var(--beni);
  color:var(--beni-deep);display:flex;align-items:center;justify-content:center;
  font-family:"Noto Serif JP",serif;font-size:12px;line-height:1.15;font-weight:600;letter-spacing:.02em;
}
.logo .name{font-family:"Noto Serif JP",serif;font-size:22px;font-weight:600;letter-spacing:.08em;}
.logo .name small{display:block;font-size:11px;color:var(--sumi-soft);letter-spacing:.18em;font-weight:400;margin-top:2px;}
nav.main ul{display:flex;gap:28px;list-style:none;}
nav.main > ul > li{position:relative;}
nav.main a{font-size:15px;letter-spacing:.05em;padding:6px 0;border-bottom:2px solid transparent;transition:.2s;white-space:nowrap;}
nav.main a:hover,nav.main a.active,nav.main li.active > a{border-color:var(--beni);color:var(--beni-deep);}
nav.main .caret{font-size:10px;margin-left:3px;opacity:.55;display:inline-block;transition:transform .2s;}
nav.main li.has-sub:hover .caret{transform:translateY(1px);}
nav.main .sub{position:absolute;top:calc(100% + 6px);left:50%;transform:translateX(-50%) translateY(-4px);background:#fff;border:1px solid var(--line);border-radius:8px;padding:8px 0;min-width:170px;list-style:none;opacity:0;visibility:hidden;transition:opacity .2s,transform .2s,visibility 0s linear .2s;box-shadow:0 12px 32px rgba(42,38,34,.10);z-index:200;}
nav.main .sub li{margin:0;}
nav.main .sub a{display:block;padding:9px 18px;font-size:14px;text-align:left;border-bottom:none;border-left:2px solid transparent;letter-spacing:.04em;}
nav.main .sub a:hover,nav.main .sub a.active{background:var(--washi-deep);color:var(--beni-deep);border-bottom:none;border-left-color:var(--beni-deep);}
nav.main li.has-sub:hover .sub,nav.main li.has-sub:focus-within .sub{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);transition-delay:0s;}

/* ---- ボタン ---- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-size:17px;font-weight:500;letter-spacing:.06em;
  padding:16px 38px;border-radius:6px;cursor:pointer;transition:.2s;border:1.5px solid transparent;
}
.btn-primary{background:var(--beni);color:#fff;box-shadow:0 6px 18px rgba(168,90,110,.28);}
.btn-primary:hover{background:var(--beni-deep);transform:translateY(-1px);}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.7);}
.btn-ghost:hover{background:rgba(255,255,255,.12);}
.btn-outline{background:#fff;color:var(--sumi);border-color:var(--kin);}
.btn-outline:hover{background:var(--washi-deep);}
.btn-lg{font-size:19px;padding:18px 52px;}

/* ---- セクション共通 ---- */
section{padding:84px 0;}
.sec-head{text-align:center;margin-bottom:52px;}
.sec-head .ja{font-family:"Noto Serif JP",serif;font-size:31px;font-weight:600;letter-spacing:.08em;}
.sec-head .en{display:block;font-size:12px;letter-spacing:.32em;color:var(--kin);text-transform:uppercase;margin-bottom:14px;}
.sec-head .desc{margin-top:14px;color:var(--sumi-soft);font-size:15px;}
.rule{width:46px;height:1px;background:var(--kin);margin:14px auto 0;}

/* ===== トップページ：ヒーロー（スライドショー） ===== */
.hero{position:relative;height:560px;overflow:hidden;}
.hero .slideshow{position:absolute;inset:0;}
.hero .slide{
  position:absolute;inset:0;background-size:cover;background-position:center;
  opacity:0;animation:heroFade 24s infinite;transform:scale(1.07);
}
.hero .slide:nth-child(1){background-image:url('assets/hero.jpg');animation-delay:0s;}
/* 夫婦スライド：他スライドと同じく暗幕(overlay)あり。見出しは出さず下のキャプションのみ表示 */
.hero .slide:nth-child(2){background-image:url('assets/hero2.jpg');background-position:center 25%;animation-delay:6s;}
.hero .slide:nth-child(3){background-image:url('assets/hero3.jpg');animation-delay:12s;}
.hero .slide:nth-child(4){background-image:url('assets/hero4.jpg');animation-delay:18s;}
@keyframes heroFade{
  0%   {opacity:0;transform:scale(1.07);}
  3%   {opacity:1;}
  22%  {opacity:1;transform:scale(1.00);}
  27%  {opacity:0;}
  100% {opacity:0;}
}
@keyframes heroCopyFade{
  0%{opacity:1;}
  21%{opacity:1;}
  25%{opacity:0;}
  49%{opacity:0;}
  53%{opacity:1;}
  100%{opacity:1;}
}
.hero .overlay{position:absolute;inset:0;z-index:2;background:linear-gradient(180deg,rgba(18,14,12,.50) 0%,rgba(18,14,12,.55) 100%);}
.hero .copy{position:absolute;inset:0;z-index:3;display:flex;flex-direction:column;justify-content:center;animation:heroCopyFade 24s infinite;}
.hero .copy .wrap{color:#fff;text-align:center;}
.hero .badge{display:inline-block;font-size:13px;letter-spacing:.14em;color:#fff;border:1px solid rgba(255,255,255,.6);border-radius:999px;padding:6px 18px;margin-bottom:24px;backdrop-filter:blur(2px);}
.hero h1{font-family:"Noto Serif JP",serif;font-weight:600;font-size:46px;line-height:1.5;letter-spacing:.04em;text-shadow:0 2px 18px rgba(0,0,0,.35);}
.hero p.lead{margin:20px auto 0;font-size:17px;line-height:2;max-width:30em;text-shadow:0 1px 10px rgba(0,0,0,.4);}
.hero .cta-row{margin-top:34px;display:flex;gap:16px;flex-wrap:wrap;justify-content:center;}
.hero .dots{position:absolute;z-index:4;bottom:24px;left:0;right:0;display:flex;gap:10px;justify-content:center;}
.hero .dots span{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.45);border:1px solid rgba(255,255,255,.7);}
.hero .copy2{position:absolute;inset:0;z-index:3;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;text-align:center;padding-bottom:84px;opacity:0;animation:heroCaption 24s infinite;pointer-events:none;background:linear-gradient(to top,rgba(0,0,0,.62) 0%,rgba(0,0,0,.30) 26%,rgba(0,0,0,0) 55%);}
.hero .copy2 .c2-main{font-family:"Noto Serif JP",serif;color:#fff;font-size:42px;font-weight:600;letter-spacing:.1em;text-shadow:0 2px 24px rgba(0,0,0,.9),0 1px 4px rgba(0,0,0,.8);}
.hero .copy2 .c2-sub{color:#fff;font-size:15px;letter-spacing:.22em;margin-top:14px;text-shadow:0 2px 12px rgba(0,0,0,.75);}
@keyframes heroCaption{0%{opacity:0;}22%{opacity:0;}26%{opacity:1;}48%{opacity:1;}52%{opacity:0;}100%{opacity:0;}}

/* ===== 下層ページ：ページヘッダー（バナー） ===== */
.page-hero{position:relative;height:260px;overflow:hidden;display:flex;align-items:center;justify-content:center;text-align:center;}
.page-hero .bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.03);}
.page-hero .ov{position:absolute;inset:0;background:rgba(26,21,18,.5);}
.page-hero .ttl{position:relative;z-index:2;color:#fff;}
.page-hero .ttl .en{display:block;font-size:12px;letter-spacing:.34em;color:#E6D8B8;margin-bottom:10px;}
.page-hero .ttl h1{font-family:"Noto Serif JP",serif;font-size:36px;font-weight:600;letter-spacing:.1em;text-shadow:0 2px 14px rgba(0,0,0,.4);}
.breadcrumb{background:var(--washi-deep);border-bottom:1px solid var(--line);font-size:12.5px;color:var(--sumi-soft);}
.breadcrumb .wrap{padding:12px 24px;}
.breadcrumb a:hover{color:var(--beni-deep);}

/* ---- 季節のお知らせ帯 ---- */
.season{background:var(--washi-deep);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.season .wrap{padding:18px 24px;text-align:center;font-size:15.5px;letter-spacing:.03em;display:flex;align-items:center;justify-content:center;gap:22px;flex-wrap:wrap;}
.season b{color:var(--beni-deep);font-weight:600;}
.season .season-cta{display:inline-flex;align-items:center;gap:6px;background:#06C755;color:#fff;padding:8px 18px;border-radius:999px;font-size:13.5px;font-weight:600;text-decoration:none;letter-spacing:.04em;box-shadow:0 2px 6px rgba(6,199,85,.25);transition:opacity .2s,transform .2s;}
.season .season-cta:hover{opacity:.92;transform:translateY(-1px);}
@media(max-width:600px){.season .wrap{flex-direction:column;gap:10px;}}

/* ---- 商品（購入ブロック・トップ＆商品ページ共通） ---- */
.shop{background:var(--card);}
.product{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center;}
.product+.product{margin-top:72px;padding-top:72px;border-top:1px solid var(--line);}
.product .photo{border-radius:10px;overflow:hidden;box-shadow:0 14px 40px rgba(42,38,34,.10);border:1px solid var(--line);}
.product .photo img{width:100%;aspect-ratio:4/3;object-fit:cover;}
.product .tag{display:inline-block;font-size:12px;letter-spacing:.08em;color:var(--matcha);border:1px solid var(--matcha);border-radius:999px;padding:3px 14px;margin-bottom:14px;}
.product .pname{font-family:"Noto Serif JP",serif;font-size:26px;font-weight:600;letter-spacing:.03em;}
.product .psub{color:var(--sumi-soft);font-size:14.5px;margin:10px 0 22px;}
.pricelist{border-top:1px solid var(--line);}
.pricelist .row{display:flex;align-items:center;justify-content:space-between;padding:15px 4px;border-bottom:1px solid var(--line);}
.pricelist .size{font-size:16px;}
.pricelist .size small{color:var(--sumi-soft);font-size:12.5px;margin-left:8px;}
.pricelist .price{font-family:"Noto Serif JP",serif;font-size:21px;font-weight:600;}
.pricelist .price small{font-size:12px;color:var(--sumi-soft);font-weight:400;margin-left:4px;font-family:"Noto Sans JP";}
.pop{display:inline-block;font-size:11px;color:#fff;background:var(--beni);border-radius:4px;padding:2px 8px;margin-left:8px;vertical-align:middle;letter-spacing:.05em;}
.pop.alt{background:var(--kin);}
.shop-cta{margin-top:26px;}
.ship-note{margin-top:16px;font-size:12.5px;color:var(--sumi-soft);line-height:1.8;}

/* ---- 時期別 価格表（商品ページ） ---- */
.ptable{width:100%;border-collapse:collapse;margin:4px 0 2px;}
.ptable thead th{font-size:12.5px;font-weight:600;color:var(--sumi);padding:8px 6px;border-bottom:1.5px solid var(--kin);line-height:1.3;text-align:center;}
.ptable thead th:first-child{text-align:left;}
.ptable thead th small{display:block;font-weight:400;color:var(--sumi-soft);font-size:10.5px;margin-top:3px;}
.ptable tbody th{text-align:left;font-weight:600;font-size:15px;padding:12px 6px;border-bottom:1px solid var(--line);white-space:nowrap;vertical-align:middle;}
.ptable tbody th small{display:block;font-weight:400;color:var(--sumi-soft);font-size:11px;margin-top:2px;}
.ptable tbody td{text-align:center;padding:12px 6px;border-bottom:1px solid var(--line);font-family:"Noto Serif JP",serif;font-size:16px;font-weight:600;white-space:nowrap;}
.ptable td.peak{color:var(--beni-deep);background:rgba(168,90,110,.05);}
.ptable tbody tr.peak th,.ptable tbody tr.peak td{color:var(--beni-deep);background:rgba(168,90,110,.05);}
.price-note{font-size:12.5px;color:var(--sumi-soft);margin-top:12px;line-height:1.75;}

/* ---- ご購入セレクター ---- */
.buy{background:var(--washi-deep);}
.buybox{max-width:680px;margin:0 auto;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:34px 34px 30px;box-shadow:0 14px 40px rgba(42,38,34,.07);}
.bb-row{display:flex;align-items:flex-start;gap:18px;padding:16px 0;border-bottom:1px solid var(--line);}
.bb-label{flex:0 0 88px;font-weight:600;font-size:14px;padding-top:9px;color:var(--sumi);}
.bb-opts{display:flex;flex-wrap:wrap;gap:10px;flex:1;}
.bb-opt{font-size:14px;border:1.5px solid var(--line);background:#fff;border-radius:999px;padding:9px 18px;cursor:pointer;transition:.15s;color:var(--sumi);font-family:inherit;}
.bb-opt:hover{border-color:var(--kin);}
.bb-opt.active{border-color:var(--beni);background:var(--beni);color:#fff;}
.bb-cool-fixed{font-size:13.5px;color:var(--beni-deep);padding-top:9px;font-weight:600;}
.bb-total{display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:6px;padding:24px 2px 4px;}
.bb-price #bb-amount{font-family:"Noto Serif JP",serif;font-size:34px;font-weight:600;color:var(--beni-deep);}
.bb-price small{font-size:12.5px;color:var(--sumi-soft);margin-left:10px;}
.bb-note{font-size:12.5px;color:var(--sumi-soft);width:100%;}
.bb-cta{width:100%;margin-top:18px;}
.bb-fine{font-size:11.5px;color:var(--sumi-soft);margin-top:14px;line-height:1.7;}
.bb-zipwrap{align-items:center;}
.bb-zip{font-size:15px;border:1.5px solid var(--line);border-radius:8px;padding:9px 14px;width:180px;font-family:inherit;}
.bb-zip:focus{outline:none;border-color:var(--beni);}
.bb-region{width:100%;font-size:13px;color:var(--matcha);font-weight:600;margin-top:2px;}
.bb-region.err{color:var(--beni-deep);}
.bb-summary{margin-top:22px;}
.bb-line{display:flex;justify-content:space-between;align-items:baseline;padding:7px 2px;font-size:14.5px;color:var(--sumi);}
.bb-line span:last-child{font-family:"Noto Serif JP",serif;font-weight:600;}
.bb-line small{font-size:11.5px;color:var(--sumi-soft);font-weight:400;margin-left:6px;font-family:"Noto Sans JP";}
.bb-grand{border-top:1.5px solid var(--kin);margin-top:10px;padding-top:16px;align-items:center;}
.bb-grand>span:first-child{font-size:18px;font-weight:600;color:var(--sumi);}
.bb-grand span:last-child{font-size:33px;color:var(--beni-deep);line-height:1.1;}
@media(max-width:860px){
  .buybox{padding:24px 18px;}
  .bb-row{flex-direction:column;gap:9px;}
  .bb-label{flex:none;padding-top:0;}
  .bb-grand span:last-child{font-size:29px;}
}

/* ---- 注意ボックス（クール便など） ---- */
.notebox{background:var(--washi-deep);border:1px solid var(--line);border-radius:10px;padding:22px 26px;}
.notebox h4{font-family:"Noto Serif JP",serif;font-size:17px;font-weight:600;margin-bottom:10px;}
.notebox p{font-size:13.5px;color:var(--sumi-soft);line-height:1.9;}
.notebox .hl{color:var(--beni-deep);font-weight:600;}
@media(max-width:860px){
  .ptable thead th,.ptable tbody th,.ptable tbody td{padding:9px 2px;}
  .ptable thead th{font-size:11px;}
  .ptable thead th small{font-size:9.5px;}
  .ptable tbody th{font-size:12.5px;}
  .ptable tbody th small{font-size:10px;}
  .ptable tbody td{font-size:12.5px;}
  .notebox{padding:18px 18px;}
}

/* ---- 3つの理由 ---- */
.reasons{background:var(--washi);}
.reason-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.reason{background:var(--card);border:1px solid var(--line);border-radius:8px;padding:46px 30px 42px;text-align:center;position:relative;}
.reason::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:40px;height:2px;background:var(--kin);}
.reason .no{font-family:"Noto Serif JP",serif;color:var(--kin);font-size:13px;letter-spacing:.3em;}
.reason .ico{width:70px;height:70px;margin:18px auto 20px;border:1px solid var(--kin);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--beni);}
.reason .ico svg{width:34px;height:34px;display:block;}
.reason h3{font-family:"Noto Serif JP",serif;font-size:20px;font-weight:600;margin-bottom:12px;letter-spacing:.04em;}
.reason p{font-size:14.5px;color:var(--sumi-soft);}
/* 写真入りこだわりカード（aboutページ用） */
.reason.has-photo{padding:0;overflow:hidden;}
.reason.has-photo::before{display:none;}
.reason.has-photo .rphoto img{width:100%;height:194px;object-fit:cover;display:block;}
.reason.has-photo .rbody{padding:28px 28px 34px;text-align:center;}
.reason.has-photo .no{display:block;margin-bottom:14px;}

/* ---- 物語 ---- */
.story{background:var(--card);}
.story-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center;}
.story-grid.rev .photo{order:2;}
.story .photo{border-radius:10px;overflow:hidden;border:1px solid var(--line);box-shadow:0 14px 40px rgba(42,38,34,.10);}
.story .photo img{width:100%;aspect-ratio:4/3;object-fit:cover;}
.story .en{font-size:12px;letter-spacing:.32em;color:var(--kin);}
.story h2{font-family:"Noto Serif JP",serif;font-size:30px;font-weight:600;line-height:1.6;margin:14px 0 22px;letter-spacing:.04em;}
.story p{color:var(--sumi-soft);font-size:15px;margin-bottom:16px;}

/* ---- 9つの穴（縁起） ---- */
.nine{background:var(--washi);}
.nine-inner{display:grid;grid-template-columns:auto 1fr;gap:56px;align-items:center;max-width:900px;margin:0 auto;}
.nine-num{flex:none;width:200px;height:200px;border-radius:50%;border:2px solid var(--kin);display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--card);box-shadow:0 10px 30px rgba(180,154,94,.15);}
.nine-num b{font-family:"Noto Serif JP",serif;font-size:96px;font-weight:600;color:var(--beni);line-height:1;}
.nine-num span{font-size:16px;color:var(--sumi);letter-spacing:.14em;margin-top:2px;}
.nine-visual{position:relative;width:380px;flex:none;}
.nine-visual img{width:100%;border-radius:14px;display:block;box-shadow:0 14px 40px rgba(42,38,34,.12);}
.nine-badge{position:absolute;left:-22px;bottom:-22px;width:118px;height:118px;border-radius:50%;background:var(--card);border:2px solid var(--kin);display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:0 10px 24px rgba(180,154,94,.2);}
.nine-badge b{font-family:"Noto Serif JP",serif;font-size:50px;font-weight:600;color:var(--beni);line-height:1;}
.nine-badge span{font-size:12px;color:var(--sumi);letter-spacing:.1em;margin-top:1px;}
.nine-text .en{font-size:12px;letter-spacing:.32em;color:var(--kin);text-transform:uppercase;}
.nine-text h2{font-family:"Noto Serif JP",serif;font-size:30px;font-weight:600;margin:12px 0 20px;letter-spacing:.04em;}
.nine-text p{color:var(--sumi-soft);font-size:15px;line-height:1.95;margin-bottom:14px;}
.nine-text b{color:var(--beni-deep);}
@media(max-width:860px){.nine-inner{grid-template-columns:1fr;gap:24px;text-align:center;justify-items:center;}.nine-num{width:160px;height:160px;}.nine-num b{font-size:76px;}.nine-visual{width:100%;max-width:360px;}.nine-text h2{font-size:24px;}}

/* ---- お客様の声 ---- */
.voices{background:var(--washi);}
.voice-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;align-items:stretch;}
.voice{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:30px 26px 26px;position:relative;overflow:hidden;display:flex;flex-direction:column;min-height:236px;box-shadow:0 8px 24px rgba(42,38,34,.05);transition:transform .2s,box-shadow .2s;}
.voice:hover{transform:translateY(-4px);box-shadow:0 16px 34px rgba(42,38,34,.10);}
.voice::before{content:"\201C";font-family:Georgia,"Noto Serif JP",serif;font-size:76px;line-height:1;color:rgba(168,90,110,.13);position:absolute;top:8px;right:18px;pointer-events:none;}
.voice::after{content:"";position:absolute;left:0;top:0;width:100%;height:3px;background:linear-gradient(90deg,var(--beni) 0%,var(--kin) 100%);opacity:.55;}
.vname{font-family:"Noto Serif JP",serif;font-weight:600;font-size:15px;color:var(--beni-deep);margin-bottom:12px;letter-spacing:.03em;}
.vbig{width:100%;height:180px;object-fit:cover;border-radius:8px;display:block;}
.voice .stars{color:var(--kin);letter-spacing:.18em;font-size:15px;margin-bottom:14px;}
.voice .vtitle{font-family:"Noto Serif JP",serif;font-weight:600;font-size:16px;color:var(--beni-deep);margin-bottom:10px;line-height:1.5;}
.voice p{font-size:14.5px;color:var(--sumi);line-height:1.95;position:relative;z-index:1;}
.voice .who{margin-top:18px;font-size:13px;color:var(--sumi-soft);}
.voice .vfoot{display:flex;align-items:center;gap:12px;margin-top:18px;}
.voice .vphoto{width:58px;height:58px;border-radius:8px;object-fit:cover;flex:none;border:1px solid var(--line);}
.voice .vfoot .who{margin-top:0;}
@media(max-width:1080px){.voice-grid{grid-template-columns:repeat(2,1fr);}}
/* お客様の声 装飾バンド */
.voice-band{margin:8px 0 52px;text-align:center;}
.voice-band .vb-photo{width:100%;max-width:1000px;display:block;margin:0 auto;border-radius:16px;box-shadow:0 12px 32px rgba(42,38,34,.10);}
.voice-band .vb-cap{font-family:"Noto Serif JP",serif;font-weight:500;font-size:24px;color:var(--sumi);line-height:1.9;margin-top:26px;letter-spacing:.02em;}
.voice-band .vb-cap .em{color:var(--beni-deep);}
.voice-band .vb-rule{width:48px;height:1px;background:var(--kin);margin:18px auto 0;opacity:.7;}
@media(max-width:860px){.voice-band .vb-cap{font-size:19px;margin-top:20px;}}

/* ---- レシピ ---- */
.recipe-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.recipe{background:var(--card);border:1px solid var(--line);border-radius:10px;overflow:hidden;transition:.2s;}
.recipe:hover{transform:translateY(-3px);box-shadow:0 14px 30px rgba(42,38,34,.12);}
.recipe .ph{height:200px;overflow:hidden;}
.recipe .ph img{width:100%;height:100%;object-fit:cover;}
.recipe .body{padding:24px 24px 28px;}
.recipe .cat{font-size:11px;letter-spacing:.12em;color:var(--matcha);}
.recipe h3{font-family:"Noto Serif JP",serif;font-size:19px;font-weight:600;margin:8px 0 10px;}
.recipe p{font-size:13.5px;color:var(--sumi-soft);}
.recipe .min{margin-top:14px;font-size:12px;color:var(--kin);letter-spacing:.06em;}
/* ---- クックパッド誘導 ---- */
.cookpad-box{max-width:680px;margin:54px auto 0;background:var(--washi-deep);border:1px solid var(--line);border-radius:12px;padding:38px 32px;text-align:center;}
.cookpad-box .cp-en{display:block;font-size:12px;letter-spacing:.3em;color:var(--kin);margin-bottom:10px;}
.cookpad-box h3{font-family:"Noto Serif JP",serif;font-size:23px;font-weight:600;margin-bottom:14px;letter-spacing:.04em;}
.cookpad-box p{font-size:14.5px;color:var(--sumi-soft);line-height:1.9;margin-bottom:24px;}
.cookpad-box b{color:var(--beni-deep);}
/* 同梱レシピ（しんじょ椀）強調カード */
.recipe.featured{border-color:var(--beni);box-shadow:0 12px 30px rgba(168,90,110,.14);}
.recipe.featured .cat{color:#fff;background:var(--beni);border-radius:4px;padding:3px 9px;display:inline-block;}
.recipe .body b{color:var(--beni-deep);}

/* ---- ご注文ガイド ---- */
.guide{background:var(--washi-deep);}
.guide-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;}
.guide .item{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:30px 30px;}
.guide .item h3{font-family:"Noto Serif JP",serif;font-size:18px;font-weight:600;margin-bottom:12px;display:flex;align-items:center;gap:10px;}
.guide .item h3 .dot{width:8px;height:8px;border-radius:50%;background:var(--beni);}
.guide .item p{font-size:14px;color:var(--sumi-soft);}
.pay-cards{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px;}
.pay-cards span{font-size:12px;border:1px solid var(--line);border-radius:4px;padding:4px 10px;color:var(--sumi-soft);background:var(--washi);}

/* ---- 手順ステップ ---- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;counter-reset:step;}
.step{background:var(--card);border:1px solid var(--line);border-radius:8px;padding:30px 22px;text-align:center;position:relative;}
.step .n{font-family:"Noto Serif JP",serif;font-size:13px;color:var(--kin);letter-spacing:.2em;}
.step .ico{width:56px;height:56px;margin:14px auto 12px;border:1px solid var(--kin);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--beni);}
.step .ico svg{width:28px;height:28px;display:block;}
.step h4{font-family:"Noto Serif JP",serif;font-size:16px;margin-bottom:8px;}
.step p{font-size:13px;color:var(--sumi-soft);}

/* ---- 表（特商法など） ---- */
.tbl{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--line);border-radius:10px;overflow:hidden;}
.tbl th,.tbl td{text-align:left;padding:18px 22px;border-bottom:1px solid var(--line);font-size:14.5px;vertical-align:top;}
.tbl th{background:var(--washi-deep);width:30%;font-weight:600;color:var(--sumi);font-family:"Noto Serif JP",serif;letter-spacing:.04em;}
.tbl tr:last-child th,.tbl tr:last-child td{border-bottom:none;}
/* プライバシーポリシー */
.policy h3{font-family:"Noto Serif JP",serif;font-size:18px;font-weight:600;color:var(--sumi);margin:32px 0 10px;padding-left:14px;border-left:3px solid var(--beni);}
.policy p{font-size:14.5px;color:var(--sumi-soft);line-height:1.95;}
.policy-list{margin:10px 0 0;padding-left:1.3em;}
.policy-list li{font-size:14.5px;color:var(--sumi-soft);line-height:1.9;list-style:disc;margin-bottom:5px;}
.step-list{margin:14px 0 0;padding-left:0;list-style:none;}
.step-list li{padding:14px 18px;background:var(--washi);border-radius:8px;margin-bottom:10px;font-size:14.5px;color:var(--sumi);line-height:1.75;}
.step-list li b{color:var(--beni-deep);margin-right:8px;font-family:"Noto Serif JP",serif;}
/* お知らせ（NEWS） */
.news-list{max-width:800px;margin:0 auto;border-top:1px solid var(--line);}
.news-item{display:flex;gap:20px;align-items:flex-start;padding:22px 4px;border-bottom:1px solid var(--line);}
.news-date{font-family:"Noto Serif JP",serif;font-size:13px;color:var(--sumi-soft);min-width:88px;padding-top:3px;letter-spacing:.04em;}
.news-cat{font-size:11px;letter-spacing:.06em;color:#fff;background:var(--beni);border-radius:4px;padding:4px 11px;white-space:nowrap;margin-top:2px;flex:none;}
.news-body{font-size:15px;color:var(--sumi);line-height:1.75;}
.news-body a{color:var(--beni-deep);font-weight:600;}
@media(max-width:640px){.news-item{flex-wrap:wrap;gap:8px 14px;}}
.sns-follow{max-width:800px;margin:56px auto 0;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:40px 30px;text-align:center;box-shadow:0 10px 30px rgba(42,38,34,.05);}
.sns-follow h3{font-family:"Noto Serif JP",serif;font-size:22px;color:var(--sumi);margin-bottom:12px;}
.sns-follow p{font-size:14px;color:var(--sumi-soft);line-height:1.9;margin-bottom:24px;}
.sns-btns{display:flex;gap:18px;justify-content:center;flex-wrap:wrap;}
.sns-ic{width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;transition:transform .2s,box-shadow .2s;}
.sns-ic svg{width:27px;height:27px;display:block;}
.sns-ic:hover{transform:translateY(-3px);box-shadow:0 8px 18px rgba(42,38,34,.20);}
.sns-ic.ig{background:linear-gradient(45deg,#feda75 5%,#fa7e1e 30%,#d62976 55%,#962fbf 78%,#4f5bd5 100%);}
.sns-ic.th{background:#000;}
.sns-ic.line{background:#06C755;}
.sns-ic.fb{background:#1877F2;}

/* ---- お問い合わせ ---- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;}
.contact-info .lead{font-size:15px;color:var(--sumi-soft);margin-bottom:24px;}
.contact-box{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:30px;margin-bottom:18px;}
.contact-box h3{font-family:"Noto Serif JP",serif;font-size:17px;margin-bottom:8px;}
.contact-box .big{font-family:"Noto Serif JP",serif;font-size:30px;color:var(--beni-deep);font-weight:600;letter-spacing:.04em;}
.form .field{margin-bottom:18px;}
.form label{display:block;font-size:13px;margin-bottom:7px;color:var(--sumi);}
.form label .req{color:var(--beni);font-size:11px;margin-left:6px;}
.form input,.form textarea{
  width:100%;border:1px solid var(--line);border-radius:6px;padding:13px 14px;
  font-family:inherit;font-size:15px;background:var(--card);color:var(--sumi);
}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--beni);}
.form input[type=file]{padding:10px 12px;background:var(--washi);font-size:13px;cursor:pointer;}
.form textarea{min-height:130px;resize:vertical;}

/* ---- 汎用テキストブロック ---- */
.prose{max-width:760px;margin:0 auto;}
.prose p{margin-bottom:18px;color:var(--sumi-soft);font-size:15.5px;}
.prose h2{font-family:"Noto Serif JP",serif;font-size:24px;margin:36px 0 16px;font-weight:600;}

/* ---- フッター ---- */
footer.site{background:var(--sumi);color:#E8E0D2;padding:56px 0 30px;}
footer.site .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;}
footer.site .name{font-family:"Noto Serif JP",serif;font-size:20px;letter-spacing:.1em;margin-bottom:14px;}
footer.site .info{font-size:13px;line-height:2;color:#C6BCAA;}
footer.site h4{font-size:13px;letter-spacing:.16em;color:#fff;margin-bottom:14px;}
footer.site ul{list-style:none;}
footer.site ul li{margin-bottom:10px;}
footer.site ul a{font-size:13.5px;color:#C6BCAA;}
footer.site ul a:hover{color:#fff;}
footer.site .copy{border-top:1px solid #44403a;margin-top:40px;padding-top:20px;text-align:center;font-size:12px;color:#9a9184;letter-spacing:.06em;}

/* ---- スマホ ---- */
@media(max-width:860px){
  /* 上部ユーティリティ：電話番号が見切れないようコンパクトに */
  .utility .wrap{height:auto;padding-top:9px;padding-bottom:9px;gap:10px;justify-content:center;}
  .tel .label{display:none;}
  .tel .num{font-size:19px;}
  .util-right{gap:12px;}
  .util-cart{white-space:nowrap;}
  /* ヘッダー：ロゴの下にメニューを2段で常時表示（スマホでも全ページに飛べる） */
  /* スマホでは追従させない（2段メニューが画面を占有しないように） */
  header.site{position:static;}
  header.site .wrap{height:auto;flex-wrap:wrap;justify-content:center;padding-top:12px;padding-bottom:8px;gap:6px;}
  .logo-img{height:64px;}
  nav.main{display:block;width:100%;}
  nav.main ul{flex-wrap:wrap;justify-content:center;gap:4px 14px;border-top:1px solid var(--line);margin-top:6px;padding-top:8px;}
  nav.main a{font-size:13.5px;padding:4px 4px;}
  /* モバイルではdropdown→インライン展開 */
  nav.main .caret{display:none;}
  nav.main > ul > li.has-sub > a{display:none;}
  nav.main .sub{position:static;transform:none;opacity:1;visibility:visible;background:none;border:none;box-shadow:none;padding:0;display:contents;}
  nav.main .sub li{display:inline-block;}
  nav.main .sub a{display:inline-block;padding:4px 4px;font-size:13.5px;border-left:none;background:none;}
  nav.main .sub a.active{border-left:none;border-color:var(--beni);background:none;}
  .hero{height:480px;}
  .hero h1{font-size:31px;}
  .hero .copy2 .c2-main{font-size:26px;}
  .page-hero{height:200px;}
  .page-hero[style*="height:520px"],
  .page-hero[style*="height:420px"]{height:280px !important;}
  .page-hero .ttl h1{font-size:25px;line-height:1.5;}
  .product,.story-grid,.contact-grid{grid-template-columns:1fr;gap:30px;}
  .story-grid.rev .photo{order:0;}
  .reason-grid,.recipe-grid,.guide-grid{grid-template-columns:1fr;}
  .voice-grid{grid-template-columns:1fr;}
  .steps{grid-template-columns:1fr 1fr;}
  footer.site .cols{grid-template-columns:1fr;gap:30px;}
  .util-left{display:none;}
  section{padding:60px 0;}
  .tel .num{font-size:21px;}
  .tbl th{width:38%;}
}

/* ---- れんこんのこと ページ ---- */
.renkon-toc{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:26px 30px;}
.renkon-toc-ttl{font-family:"Noto Serif JP",serif;font-size:16px;letter-spacing:.1em;color:var(--sumi-soft);font-weight:500;margin-bottom:14px;text-align:center;}
.renkon-toc ol{padding-left:20px;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:8px 24px;}
.renkon-toc li{font-size:14.5px;line-height:1.7;}
.renkon-toc a{color:var(--sumi);text-decoration:none;border-bottom:1px solid transparent;transition:color .2s,border-color .2s;}
.renkon-toc a:hover{color:var(--beni-deep);border-bottom-color:var(--beni-deep);}
@media(max-width:640px){.renkon-toc ol{grid-template-columns:1fr;}}

.renkon-sec{padding:60px 0 50px;border-bottom:1px solid var(--line);}
.renkon-sec:last-of-type{border-bottom:none;}
.renkon-num{font-family:"Noto Serif JP",serif;font-size:48px;color:var(--beni-deep);letter-spacing:.04em;line-height:1;margin-bottom:8px;opacity:.55;}
.renkon-h2{font-family:"Noto Serif JP",serif;font-size:28px;font-weight:600;letter-spacing:.05em;line-height:1.5;margin-bottom:20px;color:var(--sumi);}
.renkon-h3{font-family:"Noto Serif JP",serif;font-size:19px;font-weight:600;letter-spacing:.04em;margin:32px 0 12px;color:var(--sumi);border-left:3px solid var(--beni-deep);padding-left:12px;}
.renkon-lead{font-size:16px;line-height:2;color:var(--sumi);margin-bottom:30px;background:var(--washi-deep);padding:18px 22px;border-radius:8px;}
.renkon-lead b{color:var(--beni-deep);}
.renkon-sec p{font-size:15px;line-height:1.95;color:var(--sumi-soft);margin-bottom:14px;}

.renkon-figure{margin:30px 0;text-align:center;}
.renkon-figure img{width:100%;max-width:700px;height:auto;border-radius:8px;border:1px solid var(--line);box-shadow:0 8px 26px rgba(42,38,34,.08);display:block;}
.renkon-figure .cap{font-size:13px;color:var(--sumi-soft);margin-top:12px;font-style:italic;}
.renkon-figure-wrap{position:relative;display:inline-block;max-width:700px;width:100%;line-height:0;}
.renkon-img-note{position:absolute;top:10px;right:14px;background:rgba(46,42,38,.6);color:#fff;padding:3px 10px;border-radius:4px;font-size:11px;letter-spacing:.05em;line-height:1.4;font-family:"Noto Sans JP",sans-serif;}
.renkon-label{position:absolute;background:rgba(255,255,255,.94);color:var(--beni-deep);padding:3px 11px;border-radius:999px;font-size:13px;font-weight:700;border:1.5px solid var(--beni-deep);box-shadow:0 2px 6px rgba(0,0,0,.18);letter-spacing:.05em;white-space:nowrap;transform:translate(-50%,-50%);font-family:"Noto Serif JP",serif;line-height:1.3;}
@media (max-width:600px){
  .renkon-label{font-size:11px;padding:2px 8px;}
  .renkon-img-note{font-size:10px;padding:2px 8px;}
}

.renkon-timeline{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:24px;}
@media(max-width:640px){.renkon-timeline{grid-template-columns:1fr;}}
.rt-item{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:22px 24px;}
.rt-month{display:inline-block;background:var(--beni-deep);color:#fff;font-family:"Noto Serif JP",serif;font-size:14px;letter-spacing:.08em;padding:4px 14px;border-radius:999px;margin-bottom:10px;font-weight:500;}
.rt-item h4{font-family:"Noto Serif JP",serif;font-size:18px;font-weight:600;margin-bottom:8px;color:var(--sumi);}
.rt-item p{font-size:14px;line-height:1.85;color:var(--sumi-soft);margin:0;}

.renkon-parts{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:24px;}
@media(max-width:640px){.renkon-parts{grid-template-columns:1fr;}}
.rp-item{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:20px 22px;}
.rp-item h4{margin-bottom:8px;}
.rp-name{display:inline-block;font-family:"Noto Serif JP",serif;font-size:18px;font-weight:600;color:var(--beni-deep);border-bottom:2px solid var(--beni-deep);padding-bottom:2px;}
.rp-item p{font-size:14px;line-height:1.85;color:var(--sumi-soft);margin:0;}
.rp-item b{color:var(--sumi);}

.renkon-callout{background:#fff7eb;border:1px solid #e8d8b2;border-radius:10px;padding:20px 24px;margin-top:30px;}
.renkon-callout p{margin:0;font-size:14.5px;line-height:1.95;color:var(--sumi);}
.renkon-callout a{color:var(--beni-deep);font-weight:600;text-decoration:none;border-bottom:1px solid var(--beni-deep);}

.renkon-storage{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:24px;}
@media(max-width:640px){.renkon-storage{grid-template-columns:1fr;}}
.rs-item{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:22px 24px;}
.rs-item h4{font-family:"Noto Serif JP",serif;font-size:17px;font-weight:600;margin-bottom:10px;color:var(--sumi);}
.rs-item p{font-size:14px;line-height:1.85;color:var(--sumi-soft);margin:0;}
.rs-item b{color:var(--beni-deep);}

/* タイムライン（写真付き） */
.rt-has-photo{padding:0;overflow:hidden;display:flex;flex-direction:column;}
.rt-photo{width:100%;height:180px;overflow:hidden;background:var(--washi-deep);}
.rt-photo img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s;}
.rt-has-photo:hover .rt-photo img{transform:scale(1.04);}
.rt-body{padding:20px 22px;}
.rt-body h4{font-family:"Noto Serif JP",serif;font-size:18px;font-weight:600;margin-bottom:8px;color:var(--sumi);}
.rt-body p{font-size:14px;line-height:1.85;color:var(--sumi-soft);margin:0;}

/* 保存方法（写真付き） */
.rs-has-photo{padding:0;overflow:hidden;display:grid;grid-template-columns:140px 1fr;gap:0;}
.rs-photo{width:100%;height:100%;min-height:160px;overflow:hidden;background:var(--washi-deep);}
.rs-photo img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s;}
.rs-has-photo:hover .rs-photo img{transform:scale(1.04);}
.rs-body{padding:18px 20px;}
.rs-howto{font-size:13.5px;line-height:1.6;color:var(--sumi);margin:0 0 8px;padding:8px 12px;background:#fff7eb;border-left:3px solid var(--beni-deep);border-radius:4px;}
.rs-howto b{color:var(--sumi);}
@media(max-width:640px){
  .rs-has-photo{grid-template-columns:1fr;}
  .rs-photo{height:180px;}
}

/* 2カラム（テキスト+写真） */
.renkon-twocol{display:grid;grid-template-columns:1fr 280px;gap:30px;align-items:start;margin-top:20px;}
.rtc-photo img{width:100%;height:auto;border-radius:8px;border:1px solid var(--line);}
.rtc-photo .cap{font-size:12.5px;color:var(--sumi-soft);margin-top:8px;text-align:center;font-style:italic;}
@media(max-width:640px){.renkon-twocol{grid-template-columns:1fr;}}
