﻿@charset "UTF-8";
/* =========================================================
   成年後見あおぞら会  サイト共通スタイル
   テーマ：湘南の青空と海／安心・寄り添い・地域
   ========================================================= */

:root{
  /* ブランド配色（パンフレットより） */
  --sky-1:#cfeafa;     /* 空・上 */
  --sky-2:#eaf5fc;     /* 空・下 */
  --sky-3:#f4fafe;     /* ごく淡い空 */
  --blue:#2f74b5;      /* メインブルー（見出し・リンク） */
  --blue-d:#1f5388;    /* 濃紺（ロゴ・フッター） */
  --blue-dd:#173f68;
  --ink:#2b3640;       /* 本文 */
  --muted:#5d6b77;     /* 補助テキスト */
  --line:#e3ecf3;      /* 罫線 */
  --white:#ffffff;

  /* 事業カテゴリ色 */
  --c-kouken:#3f76c4;  --c-kouken-bg:#e9f1fb;   /* 成年後見：青 */
  --c-nini:#7cb342;    --c-nini-bg:#eef5e1;     /* 任意後見：緑 */
  --c-soudan:#ef9a3d;  --c-soudan-bg:#fcefdf;   /* 相談：橙 */
  --c-jukyo:#5aa86b;   --c-jukyo-bg:#e8f4ea;    /* 居住：緑 */
  --c-mimamori:#e87d5a;--c-mimamori-bg:#fcebe3; /* 見守り：珊瑚 */
  --c-shigo:#a56caa;   --c-shigo-bg:#f2eaf3;    /* 死後事務：紫 */

  --leaf:#9ccb5a;      /* 新芽アクセント */
  --note-bg:#fdf8e6;   --note-line:#e7d9a0;     /* メモ枠（淡い黄） */

  --wrap:1080px;
  --radius:18px;
  --shadow:0 10px 30px rgba(31,83,136,.08);
  --shadow-sm:0 4px 14px rgba(31,83,136,.07);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Noto Sans JP",-apple-system,BlinkMacSystemFont,"Hiragino Kaku Gothic ProN","Yu Gothic",Meiryo,sans-serif;
  color:var(--ink);
  line-height:1.9;
  font-size:16.5px;
  letter-spacing:.01em;
  background:var(--sky-3);
  -webkit-font-smoothing:antialiased;
  overflow-x:clip;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{font-family:"Zen Maru Gothic","Noto Sans JP",sans-serif;font-weight:700;line-height:1.5;color:var(--blue-d)}

.wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:20px}
.skip{position:absolute;left:-9999px}
.skip:focus{left:8px;top:8px;background:#fff;padding:8px 14px;border-radius:8px;z-index:100}

/* ===== ヘッダー ===== */
.topbar{background:var(--blue-d);color:#dceaf6;font-size:.82rem}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;gap:12px;padding-block:6px}
.topbar a{color:#fff;font-weight:700}

.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.header-main{display:flex;align-items:center;justify-content:space-between;gap:16px;padding-block:12px}
.brand{display:flex;flex-direction:column;align-items:flex-start;gap:3px;text-decoration:none}
.brand:hover{text-decoration:none}
.brand .mark{flex:none}
.brand-logo{height:50px;width:auto;display:block}
/* ワードマーク「成年後見あおぞら会」の中心(ロゴ幅の約63.5%)に合わせて配置 */
.brand-sub{font-size:.72rem;font-weight:700;letter-spacing:.2em;color:var(--muted);line-height:1;
  white-space:nowrap;margin-left:63.5%;transform:translateX(-50%)}
.brand-txt{display:flex;flex-direction:column;line-height:1.25}
.brand-txt b{font-family:"Zen Maru Gothic",sans-serif;font-size:1.18rem;color:var(--blue-d);letter-spacing:.02em}
.brand-txt span{font-size:.74rem;color:var(--muted)}

.nav{display:flex;align-items:center;gap:4px}
.nav a{padding:9px 13px;border-radius:10px;color:var(--ink);font-weight:500;font-size:.95rem}
.nav a:hover{background:var(--sky-2);text-decoration:none;color:var(--blue-d)}
.nav a.btn{margin-left:6px;color:#fff}
.nav a.btn:hover{color:#fff;background:var(--blue-d)}
.nav-toggle{display:none;border:1px solid var(--line);background:#fff;color:var(--blue-d);font-weight:700;border-radius:10px;padding:9px 13px;cursor:pointer}
.nav-backdrop{position:fixed;inset:0;background:rgba(23,63,104,.35);z-index:40}

/* ===== ボタン ===== */
.btn{display:inline-flex;align-items:center;gap:8px;background:var(--blue);color:#fff;font-weight:700;
  padding:11px 22px;border-radius:999px;border:2px solid var(--blue);transition:.15s;font-family:"Zen Maru Gothic",sans-serif}
.btn:hover{background:var(--blue-d);border-color:var(--blue-d);text-decoration:none;transform:translateY(-1px)}
.btn--ghost{background:#fff;color:var(--blue-d);border-color:#cfe0ee}
.btn--ghost:hover{background:var(--sky-2);color:var(--blue-d)}
.btn--lg{padding:15px 30px;font-size:1.05rem}
.btn--tel{background:var(--c-soudan);border-color:var(--c-soudan)}
.btn--tel:hover{background:#dd8526;border-color:#dd8526}

/* ===== ヒーロー（湘南の海・実写イラスト） ===== */
.hero{position:relative;overflow:hidden;min-height:clamp(540px,52vw,720px);display:flex;align-items:flex-start;
  background:#cfeafa url("hero-shonan.jpg") center 45%/cover no-repeat}
.hero::before{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg,rgba(244,250,254,.95) 0%,rgba(244,250,254,.8) 40%,rgba(244,250,254,.55) 62%,rgba(244,250,254,.16) 82%,rgba(255,255,255,0) 100%)}
.hero .wrap{position:relative;z-index:2;width:100%;padding-block:50px 0;text-align:center}
.hero .eyebrow{color:var(--blue);font-weight:700;letter-spacing:.18em;font-size:.78rem;margin:0 0 10px}
.hero h1{font-size:clamp(1.8rem,4.6vw,3rem);color:var(--blue-dd);margin:0 0 16px;letter-spacing:.03em;line-height:1.55;
  text-shadow:0 2px 10px rgba(255,255,255,.95),0 1px 0 rgba(255,255,255,1)}
.hero .lead{max-width:640px;margin:0 auto 24px;color:#1c456a;font-size:1.05rem;font-weight:500;
  text-shadow:0 1px 6px rgba(255,255,255,1),0 0 2px rgba(255,255,255,1)}
.hero .cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:40px}

/* ===== 汎用セクション ===== */
.section{padding-block:64px}
.section--tint{background:linear-gradient(180deg,#fff, var(--sky-3))}
.section--sky{background:linear-gradient(180deg,var(--sky-3),#fff)}
.sec-head{text-align:center;margin-bottom:14px}
.sec-head .kicker{display:inline-block;color:var(--blue);font-weight:700;letter-spacing:.16em;font-size:.74rem;margin-bottom:6px}
.sec-head h2{font-size:clamp(1.5rem,3.4vw,2rem);margin:0;position:relative;display:inline-block;padding-bottom:12px}
.sec-head h2::after{content:"";position:absolute;left:50%;bottom:0;transform:translateX(-50%);
  width:76px;height:0;border-bottom:3px dotted var(--blue);opacity:.55}
.sec-head h2 .leaf{color:var(--leaf)}
.sec-desc{text-align:center;max-width:680px;margin:0 auto 40px;color:var(--muted)}

/* ===== グリッド ===== */
.grid{display:grid;gap:22px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}

/* ===== サービスカード ===== */
.svc-card{background:#fff;border-radius:var(--radius);padding:26px 24px;box-shadow:var(--shadow-sm);
  border:1px solid var(--line);position:relative;transition:.15s}
a.svc-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);text-decoration:none}
.svc-card .ic{width:60px;height:60px;border-radius:50%;display:grid;place-items:center;margin-bottom:14px}
.svc-card h3{margin:0 0 8px;font-size:1.22rem}
.svc-card p{margin:0;color:var(--muted);font-size:.95rem}
.svc-card .more{display:inline-block;margin-top:14px;font-weight:700;color:var(--blue);font-size:.92rem}
/* カテゴリ別アクセント */
.t-kouken .ic{background:var(--c-kouken-bg);color:var(--c-kouken)} .t-kouken h3{color:var(--c-kouken)}
.t-nini .ic{background:var(--c-nini-bg);color:var(--c-nini)} .t-nini h3{color:#5f8f2f}
.t-soudan .ic{background:var(--c-soudan-bg);color:var(--c-soudan)} .t-soudan h3{color:#cf8224}
.t-jukyo .ic{background:var(--c-jukyo-bg);color:var(--c-jukyo)} .t-jukyo h3{color:#458a55}
.t-mimamori .ic{background:var(--c-mimamori-bg);color:var(--c-mimamori)} .t-mimamori h3{color:#d2654a}
.t-shigo .ic{background:var(--c-shigo-bg);color:var(--c-shigo)} .t-shigo h3{color:#8d539a}

/* ===== 詳細ブロック（事業ページ） ===== */
.svc-detail{scroll-margin-top:90px;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-sm);
  border:1px solid var(--line);padding:30px;margin-bottom:26px;display:grid;grid-template-columns:88px 1fr;gap:8px 24px;align-items:start}
.svc-detail .ic{width:72px;height:72px;border-radius:50%;display:grid;place-items:center}
.svc-detail .hd{grid-column:2}
.svc-detail .bd{grid-column:2}
.svc-detail h3{margin:0 0 4px;font-size:1.4rem}
.svc-detail .tagk{font-size:.78rem;font-weight:700;letter-spacing:.08em}
.svc-detail p{margin:.4em 0;color:var(--ink)}
.svc-detail ul{margin:12px 0 0;padding:0;list-style:none}
.svc-detail ul li{position:relative;padding:7px 0 7px 28px;border-top:1px dashed var(--line)}
.svc-detail ul li:first-child{border-top:none}
.svc-detail ul li::before{content:"";position:absolute;left:4px;top:15px;width:9px;height:9px;border-radius:50%;background:currentColor}
.svc-detail.t-kouken ul li{color:var(--c-kouken)} .svc-detail.t-nini ul li{color:var(--c-nini)}
.svc-detail.t-soudan ul li{color:var(--c-soudan)} .svc-detail.t-jukyo ul li{color:var(--c-jukyo)}
.svc-detail.t-mimamori ul li{color:var(--c-mimamori)} .svc-detail.t-shigo ul li{color:var(--c-shigo)}
.svc-detail ul li span{color:var(--ink)}
.svc-detail .note-inline{margin-top:14px;font-size:.9rem;color:var(--muted)}

/* ===== メモ枠（点線・淡い黄） ===== */
.note{background:var(--note-bg);border:2px dashed var(--note-line);border-radius:16px;padding:20px 24px;color:#6b5e2e}
.note h3,.note b{color:#7a6a2a}
.note p{margin:.3em 0}

/* ===== 想い／引用 ===== */
.philosophy{background:linear-gradient(180deg,#fff,var(--sky-3));text-align:center}
.philosophy .q{font-family:"Zen Maru Gothic",sans-serif;font-size:clamp(1.25rem,3vw,1.8rem);color:var(--blue-d);
  line-height:1.8;margin:0 auto;max-width:920px;text-wrap:pretty}
.nobr{white-space:nowrap}
.philosophy .q small{display:block;font-size:.95rem;color:var(--muted);margin-top:18px;font-family:"Noto Sans JP"}

/* ===== 数値／概要テーブル ===== */
.info{width:100%;border-collapse:collapse;background:#fff;border-radius:14px;overflow:hidden;box-shadow:var(--shadow-sm)}
.info th,.info td{text-align:left;padding:15px 18px;border-bottom:1px solid var(--line);vertical-align:top}
.info th{width:32%;background:var(--sky-2);color:var(--blue-d);font-weight:700;white-space:nowrap;font-family:"Zen Maru Gothic"}
.info tr:last-child th,.info tr:last-child td{border-bottom:none}

/* ===== 相談の流れ ===== */
.flow{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;counter-reset:step}
.flow .step{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px 18px 20px;text-align:center;box-shadow:var(--shadow-sm)}
.flow .step::before{counter-increment:step;content:"STEP " counter(step);position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:var(--blue);color:#fff;font-family:"Zen Maru Gothic";font-size:.72rem;font-weight:700;padding:3px 12px;border-radius:999px;letter-spacing:.06em;white-space:nowrap}
.flow .step .n{width:52px;height:52px;border-radius:50%;background:var(--sky-2);color:var(--blue);display:grid;place-items:center;margin:8px auto 12px}
.flow .step h3{margin:0 0 6px;font-size:1.05rem}
.flow .step p{margin:0;font-size:.88rem;color:var(--muted)}

/* ===== お知らせ ===== */
.news{list-style:none;margin:0;padding:0;background:#fff;border-radius:14px;box-shadow:var(--shadow-sm);overflow:hidden;border:1px solid var(--line)}
.news li+li{border-top:1px solid var(--line)}
.news a{display:flex;flex-wrap:wrap;align-items:center;gap:12px;padding:16px 20px;color:var(--ink)}
.news a:hover{background:var(--sky-2);text-decoration:none}
.news time{color:var(--muted);font-size:.86rem;font-variant-numeric:tabular-nums;min-width:104px}
.news .tag{font-size:.74rem;background:var(--sky-2);color:var(--blue-d);border-radius:999px;padding:2px 12px;font-weight:700}
.news .title{flex:1;min-width:200px}

/* ===== 連絡先 CTA 帯 ===== */
.contact-band{position:relative;overflow:hidden;color:#fff;
  background:linear-gradient(120deg,var(--blue-d),var(--blue))}
.contact-band .wrap{position:relative;z-index:2;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:24px;padding-block:46px}
.contact-band h2{color:#fff;margin:0 0 8px;font-size:1.6rem}
.contact-band p{margin:0;color:#dbeaf6}
.cta-boxes{display:flex;gap:26px;flex:0 1 580px;flex-wrap:nowrap;align-items:stretch}
.tel-box{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.3);border-radius:16px;padding:16px;text-align:center;flex:1 1 0;min-width:0;display:flex;flex-direction:column}
.tel-box .k{font-size:.85rem;color:#dbeaf6}
.tel-box .v{flex:1;display:flex;align-items:center;justify-content:center;margin:6px 0;font-family:"Zen Maru Gothic";font-size:clamp(1rem,4vw,2rem);font-weight:700;line-height:1.2;white-space:nowrap}
.tel-box .v a{color:#fff}
.tel-box small{display:block;font-size:.8rem;color:#cfe2f1}
.tel-box--mail{flex:1.45 1 0}
.tel-box--mail .v{font-size:clamp(.95rem,3.4vw,1.42rem);white-space:normal;word-break:break-all}
.tel-box--mail .v a{display:inline-block}

/* ===== 街並みイラスト帯 ===== */
.townscape{display:block;width:100%;height:auto;margin-bottom:-3px}

/* ===== フォーム ===== */
.form{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1px solid var(--line);padding:30px}
.form .field{margin-bottom:20px}
.form label{display:block;font-weight:700;color:var(--blue-d);margin-bottom:7px;font-size:.95rem}
.form .req{color:#d2654a;font-size:.78rem;margin-left:6px}
.form input,.form textarea,.form select{width:100%;padding:12px 14px;border:1px solid #cfdce8;border-radius:10px;font:inherit;background:#fcfdfe}
.form input:focus,.form textarea:focus{outline:2px solid var(--blue);border-color:var(--blue)}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form .check{display:flex;gap:10px;align-items:flex-start;font-weight:400;color:var(--ink)}
.form .check input{width:auto;margin-top:5px}
.form .actions{text-align:center;margin-top:8px}

/* ===== フッター ===== */
.site-footer{background:var(--blue-dd);color:#cfe0ee;padding-block:46px 0;margin-top:0}
.site-footer .wrap{display:grid;grid-template-columns:1.4fr 1fr;gap:30px}
.site-footer h3{color:#fff;font-size:1.1rem;margin:0 0 12px}
.site-footer p{margin:.3em 0;font-size:.9rem;line-height:1.85}
.site-footer a{color:#fff}
.fnav{list-style:none;margin:0;padding:0;columns:2;gap:10px}
.fnav li{margin-bottom:9px}
.fnav a{color:#cfe0ee;font-size:.92rem}
.copyright{margin-top:36px;border-top:1px solid rgba(255,255,255,.14);text-align:center;font-size:.8rem;color:#a9c4dc;padding:16px}

/* パンくず */
.crumb{font-size:.82rem;color:var(--muted);padding-block:14px}
.crumb a{color:var(--muted)}

/* ページ見出し */
.page-hero{background:linear-gradient(180deg,#cfeafa,#eef7fd);text-align:center;padding-block:54px 46px;position:relative;overflow:hidden}
.page-hero h1{font-size:clamp(1.7rem,4vw,2.4rem);margin:0 0 8px;color:var(--blue-dd)}
.page-hero p{margin:0;color:#3c5d79}
.page-hero .en{display:block;font-size:.74rem;letter-spacing:.18em;color:var(--blue);font-weight:700;margin-bottom:6px}

/* 地図 */
.map-embed{width:100%;height:260px;border:0;border-radius:14px;box-shadow:var(--shadow-sm);display:block;background:#eaf2f8}

/* FAQ */
.faq{margin-top:8px}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-sm);margin-bottom:14px;overflow:hidden}
.faq-item summary{list-style:none;cursor:pointer;padding:18px 52px 18px 22px;position:relative;font-family:"Zen Maru Gothic",sans-serif;font-weight:700;color:var(--blue-d);font-size:1.05rem}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::before{content:"Q";position:absolute;left:22px;display:none}
.faq-item summary::after{content:"";position:absolute;right:22px;top:50%;width:11px;height:11px;border-right:2px solid var(--blue);border-bottom:2px solid var(--blue);transform:translateY(-70%) rotate(45deg);transition:transform .2s}
.faq-item[open] summary::after{transform:translateY(-30%) rotate(-135deg)}
.faq-item summary:hover{background:var(--sky-2)}
.faq-a{padding:0 22px 20px;color:var(--ink)}
.faq-a p{margin:0;color:var(--muted)}

/* 汎用 */
.center{text-align:center}
.prose p{margin:0 0 1.1em}
.lead-lg{font-size:1.08rem}

/* ===== レスポンシブ ===== */
@media(max-width:980px){
  .br-pc{display:none}
  .nav{position:fixed;top:0;right:0;width:280px;max-width:80vw;height:100vh;background:#fff;flex-direction:column;align-items:stretch;
    padding:74px 18px 24px;gap:4px;box-shadow:-8px 0 30px rgba(0,0,0,.12);z-index:45;overflow-y:auto;
    opacity:0;visibility:hidden;transform:translateX(-14px);transition:opacity .22s ease,transform .22s ease,visibility .22s}
  .nav.open{opacity:1;visibility:visible;transform:translateX(0)}
  .nav a{padding:13px 12px;border-radius:10px}
  .nav a.btn{margin:8px 0 0;justify-content:center}
  .nav-toggle{display:inline-block;z-index:46}
  .brand-logo{height:40px}
  .site-footer .wrap{grid-template-columns:1fr}
  .flow{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:640px){
  body{font-size:16px}
  .grid-2,.grid-3{grid-template-columns:1fr}
  .form .row{grid-template-columns:1fr}
  .svc-detail{grid-template-columns:1fr;padding:24px}
  .svc-detail .hd,.svc-detail .bd{grid-column:1}
  .svc-detail .ic{margin-bottom:6px}
  .flow{grid-template-columns:1fr}
  .contact-band .wrap{flex-direction:column;align-items:flex-start}
  .cta-boxes{flex-basis:auto;width:100%}
  .topbar .wrap{font-size:.78rem}
  .info th{width:38%;font-size:.9rem}
}
