:root{
  --green:#00945f;
  --green-dark:#006b48;
  --orange:#ff6b35;
  --yellow:#ffcf33;
  --ink:#18211e;
  --muted:#65736e;
  --line:#e5eee9;
  --bg:#f7fbf8;
  --card:#ffffff;
  --shadow:0 18px 50px rgba(12,48,35,.12);
  --radius:28px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Hiragino Kaku Gothic ProN","Yu Gothic",Meiryo,sans-serif;color:var(--ink);background:linear-gradient(180deg,#fff 0%,var(--bg) 45%,#fff 100%);line-height:1.75}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
.container{width:min(1120px,calc(100% - 36px));margin-inline:auto}.narrow{width:min(900px,calc(100% - 36px));margin-inline:auto}.section{padding:72px 0}.section.compact{padding:44px 0}.eyebrow{display:inline-flex;align-items:center;gap:.5rem;padding:.28rem .75rem;border-radius:999px;background:#e7f6ee;color:var(--green-dark);font-weight:800;font-size:.85rem;letter-spacing:.04em}.eyebrow::before{content:"";inline-size:.55rem;block-size:.55rem;background:var(--orange);border-radius:50%}h1,h2,h3{letter-spacing:.02em;line-height:1.28;margin:0 0 16px}h1{font-size:clamp(2.35rem,5vw,4.8rem);font-weight:900}h2{font-size:clamp(1.8rem,3vw,3rem);font-weight:900}h3{font-size:clamp(1.25rem,2vw,1.65rem);font-weight:850}p{margin:0 0 1rem}.lead{font-size:clamp(1.05rem,2vw,1.3rem);color:#355247}.muted{color:var(--muted)}.grid{display:grid;gap:24px}.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.grid.four{grid-template-columns:repeat(4,minmax(0,1fr))}.card{background:rgba(255,255,255,.9);border:1px solid var(--line);border-radius:var(--radius);box-shadow:0 10px 35px rgba(12,48,35,.07);overflow:hidden}.card.pad{padding:28px}.card-image{aspect-ratio:16/10;object-fit:cover;width:100%}.pill{display:inline-flex;align-items:center;gap:.4rem;border:1px solid #dcebe3;background:#fff;border-radius:999px;padding:.45rem .75rem;font-weight:800;font-size:.9rem;color:#31584b}.button{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border-radius:999px;background:var(--green);color:#fff;font-weight:900;padding:.9rem 1.25rem;box-shadow:0 10px 25px rgba(0,148,95,.25);transition:.2s}.button:hover{transform:translateY(-2px);box-shadow:0 16px 34px rgba(0,148,95,.3)}.button.secondary{background:#fff;color:var(--green-dark);border:1px solid #cfe6da;box-shadow:none}.button.orange{background:var(--orange);box-shadow:0 10px 25px rgba(255,107,53,.24)}.actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center}.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.86);backdrop-filter:blur(18px);border-bottom:1px solid rgba(229,238,233,.8)}.header-inner{height:82px;display:flex;align-items:center;justify-content:space-between;gap:24px}.brand{display:flex;align-items:center;gap:14px}.brand img{height:38px;width:auto}.brand-copy{font-size:.78rem;color:var(--muted);line-height:1.35}.nav{display:flex;align-items:center;gap:8px}.nav a,.drop-btn{font:inherit;font-weight:850;color:#2c453a;border:0;background:transparent;padding:.65rem .75rem;border-radius:999px;cursor:pointer}.nav a:hover,.drop-btn:hover{background:#edf8f2;color:var(--green-dark)}.dropdown{position:relative}.dropdown-menu{position:absolute;right:0;top:110%;min-width:260px;background:#fff;border:1px solid var(--line);border-radius:22px;box-shadow:var(--shadow);padding:10px;display:none}.dropdown:hover .dropdown-menu,.dropdown:focus-within .dropdown-menu{display:grid}.dropdown-menu a{border-radius:14px}.menu-toggle{display:none;border:0;background:#eef8f2;color:var(--green-dark);border-radius:999px;padding:.72rem .9rem;font-weight:900}.hero{position:relative;isolation:isolate;overflow:hidden;padding:72px 0 80px}.hero::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 15% 12%,rgba(255,207,51,.36),transparent 32%),radial-gradient(circle at 85% 10%,rgba(0,148,95,.16),transparent 30%),linear-gradient(135deg,#fff 0%,#f0fbf5 100%);z-index:-2}.hero::after{content:"";position:absolute;right:-6vw;top:20px;width:min(50vw,640px);aspect-ratio:1;border-radius:42% 58% 64% 36%/48% 35% 65% 52%;background:rgba(0,148,95,.08);z-index:-1}.hero-grid{display:grid;grid-template-columns:1.02fr .98fr;gap:36px;align-items:center}.hero-media{position:relative}.hero-img{width:100%;border-radius:36px;box-shadow:var(--shadow);object-fit:cover;aspect-ratio:4/3}.floating-card{position:absolute;left:-18px;bottom:24px;background:#fff;border-radius:26px;padding:16px 18px;box-shadow:var(--shadow);max-width:280px;border:1px solid var(--line)}.quick-links{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:-36px;position:relative;z-index:2}.quick-links .card{padding:20px}.quick-links strong{display:block;font-size:1.05rem}.notice{display:grid;grid-template-columns:150px 1fr;gap:24px;align-items:center}.notice img{border-radius:24px;box-shadow:0 10px 30px rgba(12,48,35,.08)}.split{display:grid;grid-template-columns:.9fr 1.1fr;gap:36px;align-items:start}.section-title{display:flex;align-items:end;justify-content:space-between;gap:24px;margin-bottom:26px}.section-title p{max-width:640px}.store-card{display:grid;grid-template-rows:auto 1fr}.store-card .store-body{padding:22px}.store-meta{display:grid;gap:7px;color:#405b52}.store-meta span{display:flex;gap:.5rem}.category-tabs,.filters{display:flex;gap:10px;flex-wrap:wrap;margin:22px 0 28px}.filter-btn{border:1px solid #d9ebe3;background:#fff;border-radius:999px;padding:.65rem 1rem;font-weight:850;cursor:pointer}.filter-btn.is-active{background:var(--green);border-color:var(--green);color:#fff}.product-img{aspect-ratio:1/1;object-fit:contain;background:#f9fbfa;padding:22px}.faq details{border:1px solid var(--line);border-radius:20px;background:#fff;padding:18px 20px}.faq details+details{margin-top:12px}.faq summary{font-weight:900;cursor:pointer}.info-table{width:100%;border-collapse:collapse;background:#fff;border-radius:24px;overflow:hidden;box-shadow:0 10px 35px rgba(12,48,35,.06)}.info-table th,.info-table td{padding:16px 18px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}.info-table th{width:30%;background:#f0faf4;color:var(--green-dark)}.media-frame,.youtube-frame{position:relative;overflow:hidden;border-radius:28px;background:#10241b;box-shadow:var(--shadow);min-height:320px}.youtube-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}.tiktok-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px}.payment-logos{display:flex;gap:18px;flex-wrap:wrap;align-items:center}.payment-logos img{max-height:42px;width:auto;background:#fff;border-radius:12px;padding:6px;border:1px solid var(--line)}.banner-link img{border-radius:24px;box-shadow:0 10px 30px rgba(12,48,35,.08);width:100%}.page-hero{padding:58px 0 46px;background:radial-gradient(circle at 88% 12%,rgba(255,207,51,.22),transparent 32%),linear-gradient(135deg,#eef9f3,#fff)}.breadcrumbs{color:var(--muted);font-size:.93rem;margin-bottom:10px}.page-hero h1{font-size:clamp(2rem,4vw,3.6rem)}.site-footer{margin-top:60px;background:#123126;color:#e8fff4}.footer-grid{display:grid;grid-template-columns:1.2fr .8fr .8fr;gap:28px;padding:56px 0}.site-footer a{color:#e8fff4}.footer-logo{filter:brightness(0) invert(1);max-width:180px}.copyright{border-top:1px solid rgba(255,255,255,.15);padding:18px 0;color:#b7d6ca;font-size:.9rem}.list-clean{list-style:none;padding:0;margin:0;display:grid;gap:8px}.badge-row{display:flex;flex-wrap:wrap;gap:8px}.callout{background:linear-gradient(135deg,#fff8d9,#fff);border:1px solid #ffe8a6;border-radius:var(--radius);padding:28px;box-shadow:0 10px 35px rgba(155,103,0,.08)}.sdgs-icons img{width:210px;max-width:100%}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.stat{padding:20px;border-radius:24px;background:#fff;border:1px solid var(--line);text-align:center}.stat strong{display:block;font-size:1.55rem;color:var(--green-dark)}.mobile-only{display:none}
@media (max-width:980px){.hero-grid,.split,.grid.two{grid-template-columns:1fr}.grid.three,.grid.four{grid-template-columns:repeat(2,1fr)}.quick-links{grid-template-columns:repeat(2,1fr)}.nav{position:fixed;inset:82px 18px auto 18px;background:#fff;border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow);padding:16px;display:none;align-items:stretch;flex-direction:column}.nav.is-open{display:flex}.dropdown-menu{position:static;display:grid;box-shadow:none;border:0;background:#f7fbf8;margin-top:6px}.menu-toggle{display:inline-flex}.brand-copy{display:none}.footer-grid{grid-template-columns:1fr 1fr}.tiktok-grid{grid-template-columns:1fr}.stat-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:620px){.container,.narrow{width:min(100% - 28px,1120px)}.section{padding:52px 0}.grid.three,.grid.four,.quick-links{grid-template-columns:1fr}.header-inner{height:72px}.nav{inset:72px 14px auto 14px}.brand img{height:34px}.hero{padding:48px 0 60px}.floating-card{position:static;margin-top:12px}.notice{grid-template-columns:1fr}.footer-grid{grid-template-columns:1fr}.info-table th,.info-table td{display:block;width:100%}.info-table th{border-bottom:0}.stat-grid{grid-template-columns:1fr}.page-hero{padding:42px 0 36px}}

/* =========================================================
   Smartphone width fixes
   横スクロール防止・スマホ幅最適化
   ========================================================= */
html, body{
  width:100%;
  max-width:100%;
  overflow-x:hidden;
}
main, header, footer, section, .container, .narrow, .grid, .card, .callout, .section-title, .hero-grid, .split{
  min-width:0;
}
.container,.narrow{
  max-width:1120px;
  width:calc(100% - clamp(24px, 4vw, 36px));
}
iframe, video, embed, object{
  max-width:100%;
}
.callout iframe[src*="youtube.com"],
.callout iframe[src*="youtu.be"],
.card iframe[src*="youtube.com"],
.card iframe[src*="youtu.be"]{
  display:block;
  width:100% !important;
  height:auto !important;
  aspect-ratio:16 / 9;
  border:0;
  border-radius:20px;
  margin-bottom:18px;
}
.youtube-frame{
  width:100%;
  aspect-ratio:16 / 9;
  min-height:0;
}
.tiktok-grid,
.tiktok-grid > *,
.tiktok-embed{
  min-width:0 !important;
  max-width:100% !important;
  width:100% !important;
}
.tiktok-grid iframe{
  max-width:100% !important;
  width:100% !important;
}
.card, .callout{
  overflow-wrap:anywhere;
}
.actions .button{
  min-width:0;
  white-space:normal;
  text-align:center;
}
.stat-grid > br{
  display:none;
}
.payment-logos img{
  max-width:100%;
}
.info-table{
  table-layout:fixed;
}

@media (max-width:980px){
  .nav{
    max-height:calc(100dvh - 98px);
    overflow-y:auto;
    overflow-x:hidden;
  }
  .nav a,.drop-btn{
    width:100%;
    text-align:left;
  }
}

@media (max-width:620px){
  .container,.narrow{
    width:calc(100% - 24px);
  }
  .card.pad,
  .callout{
    padding:20px;
    border-radius:22px;
  }
  .section-title{
    display:block;
  }
  .actions{
    display:grid;
    grid-template-columns:1fr;
  }
  .actions .button,
  .button{
    width:100%;
  }
  .quick-links{
    margin-top:-24px;
  }
  .hero-img{
    border-radius:24px;
  }
  .payment-logos{
    gap:10px;
  }
  .payment-logos img{
    max-height:36px;
    padding:5px;
  }
  .footer-logo{
    max-width:160px;
  }
}

@media (max-width:380px){
  .container,.narrow{
    width:calc(100% - 20px);
  }
  .card.pad,
  .callout{
    padding:16px;
  }
  .brand img{
    height:30px;
  }
  h1{
    font-size:clamp(2rem, 12vw, 2.6rem);
  }
  h2{
    font-size:clamp(1.55rem, 9vw, 2.1rem);
  }
  .eyebrow{
    font-size:.78rem;
  }
}
