:root {
  --bg:#f8f6ef;
  --paper:#fffdf8;
  --ink:#2f2f2f;
  --sub:#777;
  --line:#d8d0bf;
  --line-dark:#3f3f3f;
  --green:#2f7f23;
  --green-deep:#246b1b;
  --green-soft:#eaf5e4;
  --pink:#eb7b9c;
  --blue:#2f78a8;
  --yellow:#f2d36f;
  --cream:#fff7e9;
  --shadow:0 22px 54px rgba(52,44,30,.11);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  color:var(--ink);
  background:
    linear-gradient(90deg, rgba(63,63,63,.035) 1px, transparent 1px) 0 0/44px 44px,
    linear-gradient(180deg,#fbfaf6 0%,var(--bg) 100%);
  font-family:"Noto Sans JP",-apple-system,BlinkMacSystemFont,"Hiragino Sans","Yu Gothic",Meiryo,sans-serif;
  line-height:1.85;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.container{width:min(1160px,100%);margin:0 auto;padding:0 24px}

.header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  padding:26px 0 18px;
}
.brand{display:flex;align-items:center;gap:14px}
.logo{
  width:46px;height:46px;
  border:1px solid var(--line-dark);
  border-radius:50%;
  display:grid;place-items:center;
  background:#fff;
  font-weight:900;
  box-shadow:5px 5px 0 rgba(47,127,35,.12);
}
.brand-title{font-size:18px;font-weight:900;letter-spacing:.05em;line-height:1.2}
.brand-sub{color:var(--sub);font-size:11px;letter-spacing:.15em}
.nav{display:flex;gap:22px;color:#555;font-weight:700;font-size:13px;letter-spacing:.04em}
.nav a{border-bottom:1px solid transparent}
.nav a:hover{border-color:var(--green);color:var(--green)}

.hero{
  padding:52px 0 78px;
  border-top:1px solid rgba(63,63,63,.08);
}
.hero-grid{
  display:grid;
  grid-template-columns:1.02fr .98fr;
  gap:clamp(14px,2.2vw,28px);
  align-items:center;
}
.eyebrow,.kicker{
  display:inline-flex;
  align-items:center;
  gap:10px;
  color:var(--green);
  font-size:12px;
  letter-spacing:.2em;
  font-weight:900;
  margin:0 0 18px;
}
.eyebrow::before{content:"";width:44px;height:1px;background:var(--green)}
.hero-title{
  margin:0;
  font-size:clamp(50px,5.75vw,82px);
  line-height: 1.15;
  letter-spacing:-.07em;
  font-weight:900;
}
.hero-title span{display:block;white-space:nowrap}
.hero-title span:first-child{color:var(--ink)}
.hero-title span:nth-child(2){color:var(--green)}
.hero-copy{
  margin:28px 0 0;
  max-width:650px;
  color:#4a4a4a;
  font-size:clamp(16px,2vw,19px);
  line-height:2.05;
  font-weight:700;
}
.hero-copy strong{color:var(--green);font-weight:900}
.hero-actions,.pickup-actions,.cta-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:30px;
}
.cta-actions .btn.light.secondary{
  background:#fff;
  color:#128326;
  border:2px solid rgba(255,255,255,.85);
}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-height:48px;
  padding:12px 22px;
  border-radius:999px;
  border:1px solid var(--line-dark);
  background:#fff;
  font-weight:700;
  box-shadow:5px 5px 0 rgba(63,63,63,.08);
}
.btn.primary{background:var(--green);color:#fff;border-color:var(--green)}
.btn.light{box-shadow:none}
.btn.primary.light{background:#fff;color:var(--green);border-color:#fff}

/* hero right visual: one completed collage image */
.factory-visual{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:flex-start;
  min-height:470px;
  overflow:visible;
}

.hero-collage{
  margin:0;
  width: clamp(450px, 48vw, 500px);
  max-width:none;
  transform: translate(-30px, 40px);

}

.hero-collage img{
  display:block;
  width:100%;
  height:auto;
  max-width:none;
  filter:drop-shadow(0 18px 38px rgba(52,44,30,.14));
}

.section{padding:74px 0}
.section-line{border-top:1px solid rgba(63,63,63,.12)}
.section-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:24px;
  margin-bottom:30px;
}
.kicker{margin-bottom:6px}
.section-title{
  margin:0;
  font-size:clamp(34px,4.8vw,58px);
  line-height:1.13;
  letter-spacing:-.045em;
  font-weight:900;
}
.side-note{
  background:#fff;
  border:1px dashed #aaa;
  border-radius:18px;
  padding:12px 16px;
  font-size:13px;
  font-weight:700;
  transform:rotate(2deg);
}

.pickup-card{
  display:grid;
  grid-template-columns:.95fr 1.05fr;
  gap:clamp(26px,4vw,48px);
  align-items:center;
  background:#fff;
  border:1px solid var(--line);
  border-radius:36px;
  padding:clamp(22px,4vw,44px);
  box-shadow:var(--shadow);
  position:relative;
  overflow:hidden;
}
.pickup-card::before{
  content:"LATEST SHIPMENT";
  position:absolute;
  right:26px;
  top:20px;
  color:rgba(47,127,35,.1);
  font-size:42px;
  line-height:1;
  font-weight:900;
  letter-spacing:-.05em;
}
.pickup-visual{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  background:transparent;
  border:0;
  border-radius:0;
  padding:0;
  transform:rotate(-1.2deg);
  box-shadow:none;
}
.pickup-circle{
  position:relative;
  width:clamp(180px,22vw,320px);
  aspect-ratio:1 / 1;
  border-radius:50%;
  overflow:hidden;
  background:#fffdf8;
  border:1.5px solid var(--line);
  box-shadow:0 16px 38px rgba(52,44,30,.08);
}
.pickup-circle img{
  position:absolute;
  top:50%;
  left:50%;
  width:145%;
  max-width:none;
  height:auto;
  transform:translate(-50%, -50%);
  display:block;
}
.paper-label{
  position:absolute;
  z-index:4;
  background:#fff;
  border:1px solid var(--line-dark);
  border-radius:999px;
  padding:7px 14px;
  font-size:12px;
  font-weight:900;
  letter-spacing:.08em;
  box-shadow:4px 4px 0 rgba(0,0,0,.07);
  left:clamp(18px,3vw,48px);
  bottom:clamp(14px,2.2vw,32px);
  color:var(--green);
  transform:rotate(-4deg);
}
.pickup-body{position:relative;z-index:2}
.pickup-body h3{
  margin:0 0 18px;
  font-size:clamp(34px,4.2vw,58px);
  line-height:1.14;
  letter-spacing:-.05em;
  font-weight:900;
  color:var(--green);
}
.pickup-lead{
  margin:0 0 16px;
  font-size:clamp(15px,1.45vw,18px);
  line-height:1.85;
  font-weight:700;
  letter-spacing:-.025em;
}
.pickup-lead strong{color:var(--green)}
.pickup-text{margin:0;color:#555;font-weight:700;line-height:2}

.series-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:26px;
  margin-bottom:clamp(48px, 7vw, 80px);
}
.series-card{
  position:relative;
  background:#fff;
  border:1px solid var(--line);
  border-radius:32px;
  overflow:hidden;
  box-shadow:var(--shadow);
}
.series-card.featured{transform:rotate(.6deg)}
.series-image{
  height:315px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#fff;
  border-bottom:1px solid var(--line);
  padding:24px;
}
.series-card-link{display:block;color:inherit;text-decoration:none}
.series-card-link .series-card{
  height:100%;
  transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;
}
.series-card-link:hover .series-card{
  transform:translateY(-6px);
  box-shadow:0 18px 40px rgba(0,0,0,.12);
  border-color:rgba(47,127,35,.35);
}
.series-card-link:focus-visible{
  outline:3px solid rgba(47,127,35,.35);
  outline-offset:6px;
  border-radius:28px;
}
.series-image img{width:100%;height:100%;object-fit:contain}
.series-body{padding:26px}
.series-no{margin:0;color:#999;font-size:12px;font-weight:900;letter-spacing:.16em}
.series-body h3{
  margin:8px 0 12px;
  font-size:30px;
  line-height:1.25;
  font-weight:900;
  letter-spacing:-.03em;
}
.series-body p{margin:0;color:#555}
.tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}
.tags span{
  background:var(--green-soft);
  color:var(--green);
  border-radius:999px;
  padding:5px 11px;
  font-size:12px;
  font-weight:700;
}

.memo-board{
  background:linear-gradient(180deg,#fffefb 0%,#fcfaf3 100%);
  border:1.5px solid #cfc6b2;
  border-radius:18px;
  box-shadow:0 16px 38px rgba(52,44,30,.08);
  overflow:hidden;
  position:relative;
}
.memo-board::before{
  content:"FACTORY SLIP";
  position:absolute;
  right:18px;
  top:14px;
  color:#9b907a;
  font-size:11px;
  letter-spacing:.18em;
  font-weight:900;
}
.memo-row{display:grid;grid-template-columns:170px 1fr;border-bottom:1px solid #ded6c6}
.memo-row:last-child{border-bottom:0}
.memo-key{
  background:linear-gradient(180deg,#f5efe2 0%,#f2eadb 100%);
  padding:22px;
  color:#746b57;
  font-size:12px;
  font-weight:900;
  letter-spacing:.14em;
  border-right:1px solid #ded6c6;
}
.memo-value{
  padding:22px 24px;
  color:#454545;
  font-size:16px;
  line-height:1.95;
  font-weight:700;
  background:repeating-linear-gradient(to bottom,transparent 0 33px,rgba(222,214,198,.45) 33px 34px);
}

.type-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.type-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:26px;
  padding:22px;
  box-shadow:0 14px 30px rgba(52,44,30,.07);
  min-height:220px;
}
.type-card:nth-child(2){transform:rotate(1deg)}
.type-card:nth-child(3){transform:rotate(-.8deg)}
.type-card small{display:block;color:#999;font-size:11px;font-weight:900;letter-spacing:.15em;margin-bottom:10px}
.type-card h3{margin:0 0 10px;font-size:24px;line-height:1.3;font-weight:900;color:var(--green)}
.type-card p{margin:0;color:#555;font-weight:700;line-height:1.85}

.cta-section{padding-top:42px}
.cta{
  background:#273323;
  color:#fff;
  border-radius:34px;
  padding:clamp(30px,5vw,54px);
  box-shadow:var(--shadow);
  position:relative;
  overflow:hidden;
}


.cta-section{
  padding-top:42px;
}

.cta{
  background:#273323;
  color:#fff;
  border-radius:34px;
  padding:clamp(30px,5vw,54px);
  box-shadow:var(--shadow);
  position:relative;
  overflow:hidden;
}


.cta .kicker{
  color:#bde5b7;
}

.cta h2{
  margin:0 0 16px;
  font-size:clamp(34px,5vw,58px);
  line-height:1.16;
  letter-spacing:-.045em;
  font-weight:900;
}

.cta p{
  margin:0;
  color:rgba(255,255,255,.84);
  max-width:680px;
  font-weight:700;
  line-height:2;
}

/* 下部CTA：PC版の文字幅を広げる */
.factory-check{
  position:relative;
  display:grid;
  grid-template-columns:minmax(0, 1.15fr) minmax(320px, .85fr);
  align-items:center;
  gap:24px;
}

/* 見出しの幅を広げる */
.factory-check h2{
  max-width:720px;
}

/* 2行固定にしたい場合 */
.factory-check h2 .line{
  display:block;
  white-space:nowrap;
}

/* スタンプ画像側はサイズそのまま・右寄せ */
.factory-check-visual,
.factory-check .visual,
.factory-check .stamp-visual{
  justify-self:end;
}

.factory-check::after{
  display:none; /* 右上の「出荷OK」ラベルは今回は消す */
}

.cta-content{
  position:relative;
  z-index:2;
}

.cta-stamp-visual{
  margin:0;
  display:flex;
  justify-content:flex-end;
  align-items:flex-end;
}

.cta-stamp-visual img{
  display:block;
  width:min(100%, 400px);
  height:auto;
  filter:drop-shadow(0 14px 26px rgba(0,0,0,.22));
  transform:rotate(-6deg) translateY(8px);
}

/* ボタン */
.cta-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:30px;
}

.cta-actions .btn.light.secondary{
  background:#fff;
  color:#128326;
  border:2px solid rgba(255,255,255,.85);
}
.footer{padding:34px 24px;text-align:center;color:#888;font-size:12px;letter-spacing:.08em}

/* factory memo: slip style */
.factory-slip-wrap{
  position:relative;
  padding-left:64px;
}
.factory-slip-wrap .slip-holes{
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:64px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:space-around;
  padding:28px 0;
  background:#fffaf0;
  border:1.5px solid #efc693;
  border-right:0;
  border-radius:24px 0 0 24px;
  box-shadow:0 14px 34px rgba(80,58,28,.06);
}
.factory-slip-wrap .slip-holes span{
  width:28px;
  height:28px;
  border:1.5px solid #efb878;
  border-radius:50%;
  background:#fffdf8;
}
.factory-slip{
  position:relative;
  background:#fffdf8;
  border:1.5px solid #efc693;
  border-radius:0 24px 24px 0;
  overflow:hidden;
  box-shadow:0 14px 34px rgba(80,58,28,.08);
}
.slip-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  min-height:50px;
  padding:10px 28px;
  background:#fff7e9;
  border-bottom:1.5px solid #efc693;
  color:#756b58;
  font-size:14px;
  font-weight:900;
  letter-spacing:.06em;
}
.slip-title{
  color:#8d806b;
  font-size:15px;
  font-weight:900;
  letter-spacing:.16em;
}
.slip-row{
  display:grid;
  grid-template-columns:210px minmax(0,1fr);
  border-bottom:1.5px solid #efc693;
}
.slip-key{
  display:flex;
  align-items:center;
  justify-content:center;
  padding:26px 18px;
  background:#f4ead9;
  border-right:1.5px solid #efc693;
  color:#756b58;
  font-size:16px;
  font-weight:900;
  text-align:center;
  letter-spacing:.04em;
}
.slip-value{
  padding:25px 30px;
  color:#3f3f3f;
  font-size:16px;
  line-height:2.0;
  font-weight:700;
  background:repeating-linear-gradient(to bottom,transparent 0 37px,rgba(239,198,147,.38) 37px 38px);
}
.slip-footer{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  min-height:50px;
  padding:10px 28px;
  background:#fff7e9;
  color:#756b58;
  font-size:13px;
  font-weight:900;
  letter-spacing:.04em;
}
.slip-stamp{
  position:absolute;
  display:flex;
  align-items:center;
  justify-content:center;
  border:5px solid #e62929;
  border-radius:50%;
  color:#e62929;
  background:rgba(255,255,255,.2);
  font-weight:900;
  line-height:1.1;
  text-align:center;
  pointer-events:none;
  mix-blend-mode:multiply;
}
.stamp-factory{
  right:140px;
  top:74px;
  width:92px;
  height:92px;
  font-size:19px;
  transform:rotate(-8deg);
}
.stamp-checked{
  right:30px;
  top:74px;
  width:98px;
  height:98px;
  font-size:22px;
  transform:rotate(7deg);
}


@media(max-width:980px){
  .nav,.side-note{display:none}
  .hero-grid,.pickup-card,.series-grid{grid-template-columns:1fr}

  .factory-visual{
    min-height:auto;
    margin-top:24px;
    justify-content:center;
  }

  .hero-collage{
    max-width:500px;
    transform:none;
  }

  .type-grid{grid-template-columns:repeat(2,1fr)}

  .factory-slip-wrap{padding-left:46px}
  .factory-slip-wrap .slip-holes{width:46px}
  .factory-slip-wrap .slip-holes span{width:22px;height:22px}
  .slip-row{grid-template-columns:170px minmax(0,1fr)}
  .slip-stamp{opacity:.16}
}


@media(max-width:560px){
  .container{padding:0 16px}
  .header{align-items:flex-start}
  .hero{padding:34px 0 58px}
  .hero-title{font-size:clamp(42px,13vw,58px);line-height:1.1}
  .hero-title span{white-space:normal}

  .factory-visual{
    min-height:auto;
    margin-top:18px;
    justify-content:center;
  }

  .hero-collage{
    max-width:100%;
    transform:none;
  }

  .section{padding:58px 0}
  .pickup-card{border-radius:28px;padding:20px}
  .pickup-card::before{display:none}
  .pickup-body h3{font-size:clamp(32px,10vw,46px)}
  .series-image{height:255px}
  .series-body h3{font-size:26px}
  .memo-row{grid-template-columns:1fr}
  .memo-key{border-right:0;border-bottom:1px solid #ded6c6;padding:16px 18px}
  .memo-value{padding:18px}
  .type-grid{grid-template-columns:1fr}
  .type-card{min-height:auto;transform:none!important}
  .cta::after{right:18px;top:18px}
  .pickup-circle{width:min(86vw,340px)}
  .paper-label{left:18px;bottom:12px}

  .factory-slip-wrap{padding-left:0}
  .factory-slip-wrap .slip-holes{display:none}
  .factory-slip{border-radius:22px}

  .slip-top,
  .slip-footer{
    display:block;
    padding:12px 16px;
    font-size:12px;
    line-height:1.8;
  }

  .slip-row{grid-template-columns:1fr}

  .slip-key{
    justify-content:flex-start;
    padding:14px 16px;
    border-right:0;
    border-bottom:1.5px solid #efc693;
  }

  .slip-value{
    padding:18px 16px;
    font-size:15px;
    line-height:1.9;
  }

  .slip-stamp{display:none}
	.cta-stamp-visual img{
  width:min(82vw,260px);
}
  .factory-check{
    display:block;
    padding:34px 28px 36px;
  }

  .cta-content{
    position:relative;
    z-index:2;
  }

  .cta-stamp-visual {
    margin: -42px 0 4px;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    pointer-events: none;
  }

  .cta-stamp-visual img {
    width: min(64vw, 230px);
    margin-left: auto;
    transform: rotate(-6deg) translateX(10px);
  }
  .series-grid{
    margin-bottom:48px;
}

