:root{--bg:#f8fafc;--surface:#fff;--surface-strong:#eff6ff;--text:#111827;--muted:#64748b;--primary:#1677ff;--primary-dark:#0b5ed7;--accent:#06b6d4;--line:#e5e7eb;--shadow:0 18px 45px rgba(15,23,42,.08)}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:var(--bg);color:var(--text);font-family:"Hiragino Sans","Yu Gothic","Meiryo",system-ui,sans-serif;line-height:1.75}a{color:inherit}img{max-width:100%;height:auto}h1,h2,h3,h4,p{overflow-wrap:anywhere}h1{margin:0 0 18px;font-size:clamp(2.05rem,6vw,4.7rem);line-height:1.08}h2{margin:0 0 12px;font-size:clamp(1.45rem,3vw,2.2rem);line-height:1.25}h3{margin:0 0 8px;font-size:1.12rem;line-height:1.45}.site-header{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:20px;padding:14px clamp(18px,4vw,54px);background:rgba(255,255,255,.94);border-bottom:1px solid var(--line);backdrop-filter:blur(16px)}.brand{display:inline-flex;align-items:center;gap:10px;font-weight:900;text-decoration:none;white-space:nowrap}.brand-mark{display:inline-grid;width:34px;height:34px;place-items:center;border-radius:10px;background:var(--text);color:#fff}.site-nav{display:flex;align-items:center;gap:16px;color:var(--muted);font-size:.93rem}.site-nav a{text-decoration:none}.site-nav a:hover,.site-nav a[aria-current=page]{color:var(--primary)}.nav-toggle{display:none;width:42px;height:42px;border:1px solid var(--line);border-radius:8px;background:#fff}.nav-toggle span{display:block;width:18px;height:2px;margin:4px auto;background:var(--text)}.eyebrow{margin:0 0 10px;color:var(--primary);font-size:.8rem;font-weight:900;letter-spacing:0;text-transform:uppercase}.hero{display:grid;grid-template-columns:minmax(0,1.3fr) minmax(280px,.7fr);gap:clamp(24px,5vw,64px);align-items:end;min-height:620px;padding:clamp(54px,8vw,96px) clamp(18px,5vw,72px);background:linear-gradient(110deg,rgba(17,24,39,.92),rgba(22,119,255,.24)),url("assets/hero-lifestyle.svg") center/cover;color:#fff}.hero .eyebrow{color:#93c5fd}.hero-copy{max-width:780px}.hero-copy p:not(.eyebrow){max-width:700px;margin:0;font-size:1.08rem}.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px}.hero-actions.centered{justify-content:center}.button{display:inline-flex;align-items:center;justify-content:center;min-height:46px;padding:11px 18px;border:1px solid var(--primary);border-radius:10px;background:#fff;color:var(--primary);font-weight:900;text-decoration:none;cursor:pointer}.button.primary{background:var(--primary);color:#fff}.button.ghost{border-color:rgba(255,255,255,.72);background:rgba(255,255,255,.12);color:#fff}.button.small{min-height:40px;padding:8px 14px;font-size:.92rem}.hero-panel{display:grid;gap:12px;padding:18px;border:1px solid rgba(255,255,255,.28);border-radius:14px;background:rgba(255,255,255,.14);backdrop-filter:blur(12px)}.hero-panel div{display:flex;justify-content:space-between;gap:14px;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.22)}.hero-panel div:last-child{border-bottom:0}.section{padding:clamp(48px,7vw,86px) clamp(18px,5vw,72px)}.section.compact{max-width:1180px;margin:0 auto}.section-heading{display:flex;align-items:end;justify-content:space-between;gap:20px;max-width:1180px;margin:0 auto 26px}.lead{max-width:820px;color:var(--muted)}.tinted{background:#eef6ff}.article-grid,.product-grid,.guide-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;max-width:1180px;margin:0 auto}.category-card,.article-card,.product-card,.content-panel,.contact-form,.policy,.notice,.cta-box,.faq-list details,.related-links{border:1px solid var(--line);border-radius:14px;background:#fff;box-shadow:var(--shadow)}.article-card,.product-card,.content-panel{padding:22px;text-decoration:none}.content-panel ul{margin:10px 0 0;padding-left:1.2em;color:var(--muted)}.tag,.card-kicker{display:inline-flex;margin-bottom:10px;padding:3px 10px;border-radius:999px;background:var(--surface-strong);color:var(--primary);font-size:.82rem;font-weight:900}.article-card p,.product-card p,.content-panel p{margin:0;color:var(--muted)}.text-link{display:inline-flex;color:var(--primary);font-weight:900;text-decoration:none}.ranking-grid{display:grid;gap:18px;max-width:1180px;margin:0 auto}.ranking-card{display:grid;grid-template-columns:auto 1fr;gap:18px;padding:22px;border:1px solid var(--line);border-radius:14px;background:#fff;box-shadow:var(--shadow)}.rank-badge{display:grid;width:48px;height:48px;place-items:center;border-radius:50%;background:var(--text);color:#fff;font-weight:900}.ranking-card ul,.article-body ul{margin:12px 0 0;padding-left:1.2em;color:var(--muted)}.page-title{padding:clamp(48px,7vw,84px) clamp(18px,5vw,72px) 26px;text-align:center}.page-title p{max-width:760px;margin:0 auto 18px;color:var(--muted)}.breadcrumbs{display:flex;flex-wrap:wrap;gap:8px;max-width:1180px;margin:18px auto 0;padding:0 clamp(18px,5vw,36px);color:var(--muted);font-size:.92rem}.breadcrumbs a{color:var(--primary);font-weight:900;text-decoration:none}.filter-bar{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:22px}.filter-button{min-height:40px;padding:8px 14px;border:1px solid var(--line);border-radius:999px;background:#fff;color:var(--muted);font-weight:900}.filter-button.active{background:var(--primary);color:#fff}.summary-list,.product-card dl{display:grid;gap:8px;margin:16px 0}.summary-list div,.product-card dl div{display:flex;justify-content:space-between;gap:12px;color:var(--muted)}.product-media{display:grid;gap:8px;margin:0 0 16px;aspect-ratio:4/3}.product-media img{width:100%;height:100%;object-fit:contain;border:1px solid var(--line);border-radius:12px;background:#f8fafc}.product-media figcaption{font-size:.78rem;color:var(--muted)}.article-page{max-width:1320px;margin:0 auto}.article-hero{padding:clamp(42px,7vw,78px) clamp(18px,5vw,72px);background:linear-gradient(180deg,#eff6ff 0%,rgba(248,250,252,0) 100%)}.article-hero p:not(.eyebrow){max-width:820px;color:var(--muted)}.article-layout{display:grid;grid-template-columns:250px minmax(0,1fr);gap:32px;padding:0 clamp(18px,5vw,36px) 70px}.toc{position:sticky;top:88px;align-self:start;display:grid;gap:8px;padding:18px;border:1px solid var(--line);border-radius:14px;background:#fff}.toc a{color:var(--muted);text-decoration:none}.article-body{display:grid;gap:34px;min-width:0}.article-body section{min-width:0;scroll-margin-top:90px}.notice,.cta-box,.related-links{padding:clamp(20px,4vw,30px)}.notice p,.cta-box p{margin:0 0 12px;color:var(--muted)}.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:14px;background:#fff;contain:layout paint}.comparison-table{width:100%;min-width:1180px;border-collapse:collapse}.price-table{min-width:880px}.comparison-table th,.comparison-table td{padding:14px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}.comparison-table thead th{background:#eff6ff;color:var(--primary-dark);position:sticky;top:0}.comparison-table tbody th{min-width:190px}.table-cta{min-width:190px}.price-meta{margin:12px 0;color:var(--muted);font-size:.92rem}.price-cell{display:inline-flex;min-width:92px;min-height:28px;align-items:center}.fit-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.affiliate-actions{display:grid;gap:12px;margin-top:18px}.moshimo-ad-source{display:none}.affiliate-actions .button{width:100%;max-width:360px}.shop-buttons{display:flex;flex-wrap:wrap;gap:10px}.shop-buttons.compact{display:grid;grid-template-columns:1fr;gap:8px}.shop-button{display:inline-flex;align-items:center;justify-content:center;min-height:46px;min-width:132px;padding:10px 14px;border:1px solid var(--line);border-radius:10px;background:#fff;color:var(--text);font-weight:900;text-decoration:none}.shop-button.amazon{border-color:#f0b84d;color:#5c3b00}.shop-button.rakuten{border-color:#d75a54;color:#8d1f1b}.shop-button.yahoo{border-color:#6d84d8;color:#1f3a93}.faq-list details{padding:16px 18px;margin-bottom:10px}.faq-list summary{cursor:pointer;font-weight:900}.related-links div{display:flex;flex-wrap:wrap;gap:10px}.related-links a{display:inline-flex;padding:8px 12px;border:1px solid var(--line);border-radius:10px;color:var(--primary);font-weight:900;text-decoration:none}.usecase-grid{display:grid;gap:18px}.contact-form{display:grid;gap:16px;padding:24px}.contact-form label{display:grid;gap:6px;font-weight:900}.contact-form input,.contact-form textarea{width:100%;padding:12px;border:1px solid var(--line);border-radius:10px;font:inherit}.policy{padding:28px}.site-footer{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:26px clamp(18px,5vw,72px);border-top:1px solid var(--line);background:#fff;color:var(--muted)}.site-footer div{display:flex;flex-wrap:wrap;gap:14px}.site-footer a{text-decoration:none}@media(max-width:1080px){.site-nav{gap:10px;font-size:.88rem}.article-grid,.product-grid,.guide-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.hero,.article-layout{grid-template-columns:1fr}.toc{position:static}.section-heading{align-items:start;flex-direction:column}}@media(max-width:720px){.site-nav{position:absolute;top:100%;left:0;right:0;display:none;flex-direction:column;align-items:stretch;padding:16px 18px;background:#fff;border-bottom:1px solid var(--line)}.site-nav.open{display:flex}.nav-toggle{display:block}.hero{min-height:auto}.article-grid,.product-grid,.guide-grid,.fit-grid{grid-template-columns:1fr}.shop-buttons{display:grid;grid-template-columns:1fr}.shop-button{width:100%;min-height:48px}.site-footer{align-items:flex-start;flex-direction:column}}
/* UI readability refinements: long product names, tables, cards, and mobile tap targets. */
body{
  font-size:clamp(.96rem,.92rem + .18vw,1.04rem);
  line-height:1.82;
  -webkit-text-size-adjust:100%;
  text-size-adjust:100%;
}
h1,h2,h3,h4,p,li,dt,dd,th,td,.brand,.site-nav a,.button,.shop-button,.tag,.card-kicker{
  line-break:strict;
  overflow-wrap:anywhere;
  word-break:normal;
}
h1{
  font-size:clamp(2rem,4.6vw,4rem);
  line-height:1.14;
}
h2{
  font-size:clamp(1.34rem,2.3vw,2rem);
  line-height:1.34;
}
h3{
  font-size:clamp(1.06rem,1vw + .82rem,1.22rem);
  line-height:1.48;
}
.site-header,.section-heading,.hero-panel div{
  min-width:0;
}
.brand{
  min-width:0;
  white-space:normal;
  line-height:1.25;
}
.brand span:last-child{
  min-width:0;
}
.site-nav{
  flex-wrap:wrap;
  justify-content:flex-end;
  row-gap:8px;
  min-width:0;
}
.site-nav a{
  padding:4px 0;
  line-height:1.45;
}
.hero{
  align-items:center;
}
.hero-copy,.hero-panel,.article-card,.product-card,.content-panel,.ranking-card,.notice,.cta-box,.related-links,.faq-list details{
  min-width:0;
  overflow:visible;
}
.hero-copy p:not(.eyebrow),.article-card p,.product-card p,.content-panel p,.notice p,.cta-box p{
  line-height:1.85;
}
.article-card,.product-card,.content-panel{
  display:flex;
  flex-direction:column;
  gap:10px;
  height:auto;
  min-height:100%;
}
.article-card .button,.product-card .shop-buttons,.content-panel .button{
  margin-top:auto;
}
.ranking-card{
  grid-template-columns:minmax(0,48px) minmax(0,1fr);
}
.ranking-card>div{
  min-width:0;
}
.summary-list div,.product-card dl div{
  display:grid;
  grid-template-columns:minmax(8.5rem,.85fr) minmax(0,1.15fr);
  gap:8px 14px;
  align-items:start;
}
.summary-list dt,.product-card dt{
  color:var(--text);
  font-weight:900;
}
.summary-list dd,.product-card dd{
  min-width:0;
  margin:0;
}
.product-media{
  display:grid;
  grid-template-rows:auto auto;
  gap:8px;
  aspect-ratio:auto;
}
.product-media img{
  width:100%;
  height:auto;
  aspect-ratio:4/3;
  max-height:230px;
  object-fit:contain;
}
.product-media figcaption{
  line-height:1.55;
}
.table-wrap{
  max-width:100%;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  contain:layout paint;
}
.comparison-table{
  table-layout:auto;
  min-width:1280px;
}
.wide-table{
  min-width:1580px;
}
.comparison-table th,.comparison-table td{
  min-width:118px;
  max-width:270px;
  padding:12px 14px;
  line-height:1.62;
  white-space:normal;
  vertical-align:top;
}
.comparison-table tbody th{
  position:sticky;
  left:0;
  z-index:2;
  min-width:190px;
  max-width:230px;
  background:#fff;
  box-shadow:1px 0 0 var(--line);
}
.comparison-table thead th:first-child{
  position:sticky;
  left:0;
  z-index:3;
}
.comparison-table .product-media{
  width:150px;
  min-width:150px;
  margin:0;
}
.comparison-table .product-media img{
  height:102px;
  max-height:102px;
}
.comparison-table .product-media figcaption{
  display:none;
}
.table-cta{
  min-width:180px;
}
.price-cell{
  min-width:0;
  white-space:nowrap;
}
.button,.shop-button,.filter-button,.nav-toggle{
  min-height:48px;
}
.button,.shop-button{
  padding:12px 16px;
  line-height:1.28;
  text-align:center;
  white-space:normal;
}
.shop-buttons{
  align-items:stretch;
}
.shop-button{
  flex:1 1 132px;
}
.shop-buttons.compact{
  grid-template-columns:minmax(0,1fr);
}
.related-links a,.filter-button{
  line-height:1.35;
}
@media(max-width:1080px){
  .site-header{
    align-items:flex-start;
  }
  .hero{
    min-height:auto;
  }
  .section,.article-hero,.page-title{
    padding-left:clamp(16px,4vw,34px);
    padding-right:clamp(16px,4vw,34px);
  }
  .comparison-table{
    min-width:1100px;
  }
  .wide-table{
    min-width:1450px;
  }
}
@media(max-width:720px){
  body{
    font-size:.96rem;
    line-height:1.78;
  }
  h1{
    font-size:clamp(1.82rem,8.8vw,2.65rem);
    line-height:1.18;
  }
  h2{
    font-size:clamp(1.26rem,5.8vw,1.72rem);
  }
  h3{
    font-size:1.08rem;
  }
  .site-header{
    align-items:center;
    gap:12px;
    padding:12px 16px;
  }
  .brand-mark{
    flex:0 0 auto;
  }
  .site-nav{
    justify-content:flex-start;
  }
  .site-nav a{
    padding:10px 2px;
  }
  .hero{
    gap:24px;
    padding-top:44px;
    padding-bottom:44px;
  }
  .hero-actions{
    display:grid;
    grid-template-columns:1fr;
  }
  .hero-panel{
    padding:16px;
  }
  .hero-panel div{
    display:grid;
    grid-template-columns:1fr;
    gap:4px;
  }
  .section{
    padding-top:42px;
    padding-bottom:42px;
  }
  .article-card,.product-card,.content-panel,.ranking-card{
    padding:18px;
  }
  .ranking-card{
    grid-template-columns:minmax(0,42px) minmax(0,1fr);
    gap:14px;
  }
  .rank-badge{
    width:42px;
    height:42px;
  }
  .summary-list div,.product-card dl div{
    grid-template-columns:1fr;
  }
  .product-media img{
    max-height:200px;
  }
  .comparison-table{
    min-width:980px;
  }
  .wide-table{
    min-width:1280px;
  }
  .comparison-table th,.comparison-table td{
    min-width:112px;
    max-width:230px;
    padding:11px 12px;
    font-size:.92rem;
  }
  .comparison-table tbody th{
    min-width:150px;
    max-width:170px;
  }
  .comparison-table .product-media{
    width:118px;
    min-width:118px;
  }
  .comparison-table .product-media img{
    height:84px;
    max-height:84px;
  }
  .table-cta{
    min-width:160px;
  }
  .button,.shop-button{
    width:100%;
    min-height:50px;
  }
  .breadcrumbs{
    font-size:.86rem;
  }
}
@media(max-width:430px){
  .site-header{
    padding-left:14px;
    padding-right:14px;
  }
  .brand{
    font-size:.95rem;
  }
  .brand-mark{
    width:32px;
    height:32px;
  }
  .article-layout{
    padding-left:14px;
    padding-right:14px;
  }
  .page-title p{
    font-size:.94rem;
  }
  .comparison-table{
    min-width:920px;
  }
  .wide-table{
    min-width:1180px;
  }
  .comparison-table th,.comparison-table td{
    min-width:104px;
    padding:10px;
  }
  .comparison-table tbody th{
    min-width:138px;
  }
}
/* Final UI tap-target and product image normalization. */
.button.small,.affiliate-actions .button,.article-card .button,.product-card .button,.content-panel .button,.shop-button{
  min-height:48px;
  padding-top:12px;
  padding-bottom:12px;
}
.ranking-card .product-media{
  width:min(100%,340px);
  max-width:340px;
}
.ranking-card .product-media img{
  height:220px;
  max-height:220px;
}
@media(max-width:720px){
  .button.small,.affiliate-actions .button,.article-card .button,.product-card .button,.content-panel .button,.shop-button{
    min-height:50px;
  }
  .ranking-card .product-media{
    width:100%;
    max-width:320px;
  }
  .ranking-card .product-media img{
    height:200px;
    max-height:200px;
  }
}


/* brand-media-renewal */
.brand-route-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px;max-width:1180px;margin:24px auto 0}
.brand-route{display:grid;gap:8px;padding:18px;border:1px solid var(--line);border-radius:14px;background:#fff;text-decoration:none;box-shadow:var(--shadow)}
.brand-route strong{font-size:1.15rem}
.brand-tabs{display:flex;flex-wrap:wrap;gap:10px;max-width:1180px;margin:0 auto 22px}
.brand-tabs a{display:inline-flex;align-items:center;justify-content:center;min-height:42px;padding:8px 14px;border:1px solid var(--line);border-radius:999px;background:#fff;color:var(--primary);font-weight:900;text-decoration:none}
.price-check{margin-top:auto}
.hidden-note{max-width:1180px;margin:0 auto;color:var(--muted);font-size:.92rem}
@media(max-width:1080px){.brand-route-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:720px){.brand-route-grid{grid-template-columns:1fr}.brand-tabs a{width:100%}}


/* purchase-decision-upgrade */
.decision-summary{display:grid;gap:18px}
.decision-summary .content-panel ul,.three-line-summary ul{margin:8px 0 0;padding-left:1.2em;color:var(--muted)}
.rating-cell{font-weight:900;color:#f59e0b;white-space:nowrap}
.three-line-summary{display:grid;gap:14px}

/* moshimo-easy-link-managed */
.moshimo-easy-link-slot{
  width:100%;
  margin:14px 0 0;
  overflow:hidden;
  border:1px solid var(--line);
  border-radius:12px;
  background:#fff;
}
.moshimo-easy-link-frame{
  display:block;
  width:100%;
  height:320px;
  border:0;
  background:#fff;
}
.table-cta .moshimo-easy-link-slot{
  min-width:280px;
  margin-top:10px;
}
.table-cta .moshimo-easy-link-frame{
  height:300px;
}
.article-middle-slot,.article-bottom-slot{
  grid-column:1 / -1;
}
@media(max-width:720px){
  .moshimo-easy-link-slot{
    border-radius:10px;
  }
  .moshimo-easy-link-frame{
    height:340px;
  }
  .table-cta .moshimo-easy-link-slot{
    min-width:250px;
  }
}
