:root{
  /* 2026-05-24 UI改善「公的だが、あたたかい」方向: 青を深め(brand)＋暖色アクセント(warm)＋紙質感の背景に
     2026-05-25 オーナー指示「背景の色味を限りなく白に近づけて」: 紙質感 #fdfdfc → ほぼ白 #fbfbfa
     2026-05-25 再調整 RL352: ベージュ感を更に薄め、純白寄りに（#fbfbfa→#fdfdfc / line類も白寄り中性へ） */
  /* 2026-05-25 RL360 オーナー指示「背景は白寄り・各項目と一体化しない」:
     白系背景は維持しつつ、line を視認可能なグレイ系に強化＋surface-2 を一段濃く＋shadow を二重化して
     カード/セクションが明確に浮き上がるようにする。
     2026-05-26 RL391 オーナー指示「白すぎて見にくい」: 背景を一段トーンダウンし、白カードとのコントラストを確保する。
     - --bg: #fdfdfc(ほぼ純白) → #f5f2ec(淡いウォームグレー紙質感)
     - --surface(カード白): #ffffff 維持（背景と差別化）
     - --line/--line-2: そのまま維持（境界視認） */
  --bg:#f5f2ec;--surface:#ffffff;--surface-2:#ebe6dd;
  --ink:#231f1a;--muted:#5a5249;--faint:#6a6157;
  --line:#d6d1c5;--line-2:#dfd9cc;
  --brand:#1f4d8c;--brand-d:#163f73;--brand-ink:#173d70;--brand-tint:#eaf1fb;--brand-tint-2:#dfeafb;
  --accent:#b86523;--accent-bg:#fbe4cc;--accent-bd:#e8b687;--accent-bg-d:#f5d4ae;
  --warm:#d68b3c;--warm-ink:#7a4818;--warm-bg:#fdf3e3;--warm-line:#ead5b4;
  --warn-bg:#fbf2dd;--warn-bd:#e2c074;--warn-ink:#7a5a14;
  --r-lg:14px;--r-md:9px;--r-sm:6px;--pill:999px;
  --sh-1:0 1px 2px rgba(40,30,20,.06),0 0 0 1px rgba(40,30,20,.03);--sh-2:0 2px 6px rgba(40,30,20,.09),0 12px 28px -10px rgba(60,40,20,.22);
  --fs:-apple-system,BlinkMacSystemFont,"Hiragino Kaku Gothic ProN","Hiragino Sans","Yu Gothic","YuGothic",Meiryo,"Noto Sans JP",system-ui,sans-serif;
  --fs-serif:"Hiragino Mincho ProN","Hiragino Mincho Pro","Yu Mincho","YuMincho","Noto Serif JP","ＭＳ Ｐ明朝","MS PMincho",serif;
 }
 *{box-sizing:border-box}
 body{font-family:var(--fs);color:var(--ink);background:var(--bg);margin:0;line-height:1.95;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
 .w{max-width:min(96vw,1320px);margin:0 auto;padding:26px clamp(16px,3vw,40px) 72px}
 a{color:var(--brand);text-underline-offset:2px}
 ul{padding-left:22px}
 :focus-visible{outline:2px solid var(--brand);outline-offset:2px;border-radius:3px}
 .hero h1,.hero .hslide-h,header h1{font-size:clamp(1.5rem,calc(1.2rem + 1.4vw),1.95rem);line-height:1.3;margin:0 0 6px;color:var(--brand-ink);letter-spacing:.01em;font-weight:800}
 /* 見出しはゴシック太字（キリッと）／本文も Sans のまま */
 h2,.sectionHd,.hd2,.lead-h{letter-spacing:.01em;font-weight:800}
 /* リンクの下線オフセットを広げ、視覚的なやわらかさを */
 a{text-underline-offset:3px}
 .sub{color:var(--muted);margin:0 0 16px;font-size:.96rem;max-width:62ch}
 .warn{border:1px solid var(--warn-bd);background:var(--warn-bg);border-left:4px solid var(--warn-bd);border-radius:var(--r-md);padding:13px 16px;font-size:.85rem;color:var(--warn-ink);margin:0 0 22px;line-height:1.75}
 .site-hd{background:rgba(255,255,255,.92);backdrop-filter:saturate(180%) blur(8px);-webkit-backdrop-filter:saturate(180%) blur(8px);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50;box-shadow:var(--sh-1)}
 .site-hd .in{max-width:min(96vw,1320px);margin:0 auto;padding:11px clamp(16px,3vw,40px);display:flex;flex-wrap:wrap;align-items:center;gap:6px 20px}
 .site-hd .bd{font-weight:800;color:var(--brand-ink);text-decoration:none;font-size:1.16rem;letter-spacing:.01em}
 .site-hd .bd span{color:var(--brand)}
 .site-hd nav{display:flex;flex-wrap:wrap;gap:2px 4px;margin-left:auto;font-size:.85rem}
 .site-hd nav a{color:var(--muted);text-decoration:none;padding:6px 10px;border-radius:var(--r-sm);transition:background .15s,color .15s}
 .site-hd nav a:hover{color:var(--brand);background:var(--brand-tint)}
 .site-hd nav .navav{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;padding:0;border-radius:50%;background:var(--brand-tint);color:var(--brand);border:1px solid var(--brand-tint-2);margin-left:2px}
 .site-hd nav .navav:hover{background:var(--brand);color:#fff;border-color:var(--brand)}
 .site-hd nav .navav svg{width:18px;height:18px;display:block}
 .site-hd nav .navcta{background:var(--brand);color:#fff;font-weight:700}
 .site-hd nav .navcta:hover{background:var(--brand-d);color:#fff}
 /* 2026-05-26: 補助金ポータル風「全幅スライダー＋中央コンテンツ」型ヒーロー。
    .hero は .w 内で margin auto。slider のみ画面端まで full-bleed。badge/stats/ctaは .hero 内中央。 */
 .hero{margin:18px auto 22px;background:transparent;border:0;border-radius:0;padding:0;position:relative}
 .hero::before,.hero::after{display:none}
 /* hero 内の slider 以外（badge, stats, cta）は .w 幅内の中央寄せ */
 .hero > .hero-tag{display:inline-block;margin:0 0 12px}
 .hero > .hero-stats,.hero > .hero-pts,.hero > .hero-cta{position:relative;z-index:1}
 /* スライダー本体：画面端まで full-bleed、画像も画面端まで延伸、テキストはスライド内で1320px中央 */
 .hero > .hero-slider{margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);margin-top:0;margin-bottom:20px;position:relative;overflow:hidden;border-radius:0;background:linear-gradient(135deg,var(--brand-tint) 0%,#fff 60%,var(--warm-bg) 100%)}
 .hero-slider .hslide{border-radius:0;padding-top:clamp(36px,5vw,80px);padding-bottom:clamp(36px,5vw,80px);padding-left:max(20px, calc(50vw - 600px));padding-right:max(20px, calc(50vw - 600px));min-height:clamp(280px,32vw,460px)}
 @media (min-width:1380px){.hero-slider .hslide{padding-left:calc(50vw - 600px);padding-right:calc(50vw - 600px)}}
 @media (max-width:1379px) and (min-width:768px){.hero-slider .hslide{padding-left:max(24px, 5vw);padding-right:max(24px, 5vw)}}
 @media (max-width:767px){.hero-slider .hslide{padding-left:20px;padding-right:20px}}
 .hero-slider .hslide-fig{border-radius:0}
 /* スライド内のテキストは中央 .w 基準幅で */
 .hero-slider .hslide-txt{max-width:none;width:100%}
 .hero-slider .hslide-h{font-size:clamp(1.7rem,calc(1.3rem + 1.8vw),2.4rem)!important}
 /* ドット/矢印は中央寄せ */
 .hero-slider .hero-sl-ctl,.hero-slider .hero-dots{margin-left:auto;margin-right:auto;max-width:1320px;padding-left:max(2vw, calc(50vw - 660px));padding-right:max(2vw, calc(50vw - 660px))}
 .hero-tag{display:inline-block;background:var(--brand);color:#fff;font-size:.74rem;font-weight:700;padding:4px 12px;border-radius:999px;letter-spacing:.04em;margin:0 0 12px}
 .hero h1{font-size:clamp(1.6rem,calc(1.25rem + 1.8vw),2.3rem)!important;line-height:1.28;margin:0 0 10px}
 .hero .sub{font-size:1rem;color:#3a4862;max-width:64ch;line-height:1.85;margin:0 0 16px}
 .hero-stats{display:flex;flex-wrap:wrap;gap:10px;margin:0 0 18px}
 .hero-stats .st{background:#fff;border:1px solid var(--brand-tint-2);border-radius:11px;padding:9px 16px;text-align:center;min-width:96px;box-shadow:var(--sh-1)}
 .hero-stats .st .num{font-size:1.5rem;font-weight:800;color:var(--brand-ink);font-variant-numeric:tabular-nums;line-height:1.1}
 .hero-stats .st .lbl{font-size:.72rem;color:var(--muted);font-weight:700;margin-top:2px}
 .hero-pts{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px;margin:0 0 18px}
 .hero-pt{display:flex;align-items:flex-start;gap:10px;background:#fff;border:1px solid var(--line);border-radius:11px;padding:11px 13px}
 .hero-pt .ic{font-size:1.5rem;line-height:1;flex:0 0 auto}
 .hero-pt b{display:block;font-size:.9rem;color:var(--brand-ink);font-weight:800;margin-bottom:2px}
 .hero-pt span{display:block;font-size:.78rem;color:var(--muted);line-height:1.55}
 .hero-cta{display:flex;flex-wrap:wrap;gap:10px}
 .hcta{display:inline-block;background:#fff;color:var(--brand);border:1.5px solid var(--brand);border-radius:10px;padding:11px 20px;font-size:.92rem;font-weight:700;text-decoration:none;transition:all .15s}
 .hcta:hover{background:var(--brand-tint);transform:translateY(-1px)}
 .hcta.primary{background:var(--brand);color:#fff;box-shadow:var(--sh-1)}
 .hcta.primary:hover{background:var(--brand-d);color:#fff}
 @media (max-width:560px){.hero{padding:18px 16px} .hero-stats .st{flex:1 1 28%;min-width:0;padding:8px 6px} .hero-stats .st .num{font-size:1.25rem} .hcta{flex:1 1 100%;text-align:center}}
 /* ===== ヒーロー特長スライドショー ===== */
 .hero-slider{position:relative;margin:0 0 16px}
 .hero-slides{position:relative;min-height:200px}
 /* JSなし時は全スライドを縦に並べて読める（進歩的拡張のフォールバック） */
 .hslide{position:relative;overflow:hidden;border-radius:13px;margin:0 0 16px;padding:16px 18px}
 .hslide-txt{position:relative;z-index:1;max-width:60ch}
 /* JS有効時：全スライドをGridで同一セルに重ね、非表示は visibility で“レイアウトに残す”
    →親の高さ＝最長スライドの高さに固定＝回転しても高さが揺れない（大きさ統一・CLS=0） */
 html.hjs .hero-slider.js-on .hero-slides{display:grid}
 html.hjs .hero-slider.js-on .hslide{grid-area:1 / 1;display:block;margin:0;visibility:hidden;opacity:0;pointer-events:none;transition:opacity .4s ease}
 html.hjs .hero-slider.js-on .hslide.on{visibility:visible;opacity:1;pointer-events:auto}
 /* 写真は“裏に薄く”敷く。左から白いベールでテキストの可読性を確保。読込失敗時は何も出さない */
 .hslide-fig{position:absolute;inset:0;margin:0;border:0;border-radius:inherit;background:none;z-index:0;pointer-events:none}
 .hslide-img{width:100%;height:100%;object-fit:cover;display:block;opacity:.62}
 .hslide-fig::after{content:"";position:absolute;inset:0;background:linear-gradient(105deg,rgba(255,255,255,.88) 0%,rgba(255,255,255,.50) 50%,rgba(255,255,255,.18) 100%)}
 .hslide-fig.hf-fail{display:none}
 @keyframes hslfade{from{opacity:0;transform:translateY(7px)}to{opacity:1;transform:none}}
 .hslide-badge{display:inline-block;background:#fff;border:1px solid var(--brand-tint-2);color:var(--brand-ink);font-size:.76rem;font-weight:800;padding:3px 12px;border-radius:999px;margin:0 0 9px}
 .hslide h1,.hslide .hslide-h{font-size:clamp(1.5rem,calc(1.2rem + 1.6vw),2.15rem)!important;line-height:1.28;margin:0 0 9px}
 .hslide .sub{font-size:1rem;color:#3a4862;max-width:62ch;line-height:1.95;margin:0}
 .hslide-link{display:inline-block;margin-top:10px;font-weight:700;color:var(--brand);text-decoration:none;font-size:.93rem}
 .hslide-link:hover{text-decoration:underline}
 .hero-sl-ctl{display:flex;align-items:center;gap:8px;margin-top:6px}
 .hero-slider:not(.js-on) .hero-sl-ctl{display:none} /* JSなし時は操作UIを隠す */
 .hsl-arrow,.hsl-play{width:33px;height:33px;border-radius:999px;border:1.5px solid var(--brand-tint-2);background:#fff;color:var(--brand);font-size:1.15rem;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .15s;flex:0 0 auto}
 .hsl-arrow:hover,.hsl-play:hover{background:var(--brand-tint);border-color:var(--brand)}
 .hsl-play{margin-left:auto;font-size:.92rem}
 .hero-dots{display:flex;gap:7px;align-items:center}
 .hero-dots button{width:9px;height:9px;padding:0;border:none;border-radius:999px;background:#c3d1e8;cursor:pointer;transition:width .2s,background .2s}
 .hero-dots button:hover{background:#9db6da}
 .hero-dots button.on{background:var(--brand);width:22px}
 @media (prefers-reduced-motion:reduce){.hero-slider.js-on .hslide.on{animation:none}}
 /* スマホ：ヒーローを引き締め＋カルーセル操作を44pxタップ領域に拡大 */
 @media (max-width:560px){
   .hero{padding:16px 14px;margin:14px 0 18px}
   .hero-tag{margin-bottom:9px}
   .hero-slider{margin-bottom:12px}
   .hslide{padding:14px 14px}
   .hslide-fig{display:none}/* モバイル：重い写真を出さずグラデ＋テキストで即表示＝LCP改善 */
   .hero-slider.js-on .hslide.on{min-height:168px}
   .hslide h1,.hslide .hslide-h{margin:0 0 7px}
   .hslide .sub,.hero .sub{font-size:.92rem;line-height:1.7}
   .hero-sl-ctl{gap:6px;margin-top:8px}
   .hsl-arrow,.hsl-play{width:44px;height:44px;font-size:1.3rem}
   .hsl-play{font-size:1.05rem}
   .hero-dots button{padding:11px 6px;background-clip:content-box;box-sizing:content-box}
   .hero-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:0 0 16px}
   .hero-stats .st{flex:none;min-width:0;padding:9px 8px}
   .hero-stats .st .num{font-size:1.2rem}
   .hero-cta{gap:8px}
 }
 /* ===== 機能ギャラリー（できること）===== */
 .features{margin:0 0 24px}
 .feat-h{font-size:1.3rem;color:var(--brand-ink);font-weight:800;margin:0 0 4px;border:0;padding:0}
 .feat-sub{font-size:.92rem;color:var(--muted);margin:0 0 16px;line-height:1.75;max-width:64ch}
 .feat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}
 .feat-card{position:relative;display:flex;flex-direction:column;gap:9px;background:#fff;border:1px solid var(--line);border-radius:13px;padding:16px 16px 14px;text-decoration:none;color:var(--ink);transition:transform .14s,box-shadow .14s,border-color .14s;overflow:hidden}
 .feat-card:hover{transform:translateY(-3px);box-shadow:0 8px 22px -8px rgba(20,40,86,.28);border-color:var(--brand-tint-2)}
 .feat-card.hl{border-color:var(--brand-tint-2);background:linear-gradient(160deg,#fbfdff 0%,#fff 60%)}
 .feat-card .feat-ic{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem}
 .feat-card .feat-bd{flex:1}
 .feat-card .feat-ti{font-size:1rem;font-weight:800;color:var(--brand-ink);margin:0 0 5px;line-height:1.4}
 .feat-card .feat-de{font-size:.83rem;color:var(--muted);line-height:1.65}
 .feat-card .feat-de strong{color:#2a3c5c}
 .feat-card .feat-go{font-size:.85rem;font-weight:700;color:var(--brand);margin-top:2px}
 .feat-card:hover .feat-go{text-decoration:underline}
 .feat-card .feat-badge{position:absolute;top:11px;right:11px;font-size:.66rem;font-weight:700;color:#fff;background:var(--brand);padding:2px 9px;border-radius:999px;letter-spacing:.02em}
 .feat-card .feat-badge.new{background:#1f8a4c}
 @media (max-width:560px){.feat-grid{grid-template-columns:1fr 1fr;gap:9px} .feat-card{padding:13px 12px} .feat-card .feat-ic{width:40px;height:40px;font-size:1.3rem} .feat-card .feat-ti{font-size:.92rem} .feat-card .feat-de{font-size:.78rem}}
 .site-ft{background:linear-gradient(180deg,#173d70,#16345f);color:#d3e0f3;margin-top:52px}
 .site-ft .in{max-width:min(96vw,1320px);margin:0 auto;padding:32px clamp(16px,3vw,40px) 34px}
 .site-ft .cols{display:flex;flex-wrap:wrap;gap:22px 48px;margin-bottom:18px}
 .site-ft .col h3{font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#fff;margin:0 0 9px;opacity:.85}
 .site-ft .col a{display:block;font-size:.85rem;text-decoration:none;margin:5px 0;color:#cfdcf2;transition:color .15s}
 .site-ft .col a:hover{color:#fff;text-decoration:underline}
 .site-ft .dis{font-size:.76rem;color:#a6b8d6;border-top:1px solid rgba(255,255,255,.14);padding-top:14px;line-height:1.95}
 .site-ft .cp{font-size:.78rem;color:#a6b8d6;margin-top:10px}
 .site-ft .cp a{color:#cfdcf2}
 .site-ft .toplink{display:inline-block;margin-top:14px;font-size:.82rem;color:#fff;text-decoration:none;border:1px solid rgba(255,255,255,.28);padding:6px 14px;border-radius:var(--pill);transition:background .15s}
 .site-ft .toplink:hover{background:rgba(255,255,255,.12)}
 .pp{border:1px solid var(--line);background:var(--surface);border-radius:var(--r-lg);margin:0 0 14px;box-shadow:var(--sh-1);overflow:hidden}
 .pp>summary{list-style:none;cursor:pointer;padding:13px 16px;color:var(--brand-ink);font-weight:700;font-size:.92rem;display:flex;align-items:center;justify-content:space-between;gap:10px;transition:background .15s}
 .pp>summary:hover{background:var(--surface-2)}
 .pp>summary::-webkit-details-marker{display:none}
 .pp>summary::after{content:"＋";font-size:1rem;color:var(--brand);font-weight:700;line-height:1}
 .pp[open]>summary{border-bottom:1px solid var(--line-2)}
 .pp[open]>summary::after{content:"－"}
 .pp .bd{padding:14px 16px 16px;font-size:.86rem;color:#3a4458}
 .pp .priv{font-size:.79rem;color:var(--faint);margin:2px 0 12px;line-height:1.75}
 .pbtn{font:inherit;font-size:.84rem;font-weight:700;border:1px solid var(--brand);background:var(--brand);color:#fff;border-radius:var(--r-md);padding:9px 16px;cursor:pointer;margin:0 8px 8px 0;transition:background .15s,box-shadow .15s,transform .05s;box-shadow:var(--sh-1)}
 .pbtn:hover{background:var(--brand-d);border-color:var(--brand-d)}
 .pbtn:active{transform:translateY(1px)}
 .pbtn.sec{background:var(--surface);color:var(--brand);box-shadow:none}
 .pbtn.sec:hover{background:var(--brand-tint)}
 .pbadge{display:inline-block;font-size:.7rem;font-weight:700;background:var(--accent-bg);color:var(--accent);border:1px solid var(--accent-bd);border-radius:var(--pill);padding:2px 9px;margin-left:8px;vertical-align:middle}
 .bm{font:inherit;font-size:.81rem;font-weight:700;border:1px solid var(--accent-bd);background:var(--accent-bg);color:var(--accent);border-radius:var(--pill);padding:7px 13px;cursor:pointer;margin-top:8px;transition:background .15s}
 .bm:hover{background:var(--accent-bg-d)}
 .bm.on{background:var(--accent-bg-d);box-shadow:inset 0 0 0 1px var(--accent-bd)}
 .pp .bmrow{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin:12px 0 2px}
 .pp input[type=date]{font:inherit;font-size:.85rem;padding:8px 10px;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--surface);color:var(--ink)}
 .pp ul.bml{margin:8px 0;padding-left:20px}
 .pp ul.bml li{font-size:.83rem;margin:3px 0;color:#3a4458}
 .remadd{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin:12px 0 4px}
 .remadd select,.remadd input[type=date]{font:inherit;font-size:.84rem;padding:6px 8px;border:1px solid var(--line);border-radius:var(--r-sm);background:#fff;color:var(--ink)}
 .remcal{margin:10px 0;border:1px solid var(--line);border-radius:var(--r-md);background:#fff;padding:8px 10px}
 .remcal .ch{display:flex;align-items:center;justify-content:space-between;font-size:.84rem;font-weight:700;color:var(--brand-ink);margin-bottom:6px}
 .remcal .ch button{font:inherit;border:1px solid var(--line);background:#fff;color:var(--brand);border-radius:var(--r-sm);padding:3px 9px;cursor:pointer}
 .remcal .grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;font-size:.74rem}
 .remcal .hd{text-align:center;color:var(--muted);font-weight:700;padding:3px 0}
 .remcal .cell{min-height:30px;border:1px solid var(--line-2);border-radius:4px;padding:2px;color:#3a4458;text-align:right}
 .remcal .cell.dim{color:#b9c1ce;background:#fafbfd}
 .remcal .cell.has{background:var(--brand-tint);border-color:var(--brand-tint-2)}
 .remcal .cell .dot{display:block;font-size:.62rem;color:#fff;background:var(--brand);border-radius:3px;margin-top:1px;padding:0 2px;text-align:center;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
 ul.rem{list-style:none;padding:0;margin:8px 0}
 ul.rem li{display:flex;flex-wrap:wrap;gap:6px 8px;align-items:center;font-size:.83rem;border-bottom:1px solid var(--line-2);padding:7px 0;color:#3a4458}
 ul.rem li:last-child{border-bottom:0}
 ul.rem .ty{font-size:.72rem;font-weight:700;border-radius:var(--pill);padding:1px 8px;border:1px solid var(--brand-tint-2);background:var(--brand-tint);color:var(--brand)}
 ul.rem .ty.koshin{background:#fbe8cf;border-color:#e6b277;color:#9a5a00}
 ul.rem .dt{font-weight:700;color:var(--brand-ink)}
 ul.rem .rx{margin-left:auto;border:0;background:none;color:#9aa3b2;cursor:pointer;font:inherit;font-size:.82rem}
 ul.rem .rx:hover{color:#c0392b}
 .acctbox{border:1px solid var(--line);border-radius:var(--r-md);padding:14px 16px;margin-top:16px;background:var(--surface-2)}
 .acctbox code{font-size:.78rem;background:var(--brand-tint);padding:2px 6px;border-radius:var(--r-sm);color:var(--brand-ink)}
 .acctbox input[type=email]{font:inherit;font-size:.86rem;padding:9px 11px;border:1px solid var(--line);border-radius:var(--r-sm);flex:1 1 200px;min-width:0;background:var(--surface);color:var(--ink)}
 .acctbox .pbtn:disabled,.acctbox input:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}
 h2{font-size:1.18rem;margin:30px 0 12px;padding:0 0 8px 0;border-bottom:1px solid var(--line);color:var(--brand-ink);scroll-margin-top:70px;letter-spacing:.01em}
 .flab{font-size:.79rem;font-weight:600;color:var(--muted);margin:12px 0 5px}
 .sel{display:flex;flex-wrap:wrap;gap:7px}
 .sel button{font:inherit;font-size:.82rem;padding:6px 14px;border:1px solid var(--line);background:var(--surface);color:var(--muted);border-radius:var(--pill);cursor:pointer;min-height:32px;transition:border-color .15s,background .15s,color .15s}
 .sel button:hover{border-color:var(--brand);color:var(--brand)}
 .sel button[aria-pressed="true"]{background:var(--brand);border-color:var(--brand);color:#fff;font-weight:700;box-shadow:var(--sh-1)}
 /* 表示レベル絞り込み（国/県/市区町村）— 階層別カラー */
 .sel-lvl{gap:8px;margin-bottom:4px}
 .lvl-btn{font:inherit;font-size:.86rem;padding:7px 16px;border:1.5px solid var(--line);background:var(--surface);color:var(--muted);border-radius:var(--pill);cursor:pointer;min-height:34px;font-weight:700;transition:all .15s}
 .lvl-btn:hover{transform:translateY(-1px)}
 .lvl-btn[aria-pressed="true"].lvl-nat{background:#e7f3ec;border-color:#1f8a4c;color:#1f5a37}
 .lvl-btn[aria-pressed="true"].lvl-pref{background:#fdf6e3;border-color:#b4881e;color:#7a5a14}
 .lvl-btn[aria-pressed="true"].lvl-city{background:#f3edfa;border-color:#6b3fa0;color:#3b2261}
.lvl-dot{display:inline-block;width:.62em;height:.62em;border-radius:50%;margin-right:.4em;vertical-align:-1px;background:var(--muted,#888)}
.lvl-nat .lvl-dot{background:#1f8a4c}
.lvl-pref .lvl-dot{background:#b4881e}
.lvl-city .lvl-dot{background:#6b3fa0}
 .lvl-btn[aria-pressed="false"]{opacity:.55;text-decoration:line-through}
 .lvl-btn[aria-pressed="false"]:hover{opacity:.85}
 .frow{display:flex;flex-wrap:wrap;gap:8px;margin:6px 0;align-items:center}
 select,input[type=search],input[type=number]{font:inherit;font-size:.88rem;padding:8px 10px;border:1px solid var(--line);border-radius:var(--r-sm);min-height:38px;background:var(--surface);color:var(--ink);box-sizing:border-box;transition:border-color .15s,box-shadow .15s}
 select:focus,input:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-tint);outline:none}
 input[type=search]{flex:1 1 240px;max-width:460px}
 #clr{border:1px solid var(--line);background:var(--surface);color:var(--muted);border-radius:var(--r-sm);cursor:pointer;min-height:38px;padding:6px 14px;font:inherit;font-size:.85rem;font-weight:600;transition:border-color .15s,color .15s}
 #clr:hover{border-color:var(--brand);color:var(--brand)}
 .adv-filter{margin:10px 0 4px;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--surface);padding:0}
 .adv-filter summary{cursor:pointer;padding:9px 13px;font-size:.84rem;font-weight:700;color:var(--brand);user-select:none}
 .adv-filter summary:hover{background:var(--brand-tint)}
 .adv-filter[open] summary{border-bottom:1px solid var(--line)}
 .adv-filter > div.flab{padding:0 13px}
 .adv-filter > .sel{padding:0 13px 12px}
 .guide{border:1px solid var(--brand-tint-2);background:var(--brand-tint);border-left:4px solid var(--brand);border-radius:var(--r-sm);padding:11px 14px;font-size:.84rem;color:#2a3c5c;margin:12px 0;line-height:1.7}
 .qc{font-size:.84rem;color:var(--muted);margin:14px 0 10px;font-weight:600}
 .cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:14px}
 .pager{margin:22px 0 4px}
 .pager .info{font-size:.82rem;color:var(--muted);text-align:center;margin-bottom:8px}
 .pager .pgrow{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:6px}
 .pager .pgrow button{min-width:38px;min-height:38px;padding:6px 12px;border:1px solid var(--line);background:var(--surface);color:var(--brand);border-radius:var(--r-sm);font:inherit;font-size:.86rem;font-weight:700;cursor:pointer;transition:background .15s,border-color .15s}
 .pager .pgrow button:hover:not(:disabled):not(.cur){background:var(--brand-tint);border-color:var(--brand)}
 .pager .pgrow button.cur{background:var(--brand);border-color:var(--brand);color:#fff;cursor:default}
 .pager .pgrow button:disabled{opacity:.4;cursor:not-allowed}
 .pager .pgrow .gap{color:var(--muted);padding:0 2px;font-size:.86rem}
 /* スマホ：検索フィルタ＆操作系を指で押しやすく（44px領域・フィールド全幅・iOSズーム抑止16px） */
 @media (max-width:560px){
   .flab{font-size:.82rem}
   .sel{gap:8px}
   .sel button{min-height:42px;padding:9px 15px;font-size:.86rem}
   .sel-lvl{gap:7px}
   .sel-lvl .lvl-btn{flex:1 1 0;min-width:0;min-height:46px;padding:9px 6px;font-size:.88rem;text-align:center}
   .frow{flex-direction:column;align-items:stretch;gap:10px}
   .frow>div{width:100%}
   .frow select,.frow input[type=search],.frow input[type=number]{width:100%!important}
   select,input[type=search],input[type=number]{min-height:46px;font-size:16px}
   #clr{width:100%;min-height:46px;font-size:.92rem}
   .adv-filter summary{padding:12px 13px;min-height:46px;display:flex;align-items:center}
   .pager .pgrow button{min-width:44px;min-height:44px;font-size:.92rem}
 }
 .c{position:relative;border:1px solid var(--line);background:var(--surface);border-radius:var(--r-lg);padding:16px 18px;box-shadow:var(--sh-1);transition:box-shadow .18s,transform .18s,border-color .18s}
 .c:hover{box-shadow:var(--sh-2);transform:translateY(-2px);border-color:var(--brand-tint-2)}
 .c .nm{font-weight:700;color:var(--brand-ink);font-size:1.05rem;line-height:1.45;letter-spacing:.01em}
 .c.has-bm .nm{padding-right:40px}
 /* マイ制度に保存：カード右上角の星アイコン（未保存=☆／保存済み=★金色） */
 .bmcorner{position:absolute;top:11px;right:11px;width:34px;height:34px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:1.22rem;line-height:1;padding:0;border:1px solid var(--line);background:#fff;color:#b6becb;cursor:pointer;z-index:2;box-shadow:var(--sh-1);transition:color .15s,border-color .15s,background .15s,transform .05s}
 .bmcorner:hover{color:#e0a52a;border-color:#e6cf8f;background:#fff8e8}
 .bmcorner.on{color:#e0a52a;border-color:#e6cf8f;background:#fff8e8}
 .bmcorner:active{transform:scale(.92)}
 .bmcorner:focus-visible{outline:2px solid var(--brand);outline-offset:2px}
 .c .mt{font-size:.87rem;color:var(--muted);margin:6px 0;line-height:1.7}
 .c .lb{display:inline-block;font-size:.73rem;font-weight:600;background:var(--brand-tint);color:var(--brand);border:1px solid var(--brand-tint-2);border-radius:var(--pill);padding:2px 9px;margin:0 6px 5px 0}
 .c .an{font-size:.79rem;color:var(--accent);margin-top:4px}
 .c .lb.calcbadge{background:#e6f4ee;color:#1f7a4d;border-color:#bfe3d0;font-weight:700}
 .c a{color:var(--brand)}
 .cta{display:inline-block;margin-top:10px;background:var(--brand);color:#fff !important;border:1px solid var(--brand);text-decoration:none;padding:9px 10px;border-radius:var(--r-md);font-size:.8rem;font-weight:700;line-height:1.3;white-space:nowrap;box-shadow:var(--sh-1);transition:background .15s,transform .05s}
 .cta:hover{background:var(--brand-d)}
 .cta:active{transform:translateY(1px)}
 .cta-go{display:inline-block;background:var(--accent-bg);color:var(--accent) !important;border:1px solid var(--accent-bd);text-decoration:none;padding:9px 10px;border-radius:var(--r-md);font-size:.8rem;font-weight:700;line-height:1.3;white-space:nowrap;transition:background .15s,transform .05s}
 .cta-go:hover{background:var(--accent-bg-d)}
 .cta-go:active{transform:translateY(1px)}
 .btns{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px;align-items:stretch}
 .btns a{flex:1 1 0;min-width:0;text-align:center;margin-top:0;padding:9px 8px}
 .rgi{font-size:.84rem;color:var(--muted);margin:6px 0;line-height:1.7}
 .rgi b{color:var(--brand-ink)}
 /* 2026-05-26 RL392 オーナー指示「対象・支給額の色が不自然」: surface-2(ベージュ) は本文背景と被るため、
    brand 寄りの淡水色トーンに変更してカードと調和させる */
 .acc{margin:10px 0 2px;border:1px solid var(--brand-tint-2);border-radius:var(--r-md);background:#f4f8fd;overflow:hidden}
 .acc>summary{list-style:none;cursor:pointer;padding:9px 13px;color:var(--brand);font-size:.83rem;font-weight:700;display:flex;align-items:center;justify-content:space-between;gap:8px;transition:background .15s}
 .acc>summary:hover{background:var(--brand-tint)}
 .acc>summary::-webkit-details-marker{display:none}
 .acc>summary::after{content:"＋";font-size:.95rem;line-height:1}
 .acc[open]>summary::after{content:"－"}
 .acc[open]>summary{border-bottom:1px solid var(--line-2)}
 .acc .bd{padding:10px 13px 12px}
 footer{margin-top:42px;font-size:.8rem;color:var(--muted);border-top:1px solid var(--line);padding-top:14px}
 /* ===== 会員登録 訴求セクション（join）＝誠実な価値訴求・ハイプ不使用 ===== */
 .join{margin:34px 0 0;background:linear-gradient(165deg,#f3f8ff 0%,#e9f1fc 100%);border:1px solid var(--brand-tint-2);border-radius:16px;padding:24px 22px 22px}
 .join-eyebrow{display:inline-block;font-size:.76rem;font-weight:700;color:#fff;background:var(--brand);border-radius:var(--pill);padding:3px 12px;letter-spacing:.02em;margin-bottom:10px}
 .join h2{font-size:clamp(1.2rem,1rem + 1vw,1.5rem);color:var(--brand-ink);margin:0 0 8px;border:0;padding:0;line-height:1.42;font-weight:800}
 .join .join-head p{font-size:.9rem;color:#3a4458;margin:0 0 16px;line-height:1.75;max-width:64ch}
 .join-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(208px,1fr));gap:11px;margin:0 0 18px}
 .join-card{display:flex;flex-direction:column;gap:2px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px 15px}
 .join-card .ji{font-size:1.4rem;line-height:1;margin-bottom:5px}
 .join-card b{font-size:.92rem;color:var(--brand-ink);font-weight:800}
 .join-card span{font-size:.8rem;color:var(--muted);line-height:1.6}
 .join-cta{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
 .join-cta .hcta{font-size:.98rem;padding:13px 26px}
 .join-note{font-size:.76rem;color:#5a6678;margin:14px 0 0;line-height:1.7}
 .join-note strong{color:var(--brand-ink)}
 /* ===== プレミアム 訴求セクション（premium） ===== */
 .premium{margin:18px 0 0;background:linear-gradient(165deg,#fffdf6 0%,#fdf4dd 100%);border:1px solid var(--accent-bd);border-radius:16px;padding:24px 22px 22px}
 .prem-eyebrow{display:inline-block;font-size:.76rem;font-weight:700;color:#fff;background:var(--accent);border-radius:var(--pill);padding:3px 12px;margin-bottom:10px}
 .premium h2{font-size:clamp(1.2rem,1rem + 1vw,1.5rem);color:#7a5410;margin:0 0 8px;border:0;padding:0;font-weight:800;display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}
 .prem-price{font-size:.9rem;font-weight:700;color:#fff;background:var(--accent);border-radius:var(--pill);padding:3px 12px}
 .premium .prem-bd>p{font-size:.9rem;color:#6a5012;margin:0 0 14px;line-height:1.75;max-width:64ch}
 .prem-list{list-style:none;padding:0;margin:0 0 18px;display:grid;grid-template-columns:repeat(auto-fit,minmax(258px,1fr));gap:8px}
 .prem-list li{background:#fff;border:1px solid var(--accent-bd);border-radius:10px;padding:11px 13px;font-size:.84rem;color:#3a4458;line-height:1.6}
 .prem-list li b{color:#7a5410}
 .prem-cta{display:flex;flex-wrap:wrap;gap:10px}
 .prem-cta .hcta.primary{background:var(--accent);border-color:var(--accent);color:#fff}
 .prem-cta .hcta.primary:hover{background:#8f5009;border-color:#8f5009;color:#fff}
 .prem-note{font-size:.76rem;color:#7a5a14;margin:14px 0 0;line-height:1.7}
 .prem-note strong{color:#5a4012}
 @media (max-width:560px){.w{padding:20px 15px 60px}.site-hd .in{padding:10px 15px}.site-ft .in{padding:26px 15px 28px}h2{font-size:1.1rem;margin:24px 0 10px}.cards{grid-template-columns:1fr}.join,.premium{padding:18px 15px}.join-cta .hcta{flex:1 1 100%;text-align:center}}
 @media (prefers-reduced-motion:reduce){*{transition:none !important}.c:hover{transform:none}}

 /* ===== 2026-05-26 全ページ共通 モバイル最適化（D19） ===== */
 @media (max-width:768px){
   /* iOS自動ズーム回避（入力要素16px以上） */
   input,select,textarea,button{font-size:16px!important}
   /* タップターゲット 44x44px 確保（WCAG 2.5.5 AAA） */
   button,.hcta,.hbtn,.btn,.al-btn,a.hbtn,.qe-q,.qe-support,.biz-cta a,.biz-quick a,.ind-pill,.chip,.stage-chip,.pf,.stage-chip{min-height:44px;padding-top:10px;padding-bottom:10px}
   /* 画像レスポンシブ */
   img{max-width:100%;height:auto}
   /* テーブル横スクロール */
   table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}
   /* 横スクロール完全防止 */
   html,body{overflow-x:hidden;width:100%}
   /* スティッキーヘッダー高さ縮小 */
   .site-hd{position:sticky;top:0}
   .site-hd .in{padding:8px 12px;gap:4px 12px}
   .site-hd .bd{font-size:1.05rem}
   .site-hd nav{font-size:.78rem;gap:0 2px}
   .site-hd nav a{padding:5px 7px}
   /* セーフエリア（iPhone notch） */
   body{padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);padding-bottom:env(safe-area-inset-bottom)}
   /* セクション間隔縮小 */
   h2{margin:18px 0 10px;font-size:1.08rem}
   h3{font-size:.98rem}
   .lead,.sub{font-size:.92rem;line-height:1.8}
   /* カード内 padding 縮小 */
   .card,.feat-card,.biz-card,.pcard{padding:14px 14px!important}
   /* グリッド単列 */
   .grid2,.form-grid,.biz-grid,.qe-primary-row{grid-template-columns:1fr!important;gap:10px!important}
   /* チップ群の隙間確保 */
   .chip,.stage-chip,.pf{margin:0 2px 6px 0}
   /* フッターcompact */
   .site-ft .in{padding:20px 14px 22px;gap:16px}
   /* ad枠を小さく */
   .hj-ad{margin:8px 0!important;min-height:90px}
 }
 /* タブレット小・スマホ大の中間調整 */
 @media (min-width:561px) and (max-width:768px){
   .grid2,.form-grid{grid-template-columns:1fr 1fr!important}
 }
 /* 横向きスマホ（landscape）でheroの最小高さを抑制 */
 @media (max-width:900px) and (orientation:landscape){
   .hero-slider .hslide{min-height:200px!important;padding-top:24px;padding-bottom:24px}
 }

/* 2026-05-25 暮らしの場面写真導入: ツールカードの画像化 */
.feat-card .feat-ic{overflow:hidden;border-radius:12px;padding:0;width:100%;aspect-ratio:3/2;background:var(--surface-2)}
.feat-card .feat-ic img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease}
.feat-card:hover .feat-ic img{transform:scale(1.04)}

/* 境遇別カード grid */
.situ-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin:14px 0 24px}
.situ-card{display:block;text-decoration:none;color:inherit;border:1px solid var(--line);background:var(--surface);border-radius:14px;overflow:hidden;box-shadow:var(--sh-1);transition:transform .15s,box-shadow .2s}
.situ-card:hover{transform:translateY(-2px);box-shadow:var(--sh-2)}
.situ-img{aspect-ratio:3/2;overflow:hidden;background:var(--surface-2)}
.situ-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease}
.situ-card:hover .situ-img img{transform:scale(1.04)}
.situ-bd{padding:12px 14px 14px}
.situ-ti{font-weight:700;color:var(--brand-ink);font-size:.98rem;margin-bottom:2px;line-height:1.45}
.situ-de{color:var(--muted);font-size:.82rem;line-height:1.55}

/* === Mobile responsive enhancements (2026-05-26 全ページ波及) === */
@media (max-width:560px){
  html,body{overflow-x:hidden}
  *{max-width:100%}
  img,video,iframe{max-width:100%;height:auto}
  table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%}
  pre,code{overflow-x:auto;word-break:break-all}
  /* iOS auto-zoom防止 */
  input[type=text],input[type=email],input[type=tel],input[type=url],input[type=number],input[type=search],input[type=password],select,textarea{font-size:16px}
  /* タップ領域 */
  a.btn,button,.hcta,.lvl-btn{min-height:44px}
  /* 長文URL等の折り返し */
  .src,.brief,p{overflow-wrap:anywhere;word-break:break-word}
  /* 固定幅潰し */
  [style*="width:600px"],[style*="width:700px"],[style*="width:800px"]{width:100%!important;max-width:100%!important}
}
@media (max-width:380px){
  .w{padding:14px 12px 50px}
  h1{font-size:1.2rem}
  h2{font-size:1.05rem}
}
