/*
Theme Name: 日本在宅介護支援住宅協会
Theme URI: http://www.zaitaku-shien.org/
Author: Creative Pocket
Author URI: https://www.creativepocket.jp/
Description: 一般社団法人 日本在宅介護支援住宅協会 公式サイト（デザインB）。コーポレートカラーのグリーンを基調とした、信頼感と温かみのあるデザイン。
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: zaitaku-b
*/

:root{--green:#34A853;--green-d:#2C8C45;--green-l:#46b863;--orange:#F0913A;--ink:#333;--soft:#777;--line:#e6e6e6;}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:"Hiragino Kaku Gothic ProN","Hiragino Sans","Noto Sans JP",sans-serif;color:var(--ink);line-height:1.8;font-size:14px;background:#fff;-webkit-text-size-adjust:100%}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:1120px;margin:0 auto;padding:0 26px}
.ph{background:linear-gradient(135deg,#d7e2cf,#c4d3b8);position:relative;display:flex;align-items:center;justify-content:center}
.ph::after{content:"イメージ写真";position:absolute;color:rgba(70,100,48,.5);font-size:11px;letter-spacing:.08em}
.img{background-size:cover;background-position:center;background-repeat:no-repeat}
/* header */
.head{display:flex;align-items:center;justify-content:space-between;height:74px;border-bottom:1px solid var(--line)}
.brand{display:flex;align-items:center;gap:11px}
.brand img{height:48px;width:auto}
.brand b{display:block;font-size:10px;color:#555;font-weight:600}
.brand strong{display:block;font-size:16px;color:#2f2f2f}
.gnav{display:flex;align-items:center;gap:24px}
.gnav a{font-size:13.5px;font-weight:600}
.gnav a:hover{color:var(--green)}
.login{background:var(--green);color:#fff!important;padding:8px 18px;border-radius:4px;font-size:12.5px;display:inline-flex;align-items:center;gap:6px}
.navtoggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.navtoggle span{display:block;width:26px;height:2.5px;background:#444;border-radius:2px;transition:.25s}
/* hero */
.hero{position:relative;height:430px;overflow:hidden}
.hero .bg{position:absolute;inset:0;background-size:cover;background-position:center 28%}
.hero .ov{position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,255,255,.85) 0%,rgba(255,255,255,.5) 38%,rgba(255,255,255,.05) 70%)}
.hero .inner{position:relative;z-index:2;max-width:1120px;margin:0 auto;padding:0 26px;height:100%;display:flex;align-items:center;justify-content:space-between}
.hero h1{font-size:38px;font-weight:900;line-height:1.5;color:#2b2b2b;text-shadow:0 1px 8px rgba(255,255,255,.5)}
.hero .nbox{background:#fff;border-radius:4px;padding:22px 26px;width:320px;box-shadow:0 6px 22px rgba(0,0,0,.12);border:1px solid rgba(0,0,0,.04)}
.hero .nbox h3{font-size:15px;font-weight:800;margin-bottom:14px}
.hero .nbox .it{padding:11px 0;border-bottom:1px dashed var(--line)}
.hero .nbox .it:last-child{border:0}
.hero .nbox .d{font-size:11px;color:#999;font-family:Arial}
.hero .nbox .t{font-size:13px;font-weight:600;margin-top:2px}
/* quick cards overlap */
.quick{max-width:1120px;margin:-58px auto 60px;padding:0 26px;position:relative;z-index:5;display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.qc{background:#fff;border-radius:4px;padding:24px 22px;border:1px solid var(--line);box-shadow:0 4px 14px rgba(0,0,0,.05)}
.qc .ic{width:48px;height:48px;border-radius:4px;background:rgba(52,168,83,.12);display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.qc h3{font-size:16px;font-weight:800;margin-bottom:7px}
.qc p{color:#777;font-size:12.5px;margin-bottom:12px;min-height:54px}
.qc .more{color:var(--green-d);font-weight:700;font-size:13px}
/* section */
.sec{padding:56px 0}
.sec.gray{background:#f3f5f4}
.sec-h{text-align:center;margin-bottom:38px}
.sec-h .en{font-family:Arial;font-size:22px;font-weight:800;letter-spacing:.12em;color:#2b2b2b}
.sec-h::after{content:"";display:block;width:40px;height:3px;background:var(--green);margin:10px auto 0;border-radius:2px}
/* news */
.news-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.nc{background:#fff;border-radius:4px;overflow:hidden;border:1px solid var(--line);box-shadow:0 3px 10px rgba(0,0,0,.04)}
.nc .th{height:120px}
.nc .body{padding:14px 16px}
.nc .badge{display:inline-block;font-size:10px;color:#fff;padding:2px 10px;border-radius:4px;margin-right:7px}
.b-info{background:var(--orange)}.b-sem{background:var(--green)}
.nc .date{font-size:11px;color:#999;font-family:Arial}
.nc h4{font-size:13px;font-weight:700;margin-top:8px;line-height:1.55}
/* seminar */
.sem-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:40px;align-items:start}
.sem-l .lbl,.sem-r .lbl{font-weight:800;font-size:15px;margin-bottom:16px}
.sem-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.scard{border:1px solid var(--line);border-radius:4px;padding:20px 16px;text-align:center}
.scard b{display:block;font-family:Arial;font-size:30px;font-weight:800;color:var(--green-d);line-height:1.1}
.scard .sub{font-size:10px;color:#999;margin-bottom:8px}
.scard h5{font-size:12.5px;font-weight:700;line-height:1.5;min-height:54px}
.scard a{display:inline-block;background:var(--green);color:#fff;padding:7px 16px;border-radius:4px;font-size:12px;font-weight:700;margin-top:6px}
.sem-r .row{display:flex;gap:16px;align-items:center;padding:14px 4px;border-bottom:1px solid var(--line)}
.sem-r .row b{font-family:Arial;font-size:20px;font-weight:800;color:var(--green-d);width:54px;flex:none;text-align:center}
.sem-r .row .d2{font-size:10px;color:#aaa}
.sem-r h5{font-size:12.5px;font-weight:700}
.sem-r .arc{font-size:10px;color:var(--green);font-weight:700}
/* join */
.join-sec{background:linear-gradient(120deg,var(--green-d),var(--green-l));padding:54px 0;color:#fff;text-align:center}
.join-sec h2{font-size:24px;font-weight:900;margin-bottom:8px}
.join-sec .lead{font-size:13.5px;opacity:.92;margin-bottom:30px}
.join3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:840px;margin:0 auto 30px;padding:0 26px}
.jc{background:#fff;color:#333;border-radius:4px;padding:22px;position:relative;overflow:hidden;text-align:left}
.jc::before{content:"";position:absolute;top:0;right:0;border-width:0 36px 36px 0;border-style:solid;border-color:transparent var(--orange) transparent transparent}
.jc .ic{width:42px;height:42px;border-radius:4px;background:rgba(52,168,83,.12);display:flex;align-items:center;justify-content:center;margin-bottom:10px}
.jc b{display:block;font-size:15px;margin-bottom:5px}
.jc p{font-size:12px;color:#777}
.join-btn{background:var(--orange);color:#fff;padding:15px 44px;border-radius:4px;font-weight:800;font-size:15px;display:inline-block;box-shadow:0 8px 18px rgba(0,0,0,.15)}
/* footer */
.site-footer{background:#3a3a3a;color:#cfcfcf;padding:46px 0 0}
.fbrand{text-align:center;margin-bottom:34px}
.fbrand img{height:46px;width:auto;margin:0 auto 8px;background:#fff;border-radius:4px;padding:6px}
.fbrand b{font-size:14px;color:#fff}
.fmap{display:grid;grid-template-columns:repeat(5,1fr);gap:22px;padding-bottom:34px;border-bottom:1px solid rgba(255,255,255,.14)}
.fmap h4{font-size:13px;font-weight:800;margin-bottom:14px;color:#fff}
.fmap a{display:flex;align-items:center;gap:7px;font-size:12px;color:#bdbdbd;margin-bottom:9px}
.fmap a:hover{color:#fff}
.fbot{display:flex;justify-content:space-between;align-items:center;padding:16px 0;font-size:11px;color:#9a9a9a}
.fbot .l a{margin-right:18px}
svg{display:block}

/* ===================== 下層ページ共通 ===================== */
.ph{background:linear-gradient(135deg,#dbe8d3,#c7d9ba);min-height:120px}
.page-hero{position:relative;background:linear-gradient(120deg,var(--green-d),var(--green-l));color:#fff;padding:54px 0 46px;overflow:hidden}
.page-hero::after{content:"";position:absolute;right:-80px;top:-80px;width:280px;height:280px;border-radius:50%;background:rgba(255,255,255,.10)}
.page-hero .inner{max-width:1120px;margin:0 auto;padding:0 26px;position:relative;z-index:2}
.page-hero .en{font-family:Arial;font-size:12px;letter-spacing:.22em;font-weight:700;opacity:.9;display:block;margin-bottom:8px}
.page-hero h1{font-size:30px;font-weight:900;letter-spacing:.02em}
.crumb{background:#f3f5f4;font-size:12px;color:#777}
.crumb .inner{max-width:1120px;margin:0 auto;padding:11px 26px}
.crumb a:hover{color:var(--green-d)}
.crumb span{color:#aaa;margin:0 8px}
.page-main{padding:60px 0}
.container{max-width:1000px;margin:0 auto;padding:0 26px}
.container.wide{max-width:1120px}
.block{margin-bottom:64px}
.block:last-child{margin-bottom:0}
.lead-txt{font-size:15px;color:#555;max-width:760px;margin:0 auto 6px;text-align:center}
.sect-title{text-align:center;margin-bottom:34px}
.sect-title .en{font-family:Arial;font-size:12px;letter-spacing:.2em;color:var(--green);font-weight:800;display:block;margin-bottom:6px}
.sect-title h2{font-size:25px;font-weight:900;letter-spacing:.03em}
.sect-title.left{text-align:left}
.sect-title.left h2::after{content:"";display:block;width:40px;height:3px;background:var(--green);border-radius:2px;margin-top:12px}
.prose p{margin-bottom:16px;font-size:14.5px;color:#444}
.prose strong{color:var(--green-d)}
.sign{text-align:right;font-size:14px;margin-top:18px}
.sign b{font-size:18px;font-weight:800}
.sign small{display:block;color:#888;font-size:12px}
/* info table */
.info-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line);border-radius:4px;overflow:hidden}
.info-table th,.info-table td{text-align:left;padding:16px 22px;border-bottom:1px solid var(--line);font-size:14px;vertical-align:top}
.info-table tr:last-child th,.info-table tr:last-child td{border-bottom:0}
.info-table th{width:200px;background:#f3f7f3;font-weight:800;color:#3a3a3a}
/* feature 3 grid (concept) */
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.fcard{background:#fff;border:1px solid var(--line);border-radius:4px;padding:26px 22px;border-top:4px solid var(--green)}
.fcard:nth-child(1){border-top-color:var(--orange)}
.fcard:nth-child(3){border-top-color:#5a8fc0}
.fcard .ic{width:54px;height:54px;border-radius:4px;background:rgba(52,168,83,.12);display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.fcard:nth-child(1) .ic{background:rgba(240,145,58,.14)}
.fcard:nth-child(3) .ic{background:rgba(90,143,192,.12)}
.fcard .tag{font-family:Arial;font-size:10px;letter-spacing:.12em;font-weight:700;color:var(--green-d);display:block;margin-bottom:4px}
.fcard h3{font-size:17px;font-weight:900;margin-bottom:8px}
.fcard p{font-size:13px;color:#666}
/* stats strip */
.stat-strip{display:grid;grid-template-columns:repeat(4,1fr);background:var(--green);color:#fff;border-radius:4px;overflow:hidden}
.stat-strip .s{padding:26px 14px;text-align:center}
.stat-strip .s+.s{border-left:1px solid rgba(255,255,255,.25)}
.stat-strip b{display:block;font-family:Arial;font-size:34px;font-weight:800;line-height:1.1}
.stat-strip b small{font-size:14px;margin-left:3px}
.stat-strip span{font-size:12px;opacity:.92}
/* timeline */
.tl{border-left:2px solid var(--line);margin-left:8px;padding-left:26px}
.tl .row{position:relative;padding-bottom:22px}
.tl .row::before{content:"";position:absolute;left:-34px;top:4px;width:12px;height:12px;border-radius:50%;background:var(--green);border:3px solid #fff;box-shadow:0 0 0 1px var(--green)}
.tl .yr{font-family:Arial;font-weight:800;color:var(--green-d);font-size:14px}
.tl p{font-size:13.5px;color:#555}
/* news list (page) */
.post-list{background:#fff;border:1px solid var(--line);border-radius:4px;overflow:hidden}
.post-list a{display:flex;gap:18px;align-items:center;padding:18px 22px;border-bottom:1px solid var(--line)}
.post-list a:last-child{border-bottom:0}
.post-list a:hover{background:#f7faf7}
.post-list .date{font-family:Arial;font-size:12.5px;color:#999;white-space:nowrap}
.post-list .badge{font-size:10px;color:#fff;padding:3px 12px;border-radius:4px;white-space:nowrap;flex:none}
.post-list .ttl{font-size:14px;font-weight:600}
.bdg-info{background:var(--orange)}.bdg-sem{background:var(--green)}.bdg-press{background:#5a8fc0}
.pager{display:flex;justify-content:center;gap:8px;margin-top:30px}
.pager a,.pager span{min-width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:4px;font-size:13px;font-weight:700}
.pager .cur{background:var(--green);color:#fff;border-color:var(--green)}
/* seminar feature */
.sem-feature{background:linear-gradient(110deg,var(--green-d),var(--green-l));color:#fff;border-radius:4px;padding:34px 38px;display:flex;gap:28px;align-items:center;justify-content:space-between;flex-wrap:wrap;box-shadow:0 6px 20px rgba(52,168,83,.20);position:relative;overflow:hidden}
.sem-feature::after{content:"";position:absolute;right:-50px;top:-50px;width:220px;height:220px;border-radius:50%;background:rgba(255,255,255,.10)}
.sem-feature .lbl{display:inline-block;background:#fff;color:var(--green-d);font-weight:800;font-size:11px;padding:5px 14px;border-radius:4px;margin-bottom:12px}
.sem-feature h3{font-size:22px;font-weight:900;line-height:1.45;position:relative;z-index:2}
.sem-feature .meta{margin-top:14px;display:flex;gap:22px;flex-wrap:wrap;font-size:13.5px;position:relative;z-index:2}
.sem-feature .meta span{display:flex;align-items:center;gap:7px}
.sem-feature .ev-btn{background:var(--orange);color:#fff;padding:14px 26px;border-radius:4px;font-weight:800;white-space:nowrap;position:relative;z-index:2}
/* generic cards row */
.cardrow{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.tcard{background:#fff;border:1px solid var(--line);border-radius:4px;overflow:hidden;transition:.2s}
.tcard:hover{box-shadow:0 12px 26px rgba(0,0,0,.08);transform:translateY(-3px)}
.tcard .th{height:130px;position:relative}
.tcard .state{position:absolute;top:10px;left:10px;background:#fff;font-size:10px;font-weight:700;padding:3px 11px;border-radius:4px;color:var(--green-d)}
.tcard .body{padding:16px 18px}
.tcard .d{font-family:Arial;font-size:12px;color:#999}
.tcard h4{font-size:14.5px;font-weight:800;margin:5px 0 7px;line-height:1.5}
.tcard p{font-size:12.5px;color:#6d6d6d}
/* steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.step{text-align:center;padding:0 14px;position:relative}
.step+.step::before{content:"";position:absolute;left:-12px;top:30px;width:24px;height:2px;background:var(--line)}
.step .circle{width:62px;height:62px;border-radius:50%;background:#f3f7f3;border:2px solid var(--green);color:var(--green-d);font-family:Arial;font-weight:800;font-size:22px;display:flex;align-items:center;justify-content:center;margin:0 auto 12px}
.step b{display:block;font-size:14px;font-weight:800}
.step span{font-size:12px;color:#999}
/* benefit list */
.benefits{display:grid;gap:14px}
.benefit{display:flex;gap:16px;background:#fff;border:1px solid var(--line);border-radius:4px;padding:18px 22px}
.benefit .bi{width:46px;height:46px;border-radius:4px;background:rgba(52,168,83,.12);display:flex;align-items:center;justify-content:center;flex:none}
.benefit b{display:block;font-size:14.5px}
.benefit span{font-size:13px;color:#6d6d6d}
/* buttons */
.btn{display:inline-flex;align-items:center;gap:9px;padding:14px 30px;border-radius:4px;font-weight:800;font-size:14px;cursor:pointer;border:0}
.btn-o{background:var(--orange);color:#fff;box-shadow:0 3px 10px rgba(240,145,58,.22)}
.btn-g{background:var(--green);color:#fff}
.btn-line{background:#fff;color:var(--green-d);border:2px solid var(--green)}
.btn-center{text-align:center;margin-top:34px}
/* form */
.form{background:#fff;border:1px solid var(--line);border-radius:4px;padding:34px 32px;max-width:760px;margin:0 auto}
.frow{margin-bottom:20px}
.frow label{display:block;font-size:13.5px;font-weight:700;margin-bottom:7px}
.frow label .req{background:var(--orange);color:#fff;font-size:10px;padding:2px 8px;border-radius:4px;margin-left:8px;vertical-align:middle}
.frow input,.frow select,.frow textarea{width:100%;border:1px solid #d8d8d8;border-radius:4px;padding:12px 14px;font-size:14px;font-family:inherit;color:#333}
.frow textarea{min-height:140px;resize:vertical}
.frow input:focus,.frow select:focus,.frow textarea:focus{outline:0;border-color:var(--green);box-shadow:0 0 0 3px rgba(52,168,83,.12)}
.form-note{font-size:12px;color:#999;text-align:center;margin-top:14px}
.frow .err{color:#d9480f;font-size:12px;margin-top:6px;font-weight:600}
.form-steps{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:32px}
.form-steps span{font-size:12.5px;font-weight:700;color:#aaa;padding:7px 16px;border:1px solid var(--line);border-radius:4px;background:#fff;white-space:nowrap}
.form-steps span.on{background:var(--green);color:#fff;border-color:var(--green)}
.form-steps span.done{color:var(--green-d);border-color:var(--green);background:#f0f8f0}
.form-steps i{width:22px;height:2px;background:var(--line);display:block;flex:none}
.notice{background:#eef7ee;border:1px solid var(--green);color:var(--green-d);border-radius:4px;padding:16px 20px;font-size:13.5px;margin-bottom:24px}
/* member login */
.login-box{max-width:420px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:4px;padding:34px 30px;text-align:center}
.login-box .ic{width:64px;height:64px;border-radius:50%;background:rgba(52,168,83,.12);display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.login-box h2{font-size:19px;font-weight:900;margin-bottom:8px}
.login-box p{font-size:13px;color:#777;margin-bottom:22px}
.login-box .frow{text-align:left}
/* cta band */
.cta-band{background:linear-gradient(120deg,#eef6e9,#e3f1dd);padding:50px 0;text-align:center}
.cta-band h2{font-size:22px;font-weight:900;margin-bottom:8px}
.cta-band p{font-size:13.5px;color:#5d5d5d;margin-bottom:24px}
.cta-band .btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

@media(max-width:880px){
  .page-hero h1{font-size:24px}
  .grid3,.cardrow{grid-template-columns:1fr}
  .stat-strip{grid-template-columns:repeat(2,1fr)}
  .stat-strip .s:nth-child(3){border-left:0}
  .stat-strip .s:nth-child(3),.stat-strip .s:nth-child(4){border-top:1px solid rgba(255,255,255,.25)}
  .steps{grid-template-columns:repeat(2,1fr);gap:24px 0}
  .step:nth-child(3)::before{display:none}
  .info-table th{width:120px;padding:14px}
  .info-table td{padding:14px}
  .sem-feature{padding:26px 22px}
}

/* ===== responsive ===== */
@media(max-width:1000px){
  .quick{grid-template-columns:repeat(2,1fr)}
  .news-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:880px){
  .navtoggle{display:flex}
  .gnav{position:absolute;top:74px;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;background:#fff;box-shadow:0 12px 24px rgba(0,0,0,.12);padding:8px 0;max-height:0;overflow:hidden;transition:max-height .3s ease;z-index:30}
  .gnav.open{max-height:480px}
  .gnav a{padding:13px 26px;border-bottom:1px solid var(--line);font-size:14px}
  .gnav .login{margin:10px 26px;justify-content:center}
  .head{position:relative}
  .hero{height:auto}
  .hero .inner{flex-direction:column;align-items:flex-start;gap:24px;padding:38px 26px}
  .hero .ov{background:linear-gradient(180deg,rgba(255,255,255,.9),rgba(255,255,255,.7))}
  .hero h1{font-size:30px}
  .hero .nbox{width:100%}
  .quick{margin-top:30px}
  .sem-grid{grid-template-columns:1fr;gap:34px}
  .join3{grid-template-columns:1fr;max-width:420px}
  .fmap{grid-template-columns:repeat(2,1fr);gap:20px 22px}
}
@media(max-width:560px){
  .quick{grid-template-columns:1fr}
  .news-grid{grid-template-columns:1fr}
  .sem-cards{grid-template-columns:1fr}
  .hero h1{font-size:26px}
  .fmap{grid-template-columns:1fr}
  .fbot{flex-direction:column;gap:10px;text-align:center}
}
