@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700;900&family=Noto+Serif+JP:wght@500;700&display=swap');

/* =========================================================
   障害福祉サービス 開業・指定申請サポート大阪（東亮介事務所）
   共通スタイル  —  配色は東亮介事務所グループ規約に準拠
   Navy #1a3a5c / Gold #b8935a / 背景 #faf9f6 ＋ 福祉グリーン
   ========================================================= */

:root{
  --navy:#1a3a5c;
  --navy-deep:#12293f;
  --navy-soft:#2f5478;
  --gold:#b8935a;
  --gold-deep:#9c7a44;
  --green:#2e8b6f;       /* 福祉・成長のアクセント */
  --green-deep:#236b56;
  --green-soft:#e7f3ee;
  --bg:#faf9f6;
  --bg-alt:#f1ede4;
  --ink:#23303b;
  --ink-soft:#4d5b67;
  --line:#e3ddd0;
  --white:#ffffff;
  --shadow-sm:0 2px 8px rgba(26,58,92,.06);
  --shadow:0 10px 30px rgba(26,58,92,.10);
  --shadow-lg:0 24px 60px rgba(26,58,92,.16);
  --radius:14px;
  --radius-lg:24px;
  --maxw:1120px;
  --serif:"Noto Serif JP",serif;
  --sans:"Noto Sans JP",system-ui,sans-serif;
}

*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  margin:0;font-family:var(--sans);color:var(--ink);background:var(--bg);
  line-height:1.85;font-weight:400;font-size:16px;letter-spacing:.01em;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block;}
a{color:var(--navy);text-decoration:none;transition:.2s;}
a:hover{color:var(--gold-deep);}
h1,h2,h3,h4{font-family:var(--serif);line-height:1.45;color:var(--navy);font-weight:700;margin:0 0 .6em;}
p{margin:0 0 1.2em;}
ul{margin:0 0 1.2em;padding-left:1.3em;}
.container{max-width:var(--maxw);margin:0 auto;padding:0 20px;}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0;}

/* ---------- セクション共通 ---------- */
.section{padding:72px 0;}
.section--alt{background:var(--bg-alt);}
.section--navy{background:linear-gradient(160deg,var(--navy),var(--navy-deep));color:#eaf0f5;}
.section--navy h2,.section--navy h3{color:#fff;}
.section-head{text-align:center;max-width:760px;margin:0 auto 48px;}
.section-head .eyebrow{
  display:inline-block;font-family:var(--sans);font-weight:700;font-size:.82rem;
  letter-spacing:.18em;color:var(--gold-deep);margin-bottom:14px;
}
.section--navy .section-head .eyebrow{color:var(--gold);}
.section-head h2{font-size:clamp(1.6rem,3.6vw,2.3rem);}
.section-head p{color:var(--ink-soft);margin-bottom:0;}
.section--navy .section-head p{color:#cdd9e4;}

/* ---------- ボタン ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  font-family:var(--sans);font-weight:700;font-size:1.02rem;
  padding:16px 30px;border-radius:999px;border:2px solid transparent;
  cursor:pointer;transition:.22s;text-align:center;line-height:1.4;
}
.btn i{font-size:1.05em;}
.btn--primary{background:linear-gradient(135deg,var(--gold),var(--gold-deep));color:#fff;box-shadow:0 10px 24px rgba(184,147,90,.35);}
.btn--primary:hover{transform:translateY(-2px);color:#fff;box-shadow:0 16px 32px rgba(184,147,90,.45);}
.btn--green{background:linear-gradient(135deg,var(--green),var(--green-deep));color:#fff;box-shadow:0 10px 24px rgba(46,139,111,.32);}
.btn--green:hover{transform:translateY(-2px);color:#fff;}
.btn--line{background:#06c755;color:#fff;}
.btn--line:hover{background:#05b14c;color:#fff;transform:translateY(-2px);}
.btn--ghost{background:transparent;border-color:rgba(255,255,255,.6);color:#fff;}
.btn--ghost:hover{background:rgba(255,255,255,.12);color:#fff;}
.btn--outline{background:#fff;border-color:var(--navy);color:var(--navy);}
.btn--outline:hover{background:var(--navy);color:#fff;}
.btn--lg{padding:18px 40px;font-size:1.12rem;}
.btn--block{width:100%;}

/* =========================================================
   ヘッダー
   ========================================================= */
.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.96);backdrop-filter:blur(8px);box-shadow:var(--shadow-sm);}
.header-inner{max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;gap:20px;padding:12px 20px;}
.brand{display:flex;flex-direction:column;line-height:1.3;}
.brand-main{font-family:var(--serif);font-weight:700;font-size:1.18rem;color:var(--navy);}
.brand-sub{font-size:.72rem;color:var(--ink-soft);letter-spacing:.04em;}
.brand-main .accent{color:var(--gold-deep);}
.main-nav{margin-left:auto;}
.main-nav ul{display:flex;gap:4px;list-style:none;margin:0;padding:0;}
.main-nav a{display:block;padding:10px 14px;font-weight:500;font-size:.95rem;color:var(--ink);border-radius:8px;}
.main-nav a:hover{background:var(--green-soft);color:var(--green-deep);}
.header-cta{display:flex;align-items:center;gap:10px;}
.header-phone{display:flex;flex-direction:column;line-height:1.2;text-align:right;}
.header-phone strong{font-family:var(--serif);font-size:1.18rem;color:var(--navy);letter-spacing:.02em;}
.header-phone span{font-size:.68rem;color:var(--ink-soft);}
.header-line{display:inline-flex;align-items:center;gap:6px;background:#06c755;color:#fff;font-weight:700;font-size:.9rem;padding:9px 16px;border-radius:999px;}
.header-line:hover{color:#fff;background:#05b14c;}
.menu-toggle{display:none;background:none;border:0;font-size:1.5rem;color:var(--navy);cursor:pointer;padding:6px;}
.mobile-nav{display:none;flex-direction:column;background:#fff;border-top:1px solid var(--line);padding:8px 20px 18px;}
.mobile-nav a{padding:13px 4px;border-bottom:1px solid var(--line);font-weight:500;color:var(--ink);}
.mobile-nav.open{display:flex;}

/* =========================================================
   ヒーロー
   ========================================================= */
.hero{position:relative;background:linear-gradient(155deg,#1f4368 0%,var(--navy) 45%,var(--navy-deep) 100%);color:#fff;overflow:hidden;}
.hero::after{content:"";position:absolute;right:-120px;top:-120px;width:480px;height:480px;background:radial-gradient(circle,rgba(184,147,90,.28),transparent 70%);}
.hero-inner{position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;padding:72px 20px 80px;display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center;}
.hero-ribbon{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);color:#fff;font-weight:700;font-size:.86rem;padding:8px 18px;border-radius:999px;margin-bottom:22px;}
.hero-ribbon i{color:var(--gold);}
.hero h1{color:#fff;font-size:clamp(1.85rem,4.4vw,3rem);line-height:1.4;margin-bottom:20px;}
.hero h1 .hl{color:#ffd98a;}
.hero h1 .green{color:#7ee0c0;}
.hero-lead{font-size:1.08rem;color:#dbe6f0;margin-bottom:28px;}
.hero-stats{display:flex;gap:14px;margin-bottom:30px;flex-wrap:wrap;}
.hero-stat{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.16);border-radius:var(--radius);padding:14px 18px;min-width:130px;}
.hero-stat small{display:block;font-size:.72rem;color:#b9cad9;}
.hero-stat strong{font-family:var(--serif);font-size:1.7rem;color:var(--gold);line-height:1.1;}
.hero-stat span{font-size:.78rem;color:#dbe6f0;}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;}
.hero-note{font-size:.76rem;color:#aebfce;margin:16px 0 0;}
.hero-card{background:rgba(255,255,255,.97);color:var(--ink);border-radius:var(--radius-lg);padding:28px;box-shadow:var(--shadow-lg);}
.hero-card h2{font-size:1.15rem;color:var(--navy);text-align:center;margin-bottom:18px;}
.hero-card ul{list-style:none;padding:0;margin:0;}
.hero-card li{display:flex;gap:12px;align-items:flex-start;padding:11px 0;border-bottom:1px dashed var(--line);font-size:.96rem;}
.hero-card li:last-child{border-bottom:0;}
.hero-card li i{color:var(--green);margin-top:4px;}

/* =========================================================
   実績バー
   ========================================================= */
.trust-bar{background:#fff;border-bottom:1px solid var(--line);}
.trust-bar .container{display:flex;flex-wrap:wrap;justify-content:center;gap:14px 40px;padding:22px 20px;text-align:center;}
.trust-item{display:flex;align-items:center;gap:10px;font-weight:700;color:var(--navy);font-size:.96rem;}
.trust-item i{color:var(--gold-deep);font-size:1.15rem;}

/* =========================================================
   カードグリッド（悩み・サービス・事業類型）
   ========================================================= */
.grid{display:grid;gap:24px;}
.grid--2{grid-template-columns:repeat(2,1fr);}
.grid--3{grid-template-columns:repeat(3,1fr);}
.grid--4{grid-template-columns:repeat(4,1fr);}

.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px 24px;box-shadow:var(--shadow-sm);transition:.22s;}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);}
.card-icon{width:54px;height:54px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.35rem;color:#fff;background:linear-gradient(135deg,var(--green),var(--green-deep));margin-bottom:16px;}
.card-icon.gold{background:linear-gradient(135deg,var(--gold),var(--gold-deep));}
.card-icon.navy{background:linear-gradient(135deg,var(--navy-soft),var(--navy));}
.card h3{font-size:1.18rem;margin-bottom:10px;}
.card p{color:var(--ink-soft);font-size:.95rem;margin-bottom:0;}

/* 事業類型カード（リンク付き） */
.type-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:.22s;}
.type-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);}
.type-card-body{padding:24px;flex:1;display:flex;flex-direction:column;}
.type-card .tag{display:inline-block;align-self:flex-start;background:var(--green-soft);color:var(--green-deep);font-size:.74rem;font-weight:700;padding:4px 11px;border-radius:999px;margin-bottom:12px;}
.type-card h3{font-size:1.16rem;color:var(--navy);margin-bottom:8px;}
.type-card p{font-size:.9rem;color:var(--ink-soft);flex:1;}
.type-card .more{margin-top:14px;font-weight:700;color:var(--gold-deep);font-size:.92rem;}
.type-card .more i{transition:.2s;}
.type-card:hover .more i{transform:translateX(4px);}

/* 悩みリスト（チェック） */
.worry-list{list-style:none;padding:0;display:grid;grid-template-columns:repeat(2,1fr);gap:14px;}
.worry-list li{background:#fff;border:1px solid var(--line);border-left:4px solid var(--gold);border-radius:10px;padding:16px 18px;display:flex;gap:12px;align-items:flex-start;font-weight:500;box-shadow:var(--shadow-sm);}
.worry-list li i{color:var(--gold-deep);margin-top:4px;}

/* =========================================================
   選ばれる理由 / 強み
   ========================================================= */
.reason{display:flex;gap:20px;align-items:flex-start;}
.reason-num{flex:none;width:52px;height:52px;border-radius:50%;background:var(--navy);color:#fff;font-family:var(--serif);font-size:1.3rem;font-weight:700;display:flex;align-items:center;justify-content:center;}
.reason h3{font-size:1.2rem;margin-bottom:8px;}
.reason p{color:var(--ink-soft);margin-bottom:0;font-size:.96rem;}

/* バッジ（二大国家資格の強調） */
.dual-badge{display:flex;flex-wrap:wrap;justify-content:center;gap:18px;margin-top:8px;}
.dual-badge .b{background:#fff;border:2px solid var(--gold);border-radius:var(--radius);padding:18px 26px;text-align:center;min-width:220px;box-shadow:var(--shadow-sm);}
.dual-badge .b .q{font-family:var(--serif);font-weight:700;font-size:1.2rem;color:var(--navy);}
.dual-badge .b .r{font-size:.85rem;color:var(--ink-soft);margin-top:4px;}
.dual-badge .plus{display:flex;align-items:center;font-size:1.8rem;color:var(--gold-deep);font-weight:700;}

/* =========================================================
   フロー（開業の流れ）
   ========================================================= */
.flow{counter-reset:flow;display:grid;gap:18px;}
.flow-step{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px 24px 24px 80px;box-shadow:var(--shadow-sm);}
.flow-step::before{counter-increment:flow;content:"STEP " counter(flow);position:absolute;left:24px;top:24px;width:auto;}
.flow-step .step-no{position:absolute;left:22px;top:22px;width:44px;height:44px;border-radius:50%;background:var(--green);color:#fff;font-family:var(--serif);font-weight:700;display:flex;align-items:center;justify-content:center;font-size:1.2rem;}
.flow-step h3{font-size:1.12rem;margin-bottom:6px;}
.flow-step p{margin-bottom:0;color:var(--ink-soft);font-size:.94rem;}

/* =========================================================
   料金テーブル
   ========================================================= */
.price-table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);}
.price-table th,.price-table td{padding:16px 18px;text-align:left;border-bottom:1px solid var(--line);font-size:.96rem;}
.price-table thead th{background:var(--navy);color:#fff;font-family:var(--sans);}
.price-table tbody th{font-weight:700;color:var(--navy);width:46%;}
.price-table .amount{font-family:var(--serif);font-weight:700;color:var(--gold-deep);white-space:nowrap;}
.price-note{font-size:.82rem;color:var(--ink-soft);margin-top:12px;}

/* =========================================================
   FAQ
   ========================================================= */
.faq-item{background:#fff;border:1px solid var(--line);border-radius:var(--radius);margin-bottom:14px;overflow:hidden;box-shadow:var(--shadow-sm);}
.faq-q{display:flex;gap:14px;align-items:flex-start;padding:18px 22px;cursor:pointer;font-weight:700;color:var(--navy);list-style:none;}
.faq-q::-webkit-details-marker{display:none;}
.faq-q .qmark{flex:none;width:26px;height:26px;border-radius:50%;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.85rem;}
.faq-q .chev{margin-left:auto;color:var(--gold-deep);transition:.2s;}
details[open] .faq-q .chev{transform:rotate(180deg);}
.faq-a{padding:0 22px 20px 62px;color:var(--ink-soft);font-size:.96rem;}

/* =========================================================
   CTAバンド
   ========================================================= */
.cta-band{background:linear-gradient(135deg,var(--green-deep),var(--green));color:#fff;text-align:center;}
.cta-band h2{color:#fff;font-size:clamp(1.5rem,3.4vw,2.1rem);}
.cta-band p{color:#e2f3ec;max-width:620px;margin:0 auto 28px;}
.cta-band .btn-row{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}

/* =========================================================
   フッター
   ========================================================= */
.site-footer{background:var(--navy-deep);color:#c4d2de;padding:56px 0 0;}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px;}
.footer-brand .f-logo{font-family:var(--serif);font-weight:700;font-size:1.2rem;color:#fff;margin-bottom:14px;}
.footer-brand p{font-size:.9rem;color:#a9bccc;}
.footer-col h3{color:#fff;font-size:1rem;margin-bottom:14px;font-family:var(--sans);}
.footer-col ul{list-style:none;padding:0;margin:0;}
.footer-col li{margin-bottom:9px;}
.footer-col a{color:#bccfdd;font-size:.9rem;}
.footer-col a:hover{color:var(--gold);}
.footer-social{display:flex;gap:12px;margin-top:16px;}
.footer-social a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:#fff;}
.footer-social a:hover{background:var(--gold);}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:40px;padding:18px 0;text-align:center;font-size:.82rem;color:#8ea4b6;}

/* =========================================================
   パンくず
   ========================================================= */
.breadcrumb{background:var(--bg-alt);font-size:.82rem;}
.breadcrumb ol{max-width:var(--maxw);margin:0 auto;padding:10px 20px;list-style:none;display:flex;flex-wrap:wrap;gap:8px;}
.breadcrumb li{display:flex;gap:8px;align-items:center;color:var(--ink-soft);}
.breadcrumb li:not(:last-child)::after{content:"/";color:var(--line);}

/* =========================================================
   下層ページ ヘッダー
   ========================================================= */
.page-hero{background:linear-gradient(150deg,var(--navy),var(--navy-deep));color:#fff;padding:54px 0;text-align:center;}
.page-hero h1{color:#fff;font-size:clamp(1.6rem,3.6vw,2.4rem);margin-bottom:10px;}
.page-hero p{color:#cdd9e4;margin:0;}

/* 本文プローズ */
.prose{max-width:820px;margin:0 auto;}
.prose h2{font-size:1.6rem;margin-top:1.8em;padding-bottom:.4em;border-bottom:3px solid var(--gold);}
.prose h3{font-size:1.25rem;margin-top:1.6em;color:var(--green-deep);}
.prose ul li{margin-bottom:.5em;}
.prose .lead{font-size:1.1rem;color:var(--ink-soft);}
.note-box{background:var(--green-soft);border-left:4px solid var(--green);border-radius:10px;padding:20px 24px;margin:24px 0;}
.note-box.gold{background:#f7f0e3;border-left-color:var(--gold);}

/* =========================================================
   お問い合わせフォーム
   ========================================================= */
.contact-grid{display:grid;grid-template-columns:1.3fr .9fr;gap:36px;align-items:start;}
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:32px;box-shadow:var(--shadow);}
.form-row{margin-bottom:20px;}
.form-row label{display:block;font-weight:700;color:var(--navy);font-size:.92rem;margin-bottom:7px;}
.form-row label .req{color:#c0392b;font-size:.78rem;margin-left:6px;}
.form-row input,.form-row select,.form-row textarea{
  width:100%;padding:13px 15px;border:1.5px solid var(--line);border-radius:10px;
  font-family:var(--sans);font-size:1rem;color:var(--ink);background:#fdfcfa;transition:.2s;
}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(46,139,111,.15);}
.form-row textarea{min-height:130px;resize:vertical;}
.form-consent{display:flex;gap:10px;align-items:flex-start;font-size:.88rem;color:var(--ink-soft);}
.form-consent input{width:auto;margin-top:5px;}
.contact-aside .card{margin-bottom:18px;}
.contact-aside .big-tel{font-family:var(--serif);font-size:1.7rem;color:var(--navy);font-weight:700;}
@media(max-width:820px){.contact-grid{grid-template-columns:1fr;}}

/* =========================================================
   固定モバイルCTA
   ========================================================= */
.mobile-cta{display:none;position:fixed;left:0;right:0;bottom:0;z-index:90;background:#fff;box-shadow:0 -4px 16px rgba(0,0,0,.12);padding:8px;gap:8px;}
.mobile-cta a{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:8px 4px;border-radius:10px;font-weight:700;font-size:.82rem;color:#fff;}
.mobile-cta a i{font-size:1.15rem;}
.mobile-cta .mc-tel{background:var(--navy);}
.mobile-cta .mc-line{background:#06c755;}
.mobile-cta .mc-mail{background:var(--gold-deep);}

/* =========================================================
   レスポンシブ
   ========================================================= */
@media(max-width:960px){
  .hero-inner{grid-template-columns:1fr;gap:32px;}
  .grid--4{grid-template-columns:repeat(2,1fr);}
  .footer-grid{grid-template-columns:1fr 1fr;}
}
@media(max-width:820px){
  .main-nav,.header-phone{display:none;}
  .menu-toggle{display:block;}
  .header-inner{padding:10px 16px;}
  .grid--2,.grid--3,.grid--4{grid-template-columns:1fr;}
  .worry-list{grid-template-columns:1fr;}
  .dual-badge .plus{width:100%;justify-content:center;}
  .section{padding:52px 0;}
  .mobile-cta{display:flex;}
  body{padding-bottom:64px;}
  .footer-grid{grid-template-columns:1fr;gap:28px;}
}
@media(max-width:480px){
  .hero-inner{padding:48px 16px 60px;}
  .hero-stat{min-width:calc(50% - 7px);}
  .btn{width:100%;}
  .hero-cta .btn{width:100%;}
}
