:root{
    /* ---- 白基調（白を主役に・温かみはほんのり・品） ---- */
    --white:    #FFFFFF;   /* 純白（基調） */
    --paper:    #F7F4ED;   /* ごく淡い温白：セクションの抑揚 */
    --ink:      #242019;   /* 主文字（温かい黒） */
    --ink-soft: #7E776A;   /* 補助文字（温かなグレージュ） */
    --line:     #EBE6DB;   /* 極細罫線 */
    --line-2:   #DED7C8;

    /* ---- ブランド4色（差し色として抑制して使用） ---- */
    --red:      #d71918;
    --green:    #17823b;
    --orange:   #e86b12;
    --yellow:   #f4ce21;

    --serif-jp: "Shippori Mincho", "Hiragino Mincho ProN", "Yu Mincho", serif;
    --serif-en: "Cormorant Garamond", serif;
    --sans-jp:  "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", sans-serif;

    --maxw: 1220px;
    --gut: clamp(22px, 5vw, 64px);
    --ease: cubic-bezier(.22,.61,.36,1);
  }

  *{ margin:0; padding:0; box-sizing:border-box; }
  html{ scroll-behavior:smooth; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; }
  body{
    font-family:var(--sans-jp);
    color:var(--ink);
    background:var(--white);
    line-height:2;
    font-weight:400;
    letter-spacing:.04em;
    overflow-x:hidden;
  }
  img{ display:block; max-width:100%; }
  a{ color:inherit; text-decoration:none; }
  ::selection{ background:#FCEFB6; color:var(--ink); }

  .wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gut); }

  /* ---- 共通：見出し ---- */
  .eyebrow{
    font-family:var(--serif-en); font-style:italic;
    font-size:14px; letter-spacing:.22em; text-transform:uppercase;
    color:var(--green);
    display:inline-flex; align-items:center; gap:14px;
  }
  .eyebrow::before{ content:""; width:30px; height:1px; background:var(--green); }
  .sec-title{
    font-family:var(--serif-jp); font-weight:500;
    font-size:clamp(27px,3.6vw,44px);
    line-height:1.5; letter-spacing:.06em; margin-top:22px;
  }
  .sec-title .accent{ color:var(--orange); }
  .lead{ color:var(--ink-soft); font-weight:400; }

  .arrow-link{ font-size:13.5px; letter-spacing:.12em; display:inline-flex; align-items:center; gap:10px; color:var(--ink); padding-bottom:4px; border-bottom:1px solid var(--line-2); transition:gap .3s var(--ease), border-color .3s; }
  .arrow-link:hover{ gap:16px; border-color:var(--orange); }
  .arrow-link svg{ width:16px; height:10px; }

  /* ===== Header ===== */
  .header{
    position:sticky; top:0; z-index:50;
    background:rgba(255,255,255,.78);
    backdrop-filter:saturate(140%) blur(14px);
    border-bottom:1px solid transparent;
    transition:border-color .5s var(--ease);
  }
  .header.scrolled{ border-color:var(--line); }
  .nav{ display:flex; align-items:center; justify-content:space-between; height:86px; }
  .brand{ display:flex; align-items:center; gap:12px; }
  .brand .mark{ width:64px; height:64px; flex:none; object-fit:contain; }
  .brand .wordmark{ height:46px; width:auto; }
  .menu{ display:flex; align-items:center; gap:36px; }
  .menu a{ font-size:13.5px; letter-spacing:.1em; color:var(--ink-soft); position:relative; transition:color .3s; }
  .menu a::after{ content:""; position:absolute; left:0; bottom:-7px; width:0; height:1px; background:var(--orange); transition:width .4s var(--ease); }
  .menu a:hover{ color:var(--ink); }
  .menu a:hover::after{ width:100%; }
  .btn-shop{
    font-size:13px; letter-spacing:.12em; color:var(--ink);
    border:1px solid var(--ink); padding:11px 24px; border-radius:999px;
    display:inline-flex; align-items:center; gap:9px; transition:background .35s var(--ease), color .35s, border-color .35s;
  }
  .menu a.btn-shop{ color:var(--ink); }
  .menu a.btn-shop::after{ display:none; }
  .menu a.btn-shop:hover{ background:var(--orange); color:#fff; border-color:var(--orange); }
  .btn-shop svg{ width:14px; height:9px; }
  .hamb{ display:none; }

  /* ===== Hero ===== */
  .hero{ position:relative; min-height:min(92vh,820px); display:flex; align-items:flex-end; overflow:hidden; color:#fff; }
  .hero-slides{ position:absolute; inset:0; z-index:0; }
  .hslide{ position:absolute; inset:0; background-size:cover; background-position:center; opacity:0; transform:scale(1.04); transition:opacity 1.8s var(--ease), transform 8s linear; filter:brightness(1.1) saturate(1.04); will-change:opacity, transform; }
  .hslide.is-active{ opacity:1; z-index:1; transform:scale(1.14) translate(-1.8%, -1.2%); }
  @media (prefers-reduced-motion: reduce){
    .hslide{ transition:opacity 1.8s var(--ease); }
    .hslide.is-active{ transform:none; }
  }
  .hero-scrim{ position:absolute; inset:0; z-index:1; background:
      linear-gradient(to top, rgba(20,16,10,.52) 0%, rgba(20,16,10,.16) 44%, rgba(20,16,10,.04) 100%),
      linear-gradient(to right, rgba(20,16,10,.28) 0%, rgba(20,16,10,0) 56%); }
  .hero-inner{ position:relative; z-index:2; width:100%; padding-top:clamp(70px,12vh,150px); padding-bottom:clamp(70px,10vh,128px); }
  .hero-copy{ max-width:640px; }
  .hero-copy .eyebrow{ color:#fff; margin-bottom:26px; }
  .hero-copy .eyebrow::before{ background:#fff; }
  .hero h1{
    color:#fff; font-family:var(--serif-jp); font-weight:500;
    font-size:clamp(34px,4.8vw,64px);
    line-height:1.34; letter-spacing:.05em; text-shadow:0 2px 30px rgba(0,0,0,.35);
  }
  .hero h1 .ln{ white-space:nowrap; }
  .hero h1 .l2{ color:#fff; }
  .hero .lead{ color:rgba(255,255,255,.92); margin-top:24px; font-size:clamp(14.5px,1.4vw,16px); line-height:2.1; max-width:30em; text-shadow:0 1px 16px rgba(0,0,0,.3); }
  .hero-cta{ margin-top:38px; display:flex; gap:26px; flex-wrap:wrap; align-items:center; }
  .hero .arrow-link{ color:#fff; border-color:rgba(255,255,255,.45); }
  .hero .arrow-link:hover{ border-color:#fff; }
  .btn-primary{
    background:var(--orange); color:#fff; padding:16px 34px; border-radius:999px;
    font-size:14px; letter-spacing:.12em; display:inline-flex; align-items:center; gap:11px;
    transition:transform .35s var(--ease), box-shadow .35s; box-shadow:0 12px 26px -16px rgba(232,107,18,.9);
  }
  .btn-primary:hover{ transform:translateY(-2px); box-shadow:0 18px 32px -16px rgba(232,107,18,.95); }
  .btn-primary svg{ width:16px; height:10px; transition:transform .35s var(--ease); }
  .btn-primary:hover svg{ transform:translateX(5px); }

  /* hero slideshow dots & scroll */
  .hero-dots{ position:absolute; z-index:3; right:var(--gut); bottom:clamp(70px,10vh,128px); display:flex; gap:10px; }
  .hero-dots .dot{ width:9px; height:9px; padding:0; border-radius:50%; border:1px solid rgba(255,255,255,.75); background:transparent; cursor:pointer; transition:background .3s; }
  .hero-dots .dot.is-active{ background:#fff; }
  .hero-scroll{ position:absolute; z-index:3; left:var(--gut); bottom:26px; display:inline-flex; align-items:center; gap:13px;
    font-family:var(--serif-en); font-style:italic; font-size:12px; letter-spacing:.22em; color:rgba(255,255,255,.85); text-transform:uppercase; }
  .hero-scroll::after{ content:""; width:50px; height:1px; background:rgba(255,255,255,.85); transform-origin:left; animation:scrollLn 2.2s var(--ease) infinite; }
  @keyframes scrollLn{ 0%,100%{ transform:scaleX(.35); opacity:.4 } 50%{ transform:scaleX(1); opacity:1 } }

  /* ===== Keyword strip ===== */
  .strip{ border-block:1px solid var(--line); overflow:hidden; }
  .strip-track{ display:flex; white-space:nowrap; animation:marq 38s linear infinite; }
  .strip-track .seg{ display:inline-flex; align-items:center; padding:15px 0; }
  .strip-track .seg > span{ font-family:var(--serif-en); font-style:italic; font-size:15px; letter-spacing:.18em; color:#9C978C; padding:0 38px; display:inline-flex; align-items:center; gap:38px; }
  .strip-track .seg i{ width:5px; height:5px; border-radius:50%; background:var(--green); display:inline-block; }
  @keyframes marq{ to{ transform:translateX(-50%); } }

  /* ===== Concept ===== */
  .concept{ padding:clamp(80px,12vw,160px) 0; }
  .concept .wrap{ display:grid; grid-template-columns:.95fr 1.05fr; gap:clamp(40px,7vw,90px); align-items:center; }
  .concept-figure{ aspect-ratio:5/6; background:var(--paper); border:1px solid var(--line); border-radius:4px; position:relative; display:grid; place-items:center; overflow:hidden; }
  .concept-figure .fig-media{ position:absolute; inset:-13% 0; }
  .concept-figure .fig-media img{ width:100%; height:100%; object-fit:cover; display:block; }

  /* ---- Parallax ---- */
  [data-parallax]{ will-change:transform; }
  .concept-body .sec-title{ margin-bottom:30px; }
  .concept-body p{ color:var(--ink-soft); margin-bottom:22px; font-size:15px; line-height:2.25; }
  .concept-body .sign{ font-family:var(--serif-jp); font-size:17px; color:var(--ink); margin-top:34px; letter-spacing:.08em; }

  /* ===== Values ===== */
  .values{ padding:clamp(70px,10vw,130px) 0; background:var(--paper); border-block:1px solid var(--line); }
  .values .head{ max-width:680px; margin:0 auto clamp(46px,7vw,78px); text-align:center; }
  .values .head .eyebrow{ justify-content:center; }
  .vgrid{ display:grid; grid-template-columns:repeat(3,1fr); }
  .vcard{ padding:0 clamp(20px,3vw,46px); border-left:1px solid var(--line); }
  .vcard:first-child{ border-left:none; padding-left:0; }
  .vcard:last-child{ padding-right:0; }
  .vcard .no{ font-family:var(--serif-en); font-style:italic; font-size:30px; color:var(--green); }
  .vcard .ico{ width:38px; height:38px; margin:24px 0 24px; color:var(--ink); stroke-width:1; }
  .vcard h3{ font-family:var(--serif-jp); font-weight:500; font-size:21px; letter-spacing:.1em; margin-bottom:16px; }
  .vcard p{ font-size:13.5px; color:var(--ink-soft); line-height:2.1; }

  /* ===== Products ===== */
  .products{ padding:clamp(80px,12vw,160px) 0; }
  .products .head{ display:flex; justify-content:space-between; align-items:flex-end; flex-wrap:wrap; gap:24px; margin-bottom:clamp(44px,6vw,70px); }
  .pgrid{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(18px,2vw,30px); }
  /* ---- Carousel（商品・生産者） ---- */
  .car-nav{ display:flex; gap:10px; }
  .car-btn{ width:48px; height:48px; border-radius:50%; border:1px solid var(--line-2); background:transparent; color:var(--ink); display:grid; place-items:center; cursor:pointer; transition:background .3s var(--ease), color .3s, border-color .3s; }
  .car-btn:hover{ background:var(--ink); color:#fff; border-color:var(--ink); }
  .car-btn:disabled{ opacity:.3; cursor:default; }
  .car-btn:disabled:hover{ background:transparent; color:var(--ink); border-color:var(--line-2); }
  .car-btn svg{ width:17px; height:11px; }
  .car-track{ display:flex; gap:clamp(16px,2vw,28px); overflow-x:auto; scroll-snap-type:x mandatory; scroll-behavior:smooth; padding:4px 2px 12px; margin:0 -2px; scrollbar-width:none; }
  .car-track::-webkit-scrollbar{ display:none; }
  .car-track > .pcard{ flex:0 0 clamp(248px, 30%, 332px); scroll-snap-align:start; }
  .pcard{ cursor:pointer; }
  /* 生産者カード内の番号・矢印 */
  .pcard .pno-en{ font-family:var(--serif-en); font-style:italic; font-size:13px; color:var(--green); display:inline-block; margin-top:16px; }
  .pcard .pgo-line{ display:inline-flex; align-items:center; gap:8px; margin-top:14px; font-size:12.5px; letter-spacing:.08em; color:var(--ink); border-bottom:1px solid var(--line-2); padding-bottom:3px; transition:gap .3s var(--ease), border-color .3s; }
  .pcard:hover .pgo-line{ gap:13px; border-color:var(--orange); }
  .pcard .thumb{
    aspect-ratio:3/4; background:var(--paper); border:1px solid var(--line); border-radius:4px;
    position:relative; display:grid; place-items:center; overflow:hidden;
    transition:border-color .4s var(--ease);
  }
  .pcard:hover .thumb{ border-color:var(--line-2); }
  .pcard .thumb .thumb-img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform .9s var(--ease); }
  .pcard:hover .thumb .thumb-img{ transform:scale(1.06); }
  .pcard .num{ position:absolute; z-index:2; top:12px; left:14px; font-family:var(--serif-en); font-style:italic; font-size:13px; color:#fff; text-shadow:0 1px 8px rgba(0,0,0,.5); }
  .pcard .tag{ position:absolute; z-index:2; top:12px; right:12px; font-size:10.5px; letter-spacing:.06em; color:var(--green); background:rgba(255,255,255,.92); padding:4px 11px; border-radius:999px; }
  .pcard h3{ font-family:var(--serif-jp); font-weight:500; font-size:18px; letter-spacing:.08em; margin-top:20px; }
  .pcard .en{ font-family:var(--serif-en); font-style:italic; font-size:12.5px; color:var(--ink-soft); letter-spacing:.08em; margin-top:4px; }
  .pcard .parea{ display:flex; align-items:center; gap:5px; margin-top:9px; font-size:11.5px; color:var(--ink-soft); letter-spacing:.04em; }
  .pcard .parea svg{ width:11px; height:11px; flex:0 0 auto; color:var(--green); }
  .pcard p{ font-size:12.5px; color:var(--ink-soft); margin-top:10px; line-height:1.85; }

  /* ===== Producers ===== */
  .producers{ padding:clamp(80px,12vw,160px) 0; background:var(--paper); border-block:1px solid var(--line); }
  .producers .head{ display:flex; justify-content:space-between; align-items:flex-end; flex-wrap:wrap; gap:24px; margin-bottom:clamp(40px,6vw,64px); }
  .prow{
    display:grid; grid-template-columns:44px 96px 1.4fr 1fr 56px; align-items:center; gap:28px;
    padding:26px 16px; border-top:1px solid var(--line); transition:padding .45s var(--ease);
  }
  .prow .pthumb{ width:96px; height:96px; object-fit:cover; border-radius:5px; }
  .prow:last-child{ border-bottom:1px solid var(--line); }
  .prow:hover{ padding-left:28px; }
  .prow .pno{ font-family:var(--serif-en); font-style:italic; font-size:19px; color:var(--green); }
  .prow .pname{ font-family:var(--serif-jp); font-size:22px; font-weight:500; letter-spacing:.06em; }
  .prow .pname small{ display:block; font-family:var(--sans-jp); font-size:12px; color:var(--ink-soft); font-weight:400; letter-spacing:.05em; margin-top:6px; }
  .prow .pdesc{ font-size:13px; color:var(--ink-soft); line-height:1.95; }
  .prow .pgo{ justify-self:end; color:var(--ink-soft); transition:color .3s, transform .4s var(--ease); }
  .prow:hover .pgo{ color:var(--orange); transform:translate(4px,-4px); }

  /* ===== Parallax band ===== */
  .band{ position:relative; height:clamp(360px,52vh,560px); overflow:hidden; display:grid; place-items:center; }
  .band-bg{ position:absolute; inset:-16% 0; }
  .band-bg img{ width:100%; height:100%; object-fit:cover; display:block; filter:brightness(1.1) saturate(1.04); }
  .band::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(22,18,12,.10) 0%, rgba(22,18,12,.18) 55%, rgba(22,18,12,.28) 100%); }
  .band-inner{ position:relative; z-index:2; text-align:center; color:#fff; padding:0 24px; }
  .band-eyebrow{ font-family:var(--serif-en); font-style:italic; font-size:14px; letter-spacing:.24em; text-transform:uppercase; opacity:.9; }
  .band-copy{ font-family:var(--serif-jp); font-weight:500; font-size:clamp(22px,3.6vw,42px); letter-spacing:.1em; line-height:1.75; margin-top:18px; text-shadow:0 2px 24px rgba(0,0,0,.4); }

  /* ===== News ===== */
  .news{ padding:clamp(80px,12vw,150px) 0; }
  .news .wrap{ display:grid; grid-template-columns:.65fr 1.35fr; gap:clamp(36px,6vw,72px); }
  .nitem{ display:grid; grid-template-columns:92px 78px 1fr; gap:22px; align-items:center; padding:24px 4px; border-top:1px solid var(--line); transition:color .3s; }
  .nitem:last-child{ border-bottom:1px solid var(--line); }
  .nitem:hover{ color:var(--orange); }
  .nitem time{ font-family:var(--serif-en); font-style:italic; font-size:15px; color:var(--ink-soft); }
  .nitem .ntag{ justify-self:start; font-size:10px; letter-spacing:.08em; color:var(--green); border:1px solid var(--green); padding:4px 9px; border-radius:2px; line-height:1; }
  .nitem p{ font-size:14px; }

  /* ===== CTA ===== */
  .cta{ padding:clamp(20px,4vw,40px) 0 clamp(80px,12vw,150px); }
  .cta-box{ text-align:center; border:1px solid var(--line); border-radius:6px; padding:clamp(56px,9vw,100px) var(--gut); background:radial-gradient(120% 130% at 50% -12%, #FBF4E8 0%, var(--paper) 70%); position:relative; overflow:hidden; }
  .cta-box .bar{ position:absolute; top:0; left:0; right:0; height:3px; background:linear-gradient(90deg,var(--green),var(--yellow),var(--orange),var(--red)); }
  .cta-box .eyebrow{ justify-content:center; }
  .cta-box h2{ font-family:var(--serif-jp); font-weight:500; font-size:clamp(27px,4vw,46px); letter-spacing:.06em; margin:20px 0 18px; line-height:1.45; }
  .cta-box p{ color:var(--ink-soft); font-size:14.5px; max-width:32em; margin:0 auto 40px; }

  /* ===== Company ===== */
  .company{ padding:clamp(74px,11vw,140px) 0; background:var(--paper); border-block:1px solid var(--line); }
  .company .wrap{ display:grid; grid-template-columns:1fr 1.4fr; gap:clamp(40px,6vw,80px); }
  .company .sec-title{ margin-bottom:20px; }
  .company .lead{ font-size:14.5px; }
  .ctable{ width:100%; border-collapse:collapse; }
  .ctable th, .ctable td{ text-align:left; padding:21px 4px; border-bottom:1px solid var(--line); vertical-align:top; font-size:14px; }
  .ctable tr:first-child th, .ctable tr:first-child td{ border-top:1px solid var(--line); }
  .ctable th{ width:32%; font-weight:500; color:var(--ink); font-family:var(--serif-jp); letter-spacing:.08em; }
  .ctable td{ color:var(--ink-soft); }
  .note{ font-size:11px; color:var(--orange); letter-spacing:.04em; }

  /* ===== Footer ===== */
  .footer{ padding:clamp(64px,9vw,96px) 0 32px; background:linear-gradient(180deg, var(--white) 0%, #F7F1E6 100%); }
  .footer .top{ display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:40px; padding-bottom:52px; border-bottom:1px solid var(--line); }
  .footer .fdesc{ font-size:13px; line-height:2.1; color:var(--ink-soft); margin-top:22px; max-width:24em; }
  .footer h4{ font-family:var(--serif-en); font-style:italic; font-size:14px; letter-spacing:.22em; text-transform:uppercase; color:var(--green); margin-bottom:20px; }
  .footer ul{ list-style:none; display:flex; flex-direction:column; gap:13px; }
  .footer ul a{ font-size:13px; color:var(--ink-soft); transition:color .3s; }
  .footer ul a:hover{ color:var(--orange); }
  .socials{ display:flex; gap:10px; margin-top:6px; }
  .socials a{ width:38px; height:38px; border-radius:50%; border:1px solid var(--line); display:grid; place-items:center; color:var(--ink-soft); transition:border-color .3s, color .3s; }
  .socials a:hover{ border-color:var(--orange); color:var(--orange); }
  .footer .copy{ display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px; padding-top:28px; font-size:11.5px; color:#A39E92; letter-spacing:.08em; }
  .footer .copy .en{ font-family:var(--serif-en); font-style:italic; }

  /* ===== reveal ===== */
  .reveal{ opacity:0; transform:translateY(22px); transition:opacity 1.1s var(--ease), transform 1.1s var(--ease); }
  .reveal.in{ opacity:1; transform:none; }
  /* 見出し：左からふわっと（1行） */
  .reveal-left{ opacity:0; transform:translateX(-52px); transition:opacity 1s var(--ease), transform 1.2s var(--ease); }
  .reveal-left.in{ opacity:1; transform:none; }
  .reveal-left.rl-2{ transition-delay:.35s; }   /* 見出しの少し後に出る説明文 */
  /* 下からふわっと（三つの約束カード等） */
  .reveal-up{ opacity:0; transform:translateY(44px); transition:opacity 1s var(--ease), transform 1.2s var(--ease); }
  .reveal-up.in{ opacity:1; transform:none; }
  /* グループ内アイテムを順に（生産者行/お知らせ/商品カード/会社概要行/三つの約束） */
  .rl-i:nth-child(2){ transition-delay:.12s; }
  .rl-i:nth-child(3){ transition-delay:.24s; }
  .rl-i:nth-child(4){ transition-delay:.36s; }
  .rl-i:nth-child(5){ transition-delay:.48s; }
  .rl-i:nth-child(6){ transition-delay:.60s; }
  /* 見出し：行ごとに少しずらして左から（複数行） */
  .reveal-lines .ln{ display:block; opacity:0; transform:translateX(-52px); transition:opacity 1s var(--ease), transform 1.2s var(--ease); }
  .reveal-lines.in .ln{ opacity:1; transform:none; }
  .reveal-lines.in .ln:nth-child(2){ transition-delay:.16s; }
  .reveal-lines.in .ln:nth-child(3){ transition-delay:.32s; }
  @media (prefers-reduced-motion: reduce){
    .reveal, .reveal-left, .reveal-up, .reveal-lines .ln{ opacity:1 !important; transform:none !important; transition:none !important; }
  }

  /* ===== Responsive ===== */
  @media (max-width:980px){
    .hero{ min-height:82vh; align-items:flex-end; }
    .hero-copy{ max-width:none; }
    .hero-dots{ display:none; }
    .concept .wrap{ grid-template-columns:1fr; }
    .pgrid{ grid-template-columns:repeat(2,1fr); gap:26px; }
    .vgrid{ grid-template-columns:1fr; }
    .vcard{ border-left:none; padding:34px 0; border-top:1px solid var(--line); }
    .vcard:first-child{ border-top:none; padding-top:0; }
    .vcard .ico{ margin:18px 0; }
    .news .wrap, .company .wrap{ grid-template-columns:1fr; }
    .footer .top{ grid-template-columns:1fr 1fr; gap:34px; }
  }
  @media (max-width:680px){
    .menu{
      position:fixed; inset:0 0 0 auto; width:80%; max-width:330px; background:#fff;
      flex-direction:column; align-items:flex-start; justify-content:center; gap:28px; padding:44px;
      transform:translateX(100%); transition:transform .55s var(--ease); box-shadow:-30px 0 60px -30px rgba(0,0,0,.25); z-index:60;
    }
    .menu.open{ transform:none; }
    .hamb{ display:flex; flex-direction:column; gap:6px; width:28px; cursor:pointer; z-index:70; }
    .hamb span{ height:1.5px; background:var(--ink); transition:transform .4s var(--ease), opacity .3s; }
    .hamb.on span:nth-child(1){ transform:translateY(7.5px) rotate(45deg); }
    .hamb.on span:nth-child(2){ opacity:0; }
    .hamb.on span:nth-child(3){ transform:translateY(-7.5px) rotate(-45deg); }
    .prow{ grid-template-columns:60px 1fr 36px; row-gap:10px; column-gap:18px; }
    .prow .pno{ display:none; }
    .prow .pthumb{ width:60px; height:60px; }
    .prow .pdesc{ grid-column:2/4; }
    .nitem{ grid-template-columns:84px 1fr; }
    .nitem .ntag{ display:none; }
  }
  @media (max-width:460px){ .pgrid{ grid-template-columns:1fr; } .hero h1{ font-size:31px; } }


/* ============================================================
   Sub-pages（下層ページ共通）
   ============================================================ */
.page-hero{ padding:clamp(56px,8vw,96px) 0 clamp(40px,6vw,60px); background:var(--paper); border-bottom:1px solid var(--line); text-align:center; }
.page-hero .eyebrow{ justify-content:center; }
.page-hero h1{ font-family:var(--serif-jp); font-weight:500; font-size:clamp(28px,4.2vw,48px); letter-spacing:.09em; line-height:1.4; margin-top:16px; }
.page-hero .ph-lead{ max-width:34em; margin:18px auto 0; color:var(--ink-soft); font-size:14.5px; line-height:2; }
.breadcrumb{ margin-top:24px; font-size:12px; letter-spacing:.06em; color:var(--ink-soft); }
.breadcrumb a{ color:var(--ink-soft); transition:color .3s; }
.breadcrumb a:hover{ color:var(--orange); }
.breadcrumb i{ font-style:normal; margin:0 12px; color:var(--line-2); }

/* article / legal */
.article{ padding:clamp(56px,8vw,100px) 0 clamp(80px,12vw,150px); }
.article .wrap{ max-width:880px; }
.article .lead{ font-size:15.5px; color:var(--ink-soft); line-height:2.1; margin-bottom:40px; }
.article h2{ font-family:var(--serif-jp); font-weight:500; font-size:clamp(18px,2.3vw,23px); letter-spacing:.06em; color:var(--ink); margin:54px 0 18px; padding-bottom:14px; border-bottom:1px solid var(--line); display:flex; align-items:baseline; gap:14px; }
.article h2 .no{ font-family:var(--serif-en); font-style:italic; font-size:15px; color:var(--green); }
.article h2:first-of-type{ margin-top:0; }
.article h3{ font-family:var(--serif-jp); font-weight:500; font-size:16px; margin:28px 0 10px; letter-spacing:.04em; }
.article p{ color:var(--ink-soft); font-size:14.5px; line-height:2.15; margin-bottom:16px; }
.article ul,.article ol{ margin:0 0 18px; padding-left:1.3em; color:var(--ink-soft); font-size:14.5px; line-height:2.05; }
.article li{ margin-bottom:7px; }
.article a.inline{ color:var(--orange); border-bottom:1px solid var(--line-2); }
.article .updated{ margin-top:48px; font-size:12px; color:var(--ink-soft); text-align:right; font-family:var(--serif-en); font-style:italic; }

.legal-table{ width:100%; border-collapse:collapse; margin:4px 0 10px; }
.legal-table th,.legal-table td{ text-align:left; padding:20px 18px; border-bottom:1px solid var(--line); vertical-align:top; font-size:14px; }
.legal-table tr:first-child th,.legal-table tr:first-child td{ border-top:1px solid var(--line); }
.legal-table th{ width:34%; font-family:var(--serif-jp); font-weight:500; color:var(--ink); background:var(--paper); letter-spacing:.04em; }
.legal-table td{ color:var(--ink-soft); line-height:1.95; }
.legal-table .note{ font-size:11.5px; color:var(--orange); }
@media(max-width:640px){
  .legal-table, .legal-table tbody, .legal-table tr, .legal-table th, .legal-table td{ display:block; width:auto; }
  .legal-table tr{ border-bottom:1px solid var(--line); padding:8px 0; }
  .legal-table tr:first-child th,.legal-table tr:first-child td{ border-top:none; }
  .legal-table th{ background:transparent; border-bottom:none; padding:6px 4px 2px; }
  .legal-table td{ padding:0 4px 8px; }
}

/* product list */
.plist{ padding:clamp(44px,6vw,72px) 0 clamp(80px,12vw,150px); }
.filters{ display:flex; flex-wrap:wrap; gap:10px; justify-content:center; margin-bottom:clamp(40px,6vw,66px); }
.filter{ font-size:13px; letter-spacing:.08em; padding:9px 22px; border:1px solid var(--line-2); border-radius:999px; background:transparent; color:var(--ink-soft); cursor:pointer; transition:background .3s var(--ease), color .3s, border-color .3s; font-family:inherit; }
.filter:hover{ border-color:var(--ink); color:var(--ink); }
.filter.is-active{ background:var(--ink); color:#fff; border-color:var(--ink); }
.plist-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(22px,3vw,40px); }
.plist-grid .pcard.is-hidden{ display:none; }
.plist-grid.solo{ grid-template-columns:minmax(0,340px); justify-content:center; }
.plist-grid.duo{ grid-template-columns:repeat(2,minmax(0,340px)); justify-content:center; }
.plist-grid .pcard .price{ margin-top:8px; font-family:var(--serif-jp); font-size:15px; color:var(--ink); }
.plist-grid .pcard .price small{ font-size:11px; color:var(--ink-soft); margin-left:4px; }
@media(max-width:860px){ .plist-grid{ grid-template-columns:repeat(2,1fr); gap:24px; } }
@media(max-width:480px){ .plist-grid{ grid-template-columns:1fr; } .plist-grid.duo{ grid-template-columns:minmax(0,340px); } }

/* producer detail */
.pd-intro{ padding:clamp(56px,8vw,110px) 0; }
.pd-intro .wrap{ display:grid; grid-template-columns:1.02fr 1fr; gap:clamp(40px,6vw,80px); align-items:center; }
.pd-figure{ aspect-ratio:4/5; border-radius:4px; overflow:hidden; border:1px solid var(--line); }
.pd-figure img{ width:100%; height:100%; object-fit:cover; }
.pd-meta{ display:flex; gap:34px; margin:0 0 26px; }
.pd-meta div span{ display:block; font-family:var(--serif-en); font-style:italic; font-size:11px; letter-spacing:.12em; color:var(--green); text-transform:uppercase; margin-bottom:4px; }
.pd-meta div b{ font-family:var(--serif-jp); font-weight:500; font-size:16px; letter-spacing:.04em; }
.pd-body h2{ font-family:var(--serif-jp); font-weight:500; font-size:clamp(24px,3.2vw,38px); letter-spacing:.05em; line-height:1.5; margin-bottom:26px; }
.pd-body p{ color:var(--ink-soft); font-size:14.5px; line-height:2.2; margin-bottom:18px; }
.pd-body .sign{ font-family:var(--serif-jp); color:var(--ink); margin-top:26px; letter-spacing:.06em; }
.pd-products{ padding:clamp(60px,9vw,120px) 0; background:var(--paper); border-block:1px solid var(--line); }
.pd-products .head{ text-align:center; margin-bottom:clamp(36px,5vw,56px); }
.pd-products .head .eyebrow{ justify-content:center; }
.back-link{ display:inline-flex; align-items:center; gap:10px; margin-top:8px; font-size:13px; letter-spacing:.08em; color:var(--ink); border-bottom:1px solid var(--line-2); padding-bottom:3px; }
.back-link:hover{ border-color:var(--orange); }
@media(max-width:880px){ .pd-intro .wrap{ grid-template-columns:1fr; } .pd-figure{ max-width:440px; } }


/* contact form */
.contact{ padding:clamp(50px,7vw,90px) 0 clamp(80px,12vw,150px); }
.contact .wrap{ max-width:760px; }
.contact .intro{ text-align:center; color:var(--ink-soft); font-size:15px; line-height:2.1; margin-bottom:clamp(40px,6vw,62px); }
.form{ display:grid; gap:26px; }
.field{ display:grid; gap:10px; }
.field label{ font-size:13.5px; letter-spacing:.06em; color:var(--ink); font-weight:500; display:flex; align-items:center; gap:10px; }
.field .req{ font-size:10px; letter-spacing:.08em; color:#fff; background:var(--orange); padding:3px 8px; border-radius:3px; line-height:1; }
.field .opt{ font-size:10px; letter-spacing:.08em; color:var(--ink-soft); border:1px solid var(--line-2); padding:2px 8px; border-radius:3px; line-height:1; }
.field input, .field select, .field textarea{
  width:100%; font-family:inherit; font-size:14.5px; color:var(--ink); letter-spacing:.02em;
  background:var(--white); border:1px solid var(--line-2); border-radius:4px;
  padding:14px 16px; transition:border-color .3s, box-shadow .3s; -webkit-appearance:none; appearance:none;
}
.field input::placeholder, .field textarea::placeholder{ color:#b7b0a2; }
.field textarea{ min-height:170px; resize:vertical; line-height:1.95; }
.field input:focus, .field select:focus, .field textarea:focus{ outline:none; border-color:var(--orange); box-shadow:0 0 0 3px rgba(232,107,18,.12); }
.field select{ background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2376726A' fill='none' stroke-width='1.4'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 16px center; padding-right:42px; cursor:pointer; }
.agree{ display:flex; align-items:flex-start; gap:12px; font-size:13.5px; color:var(--ink-soft); line-height:1.8; justify-content:center; margin-top:4px; }
.agree input{ margin-top:3px; width:18px; height:18px; accent-color:var(--orange); flex:none; }
.agree a{ color:var(--orange); border-bottom:1px solid var(--line-2); }
.form .submit-row{ text-align:center; margin-top:16px; }
.form .btn-primary{ border:none; cursor:pointer; font-family:inherit; padding:17px 54px; font-size:14.5px; }
.form-note{ text-align:center; margin-top:34px; font-size:12.5px; color:var(--ink-soft); line-height:1.9; }
.form-note a{ color:var(--orange); border-bottom:1px solid var(--line-2); }
.form-done{ display:none; text-align:center; padding:40px 20px 20px; }
.form-done.show{ display:block; }
.form-done .ico{ width:58px; height:58px; border-radius:50%; background:var(--green); color:#fff; display:grid; place-items:center; margin:0 auto 22px; }
.form-done h2{ font-family:var(--serif-jp); font-weight:500; font-size:24px; letter-spacing:.06em; margin-bottom:14px; }
.form-done p{ color:var(--ink-soft); font-size:14px; line-height:2.1; }
.info-row{ display:flex; justify-content:center; gap:clamp(28px,6vw,70px); flex-wrap:wrap; margin-bottom:clamp(40px,6vw,60px); text-align:center; }
.info-row .it span{ display:block; font-family:var(--serif-en); font-style:italic; font-size:11px; letter-spacing:.14em; color:var(--green); text-transform:uppercase; margin-bottom:6px; }
.info-row .it b{ font-family:var(--serif-jp); font-weight:500; font-size:15.5px; letter-spacing:.04em; }


/* products: shop link on cards + cta */
.plist-grid .pcard{ display:block; }
.plist-grid .pcard .shop-link{ display:inline-flex; align-items:center; gap:7px; margin-top:9px; font-size:12.5px; letter-spacing:.04em; color:var(--orange); }
.plist-grid .pcard:hover .shop-link{ gap:11px; }
.shop-cta{ text-align:center; margin-top:clamp(46px,6vw,68px); }


/* FAQ accordion */
.faq-list{ max-width:840px; margin:0 auto; border-top:1px solid var(--line); }
.faq-item{ border-bottom:1px solid var(--line); }
.faq-item summary{ list-style:none; cursor:pointer; display:flex; align-items:flex-start; gap:16px; padding:24px 4px; font-family:var(--serif-jp); font-weight:500; font-size:16px; letter-spacing:.04em; color:var(--ink); }
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary .q{ font-family:var(--serif-en); font-style:italic; color:var(--green); font-size:19px; line-height:1.3; flex:none; }
.faq-item summary .qt{ flex:1; line-height:1.6; }
.faq-item summary .ic{ flex:none; width:18px; height:18px; position:relative; margin-top:6px; }
.faq-item summary .ic::before,.faq-item summary .ic::after{ content:""; position:absolute; background:var(--ink-soft); }
.faq-item summary .ic::before{ top:8px; left:0; width:18px; height:1px; }
.faq-item summary .ic::after{ top:0; left:8px; width:1px; height:18px; transition:transform .3s var(--ease); }
.faq-item[open] summary .ic::after{ transform:scaleY(0); }
.faq-a{ padding:0 4px 28px 40px; color:var(--ink-soft); font-size:14px; line-height:2.1; }
.faq-a a.inline{ color:var(--orange); border-bottom:1px solid var(--line-2); }

/* about keywords */
.kw-row{ display:flex; justify-content:center; gap:clamp(30px,7vw,96px); flex-wrap:wrap; margin:clamp(40px,5vw,60px) 0; }
.kw-row .kw{ text-align:center; }
.kw-row .kw span{ font-family:var(--serif-en); font-style:italic; color:var(--green); font-size:12px; letter-spacing:.16em; text-transform:uppercase; display:block; margin-bottom:8px; }
.kw-row .kw b{ font-family:var(--serif-jp); font-weight:500; font-size:clamp(22px,3vw,30px); letter-spacing:.12em; }
.article .about-statement{ text-align:center; font-family:var(--serif-jp); font-weight:500; font-size:15px; line-height:2.15; letter-spacing:.05em; color:var(--ink); margin:clamp(40px,6vw,64px) auto; max-width:none; }
.about-statement br{ display:none; }
@media(min-width:680px){ .about-statement br{ display:inline; } }


/* membership（完全紹介制会員サービス） */
.membership{ padding:clamp(70px,10vw,130px) 0; background:var(--paper); border-block:1px solid var(--line); }
.membership .head{ text-align:center; margin-bottom:clamp(18px,2.5vw,26px); }
.membership .head .eyebrow{ justify-content:center; }
.m-lead{ text-align:center; color:var(--ink-soft); font-size:15px; line-height:2.1; max-width:32em; margin:0 auto clamp(40px,6vw,60px); }
.m-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(22px,3vw,36px); max-width:920px; margin:0 auto; }
.m-item{ background:var(--white); border:1px solid var(--line); border-radius:6px; padding:clamp(30px,4vw,46px); }
.m-item .m-no{ font-family:var(--serif-en); font-style:italic; font-size:26px; color:var(--green); }
.m-item h3{ font-family:var(--serif-jp); font-weight:500; font-size:19px; letter-spacing:.06em; margin:14px 0 14px; }
.m-item p{ color:var(--ink-soft); font-size:14px; line-height:2.05; }
@media(max-width:760px){ .m-grid{ grid-template-columns:1fr; } }

/* ===== News modal ===== */
.nitem-modal{ cursor:pointer; position:relative; }
.nitem-modal::after{ content:"＋"; position:absolute; right:4px; top:50%; transform:translateY(-50%); font-size:15px; color:var(--ink-soft); transition:color .3s, transform .35s var(--ease); }
.nitem-modal:hover::after{ color:var(--orange); transform:translateY(-50%) rotate(90deg); }
.modal{ position:fixed; inset:0; z-index:200; display:flex; align-items:center; justify-content:center; padding:24px; }
.modal[hidden]{ display:none; }
.modal-overlay{ position:absolute; inset:0; background:rgba(20,16,10,.5); backdrop-filter:blur(3px); animation:mFade .3s var(--ease); }
.modal-dialog{ position:relative; z-index:1; width:min(560px,100%); max-height:86vh; overflow:auto; background:var(--white); border:1px solid var(--line); border-radius:6px; padding:clamp(34px,5vw,54px); box-shadow:0 30px 80px -30px rgba(0,0,0,.45); animation:mRise .45s var(--ease); }
.modal-x{ position:absolute; top:14px; right:14px; width:40px; height:40px; display:grid; place-items:center; border-radius:50%; color:var(--ink-soft); background:transparent; border:none; cursor:pointer; transition:background .3s, color .3s; }
.modal-x:hover{ background:var(--paper); color:var(--ink); }
.modal-eyebrow{ margin-bottom:20px; }
.modal-date{ display:block; font-family:var(--serif-en); font-style:italic; font-size:14px; color:var(--ink-soft); letter-spacing:.08em; margin-bottom:8px; }
.modal-title{ font-family:var(--serif-jp); font-weight:500; font-size:clamp(19px,2.8vw,25px); line-height:1.65; letter-spacing:.04em; color:var(--ink); margin-bottom:22px; }
.modal-body{ font-size:14.5px; line-height:2.15; color:var(--ink); letter-spacing:.03em; }
.modal-body p+p{ margin-top:18px; }
body.modal-open{ overflow:hidden; }
@keyframes mFade{ from{opacity:0} to{opacity:1} }
@keyframes mRise{ from{opacity:0; transform:translateY(22px)} to{opacity:1; transform:none} }
