@charset "UTF-8";
/*!
Theme Name: Cocoon Child
Description: Cocoon専用の子テーマ
Theme URI: https://wp-cocoon.com/
Author: わいひら
Author URI: https://nelog.jp/
Template:   cocoon-master
Version:    1.1.3
*/

/************************************
** 全体
************************************/
.logo {
  text-align: left;
}
/*キャッチフレーズ*/
.tagline {
    text-align: left;
    font-size: 13px;
    margin: -1.0em 2em;
}
.site-name-text-link {
    color: var(--cocoon-text-color);
    text-decoration: none;
    font-weight: normal;
    padding: 0px 0px;
}

#header-in.wrap {
  max-width: 860px !important;
  margin: 0 auto !important;
}
.main {
  width: 860px !important;
  padding: 36px 8px;
  border: none;
  border-radius: none;
  position: relative;
  box-shadow: none;
  z-index: 0;
  margin: 0 auto !important;
}
@media screen and (max-width: 1023px) {
  .main {
    width: auto !important;
    margin: 0 0.5% !important;
  }
  .page .article-header.entry-header {
    width: auto !important;
    margin: 0 !important;
  }
  #header-in.wrap {
    max-width: 100% !important;
  }
}
@media screen and (max-width: 834px) {
    main.main, div.sidebar {
        padding: 32px 8px;
        margin: 12px 0;
        border-width: 0;
    }
}

.article h2 {
  background: none;
  border-left: none;
}

#footer {
    font-size: 13px;
    line-height: 1.85;
}

/* フッターリンク アンダーバー非表示（強化版） */
#footer a {
    text-decoration: none !important;
    border-bottom: none !important;
    box-shadow: none !important;
}

/* フッターのリンクを横並びにする */
.footer-links-container {
    display: flex;
    justify-content: space-around;
    gap: 20px;
    flex-wrap: wrap;
}

/* 各グループ内のリンク設定 */
.footer-links-group {
    flex: 1;
    min-width: 200px;
}

/************************************
** スコアページ：Cocoonタイトル非表示
************************************/
.page:has(.urn-score) .article-header.entry-header {
  display: none !important;
}

/************************************
** 共通：Spring アニメーション
************************************/
@keyframes urn-spring{
  0%{opacity:0;transform:translateY(20px) scale(.97)}
  60%{opacity:1;transform:translateY(-4px) scale(1.01)}
  80%{transform:translateY(2px) scale(.995)}
  100%{opacity:1;transform:translateY(0) scale(1)}
}
@keyframes urn-rise{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes urn-pulse{0%,100%{opacity:1}50%{opacity:.4}}

/************************************
** Urunifyスコア説明ページ (.urn-score)
************************************/
.urn-score {
  --brand:#3366FF;--brand-light:#EBF0FF;--brand-mid:#5A85FF;--brand-dark:#1A44CC;
  --navy:#1A1A2E;--navy-light:#2A2A42;
  --bg-card:#FFFFFF;--bg-subtle:#F4F6FB;
  --t1:#0F1729;--t2:#4A5068;--t3:#8B90A0;
  --b1:#E2E5F0;--b2:#ECEEF5;--b3:#F2F3F8;
  --cat-a:#3366FF;--cat-a-bg:#EBF0FF;--cat-a-t:#1A3DB8;
  --cat-b:#E8553D;--cat-b-bg:#FEF0ED;--cat-b-t:#A63424;
  --cat-c:#8B5CF6;--cat-c-bg:#F3EFFE;--cat-c-t:#5B3AAF;
  --cat-d:#10B981;--cat-d-bg:#ECFDF5;--cat-d-t:#067A55;
  --cat-e:#F59E0B;--cat-e-bg:#FFFBEB;--cat-e-t:#A16207;
  --radius:8px;--radius-lg:14px;--radius-xl:20px;
  --shadow-sm:0 1px 2px rgba(15,23,41,.04);
  --shadow-md:0 4px 16px rgba(15,23,41,.06);
  --shadow-lg:0 8px 32px rgba(15,23,41,.08);
  --font:'Inter','Noto Sans JP','Hiragino Kaku Gothic ProN',sans-serif;
  font-family:var(--font) !important;
  color:var(--t1);line-height:1.75;font-size:15px;
  -webkit-font-smoothing:antialiased;
  max-width:880px;margin:0 auto;padding:0;
}
.urn-score *,.urn-score *::before,.urn-score *::after{box-sizing:border-box}

/* Hero */
.urn-score .hero{padding:8px 0 40px}
.urn-score .hero-badge{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--brand);background:var(--brand-light);padding:6px 14px;border-radius:100px;margin-bottom:20px}
.urn-score .hero-badge::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--brand);animation:urn-pulse 2s infinite}
.urn-score .hero h1{font-size:clamp(28px,5vw,42px) !important;font-weight:700 !important;line-height:1.25 !important;letter-spacing:-1.2px;margin:0 0 20px 0 !important;padding:0 !important;border:none !important;background:none !important;color:var(--t1) !important}
.urn-score .hero h1 .grad{background:linear-gradient(135deg,var(--brand),var(--brand-mid),#8B5CF6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.urn-score .hero-desc{font-size:16px;color:var(--t2);line-height:1.85;margin:0}
.urn-score .anim{animation:urn-rise .7s cubic-bezier(.22,1,.36,1) both}
.urn-score .d1{animation-delay:.05s}
.urn-score .d2{animation-delay:.1s}

/* Showcase card */
.urn-score .showcase{padding:0 0 48px}
.urn-score .showcase-card{background:var(--bg-card);border:1px solid var(--b1);border-radius:var(--radius-xl);padding:36px 40px;box-shadow:var(--shadow-md);display:flex;flex-wrap:wrap;gap:40px;align-items:center}
.urn-score .sc-left{display:flex;flex-direction:column;align-items:center;gap:12px}
.urn-score .sc-ring{position:relative;width:140px;height:140px}
.urn-score .sc-ring svg{width:140px;height:140px;transform:rotate(-90deg)}
.urn-score .sc-ring-bg{fill:none;stroke:var(--b3);stroke-width:8}
.urn-score .sc-ring-fill{fill:none;stroke:url(#scoreGrad);stroke-width:8;stroke-linecap:round;stroke-dasharray:408;stroke-dashoffset:calc(408 - 408*var(--pct)/100);transition:stroke-dashoffset 1.2s cubic-bezier(.22,1,.36,1)}
.urn-score .sc-val{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;flex-direction:column}
.urn-score .sc-num{font-size:40px;font-weight:700;letter-spacing:-2px}
.urn-score .sc-num small{font-size:16px;font-weight:400;color:var(--t3);letter-spacing:0;margin-left:2px}
.urn-score .sc-city{font-size:12px;color:var(--t3);font-weight:500}
.urn-score .sc-rank{font-size:11px;color:var(--t3);background:var(--bg-subtle);padding:4px 12px;border-radius:100px}
.urn-score .sc-right{flex:1;min-width:280px;display:flex;flex-direction:column;gap:14px}
.urn-score .sc-bar{display:flex;align-items:center;gap:12px}
.urn-score .sc-bar-label{font-size:12px;font-weight:500;width:72px;flex-shrink:0;text-align:right}
.urn-score .sc-bar-track{flex:1;height:8px;background:var(--b3);border-radius:4px;overflow:hidden}
.urn-score .sc-bar-fill{height:100%;border-radius:4px;transition:width 1s cubic-bezier(.22,1,.36,1)}
.urn-score .sc-bar-val{font-size:12px;font-weight:600;width:50px;flex-shrink:0}
.urn-score .sc-bar.a .sc-bar-label,.urn-score .sc-bar.a .sc-bar-val{color:var(--cat-a-t)}
.urn-score .sc-bar.a .sc-bar-fill{background:var(--cat-a)}
.urn-score .sc-bar.b .sc-bar-label,.urn-score .sc-bar.b .sc-bar-val{color:var(--cat-b-t)}
.urn-score .sc-bar.b .sc-bar-fill{background:var(--cat-b)}
.urn-score .sc-bar.c .sc-bar-label,.urn-score .sc-bar.c .sc-bar-val{color:var(--cat-c-t)}
.urn-score .sc-bar.c .sc-bar-fill{background:var(--cat-c)}
.urn-score .sc-bar.d .sc-bar-label,.urn-score .sc-bar.d .sc-bar-val{color:var(--cat-d-t)}
.urn-score .sc-bar.d .sc-bar-fill{background:var(--cat-d)}
.urn-score .sc-bar.e .sc-bar-label,.urn-score .sc-bar.e .sc-bar-val{color:var(--cat-e-t)}
.urn-score .sc-bar.e .sc-bar-fill{background:var(--cat-e)}

/* Section */
.urn-score .sec{padding:0 0 48px}
.urn-score .sec-head{margin-bottom:28px}
.urn-score .sec-title{font-size:22px !important;font-weight:700 !important;letter-spacing:-.6px;margin:0 0 6px 0 !important;padding:0 !important;border:none !important;background:none !important;color:var(--t1) !important}
.urn-score .sec-sub{font-size:14px;color:var(--t2);line-height:1.8;margin:0}

/* Accordion — spring stagger */
.urn-score .acc{background:var(--bg-card);border:1px solid var(--b1);border-radius:var(--radius-lg);margin-bottom:12px;overflow:hidden;transition:box-shadow .2s;opacity:0;transform:translateY(20px) scale(.97)}
.urn-score .acc.urn-visible{animation:urn-spring .6s cubic-bezier(.34,1.56,.64,1) forwards}
.urn-score .acc:hover{box-shadow:var(--shadow-sm)}
.urn-score .acc-head{padding:18px 22px;display:flex;align-items:center;gap:14px;cursor:pointer;user-select:none;transition:background .15s}
.urn-score .acc-head:hover{background:var(--bg-subtle)}
.urn-score .acc-dot{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;flex-shrink:0}
.urn-score .acc.a .acc-dot{background:var(--cat-a-bg);color:var(--cat-a-t)}
.urn-score .acc.b .acc-dot{background:var(--cat-b-bg);color:var(--cat-b-t)}
.urn-score .acc.c .acc-dot{background:var(--cat-c-bg);color:var(--cat-c-t)}
.urn-score .acc.d .acc-dot{background:var(--cat-d-bg);color:var(--cat-d-t)}
.urn-score .acc.e .acc-dot{background:var(--cat-e-bg);color:var(--cat-e-t)}
.urn-score .acc-info{flex:1}
.urn-score .acc-name{font-weight:600;font-size:15px;letter-spacing:-.2px}
.urn-score .acc-pts{font-size:12px;color:var(--t3);font-weight:500;margin-top:1px}
.urn-score .acc-arrow{width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:transform .4s cubic-bezier(.34,1.56,.64,1);flex-shrink:0}
.urn-score .acc-arrow svg{width:12px;height:12px;stroke:var(--t3);fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}
.urn-score .acc.open .acc-arrow{transform:rotate(180deg)}
.urn-score .acc-body{max-height:0;overflow:hidden;transition:max-height .5s cubic-bezier(.34,1.56,.64,1)}
.urn-score .acc.open .acc-body{max-height:3000px}
.urn-score .acc-inner{padding:0 22px 22px;margin-top:-2px}
.urn-score .acc-why{font-size:13px;color:var(--t2);line-height:1.8;padding:14px 18px;background:var(--bg-subtle);border-radius:var(--radius);margin-bottom:16px;border-left:3px solid var(--b1)}
.urn-score .acc.a .acc-why{border-left-color:var(--cat-a)}
.urn-score .acc.b .acc-why{border-left-color:var(--cat-b)}
.urn-score .acc.c .acc-why{border-left-color:var(--cat-c)}
.urn-score .acc.d .acc-why{border-left-color:var(--cat-d)}
.urn-score .acc.e .acc-why{border-left-color:var(--cat-e)}

/* Sub-indicators */
.urn-score .si{border:1px solid var(--b2);border-radius:var(--radius);padding:16px 20px;margin-bottom:10px;transition:border-color .15s}
.urn-score .si:hover{border-color:var(--b1)}
.urn-score .si-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:10px}
.urn-score .si-name{font-weight:600;font-size:13px}
.urn-score .si-pts{font-size:12px;font-weight:600;color:var(--t3);background:var(--bg-subtle);padding:2px 10px;border-radius:100px}
.urn-score .si dl{display:grid;grid-template-columns:72px 1fr;gap:3px 14px;font-size:12px;margin:0}
.urn-score .si dt{color:var(--t3);font-weight:600;padding-top:1px}
.urn-score .si dd{color:var(--t2);line-height:1.7;margin:0}

/* Formula */
.urn-score .formula{background:var(--navy);border-radius:var(--radius-lg);padding:28px 32px;color:#C8CDE0;font-family:'SF Mono','Fira Code','Inter',monospace;font-size:13px;line-height:2.2;overflow-x:auto;box-shadow:var(--shadow-lg);white-space:pre}
.urn-score .formula .cm{color:#5A6080}
.urn-score .formula .res{color:#60E0C0;font-weight:700;font-size:14px}
.urn-score .formula-note{font-size:12px;color:var(--t3);margin-top:14px;line-height:1.7}

/* Data source grid — spring stagger */
.urn-score .ds-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:10px}
.urn-score .ds{background:var(--bg-card);border:1px solid var(--b2);border-radius:var(--radius);padding:16px 20px;transition:border-color .15s,box-shadow .15s;opacity:0;transform:translateY(16px) scale(.97)}
.urn-score .ds.urn-visible{animation:urn-spring .5s cubic-bezier(.34,1.56,.64,1) forwards}
.urn-score .ds:hover{border-color:var(--b1);box-shadow:var(--shadow-sm)}
.urn-score .ds-num{font-size:10px;font-weight:700;color:var(--brand);letter-spacing:1px;margin-bottom:6px}
.urn-score .ds-name{font-weight:600;font-size:13px;margin-bottom:3px}
.urn-score .ds-org{font-size:11px;color:var(--t3)}
.urn-score .ds-tag{display:inline-block;font-size:10px;font-weight:600;background:var(--cat-d-bg);color:var(--cat-d-t);padding:3px 10px;border-radius:100px;margin-top:8px;letter-spacing:.5px}

/* Edge cases — spring stagger */
.urn-score .eg{display:grid;gap:10px}
.urn-score .eg-item{display:flex;gap:14px;padding:16px 20px;background:var(--bg-card);border:1px solid var(--b2);border-radius:var(--radius);transition:border-color .15s;opacity:0;transform:translateY(16px) scale(.97)}
.urn-score .eg-item.urn-visible{animation:urn-spring .5s cubic-bezier(.34,1.56,.64,1) forwards}
.urn-score .eg-item:hover{border-color:var(--b1)}
.urn-score .eg-icon{flex-shrink:0;width:32px;height:32px;border-radius:8px;background:var(--bg-subtle);display:flex;align-items:center;justify-content:center;font-size:15px}
.urn-score .eg-text{font-size:13px;color:var(--t2);line-height:1.75}
.urn-score .eg-text strong{font-weight:600;color:var(--t1)}

/* Disclaimer */
.urn-score .disclaim{background:linear-gradient(135deg,var(--brand-light),#F3EFFE);border-radius:var(--radius-lg);padding:32px;text-align:center}
.urn-score .disclaim p{font-size:13px;color:var(--t2);line-height:1.85;max-width:580px;margin:0 auto}
.urn-score .disclaim strong{font-weight:600;color:var(--t1)}

/* Responsive — score page */
@media(max-width:640px){
  .urn-score .showcase-card{flex-direction:column;padding:28px 20px;gap:28px}
  .urn-score .sc-left{flex-direction:row;gap:20px;align-items:center}
  .urn-score .sc-ring{width:100px;height:100px}
  .urn-score .sc-ring svg{width:100px;height:100px}
  .urn-score .sc-num{font-size:28px}
  .urn-score .sc-bar-label{width:56px;font-size:11px}
  .urn-score .hero{padding:32px 0 28px}
  .urn-score .hero h1{letter-spacing:-1px !important}
  .urn-score .acc-head{padding:14px 16px}
  .urn-score .acc-inner{padding:0 16px 16px}
  .urn-score .formula{padding:20px;font-size:11px;line-height:2}
}

/************************************
** 固定ページ：見出しデザイン
************************************/
.page .article h2 {
  font-family: 'Inter', 'Noto Sans JP', sans-serif !important;
  font-size: 20px !important;
  font-weight: 700 !important;
  color: #0F1729 !important;
  letter-spacing: -.5px !important;
  border: none !important;
  border-left: 3px solid #3366FF !important;
  background: none !important;
  padding: 2px 0 2px 14px !important;
  margin: 40px 0 16px 0 !important;
  line-height: 1.4 !important;
}
.page .article h2:first-child {
  margin-top: 0 !important;
}
.page .article h3 {
  font-family: 'Inter', 'Noto Sans JP', sans-serif !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  color: #0F1729 !important;
  letter-spacing: -.3px !important;
  border: none !important;
  border-bottom: 1px solid #ECEEF5 !important;
  background: none !important;
  padding: 0 0 8px 0 !important;
  margin: 28px 0 12px 0 !important;
  line-height: 1.4 !important;
}

/************************************
** 固定ページ：テーブルデザイン
************************************/
.page .article table {
  border-collapse: collapse !important;
  width: 100% !important;
  font-size: 14px !important;
  margin: 16px 0 24px !important;
}
.page .article table td {
  padding: 10px 16px !important;
  border: none !important;
  border-bottom: 1px solid #ECEEF5 !important;
  color: #4A5068 !important;
}
.page .article table td:first-child {
  font-weight: 600 !important;
  color: #0F1729 !important;
  width: 140px !important;
  white-space: nowrap !important;
}
.page .article table a {
  color: #3366FF !important;
}

/************************************
** 固定ページ：リストデザイン
************************************/
.page .article ul {
  padding-left: 20px !important;
  margin: 12px 0 20px !important;
}
.page .article ul li {
  font-size: 14px !important;
  color: #4A5068 !important;
  line-height: 1.9 !important;
  margin-bottom: 4px !important;
}

/************************************
** 家計診断ツール：入力フォーム (.ks-*)
** ※ツール本体のフォーム部品。.urn-score配下にスコープ。
************************************/
/* 入力フォーム用の最小追加CSS（.urn-score配下にスコープ・本番でも追記要） */
.urn-score .ks-form{background:var(--bg-card);border:1px solid var(--b1);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-sm)}
.urn-score .ks-field{margin-bottom:16px}
.urn-score .ks-field label{display:block;font-size:13px;font-weight:600;margin-bottom:6px;color:var(--t1)}
.urn-score .ks-form select,.urn-score .ks-exp input{width:100%;padding:10px 12px;font-size:15px;border:1px solid var(--b1);border-radius:var(--radius);background:#fff;color:var(--t1);font-family:inherit}
.urn-score .ks-exp{margin:8px 0 4px}
.urn-score .ks-exp-row{display:grid;grid-template-columns:1fr 150px;align-items:center;gap:12px;padding:8px 0;border-bottom:1px dashed var(--b1)}
.urn-score .ks-exp-row:last-child{border-bottom:none}
.urn-score .ks-exp-row>span:first-child{font-size:14px;font-weight:600}
.urn-score .ks-exp-row small{color:var(--t3);font-weight:400;font-size:11px;margin-left:6px}
.urn-score .ks-yen{position:relative}
.urn-score .ks-yen::after{content:"円";position:absolute;right:11px;top:50%;transform:translateY(-50%);font-size:12px;color:var(--t3)}
.urn-score .ks-yen input{text-align:right;padding-right:28px}
.urn-score .ks-btn{display:block;width:100%;margin-top:14px;padding:24px;border:none;border-radius:var(--radius);background:linear-gradient(135deg,#3366FF,#8B5CF6);color:#fff;font-size:20px;font-weight:700;letter-spacing:.06em;cursor:pointer;font-family:inherit}
.urn-score .ks-btn:hover{background:var(--brand-dark)}
.urn-score .ks-err{color:var(--cat-b-t);font-size:12.5px;margin:8px 0 0;min-height:16px}
.urn-score .ks-note{font-size:11.5px;color:var(--t3);margin-top:18px;padding-top:12px;border-top:1px dashed var(--b1);line-height:1.7}

/************************************
** 都道府県 生活費ランキング (#urn-rank)
** ※.urn-score の外（別ブロック）でも効くよう #urn-rank 起点にスコープ。
** ※棒グラフは廃止。各行は 順位・県名（左）／金額・平均比（右）のみ。
************************************/
#urn-rank{
  --rk-card:#FFFFFF;--rk-subtle:#F4F6FB;
  --rk-t1:#0F1729;--rk-t2:#4A5068;--rk-t3:#8B90A0;
  --rk-b1:#E2E5F0;--rk-b2:#ECEEF5;
  --rk-radius:8px;--rk-radius-lg:14px;
  --rk-shadow:0 1px 2px rgba(15,23,41,.04);
  font-family:'Inter','Noto Sans JP','Hiragino Kaku Gothic ProN',sans-serif;
  color:var(--rk-t1);max-width:880px;margin:0 auto;
}
#urn-rank *,#urn-rank *::before,#urn-rank *::after{box-sizing:border-box}
#urn-rank .sec-head{margin-bottom:24px}
#urn-rank .sec-title{font-size:22px !important;font-weight:700 !important;letter-spacing:-.6px;margin:0 0 6px 0 !important;padding:0 !important;border:none !important;border-left:none !important;background:none !important;color:var(--rk-t1) !important}
#urn-rank .sec-sub{font-size:14px;color:var(--rk-t2);line-height:1.8;margin:0}
#urn-rank .rk-card{background:var(--rk-card);border:1px solid var(--rk-b1);border-radius:var(--rk-radius-lg);padding:18px;box-shadow:var(--rk-shadow);margin-bottom:16px}
#urn-rank .rk-card-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid var(--rk-b1)}
#urn-rank .rk-card-title{font-size:16px;font-weight:800;color:var(--rk-t1)}
#urn-rank .rk-card-nat{font-size:12.5px;font-weight:700;color:#5B3AAF}
#urn-rank .rk-ctrl{display:flex;gap:10px;align-items:center;margin-bottom:8px}
#urn-rank .rk-hh{flex:0 0 130px;padding:8px 10px;font-size:13px;border:1px solid var(--rk-b1);border-radius:var(--rk-radius);background:#fff;color:var(--rk-t1);font-family:inherit}
#urn-rank .rk-order{display:flex;flex:1;gap:0;background:var(--rk-subtle);border:1px solid var(--rk-b1);border-radius:var(--rk-radius);padding:4px}
#urn-rank .rk-ob{flex:1;padding:8px;border:none;border-radius:6px;background:transparent;color:var(--rk-t3);font-size:13px;font-weight:700;cursor:pointer;font-family:inherit;transition:background .15s,color .15s}
#urn-rank .rk-list{padding:0 2px}
#urn-rank .rk-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--rk-b2)}
#urn-rank .rk-row:last-child{border-bottom:none}
#urn-rank .rk-no{flex:0 0 auto;width:23px;height:23px;border-radius:50%;background:var(--rk-subtle);color:var(--rk-t1);font-size:12.5px;font-weight:800;display:flex;align-items:center;justify-content:center}
#urn-rank .rk-pref{flex:1;font-size:14px;font-weight:700;color:var(--rk-t1)}
#urn-rank .rk-right{flex:0 0 auto;text-align:right;display:flex;flex-direction:column;gap:2px}
#urn-rank .rk-val{font-size:15px;font-weight:800;color:var(--rk-t1);font-variant-numeric:tabular-nums;line-height:1.2}
#urn-rank .rk-diff{font-size:11.5px;font-weight:600;font-variant-numeric:tabular-nums}
#urn-rank .rk-empty{font-size:12.5px;color:var(--rk-t3);padding:14px 4px;margin:0}
#urn-rank .ks-note{font-size:11.5px;color:var(--rk-t3);margin-top:18px;padding-top:12px;border-top:1px dashed var(--rk-b1);line-height:1.7}
@media(max-width:640px){
  #urn-rank .rk-ctrl{flex-wrap:wrap}
  #urn-rank .rk-hh{flex:1 1 100%}
  #urn-rank .rk-pref{font-size:13px}
  #urn-rank .rk-val{font-size:14px}
}

/************************************
** 節約スコア解説ページ (#urn-logic)
** ※独立スコープ。固定ページのカスタムHTMLブロックに設置。
************************************/
#urn-logic{
  --lg-t1:#0F1729;--lg-t2:#4A5068;--lg-t3:#8B90A0;
  --lg-b1:#E2E5F0;--lg-b2:#ECEEF5;--lg-subtle:#F4F6FB;--lg-card:#FFFFFF;
  --lg-brand:#3366FF;--lg-purple:#5B3AAF;--lg-navy:#1A1A2E;
  --lg-radius:8px;--lg-radius-lg:14px;
  font-family:'Inter','Noto Sans JP','Hiragino Kaku Gothic ProN',sans-serif;
  color:var(--lg-t1);line-height:1.8;max-width:880px;margin:0 auto;
}
#urn-logic *,#urn-logic *::before,#urn-logic *::after{box-sizing:border-box}
#urn-logic .ulg-head{margin-bottom:28px}
#urn-logic .ulg-title{font-size:24px !important;font-weight:800 !important;letter-spacing:-.6px;margin:0 0 8px 0 !important;padding:0 !important;border:none !important;border-left:none !important;background:none !important;color:var(--lg-t1) !important}
#urn-logic .ulg-sub{font-size:14px;color:var(--lg-t2);margin:0;line-height:1.85}
#urn-logic .ulg-h3{font-size:17px !important;font-weight:700 !important;color:var(--lg-t1) !important;letter-spacing:-.3px;margin:32px 0 12px 0 !important;padding:0 0 8px 0 !important;border:none !important;border-bottom:1px solid var(--lg-b2) !important;background:none !important;line-height:1.4 !important}
#urn-logic .ulg-p{font-size:14px;color:var(--lg-t2);margin:0 0 14px;line-height:1.9}
#urn-logic .ulg-formula{background:var(--lg-navy);color:#C8CDE0;border-radius:var(--lg-radius-lg);padding:20px 24px;font-family:'SF Mono','Fira Code',monospace;font-size:13px;line-height:2;margin:0 0 12px;overflow-x:auto}
#urn-logic .ulg-note-inline{font-size:12.5px;color:var(--lg-t3);margin:0 0 8px;line-height:1.8}
#urn-logic .ulg-rank-table{display:flex;flex-direction:column;gap:6px;margin:4px 0 8px}
#urn-logic .ulg-rank-row{display:flex;align-items:center;gap:14px;padding:10px 14px;background:var(--lg-subtle);border-radius:var(--lg-radius);font-size:13.5px;font-weight:600;color:var(--lg-t1)}
#urn-logic .ulg-rank-badge{flex:0 0 88px;font-size:12px;font-weight:800;color:var(--lg-purple)}
#urn-logic .ulg-ul{padding-left:20px;margin:8px 0 8px}
#urn-logic .ulg-ul li{font-size:13.5px;color:var(--lg-t2);line-height:1.9;margin-bottom:4px}
#urn-logic .ulg-field{max-width:280px;margin:8px 0 14px}
#urn-logic .ulg-field label{display:block;font-size:13px;font-weight:600;margin-bottom:6px;color:var(--lg-t1)}
#urn-logic .ulg-field select{width:100%;padding:10px 12px;font-size:15px;border:1px solid var(--lg-b1);border-radius:var(--lg-radius);background:#fff;color:var(--lg-t1);font-family:inherit}
#urn-logic .ulg-table-wrap{overflow-x:auto;border:1px solid var(--lg-b1);border-radius:var(--lg-radius-lg);box-shadow:0 1px 2px rgba(15,23,41,.04)}
#urn-logic .ulg-table{border-collapse:collapse;width:100%;font-size:12.5px;white-space:nowrap;background:var(--lg-card)}
#urn-logic .ulg-table th{background:var(--lg-subtle);color:var(--lg-t2);font-size:11.5px;font-weight:700;padding:10px 12px;text-align:right;border-bottom:2px solid var(--lg-b1);position:sticky;top:0}
#urn-logic .ulg-table th.ulg-th-pref{text-align:left;left:0;z-index:2;background:var(--lg-subtle)}
#urn-logic .ulg-table td{padding:9px 12px;text-align:right;border-bottom:1px solid var(--lg-b2);color:var(--lg-t2);font-variant-numeric:tabular-nums}
#urn-logic .ulg-table td.ulg-td-pref{text-align:left;font-weight:700;color:var(--lg-t1);position:sticky;left:0;background:var(--lg-card);z-index:1}
#urn-logic .ulg-table td.ulg-td-total{font-weight:800;color:var(--lg-purple)}
#urn-logic .ulg-table td.ulg-td-na{color:var(--lg-t3)}
#urn-logic .ulg-table tr:last-child td{border-bottom:none}
#urn-logic .ulg-note{font-size:11.5px;color:var(--lg-t3);margin-top:14px;line-height:1.7}
@media(max-width:640px){
  /* ページ全体が横に広がらないよう #urn-logic を画面幅に収め、
     はみ出しは表ラッパー(.ulg-table-wrap)の横スクロールだけに限定する。 */
  #urn-logic{max-width:100%;overflow-x:hidden}
  #urn-logic .ulg-formula{font-size:11.5px;padding:16px;white-space:normal;word-break:break-word}
  #urn-logic .ulg-table-wrap{max-width:100%}
  #urn-logic .ulg-table th,#urn-logic .ulg-table td{padding:8px 10px;font-size:11.5px}
}

/************************************
** 費目説明ページ (#urn-cat)
** ※独立スコープ。固定ページのカスタムHTMLブロックに設置。
** ※.urn-score / #urn-rank / #urn-logic とは別スコープ。
************************************/
#urn-cat{
  --ct-t1:#0F1729;--ct-t2:#4A5068;--ct-t3:#8B90A0;
  --ct-b1:#E2E5F0;--ct-b2:#ECEEF5;--ct-subtle:#F4F6FB;--ct-card:#FFFFFF;
  --ct-brand:#3366FF;--ct-purple:#8B5CF6;--ct-purple-t:#5B3AAF;
  --ct-net-bg:#F3EFFE;--ct-net-t:#5B3AAF;
  --ct-radius:8px;--ct-radius-lg:14px;
  --ct-shadow:0 1px 2px rgba(15,23,41,.04);
  font-family:'Inter','Noto Sans JP','Hiragino Kaku Gothic ProN',sans-serif;
  color:var(--ct-t1);line-height:1.8;max-width:880px;margin:0 auto;
}
#urn-cat *,#urn-cat *::before,#urn-cat *::after{box-sizing:border-box}

/* Header */
#urn-cat .cat-head{margin-bottom:28px}
#urn-cat .cat-title{font-size:clamp(24px,4.5vw,32px) !important;font-weight:800 !important;letter-spacing:-.6px;line-height:1.3 !important;margin:0 0 12px 0 !important;padding:0 !important;border:none !important;border-left:none !important;background:none !important;color:var(--ct-t1) !important}
#urn-cat .cat-grad{background:linear-gradient(135deg,var(--ct-brand),var(--ct-purple));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
#urn-cat .cat-lead{font-size:14.5px;color:var(--ct-t2);line-height:1.9;margin:0}

/* Grid */
#urn-cat .cat-grid{display:flex;flex-direction:column;gap:12px}

/* Item card */
#urn-cat .cat-item{background:var(--ct-card);border:1px solid var(--ct-b1);border-radius:var(--ct-radius-lg);padding:20px 22px;box-shadow:var(--ct-shadow)}
#urn-cat .cat-row{display:flex;align-items:center;gap:12px;margin-bottom:10px}
#urn-cat .cat-no{flex:0 0 auto;font-size:12px;font-weight:800;color:var(--ct-purple-t);background:var(--ct-net-bg);width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;letter-spacing:.5px}
#urn-cat .cat-name{font-size:17px !important;font-weight:700 !important;color:var(--ct-t1) !important;letter-spacing:-.3px;margin:0 !important;padding:0 !important;border:none !important;border-left:none !important;border-bottom:none !important;background:none !important;line-height:1.4 !important}
#urn-cat .cat-desc{font-size:14px;color:var(--ct-t2);line-height:1.9;margin:0 0 12px}
#urn-cat .cat-desc strong{font-weight:700;color:var(--ct-t1)}

/* 判断例ボックス */
#urn-cat .cat-judge{font-size:12.5px;color:var(--ct-t2);line-height:1.85;background:var(--ct-subtle);border-radius:var(--ct-radius);padding:11px 14px;border-left:3px solid var(--ct-brand)}
#urn-cat .cat-judge + .cat-judge{margin-top:8px}
#urn-cat .cat-judge-q{display:inline-block;font-size:11px;font-weight:800;color:var(--ct-brand);margin-right:8px;letter-spacing:.3px}
/* ネット＝娯楽 の特記ボックスは紫系で強調 */
#urn-cat .cat-judge-net{background:var(--ct-net-bg);border-left-color:var(--ct-purple)}
#urn-cat .cat-judge-net .cat-judge-q{color:var(--ct-net-t)}
/* Footer */
#urn-cat .cat-foot{margin-top:24px;padding-top:18px;border-top:1px dashed var(--ct-b1)}
#urn-cat .cat-note{font-size:11.5px;color:var(--ct-t3);line-height:1.75;margin:0 0 18px}
#urn-cat .cat-cta{display:block;width:100%;text-align:center;background:linear-gradient(135deg,var(--ct-brand),var(--ct-purple));color:#fff !important;font-size:20px;font-weight:700;text-decoration:none !important;padding:24px 24px;border-radius:var(--ct-radius);border-bottom:none !important;box-shadow:none !important}
#urn-cat .cat-cta:hover{opacity:.92}

@media(max-width:640px){
  #urn-cat{max-width:100%}
  #urn-cat .cat-item{padding:16px 16px}
  #urn-cat .cat-name{font-size:16px !important}
  #urn-cat .cat-cta{display:block;text-align:center}
}
/************************************
** TOP：説明セクション (.urn-score .urn-about)
** ※診断ツールの下に追加。既存 .urn-score の変数を流用。
************************************/
.urn-score .urn-about{display:flex;gap:14px;flex-wrap:wrap}
.urn-score .ab-card{flex:1;min-width:260px;background:var(--bg-card);border:1px solid var(--b1);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-sm)}
.urn-score .ab-title{font-size:17px !important;font-weight:700 !important;color:var(--t1) !important;letter-spacing:-.3px;margin:0 0 10px 0 !important;padding:0 !important;border:none !important;border-left:none !important;background:none !important;line-height:1.4 !important}
.urn-score .ab-desc{font-size:13.5px;color:var(--t2);line-height:1.85;margin:0 0 14px}
.urn-score .ab-link{display:inline-block;font-size:13.5px;font-weight:700;color:var(--brand) !important;text-decoration:none !important;border-bottom:none !important;box-shadow:none !important}
.urn-score .ab-link:hover{color:var(--brand-dark) !important}
@media(max-width:640px){
  .urn-score .urn-about{flex-direction:column;gap:12px}
  .urn-score .ab-card{padding:20px}
}
/************************************
** 家計診断ツール：住居=対象外 表示（追記分）
** ※既存 .urn-score .ks-* の下に追記。
************************************/
/* 対象外費目の入力行 */
.urn-score .ks-exp-row.ks-row-off>span:first-child{color:var(--t3)}
.urn-score .ks-off-reason{display:block;margin-left:0 !important;margin-top:3px;line-height:1.6;font-size:11px;color:var(--t3)}
.urn-score .ks-exp-row.ks-row-off input:disabled{background:var(--bg-subtle);color:var(--t3);cursor:not-allowed}

/* 診断結果テーブルの横スクロール対応（スマホで画面ごと横に広がるのを防止） */
.urn-score .ks-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%;border-radius:var(--radius)}
.urn-score .ks-table-wrap table{min-width:440px}