/* ============================================================
   配達のがっこう  共通スタイル（モダン版）
   palette: 黒ナンバーの黄緑を主役に、洗練させる
   ============================================================ */
:root{
  --bg:#f6f8f5;            /* ごく薄いグリーンティントの白 */
  --surface:#ffffff;
  --ink:#1b2420;           /* 緑みのある黒 */
  --ink-soft:#5c6b63;
  --line:#e6ece6;
  --green:#37a04a;         /* 黒ナンバー由来・主役 */
  --green-deep:#1f7a33;
  --green-soft:#eaf5ec;
  --green-tint:#f0f8f1;
  --amber:#f0a13a;         /* アクセント2（達成・特典） */
  --ink-on-green:#06270f;
  --shadow:0 1px 2px rgba(27,36,32,.04),0 8px 24px rgba(27,36,32,.06);
  --shadow-lg:0 4px 12px rgba(27,36,32,.08),0 24px 48px rgba(27,36,32,.10);
  --r:18px;               /* やさしい丸み */
  --r-sm:12px;
  --r-pill:999px;
  --display:"Hiragino Sans","Hiragino Kaku Gothic ProN","Yu Gothic UI","Meiryo",sans-serif;
  --body:"Hiragino Sans","Hiragino Kaku Gothic ProN","Yu Gothic","Meiryo",sans-serif;
  --mono:"SFMono-Regular",Consolas,"Liberation Mono",Menlo,monospace;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:var(--body);line-height:1.7;-webkit-font-smoothing:antialiased}
.mono{font-family:var(--mono)}

@media (prefers-reduced-motion: reduce){*{animation:none!important;transition:none!important}}

/* ===== shared shell ===== */
.wrap{max-width:1120px;margin:0 auto;padding:0 1.5rem}
@media(max-width:560px){.wrap{padding:0 1.1rem}}

/* ===== top nav ===== */
.nav{position:sticky;top:0;z-index:100;background:rgba(246,248,245,.8);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;gap:1rem;height:68px}
.brand{display:flex;align-items:center;gap:.7rem;text-decoration:none}
.brand .mark{width:42px;height:42px;border-radius:13px;background:linear-gradient(145deg,var(--green),var(--green-deep));display:grid;place-items:center;box-shadow:0 4px 12px rgba(31,122,51,.28);position:relative}
.brand .mark::after{content:"配";color:#fff;font-weight:800;font-size:1.1rem}
.brand .bt{display:flex;flex-direction:column;line-height:1.15}
.brand .bt .n{font-size:1.05rem;font-weight:800;letter-spacing:.01em;color:var(--ink)}
.brand .bt .n em{color:var(--green-deep);font-style:normal}
.brand .bt .s{font-size:.62rem;color:var(--ink-soft);font-family:var(--mono);letter-spacing:.04em}
.nav-links{margin-left:auto;display:flex;gap:.3rem;align-items:center}
.nav-links a{font-size:.86rem;color:var(--ink-soft);text-decoration:none;padding:.5rem .8rem;border-radius:var(--r-pill);transition:.15s}
.nav-links a:hover{color:var(--ink);background:var(--green-soft)}
.nav-cta{background:var(--ink);color:#fff!important;font-weight:700;padding:.5rem 1.1rem!important}
.nav-cta:hover{background:var(--green-deep)!important;color:#fff!important}
@media(max-width:780px){.nav-links a:not(.nav-cta){display:none}}

/* ===== hero ===== */
.hero{position:relative;overflow:hidden;padding:3.4rem 0 2rem}
.hero::before{content:"";position:absolute;inset:0;background:
  radial-gradient(60% 50% at 85% 0%,rgba(55,160,74,.10),transparent 70%),
  radial-gradient(40% 40% at 0% 100%,rgba(240,161,58,.07),transparent 70%);pointer-events:none}
.hero-in{position:relative;display:grid;grid-template-columns:1.15fr .85fr;gap:2.5rem;align-items:center}
@media(max-width:880px){.hero-in{grid-template-columns:1fr;gap:1.8rem}}
.hero .pill{display:inline-flex;align-items:center;gap:.45rem;background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow);color:var(--green-deep);font-size:.76rem;font-weight:700;padding:.4rem .85rem;border-radius:var(--r-pill);margin-bottom:1.3rem}
.hero .pill .dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 0 3px rgba(55,160,74,.2)}
.hero h1{font-family:var(--display);font-size:clamp(2rem,5vw,3.1rem);line-height:1.22;letter-spacing:-.01em;font-weight:800;margin-bottom:1.1rem}
.hero h1 .hl{position:relative;white-space:nowrap;color:var(--green-deep)}
.hero h1 .hl::after{content:"";position:absolute;left:-.05em;right:-.05em;bottom:.08em;height:.42em;background:rgba(55,160,74,.16);z-index:-1;border-radius:3px}
.hero p.sub{font-size:1.05rem;color:var(--ink-soft);max-width:30em;margin-bottom:1.7rem}
.hero .btns{display:flex;gap:.7rem;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:.5rem;font-weight:700;font-size:.95rem;padding:.8rem 1.4rem;border-radius:var(--r-pill);text-decoration:none;transition:.18s;border:1px solid transparent;cursor:pointer}
.btn-primary{background:var(--green);color:var(--ink-on-green);box-shadow:0 6px 18px rgba(55,160,74,.3)}
.btn-primary:hover{background:var(--green-deep);color:#fff;transform:translateY(-1px)}
.btn-ghost{background:var(--surface);color:var(--ink);border-color:var(--line);box-shadow:var(--shadow)}
.btn-ghost:hover{border-color:var(--green);color:var(--green-deep)}
.hero .reassure{margin-top:1.1rem;font-size:.8rem;color:var(--ink-soft);display:flex;align-items:center;gap:.4rem}

/* ===== hero dashboard card (signature) ===== */
.dash{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-lg);padding:1.3rem;position:relative}
.dash .dash-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}
.dash .dash-top .ttl{font-size:.82rem;font-weight:700;color:var(--ink-soft)}
.dash .dash-top .live{display:inline-flex;align-items:center;gap:.35rem;font-size:.66rem;font-family:var(--mono);color:var(--green-deep);background:var(--green-soft);padding:.2rem .55rem;border-radius:var(--r-pill)}
.dash .dash-top .live .d{width:6px;height:6px;border-radius:50%;background:var(--green);animation:pulse 1.8s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.dash .big{display:flex;align-items:baseline;gap:.5rem;margin-bottom:.2rem}
.dash .big .v{font-family:var(--mono);font-size:2.7rem;font-weight:700;letter-spacing:-.02em;color:var(--ink);line-height:1}
.dash .big .u{font-size:1rem;color:var(--ink-soft);font-weight:700}
.dash .big .delta{margin-left:auto;font-size:.72rem;font-weight:700;color:var(--green-deep);background:var(--green-soft);padding:.2rem .5rem;border-radius:var(--r-pill)}
.dash .cap{font-size:.74rem;color:var(--ink-soft);margin-bottom:1.1rem}
.dash .bars{display:flex;align-items:flex-end;gap:5px;height:64px;padding:.4rem 0;border-top:1px dashed var(--line);border-bottom:1px dashed var(--line);margin-bottom:1rem}
.dash .bars i{flex:1;background:linear-gradient(var(--green),var(--green-soft));border-radius:4px 4px 2px 2px;opacity:.85;animation:grow .9s ease both}
@keyframes grow{from{height:0!important;opacity:0}}
.dash .legend{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}
.dash .legend div{background:var(--green-tint);border-radius:var(--r-sm);padding:.6rem .7rem}
.dash .legend .k{font-size:.6rem;color:var(--ink-soft);font-family:var(--mono);letter-spacing:.03em;margin-bottom:.15rem}
.dash .legend .vv{font-size:1rem;font-weight:800;color:var(--ink);font-family:var(--mono)}
.dash .note{position:absolute;top:-10px;right:14px;background:var(--amber);color:#3a2402;font-size:.64rem;font-weight:800;padding:.25rem .6rem;border-radius:var(--r-pill);box-shadow:0 4px 10px rgba(240,161,58,.35);transform:rotate(2deg)}

/* ===== marquee logos (services) ===== */
.svcrow{margin-top:2.4rem;border-top:1px solid var(--line);padding-top:1.4rem;display:flex;align-items:center;gap:1.4rem;flex-wrap:wrap}
.svcrow .lbl{font-size:.72rem;color:var(--ink-soft);font-family:var(--mono)}
.svcrow .chips{display:flex;gap:.5rem;flex-wrap:wrap}
.svcrow .chip{font-size:.8rem;font-weight:700;color:var(--ink);background:var(--surface);border:1px solid var(--line);padding:.35rem .8rem;border-radius:var(--r-pill);box-shadow:var(--shadow)}

/* ===== section base ===== */
.section{padding:3.2rem 0}
.eyebrow{display:inline-flex;align-items:center;gap:.5rem;font-size:.74rem;font-weight:800;letter-spacing:.08em;color:var(--green-deep);text-transform:uppercase;font-family:var(--mono);margin-bottom:.7rem}
.eyebrow::before{content:"";width:20px;height:2px;background:var(--green);border-radius:2px}
.section h2{font-family:var(--display);font-size:clamp(1.5rem,3.2vw,2.05rem);font-weight:800;letter-spacing:-.01em;line-height:1.3;margin-bottom:.6rem}
.section .desc{color:var(--ink-soft);max-width:40em;margin-bottom:1.8rem}

/* ===== why (背骨) — softened ===== */
.why{background:linear-gradient(160deg,#14241a,#1d3326);color:#e8efe9;border-radius:28px;padding:clamp(1.8rem,4vw,3rem);position:relative;overflow:hidden}
.why::before{content:"";position:absolute;top:-30%;right:-10%;width:50%;height:160%;background:radial-gradient(circle,rgba(55,160,74,.18),transparent 65%)}
.why .eyebrow{color:#7fd996}
.why h2{color:#fff;position:relative}
.why .free{font-size:clamp(1.05rem,2vw,1.25rem);line-height:1.85;color:#d6e3d8;margin:1.1rem 0;position:relative;max-width:30em}
.why .free b{color:#fff}
.why .turn{position:relative;font-size:clamp(1.1rem,2.2vw,1.4rem);font-weight:800;color:#fff;line-height:1.5;margin:1.4rem 0;padding-left:1.1rem;border-left:3px solid var(--green)}
.why .turn mark{background:var(--green);color:var(--ink-on-green);padding:0 .25em;border-radius:5px}
.why p.bd{position:relative;color:#bcccbf;max-width:42em;margin-bottom:.9rem;font-size:.96rem;line-height:1.85}
.why p.bd b{color:#fff}
.why .sign{position:relative;margin-top:1.4rem;display:inline-flex;align-items:center;gap:.5rem;font-family:var(--mono);font-size:.84rem;color:#7fd996;font-weight:700}

/* ===== roadmap — stepper ===== */
.steps{display:grid;gap:.9rem}
.step{display:grid;grid-template-columns:auto 1fr auto;gap:1.1rem;align-items:center;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:1.1rem 1.2rem;box-shadow:var(--shadow);transition:.18s;position:relative}
.step:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px);border-color:#d4e3d6}
.step .idx{width:48px;height:48px;border-radius:14px;background:var(--green-soft);color:var(--green-deep);display:grid;place-items:center;font-family:var(--mono);font-weight:800;font-size:1.15rem;flex-shrink:0}
.step.pay .idx{background:linear-gradient(145deg,var(--green),var(--green-deep));color:#fff;box-shadow:0 6px 14px rgba(31,122,51,.3)}
.step .st h3{font-size:1rem;font-weight:800;margin-bottom:.2rem}
.step .st p{font-size:.84rem;color:var(--ink-soft);line-height:1.6}
.step .st .tags{margin-top:.5rem;display:flex;gap:.35rem;flex-wrap:wrap}
.step .st .tags span{font-size:.66rem;font-weight:700;color:var(--green-deep);background:var(--green-tint);padding:.2rem .55rem;border-radius:var(--r-pill)}
.step .arrow{color:var(--ink-soft);font-size:1.3rem;transition:.18s}
.step:hover .arrow{color:var(--green);transform:translateX(3px)}
.step .opt{position:absolute;top:.7rem;right:1rem;font-size:.6rem;font-weight:800;color:var(--amber);font-family:var(--mono)}
@media(max-width:600px){.step{grid-template-columns:auto 1fr}.step .arrow{display:none}}

/* ===== compare ===== */
.tablewrap{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);overflow:hidden}
.ctable{width:100%;border-collapse:collapse;font-size:.88rem}
.ctable thead th{background:var(--green-tint);color:var(--ink);font-weight:800;font-size:.78rem;text-align:left;padding:.85rem 1rem;border-bottom:1px solid var(--line)}
.ctable td{padding:.85rem 1rem;border-bottom:1px solid var(--line);vertical-align:middle}
.ctable tbody tr:last-child td{border-bottom:none}
.ctable tbody tr{transition:.12s}
.ctable tbody tr:hover{background:var(--green-tint)}
.ctable .svc{font-weight:800;color:var(--ink)}
.ctable .svc small{display:block;font-weight:500;color:var(--ink-soft);font-family:var(--mono);font-size:.66rem;margin-top:1px}
.ctable .num{font-family:var(--mono);font-weight:700}
.ctable .hot{color:var(--green-deep)}
.badge{display:inline-flex;align-items:center;gap:.3rem;font-size:.66rem;font-weight:800;padding:.22rem .55rem;border-radius:var(--r-pill)}
.badge.now{background:var(--green-soft);color:var(--green-deep)}
.badge.now .d{width:5px;height:5px;border-radius:50%;background:var(--green)}
.badge.soon{background:#fdeccf;color:#9a6212}
.tbtn{display:inline-flex;align-items:center;gap:.3rem;font-size:.78rem;font-weight:700;color:#fff;background:var(--ink);text-decoration:none;padding:.4rem .8rem;border-radius:var(--r-pill);white-space:nowrap;transition:.15s}
.tbtn:hover{background:var(--green-deep)}
.tnote{font-size:.72rem;color:var(--ink-soft);margin-top:.8rem;font-family:var(--mono)}

/* ===== articles ===== */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
@media(max-width:860px){.cards{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.cards{grid-template-columns:1fr}}
.acard{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;text-decoration:none;color:inherit;box-shadow:var(--shadow);transition:.18s;display:flex;flex-direction:column}
.acard:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}
.acard .top{height:7px;background:linear-gradient(90deg,var(--green),var(--amber))}
.acard .pad{padding:1.1rem;display:flex;flex-direction:column;gap:.55rem;flex:1}
.acard .cat{font-size:.66rem;font-weight:800;color:var(--green-deep);font-family:var(--mono);letter-spacing:.03em}
.acard h3{font-size:.98rem;font-weight:800;line-height:1.5}
.acard .meta{margin-top:auto;display:flex;gap:.6rem;flex-wrap:wrap;font-size:.7rem;color:var(--ink-soft);font-family:var(--mono);padding-top:.5rem;border-top:1px solid var(--line)}

/* ===== orderer coupons ===== */
.order{background:linear-gradient(135deg,var(--green-tint),#fff);border:1px solid var(--line);border-radius:var(--r);padding:1.6rem;margin-top:1.4rem}
.order h3{font-size:1.15rem;font-weight:800;margin-bottom:.3rem}
.order .od{font-size:.85rem;color:var(--ink-soft);margin-bottom:1.1rem;max-width:42em}
.coupons{display:grid;grid-template-columns:repeat(3,1fr);gap:.7rem}
@media(max-width:680px){.coupons{grid-template-columns:1fr}}
.coupon{display:flex;align-items:center;gap:.7rem;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-sm);padding:.8rem .9rem;box-shadow:var(--shadow)}
.coupon .amt{font-family:var(--mono);font-weight:800;color:var(--green-deep);font-size:1.05rem;line-height:1;white-space:nowrap}
.coupon .ci{flex:1}
.coupon .ci .s{font-weight:800;font-size:.84rem}
.coupon .ci .s small{display:block;font-weight:500;color:var(--ink-soft);font-size:.64rem;font-family:var(--mono)}
.coupon a{font-size:.72rem;font-weight:700;color:var(--green-deep);text-decoration:none;border:1px solid var(--green);padding:.3rem .6rem;border-radius:var(--r-pill);white-space:nowrap}
.coupon a:hover{background:var(--green);color:#fff}
.bridge{margin-top:1rem;font-size:.85rem;background:var(--surface);border:1px dashed var(--green);border-radius:var(--r-sm);padding:.8rem 1rem;color:var(--ink)}
.bridge b{color:var(--green-deep)}
.bridge a{color:var(--green-deep);font-weight:700}

/* ===== stats strip ===== */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1.4rem}
@media(max-width:560px){.stats{grid-template-columns:1fr}}
.stat{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:1.3rem;text-align:center;box-shadow:var(--shadow)}
.stat .v{font-family:var(--mono);font-size:1.9rem;font-weight:800;color:var(--ink);letter-spacing:-.02em}
.stat .l{font-size:.76rem;color:var(--ink-soft);margin-top:.2rem}

/* ===== footer ===== */
footer{margin-top:3rem;background:#14241a;color:#aebfb2}
.foot-in{padding:2.4rem 0;display:flex;flex-wrap:wrap;gap:2rem;justify-content:space-between}
footer .brand .bt .n{color:#fff}
footer .brand .bt .n em{color:var(--green)}
footer .brand .bt .s{color:#7e9184}
footer .disc{max-width:34em;font-size:.72rem;line-height:1.75;color:#7e9184;font-family:var(--mono)}
footer a.fl{color:#cfe6c4;text-decoration:none;font-size:.84rem}

/* ===== article view ===== */
.article{max-width:760px;margin:0 auto;padding:2.2rem 1.5rem 3rem}
.crumb{font-size:.72rem;color:var(--ink-soft);font-family:var(--mono);margin-bottom:1.1rem}
.crumb a{color:var(--green-deep);text-decoration:none}
.article h1{font-family:var(--display);font-size:clamp(1.5rem,4vw,2rem);font-weight:800;line-height:1.4;letter-spacing:-.01em;margin-bottom:.9rem}
.abyline{display:flex;align-items:center;gap:.7rem;font-size:.76rem;color:var(--ink-soft);font-family:var(--mono);padding-bottom:1.2rem;border-bottom:1px solid var(--line);margin-bottom:1.6rem}
.abyline .who{display:flex;align-items:center;gap:.45rem;color:var(--ink);font-weight:800;font-family:var(--body)}
.abyline .dot{width:28px;height:28px;border-radius:50%;background:linear-gradient(145deg,var(--green),var(--green-deep));color:#fff;display:grid;place-items:center;font-size:.82rem;font-weight:800}
.progress{display:flex;gap:.4rem;flex-wrap:wrap;margin:1.3rem 0}
.progress span{font-size:.7rem;font-family:var(--mono);color:var(--ink-soft);background:var(--surface);border:1px solid var(--line);padding:.25rem .6rem;border-radius:var(--r-pill)}
.progress span b{color:var(--green-deep)}
.block{margin:1.6rem 0;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--surface);box-shadow:var(--shadow)}
.block>.lab{display:flex;align-items:center;gap:.6rem;padding:.7rem 1rem;font-size:.78rem;font-weight:800;background:var(--green-tint);border-bottom:1px solid var(--line)}
.block>.lab .n{width:22px;height:22px;border-radius:7px;background:var(--green);color:#fff;display:grid;place-items:center;font-family:var(--mono);font-size:.72rem}
.block>.bd{padding:1.1rem}
.specs{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}
@media(max-width:540px){.specs{grid-template-columns:1fr}}
.specs div{background:var(--green-tint);border-radius:var(--r-sm);padding:.7rem .85rem}
.specs .k{font-size:.66rem;color:var(--ink-soft);font-family:var(--mono);margin-bottom:.15rem}
.specs .v{font-weight:800;font-size:.98rem}
.specs .v small{font-weight:500;color:var(--ink-soft);font-family:var(--mono);font-size:.7rem}
.nippo table{width:100%;border-collapse:collapse;font-family:var(--mono);font-size:.84rem}
.nippo td{padding:.5rem .7rem;border-bottom:1px solid var(--line)}
.nippo td.k{color:var(--ink-soft);width:38%}
.nippo td.v{font-weight:700}
.nippo .tot td{background:var(--green-soft);color:var(--green-deep);font-weight:800;border:none}
.hand{margin-top:.9rem;font-size:.92rem;line-height:1.85}
.bd-table{width:100%;border-collapse:collapse;font-family:var(--mono);font-size:.84rem;margin:.4rem 0}
.bd-table td{padding:.45rem .3rem;border-bottom:1px dashed var(--line)}
.bd-table td:last-child{text-align:right;font-weight:700}
.bd-table .m td:last-child{color:#c2691f}
.bd-table .net td{border-top:2px solid var(--ink);border-bottom:none;color:var(--green-deep);font-weight:800;font-size:.95rem}
.revs{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}
@media(max-width:540px){.revs{grid-template-columns:1fr}}
.rev{border:1px solid var(--line);border-radius:var(--r-sm);padding:.85rem;background:var(--bg)}
.rev .rt{display:flex;align-items:center;gap:.4rem;margin-bottom:.4rem}
.rev .stars{color:var(--amber);font-size:.8rem}
.rev .who{margin-left:auto;font-size:.64rem;color:var(--ink-soft);font-family:var(--mono)}
.rev p{font-size:.84rem;line-height:1.6}
.rev .src{margin-top:.4rem;font-size:.6rem;color:var(--ink-soft);font-family:var(--mono)}
.honest{border-color:#f0d9b8}
.honest>.lab{background:#fdf2e2;color:#9a6212}
.honest>.lab .n{background:var(--amber)}
.honest ul{list-style:none}
.honest li{position:relative;padding:.55rem 0 .55rem 1.5rem;font-size:.9rem;border-bottom:1px dashed #f0d9b8;line-height:1.6}
.honest li:last-child{border-bottom:none}
.honest li::before{content:"!";position:absolute;left:0;top:.55rem;width:18px;height:18px;background:var(--amber);color:#fff;border-radius:50%;display:grid;place-items:center;font-size:.66rem;font-weight:800;font-family:var(--mono)}
.cta{margin:1.8rem 0;border-radius:var(--r);overflow:hidden;background:linear-gradient(150deg,#16271c,#1f3a28);color:#e8efe9;padding:1.5rem}
.cta h3{color:#fff;font-size:1.1rem;font-weight:800;margin-bottom:.4rem}
.cta p{font-size:.84rem;color:#bccfc0;margin-bottom:1rem}
.cta .code{display:flex;align-items:center;gap:.6rem;background:rgba(255,255,255,.06);border:1px dashed var(--green);border-radius:var(--r-sm);padding:.6rem .9rem;margin-bottom:1rem;font-family:var(--mono);font-size:.9rem}
.cta .code b{color:#fff;letter-spacing:.15em;font-size:1.05rem;flex:1}
.cta .code button{background:var(--green);color:var(--ink-on-green);border:none;font-weight:800;padding:.35rem .8rem;border-radius:var(--r-pill);cursor:pointer;font-size:.74rem}
.cta .go{display:inline-flex;align-items:center;gap:.5rem;background:var(--green);color:var(--ink-on-green);font-weight:800;text-decoration:none;padding:.75rem 1.4rem;border-radius:var(--r-pill)}
.cta .go:hover{background:#fff}
.cta .pr{margin-top:.9rem;font-size:.64rem;color:#85998b;font-family:var(--mono);line-height:1.6}
.endnote{text-align:center;font-size:.8rem;color:var(--ink-soft);margin-top:1.5rem}

/* ===== 3本柱（サイトの地図） ===== */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
@media(max-width:780px){.pillars{grid-template-columns:1fr}}
.pillar-card{display:flex;flex-direction:column;gap:.45rem;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:1.7rem 1.5rem;text-decoration:none;color:inherit;box-shadow:var(--shadow);transition:.18s;position:relative;overflow:hidden}
.pillar-card::before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,var(--green),var(--amber))}
.pillar-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px);border-color:#d4e3d6}
.pillar-card .pico{width:52px;height:52px;border-radius:15px;background:var(--green-soft);display:grid;place-items:center;font-size:1.6rem;margin-bottom:.2rem}
.pillar-card .pnum{font-size:.66rem;font-weight:800;color:var(--ink-soft);font-family:var(--mono);letter-spacing:.1em}
.pillar-card h3{font-size:1.22rem;font-weight:800}
.pillar-card .pdesc{font-size:.86rem;color:var(--ink-soft);line-height:1.75}
.pillar-card .pin{margin-top:.3rem;display:flex;flex-wrap:wrap;gap:.4rem}
.pillar-card .pin span{font-size:.68rem;font-weight:700;color:var(--green-deep);background:var(--green-tint);padding:.25rem .6rem;border-radius:var(--r-pill)}
.pillar-card .pmore{margin-top:auto;padding-top:.9rem;font-size:.84rem;font-weight:800;color:var(--green-deep)}
.pillar-card:hover .pmore{color:var(--green)}

/* ===== 家事按分ビジュアル ===== */
.anbun-formula{display:flex;align-items:center;justify-content:center;gap:.7rem;flex-wrap:wrap;background:var(--green-tint);border:1px solid var(--line);border-radius:var(--r);padding:1.4rem 1rem;margin:1.2rem 0}
.anbun-formula .fbox{background:#fff;border:1px solid var(--line);border-radius:var(--r-sm);padding:.7rem .9rem;text-align:center;min-width:96px}
.anbun-formula .fbox .ft{font-size:.64rem;color:var(--ink-soft);font-family:var(--mono);margin-bottom:.15rem}
.anbun-formula .fbox .fv{font-weight:800;font-size:1.05rem;font-family:var(--mono)}
.anbun-formula .fbox.res{background:var(--green);border-color:var(--green)}
.anbun-formula .fbox.res .ft{color:rgba(255,255,255,.85)}
.anbun-formula .fbox.res .fv{color:#fff}
.anbun-formula .op{font-size:1.4rem;font-weight:800;color:var(--green-deep)}
.anbun-item{display:flex;gap:.95rem;align-items:flex-start;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-sm);padding:1rem 1.1rem;margin-bottom:.8rem;box-shadow:var(--shadow)}
.anbun-ico{flex-shrink:0;width:46px;height:46px;border-radius:13px;background:var(--green-soft);display:grid;place-items:center;color:var(--green-deep)}
.anbun-ico svg{width:24px;height:24px}
.anbun-body{flex:1;min-width:0}
.anbun-head{display:flex;justify-content:space-between;align-items:baseline;gap:.5rem;margin-bottom:.45rem}
.anbun-head .nm{font-weight:800;font-size:.95rem}
.anbun-head .pct{font-family:var(--mono);font-weight:800;color:var(--green-deep);white-space:nowrap;font-size:.86rem}
.anbun-bar{height:18px;border-radius:6px;overflow:hidden;background:#eceee9;position:relative}
.anbun-bar .biz{display:block;height:100%;background:linear-gradient(90deg,var(--green),var(--green-deep));border-radius:6px 0 0 6px}
.anbun-legend{display:flex;gap:1.1rem;font-size:.7rem;color:var(--ink-soft);margin-top:.4rem;font-family:var(--mono)}
.anbun-legend i{font-style:normal}
.anbun-legend .sw{display:inline-block;width:10px;height:10px;border-radius:3px;margin-right:.3rem;vertical-align:-1px}
.anbun-legend .sw.b{background:var(--green-deep)}
.anbun-legend .sw.p{background:#cfd3cc}
.anbun-note{font-size:.8rem;color:var(--ink-soft);line-height:1.65;margin-top:.5rem;border-top:1px dashed var(--line);padding-top:.5rem}
.anbun-note b{color:var(--green-deep)}

/* ===== 手取り内訳バー（3分割） ===== */
.breakdown{margin:1.2rem 0}
.breakdown .b3-ttl{font-size:.84rem;font-weight:800;margin-bottom:.5rem}
.breakdown .bar3{display:flex;height:46px;border-radius:8px;overflow:hidden;border:1px solid var(--line)}
.breakdown .bar3 > span{display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;font-family:var(--mono);min-width:0;overflow:hidden;white-space:nowrap;line-height:1.2}
.breakdown .bar3 .lab{font-size:.66rem;opacity:.9}
.breakdown .bar3 .amt{font-size:.84rem;font-weight:800}
.breakdown .seg-keihi{background:#b3b7bc}
.breakdown .seg-zei{background:var(--amber)}
.breakdown .seg-net{background:linear-gradient(90deg,var(--green),var(--green-deep))}
.breakdown .b3-legend{display:flex;gap:1.2rem;flex-wrap:wrap;margin-top:.6rem;font-size:.74rem;color:var(--ink-soft)}
.breakdown .b3-legend .sw{display:inline-block;width:11px;height:11px;border-radius:3px;margin-right:.35rem;vertical-align:-1px}
.breakdown .b3-legend .sw.k{background:#b3b7bc}
.breakdown .b3-legend .sw.z{background:var(--amber)}
.breakdown .b3-legend .sw.n{background:var(--green-deep)}

/* ===== 黒ナンバー：2つの窓口は別物 ===== */
.twowin{display:grid;grid-template-columns:1fr auto 1fr;gap:.6rem;align-items:stretch;margin:1.2rem 0}
.twowin .win{border-radius:var(--r-sm);padding:1rem .9rem;text-align:center;border:1.5px solid}
.twowin .win.unyu{background:var(--green-tint);border-color:var(--green)}
.twowin .win.zei{background:#fdf2e2;border-color:var(--amber)}
.twowin .win .wlbl{font-size:.64rem;font-weight:800;font-family:var(--mono);letter-spacing:.05em}
.twowin .win.unyu .wlbl{color:var(--green-deep)}
.twowin .win.zei .wlbl{color:#9a6212}
.twowin .win .wname{font-size:1rem;font-weight:800;margin:.2rem 0}
.twowin .win .wfor{font-size:.76rem;color:var(--ink-soft)}
.twowin .vs{display:grid;place-items:center;font-weight:800;font-size:1.1rem;color:var(--ink-soft);font-family:var(--mono)}
@media(max-width:560px){.twowin{grid-template-columns:1fr;gap:.5rem}.twowin .vs{padding:.2rem}}

/* ===== 手順フロー（縦ステッパー） ===== */
.flow{margin:1.2rem 0}
.flow-row{display:flex;gap:.9rem;align-items:flex-start;position:relative;padding-bottom:.9rem}
.flow-row:not(:last-child)::before{content:"";position:absolute;left:18px;top:40px;bottom:-2px;width:2px;background:var(--line)}
.flow-num{flex-shrink:0;width:38px;height:38px;border-radius:50%;display:grid;place-items:center;font-family:var(--mono);font-weight:800;font-size:.9rem;z-index:1;background:#fff}
.flow-num.unyu{color:var(--green-deep);border:2px solid var(--green)}
.flow-num.zei{color:#9a6212;border:2px solid var(--amber)}
.flow-body{flex:1;padding-top:.2rem}
.flow-body .ftag{display:inline-block;font-size:.6rem;font-weight:800;padding:.12rem .5rem;border-radius:999px;margin-bottom:.25rem;font-family:var(--mono)}
.flow-body .ftag.unyu{background:var(--green-soft);color:var(--green-deep)}
.flow-body .ftag.zei{background:#fdf2e2;color:#9a6212}
.flow-body h4{font-size:.98rem;font-weight:800;margin-bottom:.12rem}
.flow-body p{font-size:.82rem;color:var(--ink-soft);line-height:1.6}

/* ============================================================
   UIレビュー反映パッチ（H1/H3/H4/H5/M2/M3/M6/M7/H2/L2）
   ============================================================ */
/* H1: 図解バーのコントラスト改善（白文字が読めない問題） */
.breakdown .seg-keihi{background:#5b6270}
.breakdown .bar3 .seg-zei{color:#3a2402}
.breakdown .b3-legend .sw.k{background:#5b6270}
/* L2: 星評価はアクセント色と役割を分ける */
.rev .stars{color:#d98a1f}
/* H3: 固定ヘッダ分、アンカー着地が隠れないように */
section[id]{scroll-margin-top:84px}
/* M2: キーボード/支援技術向けフォーカスリング */
a:focus-visible,button:focus-visible{outline:2px solid var(--green-deep);outline-offset:2px;border-radius:6px}
/* M3: ロゴを黒ナンバー風（黒地×アンバー文字）に */
.brand .mark{background:#17181a;box-shadow:0 4px 12px rgba(0,0,0,.22)}
.brand .mark::after{color:var(--amber)}
/* H5: 本文タイポの底上げ */
.article{font-size:1rem}
.hand{font-size:.95rem}
.block>.lab{font-size:.85rem;letter-spacing:.01em}
/* H4: 「あわせて読みたい」枠の共通クラス（inline廃止用） */
.related{background:var(--green-tint);border:1px solid var(--line);border-radius:var(--r);padding:1.2rem 1.4rem;margin:1.8rem 0}
.related-ttl{font-size:.8rem;font-weight:800;color:var(--green-deep);font-family:var(--mono);margin-bottom:.7rem}
.related-list{display:flex;flex-direction:column;gap:.5rem;font-size:.9rem}
.related-list a{color:var(--ink);text-decoration:none;font-weight:700}
.related-list a:hover{color:var(--green-deep)}
/* M7: 横スクロール表に「まだ続く」シャドウを出す */
.scrollx{overflow-x:auto;background:
  linear-gradient(90deg,var(--surface) 30%,rgba(255,255,255,0)),
  linear-gradient(90deg,rgba(255,255,255,0),var(--surface) 70%) 100% 0,
  radial-gradient(farthest-side at 0 50%,rgba(27,36,32,.16),rgba(0,0,0,0)),
  radial-gradient(farthest-side at 100% 50%,rgba(27,36,32,.16),rgba(0,0,0,0)) 100% 0;
  background-repeat:no-repeat;background-size:40px 100%,40px 100%,14px 100%,14px 100%;background-attachment:local,local,scroll,scroll}
/* M6: ヒーローの実績ダッシュボードをリンク化 */
a.dash{text-decoration:none;color:inherit;display:block;transition:.18s}
a.dash:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.dash-more{margin-top:.9rem;text-align:right;font-size:.74rem;font-weight:800;color:var(--green-deep);font-family:var(--mono)}
/* H2: アフィリ未設定リンクは「準備中」表示で無効化 */
.go-soon{background:#d2d6d0!important;color:#566!important;box-shadow:none!important;pointer-events:none;cursor:default;flex-direction:column;gap:.15rem}
.go-soon::after{content:"リンク準備中";display:block;font-size:.7rem;font-weight:800;letter-spacing:.05em;opacity:.85}
.tbtn.soon{background:#cfd3cc;color:#5c6b63;pointer-events:none}
.coupon a.soon{border-color:#cfd3cc;color:#9aa0a6;pointer-events:none}

/* ============================================================
   公開前パッチ2（PR表記/行長/印刷/inlineクラス化）
   ============================================================ */
/* ② 行長：プロセ（文章）は読みやすい幅で折り返す。表・図は全幅維持 */
.article p,.article ul,.article ol{max-width:42em}
/* ④ inline置換用の共通クラス */
.lead{font-size:1.05rem;line-height:1.9}
.note-sm{font-size:.84rem;color:var(--ink-soft);line-height:1.7}
.tbl-intro{font-size:.92rem;margin-bottom:.6rem}
.acard-desc{font-size:.82rem;color:var(--ink-soft);line-height:1.6;max-width:none}
/* ① 記事冒頭のPR（広告）表記ラベル */
.pr-top{display:inline-block;font-size:.7rem;font-weight:700;color:var(--ink-soft);background:var(--green-tint);border:1px solid var(--line);border-radius:var(--r-pill);padding:.2rem .75rem;margin-bottom:1.1rem;font-family:var(--mono);letter-spacing:.02em}
/* ③ 印刷スタイル：ナビ・CTA・装飾を隠し、本文を読みやすく */
@media print{
  .nav,.cta,.go-soon,.related,.endnote,.dash-more,footer .disc{display:none!important}
  body{background:#fff;color:#000}
  .article{max-width:100%;padding-top:1rem}
  .block,.dash,.acard{box-shadow:none}
  a{color:#000;text-decoration:underline}
  a[href^="http"]::after{content:" (" attr(href) ")";font-size:.8em;color:#555}
}
