<style>
/* ===== BASE ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Noto Sans JP","Hiragino Kaku Gothic ProN","Yu Gothic",sans-serif;
  font-size:16px;line-height:1.9;color:#222;background:#fff;
}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
p{margin-bottom:1em}
p:last-child{margin-bottom:0}

/* ===== COLOR TOKENS ===== */
:root{
  --aq:        #0097a7;
  --aq-d:      #00737f;
  --aq-l:      #e0f5f7;
  --aq-mid:    #b2ebf2;
  --or:        #e8670e;
  --or-d:      #c55506;
  --or-l:      #fef0e6;
  --hero-bg:   #0a2d3a;
  --hero-mid:  #0d3d4f;
  --navy:      #1a3a5c;
  --gray-bg:   #f4f6f7;
  --gray-mid:  #e8ecee;
  --border:    #dde3e6;
  --text:      #222;
  --sub:       #4a5568;
  --inner-w:   1080px;
  --content-w: 1000px;
  --r:         4px;
}

/* ===== LAYOUT ===== */
.l-inner  {max-width:var(--inner-w);margin:0 auto;padding:0 24px}
.l-content{max-width:var(--content-w);margin:0 auto;padding:0 24px}

/* ===== PLACEHOLDER ===== */
.ph{
  display:flex;align-items:center;justify-content:center;
  flex-direction:column;gap:6px;color:#888;font-size:12px;font-weight:500;
  margin:20px 0;
}
.ph-cap{font-size:14px;color:#1e1e1e;text-align:center;margin-top:-12px;margin-bottom:16px}
.ph-sm {}.ph-md{}.ph-lg{}.ph-xl{}
.ph-2col{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:20px 0}
.ph-2col .ph{padding: 5%;}

/* ===== HERO KV ===== */
.hero {
  background:
    url("../img/hero-bg.jpg") center right / cover no-repeat;
  padding: 64px 0 0;
  color: #fff;
  position: relative;
  overflow: hidden;
}
.hero-body{
  position:relative;
  display:grid;grid-template-columns:1fr 400px;gap:48px;
  align-items:center;padding-bottom:56px;
}
.hero-eyebrow{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.hero-badge-date{
  background:var(--or);color:#fff;font-size:13px;font-weight:700;
  padding:5px 14px;border-radius:3px;letter-spacing:.03em;
}
.hero-badge-cat{
  border:1px solid rgba(255,255,255,.4);color:rgba(255,255,255,.85);
  font-size:12px;padding:4px 10px;border-radius:3px;
}
.hero h1{
  font-size:28px;font-weight:900;line-height:1.5;
  margin-bottom:20px;letter-spacing:-.01em;
}
.hero h1 em{font-style:normal;color:#f5c842}
.hero-sub{
  font-size:14px;line-height:1.9;color:#ebebeb;margin-bottom:28px;
}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap}
.btn-or{
  background:var(--or);color:#fff;
  padding:13px 28px;border-radius:3px;font-size:14px;font-weight:700;
  border:2px solid var(--or);transition:all .2s;display:inline-block;
}
.btn-or:hover{background:var(--or-d);border-color:var(--or-d)}
.btn-or-outline{
  background: #0b2d39;color:#fff;
  padding:13px 28px;border-radius:3px;font-size:14px;font-weight:700;
  border:2px solid rgba(255,255,255,.55);transition:all .2s;display:inline-block;
}
.btn-or-outline:hover{background:rgba(255,255,255,.08)}
.hero-img-col .ph{
  height:340px;
}

/* ===== STATS BAR ===== */
.stats-bar{
  background:rgba(0,0,0,.25);
  border-top:1px solid rgba(255,255,255,.08);
  position:relative;
}
.stats-row{display:flex;border-top:none}
.stat-c{
  flex:1;text-align:center;padding:22px 12px;
  border-right:1px solid rgba(255,255,255,.08);color:#fff;
}
.stat-c:last-child{border-right:none}
.stat-num{font-size:32px;font-weight:900;color:#7fdde8;line-height:1.1;letter-spacing:-.02em}
.stat-num em{font-size:15px;font-style:normal}
.stat-lbl{font-size:11px;color:#88b8c4;margin-top:4px;line-height:1.5}

/* ===== MAIN CONTENT WRAPPER ===== */
.main-wrap{}

/* ===== ARTICLE META ===== */
.art-meta{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  margin-bottom:28px;padding-bottom:20px;border-bottom:1px solid var(--border);
}
.tag{font-size:11px;padding:3px 10px;border-radius:2px;background:#f0f0f0;color:#555;border:1px solid #ddd}
.tag-aq{background:var(--aq-l);color:var(--aq-d);border-color:var(--aq-mid)}
.tag-date{background:transparent;color:#999;border:none;font-size:12px}

/* ===== HEADINGS ===== */
.lp-h2{
  font-size:22px;font-weight:900;color:#1a1a1a;line-height:1.5;
  border-bottom:2px solid var(--aq);padding-bottom:10px;margin:52px 0 22px;
}
.lp-h2:first-child{margin-top:0}
.lp-h3{
  font-size:17px;font-weight:700;color:#1a1a1a;line-height:1.5;
  padding-left:12px;border-left:4px solid var(--aq);margin:32px 0 14px;
}
.lp-h4{font-size:15px;font-weight:700;color:#333;margin:22px 0 10px}

/* ===== TEXT ===== */
.lead-text{font-size:16px;font-weight:500;color:#1a1a1a;line-height:1.85;margin-bottom:24px}
.body-text{font-size:15px;color:var(--sub);line-height:1.9}
.bold{font-weight:700;color:#1a1a1a}
.aq{color:var(--aq)}
.or{color:var(--or)}

/* ===== INLINE CTA ===== */
.inline-cta{
  background:var(--gray-bg);border:1px solid var(--border);
  border-radius:var(--r);padding:22px 24px;text-align:center;margin:40px 0;
}
.inline-cta p{font-size:14px;color:#333;font-weight:700;margin-bottom:14px}
.btn-cta{
  display:inline-block;background:var(--or);color:#fff;
  font-size:14px;font-weight:700;padding:12px 36px;border-radius:3px;transition:background .2s;
}
.btn-cta:hover{background:var(--or-d)}

/* ===== NOTE BOXES ===== */
.note-box{
  background:#fffbea;border:1px solid #f0c040;
  border-left:4px solid #e0a000;border-radius:var(--r);
  padding:12px 16px;font-size:14px;color:#6b4c00;margin:16px 0;
}
.info-box{
  background:var(--aq-l);border:1px solid var(--aq-mid);
  border-left:4px solid var(--aq);border-radius:var(--r);
  padding:14px 18px;font-size:14px;color:#1a1a1a;margin:20px 0;line-height:1.75;
}

/* ===== COMPARE TABLE ===== */
.cmp-tbl{width:100%;border-collapse:collapse;font-size:14px;margin:20px 0}
.cmp-tbl thead th{background:var(--navy);color:#fff;padding:10px 14px;text-align:center;font-weight:700}
.cmp-tbl thead th.th-now{background:#888}
.cmp-tbl thead th.th-ksk{background:var(--aq-d)}
.cmp-tbl tbody td{padding:9px 14px;border:1px solid var(--border);vertical-align:middle}
.cmp-tbl .td-lbl{font-weight:700;background:#f8f8f8;width:20%}
.cmp-tbl .td-new{color:var(--aq-d);font-weight:600}
.cmp-tbl tbody tr:nth-child(even) td{background:#fafafa}

/* ===== CONCEPT CARDS ===== */
.concept-3col{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin:24px 0}
.concept-c{border:1px solid var(--border);border-radius:var(--r);border-top:3px solid var(--aq);padding:22px 18px;background:#fff}
.concept-c:nth-child(2){border-top-color:var(--navy)}
.concept-c:nth-child(3){border-top-color:#2a6a40}
.concept-c-no{font-size:11px;font-weight:700;color:var(--aq);letter-spacing:.1em;margin-bottom:8px;display:block}
.concept-c:nth-child(2) .concept-c-no{color:var(--navy)}
.concept-c:nth-child(3) .concept-c-no{color:#2a6a40}
.concept-c h3{font-size:15px;font-weight:700;color:#1a1a1a;margin-bottom:8px;line-height:1.45}
.concept-c .ph{height:88px;margin:10px 0}
.concept-c p{font-size:13px;color:var(--sub);line-height:1.75;margin-bottom:0}

/* ===== STEPS ===== */
.step-item{
  display:flex;gap:14px;align-items:flex-start;
  padding:14px 16px;border:1px solid var(--border);border-radius:var(--r);
  margin-bottom:10px;background:#fff;
}
.step-num{
  width:30px;height:30px;background:var(--aq);color:#fff;border-radius:50%;
  font-size:14px;font-weight:900;display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.step-item h4{font-size:14px;font-weight:700;color:#1a1a1a;margin-bottom:3px}
.step-item p{font-size:13px;color:var(--sub);margin-bottom:0;line-height:1.65}

/* ===== STATS 3COL ===== */
.stat3col{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:24px 0}
.stat3-c{background:var(--hero-bg);color:#fff;border-radius:var(--r);padding:20px 16px;text-align:center}
.stat3-num{font-size:30px;font-weight:900;color:#7fdde8;line-height:1.1;letter-spacing:-.02em}
.stat3-num em{font-size:15px;font-style:normal}
.stat3-lbl{font-size:12px;color:#88b8c4;margin-top:5px;line-height:1.5}

/* ===== RISK BOXES ===== */
.risk-box{border:1px solid var(--border);border-left:4px solid var(--or);border-radius:var(--r);padding:12px 16px;margin-bottom:10px;background:#fff}
.risk-box h4{font-size:14px;font-weight:700;color:#1a1a1a;margin-bottom:3px}
.risk-box p{font-size:13px;color:var(--sub);margin-bottom:0}

/* ===== ACTION CARDS ===== */
.action-3col{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin:24px 0}
.action-c{border:1px solid var(--border);border-radius:var(--r);padding:20px 18px;background:#fafbfc}
.action-c-no{background:var(--aq-l);color:var(--aq-d);font-size:11px;font-weight:700;padding:3px 10px;border-radius:2px;display:inline-block;margin-bottom:10px}
.action-c h3{font-size:15px;font-weight:700;color:#1a1a1a;margin-bottom:8px;line-height:1.4}
.action-c p{font-size:13px;color:var(--sub);line-height:1.75;margin-bottom:0}

/* ===== TIMELINE ===== */
.tl-outer{overflow-x:auto;margin:20px 0;padding-bottom:4px}
.tl-row{display:flex;min-width:680px;position:relative}
.tl-row::before{content:"";position:absolute;top:18px;left:30px;right:30px;height:2px;background:var(--aq)}
.tl-col{flex:1;padding-top:44px;text-align:center;position:relative;padding-left:4px;padding-right:4px}
.tl-dot{
  width:12px;height:12px;border-radius:50%;background:var(--aq);
  border:2px solid #fff;box-shadow:0 0 0 2px var(--aq);
  position:absolute;top:13px;left:50%;transform:translateX(-50%);z-index:1;
}
.tl-dot-or{background:var(--or);box-shadow:0 0 0 2px var(--or)}
.tl-date{font-size:12px;font-weight:700;color:var(--aq-d);margin-bottom:6px;line-height:1.4}
.tl-hl .tl-date{color:var(--or)}
.tl-app{
  font-size:11px;background:var(--aq-l);border:1px solid var(--aq-mid);
  color:var(--aq-d);border-radius:2px;padding:3px 5px;margin-bottom:4px;line-height:1.4;
}
.tl-hl .tl-app{background:var(--or-l);border-color:#f4c09a;color:var(--or-d);font-weight:600}

/* ===== MJS対応表 ===== */
.app-tbl{width:100%;border-collapse:collapse;font-size:14px;margin:20px 0}
.app-tbl thead th{background:var(--hero-bg);color:#fff;padding:10px 14px;text-align:left;font-size:13px;font-weight:700}
.app-tbl tbody tr{border-bottom:1px solid var(--border)}
.app-tbl tbody tr:hover{background:#f0fafc}
.app-tbl td{padding:10px 14px;vertical-align:middle}
.td-no  {width:46px;color:#bbb;font-size:12px;text-align:center}
.td-name{font-weight:700;color:#1a1a1a}
.td-time{font-weight:700;white-space:nowrap}
.td-note{font-size:12px;color:#888}
.t-aug{color:#a81717}.t-sep{color:#c05000}.t-nov{color:#2a6a40}
.t-jan{color:#1a3a9c}.t-jun{color:#6a1a9c}
.tp{display:inline-block;font-size:10px;padding:1px 6px;border-radius:8px;font-weight:700;margin-left:4px}
.tp-aug{background:#fdeaea;color:#a81717}
.tp-sep{background:var(--or-l);color:var(--or-d)}
.tp-nov{background:#e8f5e9;color:#2a6a40}
.tp-jan{background:#e3eeff;color:#1a3a9c}
.tp-jun{background:#f3e5ff;color:#6a1a9c}
.t-warn{color:var(--or-d);font-weight:700;font-size:12px}
.tl-legend{display:flex;align-items:center;gap:8px;font-size:12px;color:#888;flex-wrap:wrap;margin-top:8px}

/* ===== 製品カード ===== */
.prod-intro{font-size:15px;font-weight:700;color:#1a1a1a;text-align:center;margin:40px 0 6px;padding-top:40px;border-top:1px solid var(--border)}
.prod-intro-sub{font-size:14px;color:var(--sub);text-align:center;margin-bottom:24px}
.prod-card{border:1px solid var(--border);border-radius:var(--r);padding:24px;margin-bottom:20px;background:#fff}
.prod-card-head{display:flex;align-items:flex-start;gap:20px;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid #eee}
.prod-logo{width:180px;flex-shrink:0}
.prod-logo .ph{height:52px;margin:0;font-size:11px}
.prod-meta{flex:1}
.prod-cat{font-size:12px;color:#888}
.prod-name{font-size:18px;font-weight:900;color:#1a1a1a;margin:3px 0 2px}
.prod-kana{font-size:11px;color:#bbb}
.prod-desc{font-size:14px;color:var(--sub);line-height:1.8;margin-bottom:14px}
.prod-tags{display:flex;flex-wrap:wrap;gap:6px}
.prod-tag{font-size:11px;padding:2px 9px;border-radius:2px;background:var(--aq-l);color:var(--aq-d);border:1px solid var(--aq-mid)}

/* ===== BOTTOM CTA ===== */
.bottom-cta{background:var(--gray-bg);border-top:1px solid var(--border);padding:48px 0;text-align:center}
.bottom-cta p{font-size:15px;color:#333;margin-bottom:20px}
.bottom-cta-btns{display:flex;justify-content:center;gap:16px;flex-wrap:wrap;margin-bottom:16px}
.btn-outline{
  display:inline-block;border:2px solid var(--aq);color:var(--aq);
  font-size:14px;font-weight:700;padding:11px 32px;border-radius:3px;transition:all .2s;
}
.btn-outline:hover{background:var(--aq);color:#fff}
.btn-cta-lg{
  display:inline-block;background:var(--or);color:#fff;
  font-size:15px;font-weight:700;padding:14px 44px;border-radius:3px;transition:background .2s;
}
.btn-cta-lg:hover{background:var(--or-d)}
.bottom-cta-sub{font-size:13px;color:#888}
.bottom-cta-sub a{color:var(--aq)}
.bottom-cta-sub a:hover{text-decoration:underline}

.inline-cta-band {
  width: 100%;
  padding: 40px 24px;
  text-align: center;
  box-sizing: border-box;
}
.inline-cta-band p {
  font-size: 24px;
  font-weight: 700;
  color: #1a1a1a;
  margin-bottom: 18px;
  line-height: 1.6;
}
.inline-cta-band small {
  display: block;
  font-size: 12px;
  color: #888;
  margin-top: 12px;
}

/* ===== MJS対応予定セクション ===== */
.mjs-plan-wrap {
  background: #f4f6f7;
  border-top: 3px solid #f5c842;
  border-bottom: 3px solid #f5c842;
  padding: 36px 24px 24px;
  margin: 40px 0;
}
.mjs-plan-head {
  text-align: center;
  margin-bottom: 20px;
}
.mjs-plan-catch {
  font-size: 32px;
  font-weight: 900;
  color: #0a2d3a;
  line-height: 1.4;
  margin-bottom: 6px;
  letter-spacing: -.01em;
}
.mjs-plan-catch em {
  font-style: normal;
  color: #e8670e;
}
.mjs-plan-timing {
  font-size: 20px;
  font-weight: 700;
  color: #e8670e;
  margin-bottom: 14px;
}
.mjs-brand-row {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 6px;
}
.mjs-brand-tag {
  display: inline-block;
  background: #0a2d3a;
  color: #f5c842;
  font-size: 16px;
  font-weight: 700;
  padding: 4px 12px;
  border-radius: 2px;
}
.mjs-sys-box {
  background: #fff;
  border: 1px solid #dde3e6;
  border-radius: 4px;
  padding: 16px 20px;
}
.mjs-sys-label {
  font-size: 16px;
  font-weight: 700;
  color: #0097a7;
  letter-spacing: .08em;
  margin-bottom: 10px;
}
.mjs-sys-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.mjs-sys-tag {
  display: inline-block;
  background: #e0f5f7;
  border: 1px solid #b2ebf2;
  color: #00737f;
  font-size: 14px;
  padding: 4px 10px;
  border-radius: 2px;
}
.mjs-plan-note {
  font-size: 11px;
  color: #aaa;
  text-align: center;
  margin: 10px 0 0;
}

/* ===== RESPONSIVE ===== */
@media(max-width:860px){
  .hero-body{grid-template-columns:1fr}
  .hero-img-col{display:none}
  .concept-3col,.action-3col,.stat3col{grid-template-columns:1fr}
  .ph-2col{grid-template-columns:1fr}
  .stats-row{flex-wrap:wrap}
  .stat-c{flex:0 0 50%}
}

</style>
