/* Minimal, framework-free styles */
:root{
  --bg:#ffffff;
  --fg:#222;
    --green:#5bb266;
  --muted:#666;
  --brand:#2e7d32; /* green */
  --brand-2:#ff7043; /* accent */
--red-bg:#d0000f;
    --blue-bg:#1d3f91;
  --surface:#edf3e2;
  --border:#e5e7eb;
  --borderDk:#808080;
    --orange:#EE7B30;
     --ly-bg:#fcfce1;
    --borderLy:#e0e0be;
    
  --shadow:0 6px 18px rgba(0,0,0,.08);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-size: 16px;
line-height: 1.6;
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Noto Sans JP", Roboto, Arial, "Hiragino Kaku Gothic ProN", "Yu Gothic UI", "Yu Gothic", Meiryo, sans-serif !important;
color:var(--fg);background:#fff}
main#top img{max-width:100%;display:block}




main#top .container{max-width:1120px;margin:0 auto;padding:0 16px}
main#top .muted{color:var(--muted);font-size:.95rem;line-height: 2.3;}
main#top .textalign-center{text-align: center}
/* 商品一覧＆タブ内のグリッド両方に */
main#top .grid,main#top  .panel.active{align-items:start;}  /* 既定の stretch を無効化 */
main#top #filter{background-color: #f7f7f7;position: relative;}

/* Header */
main#top .site-header{position:sticky;top:0;background:#fff;border-bottom:1px solid var(--border);z-index:50}
main#top .header-inner{display:flex;align-items:center;justify-content:space-between;height:64px}
main#top .brand{display:inline-flex;align-items:center;gap:.5rem;text-decoration:none;color:var(--fg);font-weight:700}
main#top .brand-leaf{filter:grayscale(.2)}


/* ===== Fancy Triptych (prefix: eco3x-) ===== */
main#top .eco3x{
  --ink:#0f2d17; --muted:#3f5d47; --white:#fff;
  --g1:#2e7d32; --g2:#3e8742; --g3:#225a29;
  --noise: url("data:image/svg+xml;utf8,\
<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120' viewBox='0 0 120 120'>\
<filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix type='saturate' values='0'/><feComponentTransfer><feFuncA type='table' tableValues='0 0 .08 0'/></feComponentTransfer></filter>\
<rect width='120' height='120' filter='url(%23n)'/></svg>");
  background:
    radial-gradient(1200px 400px at 50% -280px, #e6f3e8 0, #ffffff 32%, transparent 60%) top center no-repeat,
    #fff;
  position:relative; padding:48px 0 28px; overflow:hidden;
}
main#top .eco3x .container{max-width:1120px;margin:0 auto;padding:0 16px}
main#top .eco3x-sp{display:none}@media(max-width:700px){.eco3x-sp{display:inline}}

main#top .eco3x-head{text-align:center}
main#top .eco3x-eyebrow{ color:var(--muted); letter-spacing:.15em; margin:0 0 6px }
main#top .eco3x-title{
  margin:0; font-weight:900; letter-spacing:.02em; line-height:1.1;
  font-size:clamp(28px,4.6vw,54px); color:var(--ink); text-transform:uppercase;
}
main#top .eco3x-title span{ color:#5fbf6a }
main#top .eco3x-title strong{
  background:var(--brand);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
main#top .eco3x-sub{ margin:10px 0 6px; color:var(--muted) }
main#top .meow-script-regular{
font-family: "Meow Script", cursive;
  font-weight: 400;
  font-style: normal;
  position: absolute;
  inset: -95px 36px 0 0;
  display: grid;
  place-items: start end;
  z-index: 10;
  font-size: 200px;
  transform: rotate(-15deg);
  transform-origin: top right;
  color: var(--orange);
}
main#top .cb6-subword{
  position: relative;
  inset: 0;
  z-index: 1;
  display: grid;
  place-items: normal;
  text-align: center;
  font-weight: 400;
  letter-spacing: 1em;
  line-height: 1;
  font-size: 25px;
  color: #fff;
  text-shadow: 0 18px 35px rgba(0,0,0,.18), 0 3px 0 rgba(0,0,0,.06);
  opacity: .96;
}
main#top .cb6-wrap{position: relative;}

















/* ========= Cups Banner Section (cb6) – FIXED ========= */
main#top .cb6{
  position:relative;
  width:100%;
  overflow:hidden;
  padding:56px 0 64px;
}

/* テーマ */
main#top .cb6--reuse{
  --bg1:#e6f6ee; --bg2:#ffffff; --accent:#2e7d32;
  /* 調整用の変数（必要に応じて値を変えてOK） */
  --cup-size:clamp(56px, 13vw, 101px);
  --row-offset: -18%;   /* 文字に対する縦方向の重なり量（マイナスで上へ） */
  background:var(--accent);
}
main#top .cb6--sleeve{
  --bg1:#e6f6ee; --bg2:#ffffff; --accent:#6e911f;
  /* 調整用の変数（必要に応じて値を変えてOK） */
  --cup-size:clamp(56px, 13vw, 101px);
  --row-offset: -18%;   /* 文字に対する縦方向の重なり量（マイナスで上へ） */
  background:var(--accent);
}
main#top .cb6--super{
  --bg1:#e6f6ee; --bg2:#ffffff; --accent:#2e7d32;
  /* 調整用の変数（必要に応じて値を変えてOK） */
  --cup-size:clamp(56px, 13vw, 101px);
  --row-offset: -18%;   /* 文字に対する縦方向の重なり量（マイナスで上へ） */
  background:var(--accent);
}

main#top .cb6-inner{width:min(1200px,100%);margin:0 auto 77px;padding:0 16px}

/* ヒーロー */
main#top .cb6-hero{
  position:relative;
  height:clamp(240px, 36vw, 460px);
  margin-bottom: clamp(70px, 10vw, 95px);
  isolation:isolate;
}

/* 後ろ：大見出し */
main#top .cb6-word{
position: relative;
  inset: 28px 0 0 0;
  z-index: 1;
  display: grid;
  place-items: center;
  text-align: center;
  font-weight: 900;
  letter-spacing: -.07em;
  line-height: 1;
  font-size: 217px;
  color: #fff;
  text-shadow: 0 18px 35px rgba(0,0,0,.18), 0 3px 0 rgba(0,0,0,.06);
  opacity: .96;
  font-family: "Oswald", sans-serif;
}

/* 前：カップ列（ulのマーカー対策） */
main#top .cb6-row{
position: relative;
  left: 50%;
  top: 58px;
  transform: translate(-50%, var(--row-offset, -12%));
  z-index: 20;
  display: flex;
  gap: clamp(10px, 1.6vw, 20px);
  justify-content: center;
  align-items: flex-end;
  padding: 4px 8px 0;
  list-style: none;
  margin: 0;
}
main#top .cb6--reuse .cb6-row,
main#top .cb6--sleeve .cb6-row,
main#top .cb6--super .cb6-row{
  padding: 44px 8px 0;
}
main#top .cb6-cup{position:relative; width:var(--cup-size)}
main#top .cb6-cup img{
  width:100%; height:auto; display:block;
  filter: drop-shadow(0 18px 20px rgba(0,0,0,.22))
          drop-shadow(0 2px 0 rgba(255,255,255,.25));
  transition: transform .2s ease;
}
main#top .cb6-cup:hover img{transform:translateY(-23px)}
/* 接地影（指定どおりのラディアル） */
main#top .cb6-cup::after{
  content:""; position:absolute; left:50%; bottom:-6px; transform:translateX(-50%);
  width:80%; height:14px;
  background: radial-gradient(ellipse at center, rgba(0,0,0,.28), rgba(0,0,0,0) 70%);
  filter: blur(1px);
}

/* 下部コンセプト枠 */
main#top .cb6-concepts{
  display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:16px;
  position:relative; z-index:0;   /* カップ(2)より奥に */
}
main#top .cb6-card{
  background:#fff;
  border:2px solid color-mix(in oklab, var(--accent) 70%, #fff 30%);
  border-radius:14px;
  padding:32px 18px 36px;
  box-shadow:0 10px 24px rgba(0,0,0,.06);
}
main#top .cb6-card h4{
  margin:0 0 8px; font-size:1.2rem; letter-spacing:.12em;
  color:var(--accent); text-align:center; font-weight:900
}
main#top .cb6-card p{margin:0; color:#234; line-height:1.75;text-align: center;padding: 0 37px;}

@media (max-width:800px){
  main#top .cb6-concepts{grid-template-columns:1fr}
}
main#top .cb6-underline {
  display: block;
  width: 50px;
  height: 3px;
  margin: 11px auto 18px;
  background: var(--accent);
  border-radius: 2px;
}
main#top .cb6-plan {
  color: #1a6617;
  margin-top: 10px;
  display: block;
  font-size: .9rem;
}
main#top .cb6--super .cb6-hero,
main#top .cb6--sleeve .cb6-hero,
main#top .cb6--reuse .cb6-hero{
    margin: 78px 0 100px;
  height: auto;
}
main#top .cb6--sleeve .cb6-plan {
  color: #5a7914;
}
main#top .cb6--super .meow-script-regular{
  inset: -123px 104px 0 0;
}
/* 既存と被らないように全て ecoFab- 接頭辞 */
main#top .ecoFab-wrap{
  position: relative; /* 絶対配置の基準にする */
}
main#top .font--mini{
  font-size: 40%;letter-spacing: -.06em;
}

main#top .ecoFab-button {
  position: absolute;
top: -97px;
  right: -32px;
  width: clamp(96px, 12vw, 132px);
  height: clamp(96px, 12vw, 132px);
  border-radius: 50%;
  background: #F5812A;
  color: #fff;
  text-decoration: none;
  display: grid;
  place-items: center;
  text-align: center;
  line-height: 1.35;
  font-weight: 700;
  box-shadow: 0 7px 13px rgba(0,0,0,.18), 0 4px 12px rgba(0,0,0,.3);
  z-index: 5;
  transition: transform .15s ease, box-shadow .15s ease;
}

/* テキスト */
main#top .ecoFab-label{
  padding: 21px 0 0;
  font-size: clamp(12px, 1.6vw, 15px);
  letter-spacing: .02em;line-height: 1.6;
}

/* ホバー/フォーカスの少し浮く感じ */
main#top .ecoFab-button:hover,
main#top .ecoFab-button:focus-visible{
  transform: translateY(-2px);
  box-shadow:
    0 18px 36px rgba(0,0,0,.22),
    0  6px 16px rgba(0,0,0,.14);
  outline: none;
}
main#top .ecoFab-ext {
  width: 30px;
  height: auto;
  padding: 0;
  fill: #FFF;
}


@media (max-width: 560px){

  main#top .ecoFab-ext{
    bottom: -12px;
    right: 10px;
  }
}




























main#top .filter-group-title{display: flex;justify-content: space-between;margin-bottom: 20px;}

/* Buttons */
main#top .btnReuse{position: relative;appearance:none;border:1px solid var(--border);padding:.6rem 1rem;border-radius:10px;background:#fff;cursor:pointer;text-decoration:none;display:block;align-items:center;gap:.5rem;box-shadow:var(--shadow);width: 100%;}
main#top .btnReuse:hover,.btnClear:hover{transform:translateY(-3px)}
main#top .btnReuse.primarybtnReuse{background:var(--brand);border-color:var(--brand);color:#fff;border-radius: 5px;padding: 14px 18px;}
main#top .btnReuse.cvrbtnReuse{background:var(--red-bg);border-color:var(--red-bg);color:#fff;border-radius: 5px;padding: 14px 18px;}
main#top .btnReuse.printbtnReuse{background:var(--blue-bg);border-color:var(--blue-bg);color:#fff;border-radius: 5px;padding: 14px 18px;font-size: 14px;}

main#top .btnReuse.ghost{background:#fff}
main#top .btnReuse.small{padding:.45rem .8rem}
main#top .btnReuse .circle-arrow{
  pointer-events:none;
  position:absolute;
  top:50%;
  right:9px;
  width:37px;
  height:37px;
  transform:translateY(-50%);
  background:#fff;
  border-radius:50%;
  display:grid;
  place-items:center;
  transition: transform .15s ease;
}
main#top .btnReuse:hover .circle-arrow{
  transform:translateY(-50%) translateX(2px); /* ほんの少しスライド */
}

/* 円の中の矢印（↗） */
main#top .btnReuse .circle-arrow::before{
  content:"";
  width:9px;
  height:9px;
  border-right:3px solid var(--brand);  
  border-top:3px solid var(--brand);
  transform:rotate(45deg);    
  display:block;margin-right: 4px;
}
main#top .printbtnReuse .circle-arrow::before{ 
    border-right:3px solid var(--blue-bg);  
  border-top:3px solid var(--blue-bg);}
main#top .cvrbtnReuse .circle-arrow::before{ 
    border-right:3px solid var(--red-bg);  
  border-top:3px solid var(--red-bg);}
/* 無効状態の購入ボタン */
main#top .btnReuse.is-disabled {
  background-color: #6d6d6d;  
  color: #fff;            
  border: none;           
  cursor: default;         
  pointer-events: none;    
  opacity: 0.8;            
}

main#top .btnReuse.is-disabled:hover,
main#top .btnReuse.is-disabled:focus {
  background-color: #aaa;  
  color: #fff;
  opacity: 0.8;
}

/* キーボード操作時のフォーカス */
main#top .btnReuse:focus-visible{
  outline: 2px solid #6bb7ff;
  outline-offset: 3px;
  text-decoration: none;
}
main#top .btnClear{appearance:none;border:1px solid var(--borderDk);padding:.6rem 1rem;border-radius:999px;background:#fff;cursor:pointer;text-decoration:none;display:inline-block;align-items:center;gap:.5rem;}
main#top .mb38{margin-bottom: 38px;}

/* Hero */
main#top .hero{color:#fff;background:#1b1b1b;background-size:cover;background-position:center}
main#top .hero-inner{padding:72px 0}
main#top .hero h1{font-size:clamp(26px,4vw,44px);margin:0 0 10px}
main#top .hero .lead{font-size:1.1rem;margin:0 0 20px}
main#top .cta-group{display:flex;gap:12px;flex-wrap:wrap}

/* Sections */
main#top .section{padding:106px 0}
main#top .section.alt{background:#dee6d8}
main#top h2{font-size:clamp(23px,3vw,34px);margin:55px 0 14px;text-align: center;color: #234;font-weight: 900;}

/* Filters */
main#top .filters{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:start;margin:12px 0 16px}
main#top .filter-group h3{margin:.2rem 0 .6rem;font-size:1rem;color:var(--muted)}
main#top .chips{display:flex;flex-wrap:wrap;gap:8px}
main#top .chip {
  border: 1px solid #efefef;
  border-radius: 999px;
  padding: .35rem .8rem;
  background: #fff;
  cursor: pointer;
  font-size: 1rem;
  margin: .08rem 0;
  user-select: none;
  box-shadow: 0 3px 2px rgba(0,0,0,.1);
}
main#top .chip.active{background:var(--brand);border-color:var(--brand);color:#fff}
main#top .filter-actions{display:flex;gap:8px;align-items:center}
main#top .filter-actions input[type="search"]{padding: 0.7rem 1rem;
    border: 0;background: transparent;
  border-bottom: 1px solid var(--borderDk);
  min-width: 640px;}

main#top .buy-block {
  display: grid;
  gap: 8px;
}
@media (min-width: 720px) {
 main#top  .buy-block {
    grid-template-columns: 1fr auto; /* 左にセレクト、右に購入ボタン */
    align-items: center;
  }
}
main#top .buy-select-wrap {
  display: grid;
  gap: 4px;width: 100%;margin: 0 0 7px;
}
main#top .buy-label {
  font-size: .90rem;
  color: var(--muted);
}
main#top .buy-select {
  padding: 12px 10px;
  border: 1px solid #ddd;
  border-radius: 10px;cursor: pointer;
}


/* Grid */
main#top .grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
@media (max-width:960px){main#top .grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:600px){main#top .grid{grid-template-columns:1fr}}

/* Card */
main#top .card{background:#fff;border-radius:16px;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow)}
main#top .card > img{
  width: 100%;
  aspect-ratio: 1 / 1;   /* 常に正方形の枠になる（レスポンシブで効く） */
  object-fit: cover;      /* 画像を枠いっぱいに収めて余りをクロップ */
  object-position: 50% 50%; /* 見せたい位置の微調整（中央基準） */
  display: block;
}
main#top .card-body{padding:14px}
main#top .card h3{margin:.9rem 0 1rem;font-size:1.05rem}
main#top .meta{display:flex;gap:6px;flex-wrap:wrap;margin:.2rem 0 1.4rem}
main#top .badge{font-size:.8rem;border:1px solid var(--border);border-radius:999px;padding:.2rem .55rem;background:#fff}
main#top .meta .badge.primary{background:rgba(46,125,50,.08);border-color:rgba(46,125,50,.25);color:#1b5e20}
main#top .kv{display:grid;grid-template-columns:96px 1fr;gap:8px;font-size:.95rem}
main#top .kv dt{color:var(--muted)}
main#top .card-actions{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
main#top .printText {margin: 0.7rem 0;
  font-size: .8rem;
  color: var(--muted);}

/* Tabs */
main#top .tabs{display:flex;gap:8px;margin:36px 0 16px;border-bottom: 6px solid var(--brand);}
main#top .tab{background: #88ab89;color: #fff;
  border-radius: 6px 6px 0 0;
  padding: 1.2rem 2rem;
  cursor: pointer;
  border: 0;
  font-size: 1.3rem;
  font-weight: 700;}
main#top .tab.active{background:var(--brand);border-color:var(--brand);color:#fff}
main#top .panel{display:none}
main#top .panel.active{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
@media (max-width:960px){main#top .panel.active{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:600px){main#top .panel.active{grid-template-columns:1fr}}

/* Gallery */
main#top #gallery{background-color: #f7f7f7;}
main#top .gallery{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
@media (max-width:800px){main#top .gallery{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:520px){main#top .gallery{grid-template-columns:1fr}}


/* Lightbox */
body.no-scroll{overflow:hidden}

main#top .lightbox{
  position:fixed; inset:0; background:rgba(0,0,0,.8);
  display:grid; grid-template-columns: 64px 1fr 64px; place-items:center;
  z-index:1000; padding:24px; transition:opacity .2s ease;
}
main#top .lightbox.is-hidden{opacity:0; pointer-events:none}

main#top .lb-stage{max-width:min(92vw,1200px); max-height:86vh; margin:0; position:relative}
main#top #lb-image{max-width:100%; max-height:86vh; object-fit:contain; border-radius:12px; box-shadow:var(--shadow)}
main#top #lb-caption{margin-top:8px; color:#fff; text-align:center; font-size:.95rem; opacity:.85}
main#top .lb-counter{position:absolute; top:8px; right:12px; color:#fff; font-size:.9rem; background:rgba(0,0,0,.35); padding:4px 8px; border-radius:999px}

main#top .lb-btn{
  width:44px; height:44px; border-radius:50%;
  border:1px solid rgba(255,255,255,.5);
  background:rgba(0,0,0,.35); backdrop-filter:saturate(120%) blur(2px);
  cursor:pointer; display:grid; place-items:center;
  transition:transform .15s ease, background .15s ease;
}
main#top .lb-btn:hover{transform:translateY(-1px); background:rgba(255,255,255,.12)}
main#top .lb-btn:focus-visible{outline:2px solid #6bb7ff; outline-offset:3px}

/* × (close) */
main#top .lb-close{position:absolute; top:18px; right:18px}
main#top .lb-close::before, .lb-close::after{
  content:""; position:absolute; width:20px; height:2px; background:#fff; border-radius:2px;
}
main#top .lb-close::before{transform:rotate(45deg)}
main#top .lb-close::after{transform:rotate(-45deg)}

/* ◀ / ▶ */
main#top .lb-prev::before, .lb-next::before{
  content:""; display:block; width:10px; height:10px; border-top:3px solid #fff; border-left:3px solid #fff;
}
main#top .lb-prev{justify-self:center}
main#top .lb-prev::before{transform:rotate(-45deg)}
main#top .lb-next{justify-self:center}
main#top .lb-next::before{transform:rotate(135deg)}

/* クリック領域のレイアウト微調整 */
main#top .lightbox > .lb-prev{grid-column:1}
main#top .lightbox > .lb-stage{grid-column:2}
main#top .lightbox > .lb-next{grid-column:3}

/* ギャラリー画像にホバー効果（任意） */
main#top .gallery-img{cursor:zoom-in; transition:transform .15s ease}
main#top .gallery-img:hover{transform:scale(1.015)}
main#top .gallery-item {
  position: relative;
}

main#top .gallery-caption {
position: absolute;
  bottom: 8px;
  right: 8px;
  background: rgba(80, 80, 80, 0.6);
  color: #fff;
  font-size: 0.9rem;
  padding: 3px 8px;
  border-radius: 4px;
}
main#top .gallery-img {
  width: 100%;
  aspect-ratio: 1 / 1;   /* 枠を常に正方形にする */
  object-fit: cover;      /* はみ出た部分はトリミング */
  object-position: center; /* 画像の中央を基準に表示 */
  border-radius: 1px;
  display: block;
}
main#top .btnReuse.primarybtnReuse.gallerybtn{padding: 20px 0;
  background: #616161;
  font-size: 17px;
  border-radius: 2px;
  border: 0;}




/* ============ Eco ============ */
main#top .ecoV2-intro{background:#fff; padding:103px 0 82px}
main#top .ecoV2-intro__inner{max-width:920px; margin:0 auto; text-align:center}
main#top .ecoV2-h2{font-size:clamp(22px,3.2vw,30px); margin:0 0 10px;position: relative; font-weight:700;z-index: 1;}
main#top .ecoV2-underline{
 display: block;
  width: 105px;
  height: 5px;
  margin: 24px auto 47px;
  background: var(--brand);
  border-radius: 2px;
}
main#top .ecoV2-txt{color: #234;
  margin: 0 0 33px 0;
  line-height: 2.3;}

/* Green block */
main#top .ecoV2-green{
  position: relative; 
  background:var(--brand);
  padding:164px 0 111px; color:#fff; position:relative;
}
main#top .ecoV2-h3{
    position: relative;
  margin:0; font-weight:700; text-align:center;
 font-size: clamp(22px,3.2vw,30px);
  color:#fff;
}
main#top .effect-t::before,
main#top .ecoV2-green::before {
content: "";
  position: absolute;
  top: -23px;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 60px solid transparent;
  border-right: 60px solid transparent;
  border-top: 60px solid #3e8742;
  pointer-events: none;
  z-index: 1;
  filter: drop-shadow(0 16px 0 rgb(43, 119, 45));
}


@media (max-width:600px){
  main#top .ecoV2-green::before{
    top:-10px;
    border-left:30px solid transparent;
    border-right:30px solid transparent;
    border-top:30px solid #3e8742;
  }
}
main#top .ecoV2-underline--center{background:#fff; opacity:.9}

main#top .ecoV2-watermark{
    font-family: "Oswald", sans-serif;
position: absolute;
  inset: auto 0;
    top: auto;
  top: -99px;
  text-align: center;
  font-weight: 600;
  letter-spacing: .08em;
  font-size: min(22vw,96px);
  color: rgba(255,255,255,.08);
  pointer-events: none;
  user-select: none;
}
main#top .ecoV2-watermark--light{
color: #edf7ef;
  z-index: -1;
}

main#top .ecoV2-circles{
  display:grid; gap:18px; margin:22px 0 28px;
  grid-template-columns:repeat(3,minmax(0,1fr));
}
@media (max-width:960px){ main#top .ecoV2-circles{grid-template-columns:repeat(2,minmax(0,1fr))} }
@media (max-width:640px){ main#top .ecoV2-circles{grid-template-columns:1fr} }


main#top .ecoV2-circles{
  place-items: center;
}

main#top .ecoV2-circle{
  width: min(100%, 320px);   
  aspect-ratio: 1 / 1;     
  border-radius: 50%;
  background: #fff;
  color: #1e1e1e;
  padding: 22px;            
  box-shadow: 0 12px 26px rgba(0,0,0,.2);
  display: flex;             
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
}

main#top .ecoV2-circle__icon{
width: 77px;
  height: auto;
  margin: 0 0 17px;
}

@media (max-width: 640px){
  main#top .ecoV2-circle{
    width: clamp(220px, 72vw, 320px);  /* モバイルでちょうど良い直径に */
  }
}


main#top .ecoV2-circle__ttl{color:var(--brand);margin:4px 0 6px; font-size:1.05rem; font-weight:700}
main#top .ecoV2-circle__txt{margin:0; font-size:.95rem; color:#3a3a3a}

main#top .ecoV2-feature{
  display:grid; gap:24px; align-items:center;
  grid-template-columns: 1.1fr 1.2fr;margin: 122px 0 0 0;
}
@media (max-width:960px){ main#top .ecoV2-feature{grid-template-columns:1fr} }

main#top .ecoV2-media{
  position:relative; margin:0;width: 90%;
}
main#top .ecoV2-media img{width:100%; height:auto; display:block}
main#top .ecoV2-scribble{
  position:absolute; left:14px; top:-10px; transform:rotate(-15deg);
  background:rgba(255,255,255,.2); color:#fff;
  border:1px dashed rgba(255,255,255,.8);
  padding:6px 10px; border-radius:8px; font-weight:700; backdrop-filter:blur(2px);
}

main#top .ecoV2-feature__body{color:#fff;position: relative;}
main#top .ecoV2-feature__ttl{font-size:clamp(20px,3.2vw,28px); margin:0 0 34px; font-weight:700}
main#top .ecoV2-feature__body p{margin:.5rem 0 1.5rem;line-height: 2.3;}

/* Original section */
main#top .ecoV2-original{background:#fff; position:relative; padding:153px 0 76px}
main#top .ecoV2-original__inner{max-width:900px; margin:0 auto; text-align:center}
main#top .ecoV2-para{display:grid; gap:14px; color:var(--fg)}
main#top .ecoV2-watermark2{bottom: 0;
  top: auto;
  right: 0;
  left: auto;
  font-size: min(22vw,100px);}

/* ============ /Eco  ============ */



main#top .spBr{display: none}

main#top dd {
  margin-top: 0;
}





@media (max-width: 840px){
  main#top   .pcBr{display: none}
main#top .spBr{display: block}
main#top .filter-actions input[type="search"] {
  min-width: 100%;
}
main#top .cb6 {
  padding: 6px 0 1px;
}
  main#top .cb6-subword {
    line-height: 1.3;
    font-size: 19px;
    letter-spacing: 0.2em;
    margin-bottom: 10px;
  }
   main#top  .cb6-word {
        inset: 6px 0 0 0;
    font-size: 69px;
    }
    
  main#top  .meow-script-regular {
  inset: 27px 16px 0 0;
  font-size: 56px;
} 
    
   main#top  .cb6-row {
top: 49px;
    flex-wrap: wrap;
    }
    main#top .cb6--super .meow-script-regular {
  inset: 0px 27px 0 0;
}
main#top .cb6-cup {
  width: 15%;
}
main#top .cb6--super .cb6-hero, main#top .cb6--sleeve .cb6-hero, main#top .cb6--reuse .cb6-hero {
  margin: 78px 0 50px;

}
 main#top  .ecoFab-button {
    top: -79px;
    right: -5px;
  }
    
   main#top   .ecoFab-ext {
    width: 19px;
    height: 19px;
  } 
    
main#top   .ecoFab-label {
  line-height: 1.3;
}  
    
  main#top   .filters {
  gap: 0px;
    }
    
  main#top .filter-actions {
  width: 60%;
}  
   main#top  .tabs {
  flex-wrap: wrap;border-bottom: 0;
}
    main#top .tab {width: 100%;
  border-radius: 6px;
  padding: 1rem 0;
}
    
   main#top  .ecoV2-watermark {
  top: -65px;
  font-size: min(22vw,65px);
}
   main#top  .textLeftText{
    text-align: left;
    }
    
   main#top  .ecoV2-feature .ecoV2-feature__ttl{
  margin-top: 39px;
}
    
    
    
    main#top .btnReuse.printbtnReuse{font-size: 16px;}
    
    
    
    





}




@media (min-width: 440px) and (max-width: 840px) {
   main#top .cb6-word {
    font-size: 115px;
  }
     main#top .cb6-subword {
    font-size: 25px;
  }
      main#top .meow-script-regular {
    font-size: 85px;
  }
 main#top .cb6-cup {
    width: 11%;
  }   
    
    
}
@media (max-width: 1666px) {
  .side-menu-wrapper {
    display: none !important;
  }
}































