body{margin:0;font-family:"Noto Sans JP",system-ui,sans-serif;color:#26303b;background:#fcfdfe;line-height:1.85;}
.wrap{max-width:1000px;margin:0 auto;padding:0 24px;}
.nav{border-bottom:1px solid #e6ebef;background:#fff;} .nav .wrap{display:flex;align-items:center;gap:24px;height:60px;}
.brand{font-weight:800;font-size:20px;letter-spacing:-.02em;} .brand .dot{color:#0f7c8a;}
.nav nav{display:flex;gap:18px;font-size:13px;color:#5e6b78;} .search{margin-left:auto;border:1px solid #cfd8de;border-radius:20px;padding:7px 15px;font-size:12.5px;color:#9aa7b2;}
h1{font-size:26px;margin:26px 0 4px;} .lead{color:#5e6b78;font-size:14px;margin:0 0 16px;}
.note{font-size:12px;color:#5e6b78;background:#f4f7f9;border:1px solid #e6ebef;border-radius:8px;padding:11px 14px;margin:14px 0;}
.grp{margin:24px 0 8px;font-weight:700;font-size:15px;border-left:3px solid #0f7c8a;padding-left:11px;} .grp .meta{color:#9aa7b2;font-size:12px;font-weight:500;margin-left:8px;}
ul.cl{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:0 28px;}
@media(max-width:680px){ul.cl{grid-template-columns:1fr;}}
ul.cl li{padding:9px 0;border-bottom:1px solid #e6ebef;font-size:14px;display:flex;align-items:center;gap:8px;}
ul.cl li .k2{margin-left:auto;color:#9aa7b2;font-size:11px;}
a{color:#0f7c8a;text-decoration:none;} a:hover{text-decoration:underline;}
.nav nav a{color:#5e6b78;text-decoration:none;} .nav nav a:hover{color:#26303b;}
.tag{font-size:10px;color:#0f7c8a;background:#e8f3f5;border-radius:4px;padding:1px 7px;font-weight:600;}
.crumb{font-size:12px;color:#9aa7b2;margin:14px 0 0;}
.hero{padding:50px 0 30px;border-bottom:1px solid #e6ebef;}
.hero .kick{font-family:"Inter";font-size:11px;letter-spacing:.2em;color:#0f7c8a;font-weight:700;text-transform:uppercase;}
.hero h1{font-size:34px;line-height:1.35;margin:10px 0 8px;letter-spacing:-.02em;}
.hero p{font-size:15px;color:#5e6b78;max-width:620px;margin:0;}
.hbox{border:1px solid #cfd8de;border-radius:24px;padding:11px 18px;color:#9aa7b2;font-size:13px;margin-top:22px;display:inline-block;}
.cards{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;margin:26px 0;}
@media(max-width:780px){.cards{grid-template-columns:1fr;}}
.card{border:1px solid #e6ebef;border-radius:12px;padding:18px;background:#fff;}
.card h3{margin:0 0 6px;font-size:15px;} .card p{margin:0;font-size:12.5px;color:#5e6b78;}
.entry{display:block;border:1px solid #e6ebef;border-radius:14px;padding:22px 24px;background:#fff;margin:22px 0;}
.entry:hover{border-color:#0f7c8a;text-decoration:none;} .entry .t{font-size:18px;font-weight:700;color:#26303b;}
.entry .d{font-size:13px;color:#5e6b78;margin-top:3px;} .entry .go{float:right;color:#0f7c8a;font-weight:700;}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid #e6ebef;border-radius:12px;margin:24px 0;background:#fff;}
.stats div{padding:18px 20px;border-left:1px solid #e6ebef;} .stats div:first-child{border-left:0;}
.stats .n{font-family:"Inter";font-size:26px;font-weight:700;color:#26303b;letter-spacing:-.02em;} .stats .l{font-size:12px;color:#5e6b78;margin-top:2px;}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin:10px 0 4px;}
.chips a{font-size:13px;border:1px solid #cfd8de;border-radius:18px;padding:6px 14px;color:#3c4856;}
.chips a:hover{border-color:#0f7c8a;color:#0f7c8a;text-decoration:none;}
.sect-t{font-size:18px;margin:30px 0 8px;}
.fcards{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;} @media(max-width:780px){.fcards{grid-template-columns:1fr;}}
.fcard{border:1px solid #e6ebef;border-radius:12px;padding:16px 18px;background:#fff;display:block;}
.fcard:hover{border-color:#0f7c8a;text-decoration:none;} .fcard .n{font-weight:700;color:#26303b;font-size:14.5px;}
.fcard .b{font-size:12px;color:#5e6b78;margin-top:3px;} .fcard .tag{margin-top:8px;display:inline-block;}
footer{border-top:1px solid #e6ebef;margin-top:30px;padding:20px 0;color:#9aa7b2;font-size:11.5px;}
*,*::before,*::after{box-sizing:border-box;}
.bar{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid #e6ebef;border-radius:12px;margin:18px 0;background:#fff;}
.bar div{padding:16px 18px;border-left:1px solid #e6ebef;} .bar div:first-child{border-left:0;}
.bar .n{font-family:Inter;font-size:22px;font-weight:700;} .bar .l{font-size:11.5px;color:#5e6b78;}
html,body{overflow-x:hidden;}
.hero2{text-align:center;margin:0 0 16px;padding:96px 24px 84px;border-bottom:1px solid #e6ebef;
  background:linear-gradient(180deg,rgba(26,42,40,.56) 0%,rgba(18,52,50,.48) 52%,rgba(13,92,82,.62) 100%),url('/static/warm_team.jpg');
  background-size:cover;background-position:center 40%;}
.hero2__in{max-width:1000px;margin:0 auto;}
.hero2 .kick{font-family:'Zen Maru Gothic',sans-serif;letter-spacing:.04em;font-size:13px;font-weight:700;color:#9de0d6;}
.hero2 h1{font-size:35px;line-height:1.42;margin:14px auto 12px;max-width:780px;letter-spacing:-.01em;color:#fff;text-shadow:0 2px 18px rgba(0,0,0,.35);}
.hero2 h1 .hl{color:#5fe0ec;}
.hero2 p{max-width:600px;margin:0 auto;color:#dbe6ea;font-size:14.5px;line-height:1.8;text-shadow:0 1px 10px rgba(0,0,0,.3);}
@media(max-width:780px){.hero2 h1{font-size:25px;} .hero2{padding:60px 18px 52px;}}
.hsearch{display:flex;justify-content:center;gap:8px;margin:30px auto 0;max-width:580px;}
.hsearch input{flex:1;min-width:0;padding:16px 22px;border:1px solid transparent;border-radius:32px;font-size:15px;box-shadow:0 8px 30px rgba(0,0,0,.22);}
.hsearch input:focus{outline:0;box-shadow:0 8px 30px rgba(0,0,0,.3),0 0 0 3px rgba(95,224,236,.5);}
.hsearch button{padding:16px 32px;border:0;border-radius:32px;background:#0f7c8a;color:#fff;font-weight:700;font-size:15px;cursor:pointer;white-space:nowrap;box-shadow:0 8px 24px rgba(15,124,138,.4);}
.hsearch button:hover{background:#0c6a76;}
.hsub{font-size:12.5px;color:#bcccd2;margin-top:18px;} .hsub b{color:#fff;font-family:Inter;}
.brandlink{text-decoration:none;display:inline-flex;}
.brandlogo{display:inline-flex;align-items:center;gap:6px;}
.brandlogo__icon{width:26px;height:26px;display:block;flex:none;}
.brandtext{font-family:'Zen Maru Gothic',sans-serif;font-weight:700;font-size:18px;color:#1A2A36;line-height:1;}
.brandtext .dot{color:#0f7c8a;}
h1,.hero2 h1,.sect-t,.pillar h2,.ab__h{font-family:'Zen Maru Gothic',sans-serif;}
.sect-sub{font-size:11px;font-weight:700;color:#0f7c8a;background:#e7f3f5;border-radius:10px;padding:2px 9px;margin-left:8px;vertical-align:middle;}
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:34px;margin:36px 0 12px;}
@media(max-width:780px){.pillars{grid-template-columns:1fr;gap:24px;}}
.pillar{border-top:2px solid #1d2730;padding:14px 0 0;}
.pillar .pl__no{font-family:Inter;font-size:12px;font-weight:700;letter-spacing:.12em;color:#9aa7b2;}
.pillar h2{margin:7px 0 9px;font-size:16px;color:#1d2730;font-weight:700;}
.pillar p{margin:0;font-size:13px;color:#5e6b78;line-height:1.9;}
.jobcards{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin:8px 0 20px;}
@media(max-width:780px){.jobcards{grid-template-columns:1fr;}}
.jobcard{border:1px solid #e6ebef;border-radius:16px;padding:16px 18px;background:#fff;display:flex;flex-direction:column;gap:6px;}
.jc__ttl{font-weight:700;font-size:14px;color:#1d2730;line-height:1.5;}
.jc__ttl:hover{color:#0f7c8a;}
.jc__co{font-size:12.5px;} .jc__co a{color:#0f7c8a;}
.jc__meta{font-size:11.5px;color:#9aa7b2;display:flex;flex-wrap:wrap;gap:6px;align-items:center;}
.jc__pin{width:13px;height:13px;color:#b3bdc6;flex:none;}
.jc__src{color:#b3bdc6;}
.jc__btn{align-self:flex-start;margin-top:4px;font-size:12px;font-weight:700;color:#0f7c8a;border:1px solid #cfe3e6;border-radius:18px;padding:5px 14px;}
.jc__btn:hover{background:#0f7c8a;color:#fff;border-color:#0f7c8a;text-decoration:none;}
.about{display:flex;gap:36px;border-top:1px solid #e6ebef;margin:34px 0 8px;padding:26px 0 0;}
@media(max-width:680px){.about{flex-direction:column;gap:10px;}}
.ab__h{flex:none;width:150px;font-size:13px;font-weight:700;color:#1d2730;margin:0;}
.ab__body{flex:1;}
.ab__body p{margin:0 0 8px;font-size:13px;color:#5e6b78;line-height:1.95;}
.ab__src{font-size:11.5px;color:#9aa7b2;}
.gy{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0 20px;}
.gy a{font-size:13px;border:1px solid #cfd8de;border-radius:18px;padding:6px 13px;color:#3c4856;}
.gy a:hover{border-color:#0f7c8a;color:#0f7c8a;text-decoration:none;} .gy a .c{color:#9aa7b2;font-size:11px;margin-left:5px;}
.prefs{columns:4;column-gap:24px;} @media(max-width:780px){.prefs{columns:2;}}
.prefs a{display:block;padding:7px 0;border-bottom:1px solid #f0f3f5;font-size:13.5px;}
.prefs a .c{float:right;color:#9aa7b2;font-size:11px;}
.jpmap{max-width:560px;margin:10px auto 2px;}
.jpmap-svg{width:100%;height:auto;display:block;}
.jpmap-svg .tile{transition:filter .12s;}
.jpmap-svg a.jtile{cursor:pointer;}
.jpmap-svg a.jtile:hover .tile{filter:brightness(1.08);stroke:#0f7c8a;stroke-width:2;}
.jlegend{display:flex;align-items:center;justify-content:center;gap:3px;margin:8px 0 0;}
.jlegend .lg-sw{width:22px;height:11px;display:inline-block;border-radius:2px;}
.jlegend .lg-cap{font-size:11px;color:#6b7785;margin:0 6px;}
.jpmap__note{font-size:12px;color:#6b7785;text-align:center;margin:8px 0 20px;}
.regions{display:grid;grid-template-columns:repeat(4,1fr);gap:14px 20px;margin:6px 0 22px;}
@media(max-width:780px){.regions{grid-template-columns:1fr 1fr;}}
.region__h{font-size:13px;font-weight:700;color:#0f7c8a;margin:0 0 6px;border-bottom:1px solid #e6ebef;padding-bottom:4px;}
.region__list a{display:block;padding:4px 0;font-size:13px;color:#3c4856;text-decoration:none;}
.region__list a:hover{color:#0f7c8a;}
.region__list .rc{float:right;color:#9aa7b2;font-size:11px;}
.ranks{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:8px 0 22px;}
@media(max-width:780px){.ranks{grid-template-columns:1fr 1fr;}}
.rankcard{display:block;border:1px solid #e6ebef;border-radius:16px;padding:15px 16px;background:#fff;}
.rankcard:hover{border-color:#0f7c8a;text-decoration:none;box-shadow:0 4px 14px rgba(15,124,138,.07);}
.rk__head{display:flex;justify-content:space-between;align-items:baseline;gap:8px;}
.rk__name{font-weight:700;font-size:14px;color:#1d2730;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.rk__score{font-family:Inter;font-weight:800;color:#0f7c8a;font-size:21px;white-space:nowrap;flex:none;} .rk__score small{font-size:11px;color:#9aa7b2;font-weight:500;}
.rk__stars{font-size:12.5px;letter-spacing:1.5px;margin-top:4px;} .rk__stars .s-on{color:#e8a33d;} .rk__stars .s-off{color:#d6dde2;}
.rk__stars .rk__lbl{color:#9aa7b2;font-size:10.5px;letter-spacing:0;margin-left:6px;}
.rk__meta{display:flex;align-items:center;gap:4px;font-size:11.5px;color:#7e8a95;margin-top:10px;}
.rk__pin{width:12px;height:12px;color:#b3bdc6;flex:none;}
.rk__axes{display:flex;gap:6px;flex-wrap:wrap;margin-top:9px;}
.rk__axes span{font-size:10.5px;color:#5e6b78;background:#f1f5f6;border-radius:6px;padding:3px 8px;}
.rk__axes b{color:#1d2730;font-family:Inter;font-weight:700;}
.srch{margin:14px 0;} .srch input{width:340px;max-width:70%;padding:10px 14px;border:1px solid #cfd8de;border-radius:22px;font-size:14px;}
.srch button{padding:10px 18px;border:0;border-radius:22px;background:#0f7c8a;color:#fff;font-weight:700;margin-left:6px;cursor:pointer;}
@media(max-width:640px){
  .wrap{padding:0 16px;}
  .nav .wrap{gap:14px;height:54px;}
  .nav .search{display:none;}
  .nav nav{margin-left:auto;} .nav nav a{white-space:nowrap;}
  .hero2{padding:42px 22px 34px;}
  .hero2 .kick{font-size:10px;letter-spacing:.16em;}
  .hero2 h1{font-size:20px;line-height:1.55;margin:11px auto 10px;} .hero2 h1 br{display:none;}
  .hero2 p{font-size:12.5px;line-height:1.85;max-width:none;}
  .hsearch{flex-direction:column;gap:10px;max-width:none;margin-top:20px;}
  .hsearch input{width:100%;padding:14px 18px;}
  .hsearch button{width:100%;padding:14px;}
  .sect-t{font-size:16px;}
  .ranks, .jobcards{
    display:flex; grid-template-columns:none;
    overflow-x:auto; -webkit-overflow-scrolling:touch;
    scroll-snap-type:x mandatory; scroll-padding-left:16px;
    gap:12px; margin:8px -16px 22px; padding:4px 16px 10px;
    scrollbar-width:none;
  }
  .ranks::-webkit-scrollbar, .jobcards::-webkit-scrollbar{display:none;}
  .ranks > .rankcard{flex:0 0 80%; scroll-snap-align:start;}
  .jobcards > .jobcard{flex:0 0 84%; scroll-snap-align:start;}
  .about{gap:8px;} .ab__h{width:auto;}
  .intro__in{padding:30px 22px 26px;} .intro__h{font-size:22px;}
  .intro__cols{grid-template-columns:1fr;margin:26px 0 22px;}
  .intro__cols .ic{padding:18px 0 0;border-left:0;border-top:1px solid #dde9ea;}
  .intro__cols .ic:first-child{padding-top:0;border-top:0;}
  .intro__foot a{margin-left:0;}
  .ft__cols{grid-template-columns:1fr 1fr;}
}
.intro{margin:40px 0 12px;}
.intro__in{background:linear-gradient(180deg,#f6fafa 0%,#eef6f6 100%);border-radius:22px;padding:48px 48px 40px;}
.intro__head{max-width:660px;}
.kick2{font-family:Inter;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:#0f7c8a;font-weight:700;display:flex;align-items:center;gap:11px;margin:0 0 16px;}
.kick2::before{content:"";width:28px;height:2px;background:#0f7c8a;display:inline-block;}
.intro__h{font-family:'Zen Maru Gothic',sans-serif;font-size:30px;line-height:1.42;letter-spacing:-.01em;color:#0e3f47;margin:0 0 16px;}
.intro__lead{font-size:14px;line-height:2.05;color:#465863;margin:0;max-width:620px;}
.intro__cols{display:grid;grid-template-columns:repeat(3,1fr);margin:38px 0 30px;}
.intro__cols .ic{padding:2px 30px;border-left:1px solid #d4e4e5;}
.intro__cols .ic:first-child{padding-left:0;border-left:0;}
.ic__n{font-family:Inter;font-size:30px;font-weight:800;letter-spacing:-.025em;line-height:1.05;color:#0f7c8a;}
.ic__n .ic__u{font-size:15px;font-weight:700;margin-left:3px;letter-spacing:0;}
.ic h3{font-family:'Zen Maru Gothic',sans-serif;font-size:15px;color:#12424a;margin:13px 0 9px;}
.ic p{font-size:12.5px;line-height:1.95;color:#56646f;margin:0;}
.intro__foot{display:flex;flex-wrap:wrap;align-items:center;gap:9px 13px;border-top:1px solid #dde9ea;padding-top:20px;}
.intro__foot .sb{font-size:12px;color:#3c6b70;} .intro__foot .sb b{font-family:Inter;color:#0f7c8a;font-size:13px;}
.intro__foot .sep{color:#c2d2d3;font-size:11px;}
.intro__foot a{color:#0f7c8a;font-weight:700;font-size:13px;text-decoration:none;}
.intro__foot a:hover{text-decoration:underline;}
.intro__note{font-size:11.5px;color:#9aa7b2;line-height:1.7;margin:13px 0 0;}
@media(max-width:820px){
  .intro__in{padding:30px 22px 26px;} .intro__h{font-size:22px;line-height:1.45;}
  .intro__cols{grid-template-columns:1fr !important;margin:24px 0 20px;}
  .intro__cols .ic{padding:18px 0 0;border-left:0;border-top:1px solid #dde9ea;}
  .intro__cols .ic:first-child{padding-top:0;border-top:0;}
  .intro__foot{gap:7px 11px;} .intro__foot a{margin-left:0;}
  .ft__cols{grid-template-columns:1fr 1fr !important;gap:18px 16px;}
}
.doc{max-width:780px;margin:6px auto 0;}
.doc h2{font-family:'Zen Maru Gothic',sans-serif;font-size:18px;margin:30px 0 10px;padding-bottom:6px;border-bottom:1px solid #e6ebef;color:#13474d;}
.doc h3{font-size:15px;margin:20px 0 6px;color:#1d2730;}
.doc p,.doc li{font-size:13.5px;line-height:1.95;color:#3c4856;}
.doc ul,.doc ol{padding-left:1.3em;margin:6px 0 12px;}
.doc dl{margin:8px 0 16px;} .doc dt{font-weight:700;color:#1d2730;margin-top:10px;font-size:13.5px;}
.doc dd{margin:2px 0 0;font-size:13.5px;color:#3c4856;}
.doc .updated{font-size:12px;color:#9aa7b2;margin:0 0 8px;}
.doc .draftnote{background:#fff7ed;border:1px solid #fde4c8;border-radius:10px;padding:11px 14px;font-size:12.5px;color:#8a5a1a;margin:14px 0;}
.faq dt{cursor:default;} .faq dt::before{content:"Q. ";color:#0f7c8a;font-weight:700;}
.faq dd::before{content:"A. ";color:#9aa7b2;font-weight:700;}
.ft{border-top:1px solid #e6ebef;margin-top:40px;background:#fbfcfc;}
.ft .wrap{padding:34px 24px 26px;}
.ft__cols{display:grid;grid-template-columns:repeat(4,1fr);gap:22px 18px;}
.ft__h{font-size:12.5px;font-weight:700;color:#1d2730;margin:0 0 10px;}
.ft__col ul{list-style:none;margin:0;padding:0;}
.ft__col li{margin:0 0 7px;}
.ft__col a{font-size:12.5px;color:#5e6b78;text-decoration:none;}
.ft__col a:hover{color:#0f7c8a;}
.ft__brand .ft__logo{font-family:'Zen Maru Gothic',sans-serif;font-weight:700;font-size:17px;color:#13474d;}
.ft__op{font-size:11.5px;color:#9aa7b2;line-height:1.8;margin:8px 0 0;}
.ft__op a{color:#5e6b78;}
.ft__note{font-size:11px;color:#9aa7b2;line-height:1.8;margin:22px 0 0;border-top:1px solid #eef2f4;padding-top:16px;}
.ft__note a{color:#5e6b78;}
.ft__cp{font-size:11px;color:#b3bdc6;margin:10px 0 0;}
.artlist{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin:18px 0 8px;}
@media(max-width:680px){.artlist{grid-template-columns:1fr;}}
.artcard{display:block;border:1px solid #e6ebef;border-radius:14px;padding:18px 20px;background:#fff;text-decoration:none;transition:box-shadow .12s,border-color .12s;}
.artcard:hover{border-color:#0f7c8a;box-shadow:0 6px 20px rgba(15,124,138,.08);}
.art__date{font-family:Inter;font-size:11px;color:#9aa7b2;}
.art__ttl{font-family:'Zen Maru Gothic',sans-serif;font-size:15.5px;font-weight:700;color:#13474d;margin:6px 0 7px;line-height:1.5;}
.art__ex{font-size:12.5px;color:#5e6b78;line-height:1.8;}
.a-img{max-width:100%;height:auto;border-radius:8px;border:1px solid #e6ebef;margin:10px 0;}
.toc{background:#f6f9fa;border:1px solid #e6ebef;border-radius:10px;padding:14px 18px;margin:18px 0;font-size:14px;}
.toc__t{font-weight:700;color:#1A2A36;margin:0 0 8px;}
.toc ul{margin:0;padding-left:18px;line-height:1.95;list-style:none;}
.toc a{color:#0f7c8a;text-decoration:none;}
.toc li.sub{margin-left:16px;font-size:13px;}
.author-bio{margin-top:34px;padding:16px 18px;background:#f6f9fa;border:1px solid #e6ebef;border-radius:10px;font-size:13px;color:#4a5a66;line-height:1.85;}
.mb2{margin-bottom:2px;}
.mt24{margin-top:24px;}
.nav-search{margin-left:auto;border:0;padding:0;}
.nav-search input{border:1px solid #cfd8de;border-radius:20px;padding:7px 14px;font-size:12.5px;}
.ft__dot{color:#0f7c8a;}
