:root{
  --hg-green:#123c2b;
  --hg-green-soft:#eaf3eb;
  --hg-red:#9a2632;
  --hg-ink:#1e2923;
  --hg-body:#34483e;
  --hg-muted:#63736a;
  --hg-line:#e2dacd;
  --hg-paper:#f7f2e8;
  --hg-white:#fffdf8;
}
body{
  background:var(--hg-paper) !important;
  color:var(--hg-ink) !important;
  font-family:"Noto Sans JP","Yu Gothic",Meiryo,sans-serif !important;
  line-height:1.95 !important;
  letter-spacing:0 !important;
  font-feature-settings:"palt";
}
p,li,td,dd{
  color:var(--hg-body);
  font-size:16px;
  line-height:1.95;
}
h1,h2,h3{
  letter-spacing:0 !important;
  color:var(--hg-green) !important;
}
h1{
  font-family:"Noto Serif JP","Yu Mincho",serif !important;
  font-size:clamp(34px,5.2vw,58px) !important;
  line-height:1.3 !important;
  font-weight:700 !important;
}
h2{
  font-family:"Noto Serif JP","Yu Mincho",serif !important;
  font-size:clamp(26px,3.6vw,40px) !important;
  line-height:1.45 !important;
  margin-top:1.7em;
}
h3{
  font-size:20px !important;
  line-height:1.55 !important;
  font-weight:800 !important;
}
.site-header,.header-inner,header,[class*="header"]{
  letter-spacing:0 !important;
}
.site-intro{
  max-width:1180px;
  margin:0 auto;
  padding:58px 22px 34px;
}
.site-intro .kicker{
  display:inline-block;
  margin:0 0 12px;
  color:var(--hg-red);
  font-size:13px;
  font-weight:900;
  letter-spacing:.08em !important;
}
.site-intro p:last-child{
  max-width:760px;
  margin:18px 0 0;
  font-size:18px;
  font-weight:600;
  color:var(--hg-body);
}
.section,.sales-section,section{
  scroll-margin-top:88px;
}
.sales-section,.wrap{
  color:var(--hg-ink);
}
.sales-title h2,.section h2{
  margin-top:0;
}
.sales-title p,.intro,.lead{
  color:var(--hg-muted) !important;
  font-size:17px !important;
}
.card,.problem-card,.product-card,.image-card,.step,.set-panel,.recommend,
[class*="card"],[class*="pickup_link"]{
  border-radius:10px !important;
}
.card,.problem-card,.product-card,.image-card,.step,.set-panel,
[class*="pickup_link"]{
  background:var(--hg-white) !important;
  border:1px solid var(--hg-line) !important;
  box-shadow:0 12px 30px rgba(18,60,43,.07) !important;
}
.problem-card strong,.badge,.section-kicker{
  color:var(--hg-red) !important;
  font-weight:900 !important;
  letter-spacing:.08em !important;
}
.buy-btn,.btn,.sub-btn,button,[class*="button"]{
  border-radius:8px !important;
  font-weight:900 !important;
}
.buy-btn{
  background:#d71920 !important;
  color:white !important;
}
table{
  border-radius:10px;
  overflow:hidden;
}
th{
  background:var(--hg-green-soft) !important;
  color:var(--hg-green) !important;
}
@media(max-width:880px){
  .site-intro{
    padding:38px 16px 22px;
  }
  p,li,td,dd{
    font-size:15px;
  }
  .sales-title p,.intro,.lead,.site-intro p:last-child{
    font-size:16px !important;
  }
}
/* HIDEGEN final dark header/footer override */
.site-header,
header.site-header,
.site-header .header-inner,
header.site-header .header-inner {
  background: #0e3d2b !important;
  color: #ffffff !important;
  border-bottom: 0 !important;
  box-shadow: none !important;
}
.site-header .brand,
.site-header .brand:visited,
.site-header .brand span,
.site-header .nav a,
.site-header .nav a:visited,
.site-header nav a,
.site-header nav a:visited {
  color: #ffffff !important;
  background: transparent !important;
  text-decoration: none !important;
}
.site-header .brand span,
.site-header .text-logo-sub {
  color: rgba(255,255,255,.72) !important;
}
.site-footer,
footer.site-footer,
.site-footer .footer-inner,
footer.site-footer .footer-inner {
  background: #0e3d2b !important;
  color: #ffffff !important;
  border-top: 0 !important;
}
.site-footer *,
footer.site-footer *,
.site-footer a,
footer.site-footer a {
  color: #ffffff !important;
  text-decoration: none !important;
}
.site-footer .footer-brand span,
footer.site-footer .footer-brand span {
  color: rgba(255,255,255,.72) !important;
}
/* HIDEGEN final Japanese readability fix: natural wrapping without forced phrase breaks */
p, li, dd, td, th, .lead, .page-lead, .sales-lead, .home-about-panel p, .section-block p, .main-content p, .main-content li, .article p, .article li, .cta p, .problem-card p, .guide-link p, .usecase-card p {
  word-break: normal !important;
  overflow-wrap: normal !important;
  line-break: strict !important;
}
.home-about-panel p, .home-visual-hero p, .site-intro p {
  max-width: 980px !important;
}
.shop-grid .card, .final-offer h2, body .site-intro.home-visual-hero h1, body .site-intro.home-visual-hero p {
  word-break: normal !important;
  overflow-wrap: normal !important;
  line-break: strict !important;
}
.nowrap-term { white-space: nowrap !important; }
/* HIDEGEN final readable layout: keep text areas wide, then let the browser wrap naturally. */
html body main.page-wrap,
html body main.clean-page,
html body main.product-clean-page,
html body .page-wrap,
html body .clean-page,
html body .product-clean-page,
html body .wrap,
html body .main-content,
html body .article,
html body .blog_body {
  width: min(100% - 32px, 1180px) !important;
  max-width: 1180px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  box-sizing: border-box !important;
}
html body .sales-section,
html body .section,
html body section,
html body .section-block,
html body .sales-title,
html body .home-about-panel,
html body .site-intro,
html body .home-visual-hero,
html body .product-clean-page .section {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}
html body .page-lead,
html body .lead,
html body .intro,
html body .section-desc,
html body .section-text,
html body .sales-title p,
html body .site-intro p,
html body .home-visual-hero p,
html body .home-about-panel p,
html body .sales-lead,
html body .article p,
html body .article li,
html body .blog_body p,
html body .blog_body li,
html body .main-content p,
html body .main-content li,
html body .section-block p,
html body .cta p,
html body .problem-card p,
html body .guide-link p,
html body .usecase-card p,
html body .product-clean-page .section-desc,
html body .product-clean-page .section-text {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  white-space: normal !important;
  word-break: normal !important;
  overflow-wrap: break-word !important;
  line-break: strict !important;
  text-wrap: pretty;
}
html body .sales-title p,
html body .page-lead,
html body .section-desc,
html body .home-about-panel p {
  font-size: clamp(15px, 1.45vw, 17px) !important;
  line-height: 2 !important;
}
@media (max-width: 760px) {
  html body main.page-wrap,
  html body main.clean-page,
  html body main.product-clean-page,
  html body .page-wrap,
  html body .clean-page,
  html body .product-clean-page,
  html body .wrap,
  html body .main-content,
  html body .article,
  html body .blog_body {
    width: min(100% - 24px, 1180px) !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
}