/* ── Design Tokens ── */
:root{
  --p:#237665;--pl:#36907E;--pd:#165447;--ph:#1D6456;
  --pb:#EAF5F2;--pb2:#D4EBE6;
  --a:#DC7035;--al:#E88A58;--ad:#C05E25;--ab:#FDF0E8;
  --bg:#F6F3ED;--s0:#FFFFFF;--s1:#F0EDE7;
  --tx:#1C2B26;--t2:#4A6259;--t3:#7A9088;--t4:#B0C4BF;
  --tl:#4A6259;--g8:#1C2B26;--g4:#B0C4BF;
  --g0:#F8F6F3;--g1:#ECEAE6;--g2:#DDD9D3;--cr:#F6F3ED;
  --bd:#DDD9D3;--bdl:#ECEAE6;
  --sh1:0 1px 2px rgba(28,43,38,.06);
  --sh2:0 1px 4px rgba(28,43,38,.07),0 4px 16px rgba(28,43,38,.05);
  --sh3:0 2px 8px rgba(28,43,38,.08),0 8px 32px rgba(28,43,38,.07);
  --sh4:0 4px 16px rgba(28,43,38,.1),0 16px 48px rgba(28,43,38,.09);
  --tr:all .22s cubic-bezier(.4,0,.2,1);
  --r4:4px;--r8:8px;--r12:12px;--r16:16px;--r24:24px;--rf:9999px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body.tunagu-portal{background:var(--bg);color:var(--tx);font-family:'Noto Sans JP',-apple-system,'Hiragino Kaku Gothic ProN',Meiryo,sans-serif;font-size:15px;line-height:1.75;font-weight:400}
body.tunagu-portal a{color:var(--p);text-decoration:none;transition:var(--tr)}
body.tunagu-portal a:hover{color:var(--pl)}
body.tunagu-portal img{max-width:100%;height:auto;display:block}
body.tunagu-portal button,body.tunagu-portal select,body.tunagu-portal input,body.tunagu-portal textarea{font-family:inherit}
body.tunagu-portal h1{font-size:clamp(1.7rem,4vw,2.6rem);font-weight:800;line-height:1.25;letter-spacing:-.02em;color:var(--tx)}
body.tunagu-portal h2{font-size:clamp(1.3rem,3vw,1.85rem);font-weight:700;line-height:1.35;letter-spacing:-.01em;color:var(--tx)}
body.tunagu-portal h3{font-size:1.2rem;font-weight:700;line-height:1.45;color:var(--pd)}
body.tunagu-portal h4{font-size:1rem;font-weight:700;color:var(--tx)}
body.tunagu-portal p{margin-bottom:1em}
.con{max-width:1200px;margin:0 auto;padding:0 24px}
.sec{padding:72px 0}
.sec-sm{padding:48px 0}
.sec-white{background:var(--s0)}
.sec-bg{background:var(--s0)}
.sec-gray{background:var(--s1)}
.sec-hd{text-align:center;margin-bottom:52px}
.sec-hd::before{content:'';display:block;width:40px;height:3px;background:linear-gradient(90deg,var(--p),var(--pl));border-radius:2px;margin:0 auto 18px}
.sec-hd h2{margin-bottom:10px}
.sec-hd p{color:var(--t2);max-width:480px;margin:0 auto}
.site-header{position:sticky;top:0;z-index:200;background:rgba(255,255,255,.96);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--bdl);box-shadow:var(--sh1)}
.hdr-inner{max-width:1200px;margin:0 auto;padding:0 24px;height:68px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none}
.logo-icon{width:34px;height:34px;background:linear-gradient(135deg,var(--pd),var(--p));border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0;color:#fff}
.logo-text{display:flex;flex-direction:column;gap:1px}
.logo-m{font-size:1.08rem;font-weight:900;color:var(--pd);letter-spacing:.03em;line-height:1.2}
.logo-s{font-size:.58rem;color:var(--t3);letter-spacing:.07em;font-weight:500}
.hdr-nav{display:flex;align-items:center;gap:2px;flex:1;margin-left:16px}
.nav-a{font-size:.8rem;font-weight:600;color:var(--t2);padding:7px 10px;border-radius:var(--r8);white-space:nowrap;transition:var(--tr)}
.nav-a:hover{color:var(--p);background:var(--pb)}
.btn-cta{background:var(--a);color:#fff;padding:9px 20px;border-radius:var(--rf);font-size:.8rem;font-weight:700;white-space:nowrap;transition:var(--tr);box-shadow:0 2px 8px rgba(220,112,53,.25);margin-left:6px}
.btn-cta:hover{background:var(--al);color:#fff;transform:translateY(-1px)}
.ham{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;border-radius:8px}
.ham span{display:block;width:20px;height:2px;background:var(--tx);border-radius:2px}
.mob-nav{display:none;position:fixed;top:68px;left:0;right:0;bottom:0;background:var(--s0);z-index:199;padding:20px 20px 40px;flex-direction:column;gap:2px;overflow-y:auto}
.mob-nav.open{display:flex}
.mob-a{padding:13px 16px;font-size:.93rem;font-weight:600;color:var(--tx);border-radius:var(--r8)}
.mob-a:hover{background:var(--pb);color:var(--p)}
@media(max-width:860px){.hdr-nav{display:none}.ham{display:flex}}
.bc{background:var(--s0);border-bottom:1px solid var(--bdl);padding:10px 0}
.bc-in{max-width:1200px;margin:0 auto;padding:0 24px;display:flex;align-items:center;gap:6px;font-size:.73rem;color:var(--t3);flex-wrap:wrap}
.bc-a{color:var(--p);font-weight:500}
.bc-sep{color:var(--t4)}
.hero{background:linear-gradient(145deg,rgba(22,84,71,.88) 0%,rgba(30,110,94,.82) 40%,rgba(35,118,101,.78) 70%,rgba(45,155,136,.72) 100%),url('https://goodbyinc.com/wp-content/uploads/2026/04/IMG_1727.jpg') center/cover no-repeat;padding:96px 24px 88px;color:#fff;position:relative;overflow:hidden;text-align:center}
.hero::before{content:'';position:absolute;inset:0;opacity:.03;background-image:radial-gradient(circle,#fff 1px,transparent 1px);background-size:28px 28px;pointer-events:none}
.hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:80px;background:linear-gradient(to bottom,transparent,rgba(22,84,71,.3));pointer-events:none}
.hero .con{position:relative;z-index:1;max-width:760px}
.hero h1{color:#fff;margin-bottom:16px;text-shadow:0 2px 16px rgba(0,0,0,.35)}
.hero-sub{font-size:.98rem;opacity:1;color:rgba(255,255,255,.95);margin-bottom:8px;max-width:520px;margin-left:auto;margin-right:auto;line-height:1.8;text-shadow:0 1px 6px rgba(0,0,0,.22)}
.hero-tags{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin:20px auto 32px}
.hero-tag{background:rgba(255,255,255,.13);color:rgba(255,255,255,.94);padding:5px 13px;border-radius:var(--rf);font-size:.73rem;font-weight:600;border:1px solid rgba(255,255,255,.22)}
.search-box{background:#fff;border-radius:var(--r16);padding:22px 26px;max-width:700px;margin:0 auto;box-shadow:0 8px 40px rgba(0,0,0,.18)}
.search-box h3{color:var(--pd);font-size:1rem;margin-bottom:16px;text-align:left}
.search-row{display:flex;gap:8px;flex-wrap:wrap}
.s-sel{flex:1;min-width:155px;padding:11px 32px 11px 13px;border:1.5px solid var(--bdl);border-radius:var(--r8);font-size:.86rem;color:var(--tx);background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='6' viewBox='0 0 11 6'%3E%3Cpath d='M1 1l4.5 4 4.5-4' stroke='%237A9088' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat right 11px center;appearance:none;cursor:pointer}
.s-sel:focus{outline:none;border-color:var(--p);box-shadow:0 0 0 3px rgba(35,118,101,.1)}
.s-btn{background:var(--p);color:#fff;border:none;padding:11px 22px;border-radius:var(--r8);font-size:.86rem;font-weight:700;cursor:pointer;white-space:nowrap}
.s-btn:hover{background:var(--ph)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:11px 24px;border-radius:var(--rf);font-size:.86rem;font-weight:700;transition:var(--tr);cursor:pointer;border:none;white-space:nowrap}
.btn-p{background:var(--a);color:#fff;box-shadow:0 2px 8px rgba(220,112,53,.22)}
.btn-p:hover{background:var(--al);color:#fff;transform:translateY(-2px)}
.btn-s{background:var(--s0);color:var(--p);border:1.5px solid var(--p)}
.btn-s:hover{background:var(--pb)}
.btn-w{background:rgba(255,255,255,.95);color:var(--pd);font-weight:700}
.btn-w:hover{background:#fff;transform:translateY(-1px)}
.btn-lg{padding:14px 32px;font-size:.95rem}
.btn-sm{padding:7px 16px;font-size:.76rem}
.cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.worry-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:12px}
.worry-card{background:var(--s0);border:1.5px solid var(--bdl);border-radius:var(--r12);padding:17px 20px;display:flex;align-items:flex-start;gap:13px;text-decoration:none;color:var(--tx);transition:var(--tr);box-shadow:var(--sh1)}
.worry-card:hover{border-color:var(--p);transform:translateY(-3px);box-shadow:var(--sh3);color:var(--tx)}
.worry-ic{min-width:38px;height:38px;background:linear-gradient(135deg,var(--pb),var(--pb2));border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:1.15rem;flex-shrink:0}
.worry-txt{font-size:.83rem;font-weight:600;color:var(--tx);line-height:1.55}
.feat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(275px,1fr));gap:22px}
.feat-card{background:var(--s0);border-radius:var(--r16);padding:34px 26px;border:1px solid var(--bdl);box-shadow:var(--sh2);position:relative;overflow:hidden;transition:var(--tr);text-align:center}
.feat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--p),var(--pl))}
.feat-card:hover{transform:translateY(-5px);box-shadow:var(--sh4)}
.feat-icon{font-size:2.5rem;display:block;margin-bottom:14px}
.feat-title{font-size:1.08rem;font-weight:700;color:var(--pd);margin-bottom:10px;line-height:1.4}
.feat-desc{font-size:.84rem;color:var(--t2);line-height:1.8}
.area-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(175px,1fr));gap:12px}
.area-card{background:var(--s0);border:1.5px solid var(--bdl);border-radius:var(--r12);padding:22px 14px;text-align:center;text-decoration:none;color:var(--tx);transition:var(--tr);display:block;box-shadow:var(--sh1)}
.area-card:hover{border-color:var(--p);background:var(--pb);transform:translateY(-3px);box-shadow:var(--sh3)}
.area-card.hot{border-color:var(--p);background:linear-gradient(145deg,var(--s0),var(--pb))}
.area-badge{display:inline-block;background:var(--a);color:#fff;font-size:.63rem;font-weight:700;padding:2px 9px;border-radius:var(--rf);margin-bottom:9px}
.area-name{font-size:1.08rem;font-weight:700;color:var(--pd);margin-bottom:4px}
.area-cnt{font-size:.73rem;color:var(--t3)}
.cond-wrap{display:flex;flex-wrap:wrap;gap:10px}
.cond-tag{display:inline-flex;align-items:center;gap:6px;background:var(--s0);border:1.5px solid var(--bd);color:var(--t2);padding:9px 18px;border-radius:var(--rf);font-size:.84rem;font-weight:600;transition:var(--tr);text-decoration:none;box-shadow:var(--sh1)}
.cond-tag:hover{background:var(--p);border-color:var(--p);color:#fff;transform:translateY(-2px)}
.fac-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:22px}
.fac-card{background:var(--s0);border-radius:var(--r16);overflow:hidden;border:1px solid var(--bdl);box-shadow:var(--sh2);text-decoration:none;color:var(--tx);display:block;transition:var(--tr)}
.fac-card:hover{transform:translateY(-6px);box-shadow:var(--sh4);border-color:transparent}
.fac-img{height:175px;display:flex;align-items:center;justify-content:center;font-size:2.8rem;background:linear-gradient(145deg,var(--pb) 0%,var(--pb2) 100%);overflow:hidden;position:relative}
.fac-img img{width:100%;height:175px;object-fit:cover}
.fac-body{padding:18px 20px}
.fac-type{font-size:.68rem;font-weight:700;color:var(--p);background:var(--pb);padding:3px 10px;border-radius:var(--rf);display:inline-block;margin-bottom:9px;letter-spacing:.04em}
.fac-name{font-size:1.02rem;font-weight:700;color:var(--pd);margin-bottom:5px;line-height:1.4}
.fac-loc{font-size:.77rem;color:var(--t3);margin-bottom:11px;display:flex;align-items:center;gap:4px}
.fac-fee{font-size:.82rem;margin-bottom:13px;color:var(--t2)}
.fac-fee strong{font-size:1.12rem;color:var(--a);font-weight:800}
.badges{display:flex;flex-wrap:wrap;gap:5px}
.badge{font-size:.67rem;padding:3px 9px;border-radius:var(--rf);font-weight:600}
.badge-y{background:var(--pb);color:var(--p);border:1px solid var(--pb2)}
.case-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(295px,1fr));gap:22px}
.case-card{background:var(--s0);border-radius:var(--r16);padding:26px 22px 26px 26px;box-shadow:var(--sh2);display:block;text-decoration:none;color:var(--tx);transition:var(--tr);border:1px solid var(--bdl);border-left:4px solid var(--a)}
.case-card:hover{transform:translateY(-5px);box-shadow:var(--sh4);border-color:var(--a)}
.case-cat{font-size:.68rem;font-weight:700;color:var(--a);background:var(--ab);padding:3px 9px;border-radius:var(--rf);display:inline-block;margin-bottom:11px}
.case-title{font-size:.96rem;font-weight:700;color:var(--pd);line-height:1.55;margin-bottom:7px}
.case-sub{font-size:.81rem;color:var(--t2);line-height:1.7}
.col-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:22px}
.col-card{background:var(--s0);border-radius:var(--r16);overflow:hidden;border:1px solid var(--bdl);box-shadow:var(--sh2);display:block;text-decoration:none;color:var(--tx);transition:var(--tr)}
.col-card:hover{transform:translateY(-5px);box-shadow:var(--sh4);border-color:transparent}
.col-img{height:148px;background:linear-gradient(145deg,var(--pb),var(--pb2));display:flex;align-items:center;justify-content:center;font-size:2.2rem;overflow:hidden}
.col-img img{width:100%;height:148px;object-fit:cover}
.col-body{padding:17px 19px}
.col-cat{font-size:.67rem;font-weight:700;color:var(--p);background:var(--pb);padding:2px 8px;border-radius:var(--rf);display:inline-block;margin-bottom:8px}
.col-title{font-size:.91rem;font-weight:700;color:var(--pd);line-height:1.55;margin-bottom:7px}
.col-exc{font-size:.79rem;color:var(--t2);line-height:1.7;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.col-meta{font-size:.7rem;color:var(--t4);margin-top:10px}
.area-cta{background:linear-gradient(135deg,var(--pd) 0%,var(--p) 60%,var(--pl) 100%);border-radius:var(--r24);padding:50px 44px;display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap;box-shadow:0 8px 32px rgba(22,84,71,.2)}
.area-cta h3{color:#fff;font-size:1.4rem;margin-bottom:10px;line-height:1.35}
.area-cta p{color:rgba(255,255,255,.96);font-size:.87rem;line-height:1.8;margin:0}
.area-cta-btns{display:flex;gap:10px;flex-wrap:wrap;flex-shrink:0}
.faq-list{display:flex;flex-direction:column;gap:8px}
.faq-item{background:var(--s0);border-radius:var(--r12);border:1px solid var(--bdl);overflow:hidden;box-shadow:var(--sh1);transition:var(--tr)}
.faq-item.open{border-color:var(--pb2);box-shadow:var(--sh2)}
.faq-q{padding:17px 20px;font-size:.9rem;font-weight:600;color:var(--tx);display:flex;align-items:center;gap:11px;cursor:pointer;user-select:none}
.faq-q:hover{background:var(--bg)}
.faq-qm{min-width:27px;height:27px;background:var(--p);color:#fff;border-radius:var(--rf);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.72rem;flex-shrink:0}
.faq-a{padding:2px 20px 16px 58px;font-size:.86rem;color:var(--t2);line-height:1.85;display:none}
.faq-item.open .faq-a{display:block}
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(155px,1fr));gap:0;background:var(--s0);border-radius:var(--r16);border:1px solid var(--bdl);box-shadow:var(--sh2);overflow:hidden}
.step{text-align:center;padding:32px 16px;position:relative;border-right:1px solid var(--bdl)}
.step:last-child{border-right:none}
.step-no{width:50px;height:50px;background:linear-gradient(135deg,var(--p),var(--pl));color:#fff;border-radius:var(--rf);display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:800;margin:0 auto 14px;box-shadow:0 4px 12px rgba(35,118,101,.22)}
.step-t{font-size:.9rem;font-weight:700;margin-bottom:7px;color:var(--pd)}
.step-d{font-size:.77rem;color:var(--t2);line-height:1.7}
.final-cta{background:linear-gradient(145deg,var(--pd) 0%,var(--p) 55%,var(--pl) 100%);padding:80px 24px;text-align:center;position:relative;overflow:hidden}
.final-cta::before{content:'';position:absolute;inset:0;opacity:.04;background-image:radial-gradient(circle,#fff 1px,transparent 1px);background-size:28px 28px;pointer-events:none}
.final-cta .con{position:relative;z-index:1}
.final-cta h2{color:#fff;margin-bottom:12px}
.final-cta p{color:rgba(255,255,255,.96);font-size:.93rem;margin-bottom:34px;max-width:460px;margin-left:auto;margin-right:auto}
.with-sb{display:grid;grid-template-columns:1fr 292px;gap:36px;align-items:start}
.sb{position:sticky;top:80px;display:flex;flex-direction:column;gap:14px}
.sb-card{background:var(--s0);border-radius:var(--r16);padding:22px;border:1px solid var(--bdl);box-shadow:var(--sh2)}
.sb-title{font-size:.75rem;font-weight:700;color:var(--t3);margin-bottom:13px;padding-bottom:10px;border-bottom:1px solid var(--bdl);letter-spacing:.08em;text-transform:uppercase}
@media(max-width:900px){.with-sb{grid-template-columns:1fr}.sb{position:static}}
.info-tbl{width:100%;border-collapse:collapse;font-size:.84rem;border-radius:var(--r12);overflow:hidden;box-shadow:var(--sh1)}
.info-tbl tr{border-bottom:1px solid var(--bdl)}
.info-tbl tr:last-child{border-bottom:none}
.info-tbl th{background:var(--bg);padding:12px 15px;text-align:left;font-weight:700;color:var(--t3);width:30%;font-size:.76rem;letter-spacing:.04em;vertical-align:top}
.info-tbl td{padding:12px 15px;color:var(--tx);background:var(--s0)}
.pg-hd{background:linear-gradient(145deg,var(--pd) 0%,var(--p) 100%);padding:50px 24px;color:#fff;position:relative;overflow:hidden}
.pg-hd::after{content:'';position:absolute;right:-50px;bottom:-50px;width:200px;height:200px;background:rgba(255,255,255,.04);border-radius:50%}
.pg-hd h1{color:#fff;font-size:clamp(1.35rem,3.5vw,1.95rem);margin-bottom:8px;position:relative;z-index:1}
.pg-hd p{opacity:.85;font-size:.88rem;max-width:520px;margin:0;position:relative;z-index:1}
.filter{background:var(--s0);border-radius:var(--r12);padding:18px 22px;border:1px solid var(--bdl);margin-bottom:26px;box-shadow:var(--sh1)}
.filter-row{display:flex;gap:11px;flex-wrap:wrap;align-items:flex-end}
.f-gr{display:flex;flex-direction:column;gap:5px;flex:1;min-width:135px}
.f-gr label{font-size:.vrem;font-weight:700;color:var(--t3);letter-spacing:.07em;text-transform:uppercase}
.f-gr select{padding:8px 30px 8px 11px;border:1.5px solid var(--bdl);border-radius:var(--r8);font-size:.84rem;font-family:inherit;background:var(--s0) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%237A9088' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat right 10px center;appearance:none}
.f-gr select:focus{outline:none;border-color:var(--p)}
.notice{background:var(--pb);border-left:3px solid var(--p);padding:12px 17px;border-radius:0 var(--r8) var(--r8) 0;font-size:.83rem;line-height:1.75;color:var(--t2);margin:14px 0}
.tag{display:inline-block;padding:3px 9px;border-radius:var(--rf);font-size:.68rem;font-weight:700;letter-spacing:.03em}
.tag-p{background:var(--pb);color:var(--p)}
.tag-a{background:var(--ab);color:var(--a)}
.article{font-size:.91rem;line-height:1.95}
.article h2{font-size:1.2rem;font-weight:700;color:var(--pd);margin:36px 0 14px;padding:12px 16px;background:var(--bg);border-left:3px solid var(--p);border-radius:0 var(--r8) var(--r8) 0}
.article h3{font-size:1rem;font-weight:700;color:var(--pd);margin:24px 0 10px;padding-left:11px;border-left:2px solid var(--pb2)}
.article p{margin-bottom:16px;color:var(--tx)}
.article ul{list-style:none;margin:0 0 16px}
.article ul li{padding:5px 0 5px 18px;position:relative;border-bottom:1px solid var(--bdl)}
.article ul li:last-child{border-bottom:none}
.article ul li::before{content:'';position:absolute;left:0;top:50%;width:7px;height:7px;background:var(--p);border-radius:50%;transform:translateY(-50%)}
.article strong{color:var(--pd);font-weight:700}
.pag{display:flex;justify-content:center;gap:6px;margin-top:44px}
.pag a,.pag span{display:inline-flex;align-items:center;justify-content:center;min-width:38px;height:38px;padding:0 10px;border-radius:var(--r8);border:1.5px solid var(--bdl);font-size:.83rem;font-weight:600;color:var(--t2)}
.pag a:hover,.pag .cur{background:var(--p);border-color:var(--p);color:#fff}
.info-box{background:var(--s0);border-radius:var(--r16);padding:36px;margin-bottom:32px;border:1px solid var(--bdl);box-shadow:var(--sh2)}
.info-box h2{font-size:1.35rem;margin-bottom:24px;padding-bottom:14px;border-bottom:2px solid var(--pb)}
.check-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;margin-top:16px}
.check-item{background:var(--bg);border-radius:var(--r12);padding:18px;display:flex;align-items:flex-start;gap:12px}
.check-icon{width:32px;height:32px;background:var(--p);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.85rem;flex-shrink:0;margin-top:2px}
.check-item h4{font-size:.88rem;color:var(--pd);margin-bottom:6px}
.check-item p{font-size:.8rem;color:var(--t2);line-height:1.7;margin:0}
.anxiety-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;margin-top:16px}
.anxiety-card{background:var(--bg);border-radius:var(--r12);padding:20px;border-left:3px solid var(--a)}
.anxiety-card .q{font-weight:700;color:var(--pd);font-size:.88rem;margin-bottom:8px}
.anxiety-card .a{font-size:.81rem;color:var(--t2);line-height:1.75;margin:0}
.tf-footer{background:#1A2E28;color:#E8F0ED;padding:64px 24px 32px;font-family:'Noto Sans JP',-apple-system,sans-serif}
.tf-ft-inner{max-width:1200px;margin:0 auto}
.tf-ft-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:0}
.tf-ft-logo-row{display:flex;align-items:center;gap:10px;text-decoration:none;margin-bottom:14px}
.tf-ft-logo-icon{width:36px;height:36px;background:linear-gradient(135deg,#2D7A68,#3A9C88);border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:.9rem;color:#fff;font-weight:900;flex-shrink:0}
.tf-ft-logo-name{font-size:1.15rem;font-weight:900;color:#7ECABB;letter-spacing:.04em}
.tf-ft-tagline{font-size:.82rem;color:#A8C4BC;line-height:1.85;margin-bottom:18px}
.tf-ft-tel{font-size:.84rem;color:#C8DDD8;line-height:1.9;margin-bottom:18px}
.tf-ft-tel strong{color:#fff;font-weight:700}
.tf-ft-cta{display:inline-block;background:#DC7035;color:#fff;padding:9px 20px;border-radius:50px;font-size:.8rem;font-weight:700;text-decoration:none;transition:background .2s}
.tf-ft-cta:hover{background:#E88A58;color:#fff}
.tf-ft-hd{font-size:.68rem;font-weight:700;color:#7ECABB;letter-spacing:.14em;text-transform:uppercase;margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.12)}
.tf-ft-links{list-style:none;padding:0;margin:0}
.tf-ft-links li{margin-bottom:9px}
.tf-ft-links a{font-size:.82rem;color:#C0D8D2;text-decoration:none;transition:color .2s;line-height:1.4;display:block}
.tf-ft-links a:hover{color:#7ECABB}
.tf-ft-badge{display:flex;flex-direction:column;gap:6px;margin-top:20px}
.tf-ft-badge span{font-size:.74rem;color:#A8C4BC;background:rgba(255,255,255,.07);padding:5px 10px;border-radius:5px;display:inline-block}
.tf-ft-divider{border:none;border-top:1px solid rgba(255,255,255,.1);margin:40px 0 24px}
.tf-ft-btm{display:flex;flex-direction:column;gap:8px}
.tf-ft-note{font-size:.78rem;color:#90AEA7;line-height:1.75;margin:0}
.tf-ft-copy{font-size:.72rem;color:#607872;margin:0}
@media(max-width:860px){
  .tf-ft-grid{grid-template-columns:1fr 1fr;gap:32px}
  .area-cta{flex-direction:column;text-align:center}
  .fac-grid,.case-grid,.col-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){
  .tf-ft-grid{grid-template-columns:1fr}
  .tf-footer{padding:48px 20px 28px}
  .fac-grid,.case-grid,.col-grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr 1fr}
  .step{border-right:none;border-bottom:1px solid var(--bdl)}
  .step:last-child{border-bottom:none}
  .hero{padding:64px 20px 56px}
  .sec{padding:52px 0}
  .area-cta{padding:32px 22px}
  .info-box{padding:24px 20px}
}
@media(max-width:420px){
  .fac-grid,.case-grid,.col-grid{grid-template-columns:1fr}
  .cta-btns{flex-direction:column;align-items:center}
  .con{padding:0 16px}
}
/* ── Specificity overrides: button text colors ── */
body.tunagu-portal a.btn-cta,
body.tunagu-portal a.btn-cta:hover{color:#fff !important}
body.tunagu-portal a.btn-p,
body.tunagu-portal a.btn-p:hover{color:#fff !important}
body.tunagu-portal a.btn-w,
body.tunagu-portal a.btn-w:hover{color:var(--pd) !important;font-weight:700}
body.tunagu-portal a.btn-s,
body.tunagu-portal a.btn-s:hover{color:var(--p) !important}
/* ── Green-background section text visibility ── */
.area-cta a,
.area-cta a:hover,
.final-cta a,
.final-cta a:hover{color:#fff}
.hero a:not(.btn-p):not(.btn-w):not(.search-box a){color:rgba(255,255,255,.92)}
.pg-hd a,.pg-hd a:hover{color:#fff}
