/* ========== top_redesign.css ========== */
/* トップページ リデザイン用スタイル */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Noto Sans JP',sans-serif;color:#1a1a2e;line-height:1.7;background:#f0f2f5;overflow-x:hidden}
a{text-decoration:none;color:inherit}
ul{list-style:none}

/* ========== カラーテーマ ========== */
:root,[data-theme="sougou"]{
  --p:#16a085;--pd:#0e8c73;--pl:#1abc9c;--pm:#e8f8f5;--pp:#f8fffe;
  --hero-bg:#1a1a2e;
}
[data-theme="matsudo"]{--p:#1976D2;--pd:#1565C0;--pl:#42A5F5;--pm:#E3F2FD;--pp:#f5faff;--hero-bg:#0d1b3e}
[data-theme="adachi"]{--p:#EF6C00;--pd:#E65100;--pl:#FFA726;--pm:#FFF3E0;--pp:#fffcf5;--hero-bg:#2e1a00}
[data-theme="edogawa"]{--p:#7B1FA2;--pd:#6A1B9A;--pl:#AB47BC;--pm:#F3E5F5;--pp:#fcf5ff;--hero-bg:#1a0a2e}
[data-theme="arakawa"]{--p:#D32F2F;--pd:#C62828;--pl:#EF5350;--pm:#FFEBEE;--pp:#fff8f8;--hero-bg:#2e0a0a}
[data-theme="kita"]{--p:#00897B;--pd:#00695C;--pl:#26A69A;--pm:#E0F2F1;--pp:#f5fffd;--hero-bg:#0a1a18}

/* ========== 画像切替ナビ ========== */
.img-switcher{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  background:linear-gradient(135deg,#1a1a2e 0%,#2d3748 100%);
  color:#fff;padding:10px 16px;box-shadow:0 4px 20px rgba(0,0,0,.3);
}
.img-switcher-inner{max-width:1200px;margin:0 auto}
.img-switcher h3{font-size:13px;font-weight:700;margin-bottom:8px;display:flex;align-items:center;gap:6px}
.img-switcher h3 i{color:var(--pl)}
.img-tabs{display:flex;gap:6px;flex-wrap:wrap}
.img-tab{
  padding:6px 14px;border-radius:8px;font-size:11px;font-weight:600;
  cursor:pointer;transition:.2s;border:1.5px solid rgba(255,255,255,.15);
  background:transparent;color:rgba(255,255,255,.6);font-family:inherit;
  white-space:nowrap;
}
.img-tab:hover{border-color:rgba(255,255,255,.4);color:#fff}
.img-tab.active{background:var(--p);border-color:var(--p);color:#fff}
.img-tab .src{font-size:9px;opacity:.6;display:block;margin-top:1px}

/* ========== ヘッダー ========== */
.header{background:#fff;border-bottom:1px solid #e2e8f0;position:sticky;top:0;z-index:100}
.has-switcher .header{top:84px}
.header-inner{
  max-width:1200px;margin:0 auto;padding:0 16px;
  display:flex;align-items:center;height:56px;justify-content:space-between;
}
.logo{display:flex;align-items:center;gap:8px}
.logo-mark{flex-shrink:0}
.logo-mark img{height:38px;width:auto;display:block}
.logo-text{font-size:18px;font-weight:900;color:#1a1a2e}
.logo-text small{display:block;font-size:9px;color:#718096;font-weight:400;letter-spacing:.05em}
.logo-theme-img{height:38px;width:auto;display:block}
.nav-center{display:flex;gap:2px;align-items:center}
.nav-center a{padding:6px 14px;border-radius:6px;font-size:12px;font-weight:500;color:#4a5568;transition:.2s}
.nav-center a:hover{background:var(--pm);color:var(--p)}
.nav-center a.active{background:var(--pm);color:var(--p);font-weight:700}
.hdr-right{display:flex;gap:8px;align-items:center}
.btn-os{padding:6px 14px;border:1.5px solid #cbd5e0;border-radius:6px;font-size:12px;color:#4a5568;transition:.2s;background:transparent}
.btn-os:hover{border-color:var(--p);color:var(--p)}
.btn-ps{padding:6px 14px;border-radius:6px;font-size:12px;color:#fff;background:var(--p);transition:.2s;border:1.5px solid var(--p)}
.btn-ps:hover{background:var(--pd)}
[data-theme="sougou"] .hdr-right{visibility:hidden}
[data-theme="sougou"] .sp-auth{display:none}
[data-theme="sougou"] .fc-auth{display:none}
[data-theme="sougou"] .fg{grid-template-columns:repeat(3,1fr)}

/* ========== ヒーロー（写真バナー版） ========== */
.hero{position:relative;overflow:hidden;height:340px}
.hero-bg{
  position:absolute;top:0;left:0;right:0;bottom:0;
  background-size:cover;background-position:center 40%;
  transition:background-image .5s ease;
}
.hero-overlay{
  position:absolute;top:0;left:0;right:0;bottom:0;
  background:linear-gradient(135deg,rgba(22,160,133,.65) 0%,rgba(26,26,46,.45) 50%,rgba(26,26,46,.2) 100%);
}
.hero-grid{
  max-width:1200px;margin:0 auto;padding:0 20px;
  position:relative;z-index:2;height:340px;
  display:flex;align-items:center;justify-content:center;
}
.hero-content{padding:48px 0;text-align:center}
.hero-label{
  display:inline-flex;align-items:center;gap:5px;
  background:rgba(255,255,255,.15);color:rgba(255,255,255,.9);
  padding:4px 12px;border-radius:50px;font-size:11px;font-weight:600;
  margin-bottom:16px;backdrop-filter:blur(4px);
}
.hero-content h2{font-size:clamp(28px,4vw,44px);font-weight:900;color:#fff;line-height:1.2;margin-bottom:12px;text-shadow:0 2px 16px rgba(0,0,0,.3)}
.hero-content h2 span{background:linear-gradient(90deg,#fff,rgba(255,255,255,.85));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-content p{font-size:15px;color:rgba(255,255,255,.7);margin-bottom:28px;text-shadow:0 1px 4px rgba(0,0,0,.2);white-space:nowrap}
.hero-cards{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.hero-card{
  display:flex;flex-direction:column;align-items:center;text-align:center;
  background:rgba(255,255,255,.15);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border:1.5px solid rgba(255,255,255,.25);border-radius:14px;padding:24px 32px;
  transition:.3s;min-width:160px;
}
.hero-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.2);background:var(--p);border-color:var(--p);color:#fff}
.hero-card:hover .fci{background:rgba(255,255,255,.2)}
.hero-card:hover .fci i{color:#fff}
.hero-card:hover h3{color:#fff}
.hero-card:hover p{color:rgba(255,255,255,.7)}
.hero-card .fci{width:80px;height:80px;background:rgba(255,255,255,.15);border-radius:16px;display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.hero-card .fci i{font-size:40px;color:#fff}
.hero-card h3{font-size:20px;font-weight:700;color:#fff;margin-bottom:4px}
.hero-card p{font-size:11px;color:rgba(255,255,255,.6);white-space:nowrap}
[data-theme="sougou"] .hero-card-auth{display:none}
.hero-btns{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}
.hb{padding:14px 30px;border-radius:10px;font-size:14px;font-weight:700;transition:.25s}
.hb-p{background:#fff;color:var(--p);box-shadow:0 4px 16px rgba(0,0,0,.15)}
.hb-p:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.2)}
.hb-g{background:transparent;color:rgba(255,255,255,.85);border:1.5px solid rgba(255,255,255,.35)}
.hb-g:hover{border-color:#fff;color:#fff}

/* 画像情報表示 */
.hero-img-info{
  position:absolute;bottom:12px;right:16px;z-index:3;
  background:rgba(0,0,0,.55);color:rgba(255,255,255,.8);
  padding:6px 14px;border-radius:8px;font-size:11px;
  backdrop-filter:blur(6px);
}
.hero-img-info a{color:var(--pl);text-decoration:underline}

/* ========== 2カラムカード ========== */
.dual{background:var(--pp);padding:48px 16px}
.dual-grid{max-width:900px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:20px}
.dc{background:#fff;border-radius:14px;overflow:hidden;box-shadow:0 2px 16px rgba(0,0,0,.04);transition:.3s}
.dc:hover{transform:translateY(-2px)}
.dc-header{background:linear-gradient(135deg,var(--p),var(--pl));padding:20px;color:#fff}
.dc-header h3{font-size:16px;font-weight:700;margin-bottom:2px}
.dc-header p{font-size:12px;opacity:.8}
.dc-body{padding:16px 20px}
.dc-body a{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid #f0f0f0;font-size:13px;transition:.2s}
.dc-body a:hover{color:var(--p)}
.dc-body a:last-child{border-bottom:none}
.dc-body a i{color:var(--p);font-size:10px}
.dc-more{display:flex;align-items:center;justify-content:center;gap:4px;margin-top:8px;padding:10px 0 4px !important;border-top:1px solid #e2e8f0 !important;border-bottom:none !important;font-weight:700;color:var(--p) !important;font-size:13px}

/* ========== 事業者様向けCTA ========== */
.biz-cta{position:relative;overflow:hidden;min-height:340px}
.biz-cta-bg{
  position:absolute;top:0;left:0;right:0;bottom:0;
  background-size:cover;background-position:center 60%;
  transition:background-image .5s ease;
}
.biz-cta-overlay{
  position:absolute;top:0;left:0;right:0;bottom:0;
  background:linear-gradient(135deg,rgba(26,26,46,.82) 0%,rgba(45,55,72,.6) 50%,rgba(26,26,46,.4) 100%);
}
.biz-cta-inner{
  position:relative;z-index:2;
  max-width:960px;margin:0 auto;padding:56px 20px;
  display:flex;flex-direction:column;align-items:flex-start;
}
.biz-label{
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(255,255,255,.15);color:rgba(255,255,255,.9);
  padding:5px 14px;border-radius:50px;font-size:11px;font-weight:700;
  margin-bottom:16px;backdrop-filter:blur(4px);
}
.biz-cta-text h2{font-size:clamp(22px,3vw,30px);font-weight:900;color:#fff;line-height:1.4;margin-bottom:12px;text-shadow:0 2px 12px rgba(0,0,0,.3)}
.biz-cta-text p{font-size:14px;color:rgba(255,255,255,.7);line-height:1.8;margin-bottom:24px;text-shadow:0 1px 4px rgba(0,0,0,.2)}
.biz-btn{
  display:inline-flex;align-items:center;
  padding:14px 32px;border-radius:10px;font-size:14px;font-weight:700;
  color:#1a1a2e;background:linear-gradient(135deg,#fff 0%,#e2e8f0 100%);
  transition:.3s;box-shadow:0 4px 16px rgba(0,0,0,.2);
}
.biz-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.3)}
.biz-img-info{
  position:absolute;bottom:12px;right:16px;z-index:3;
  background:rgba(0,0,0,.55);color:rgba(255,255,255,.8);
  padding:6px 14px;border-radius:8px;font-size:11px;
  backdrop-filter:blur(6px);
}
.biz-img-info a{color:var(--pl);text-decoration:underline}
.biz-img-switcher{
  position:absolute;top:12px;right:16px;z-index:3;
  display:flex;gap:4px;
}
.biz-img-switcher button{
  width:28px;height:28px;border-radius:50%;border:2px solid rgba(255,255,255,.5);
  background:rgba(0,0,0,.4);color:#fff;font-size:11px;font-weight:700;cursor:pointer;
  font-family:inherit;transition:.2s;backdrop-filter:blur(4px);
}
.biz-img-switcher button.active{background:var(--p);border-color:#fff}

/* ========== 新着情報 ========== */
.news{padding:48px 16px}
.news-inner{max-width:720px;margin:0 auto}
.sh{text-align:center;margin-bottom:36px}
.sh h2{font-size:20px;font-weight:900}
.sh p{font-size:13px;color:#a0aec0;margin-top:6px}
.ni{display:flex;align-items:center;gap:12px;padding:10px 12px;border-bottom:1px solid #e2e8f0;transition:.2s;border-radius:6px}
.ni:hover{background:var(--pm)}
.nd{font-size:11px;color:#a0aec0;min-width:78px;font-family:monospace}
.nb{font-size:9px;background:var(--p);color:#fff;padding:2px 8px;border-radius:3px;font-weight:700;white-space:nowrap}
.nt{font-size:13px;flex:1}
.nt a{transition:.2s}
.nt a:hover{color:var(--p)}

/* ========== フッター ========== */
.footer{background:#1a1a2e;color:rgba(255,255,255,.45);padding:36px 16px 20px}
.footer-inner{max-width:1200px;margin:0 auto}
.f-top{display:grid;grid-template-columns:1fr 2fr;gap:32px;margin-bottom:24px}
.f-brand .fl{color:#fff;font-size:20px;font-weight:900;display:block;margin-bottom:6px}
.f-brand p{font-size:11px;line-height:1.6}
.f-pmark{display:flex;align-items:center;gap:10px;margin-top:14px}
.pmark-img{height:56px;width:auto}
.f-pmark small{font-size:10px;color:rgba(255,255,255,.5);line-height:1.4}
.f-links{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.f-links h4{color:rgba(255,255,255,.7);font-size:12px;margin-bottom:8px}
.f-links a{display:block;font-size:11px;color:rgba(255,255,255,.35);padding:2px 0;transition:.2s}
.f-links a:hover{color:var(--pl)}
.f-copy{border-top:1px solid rgba(255,255,255,.06);padding-top:16px;font-size:10px;text-align:center}

/* ========== SPクイックアクション ========== */
.sp-quick{display:none}
.sp-quick-inner{padding:16px}
.sp-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.sp-btn{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:6px;padding:18px 8px;background:#fff;border:1px solid #e2e8f0;
  border-radius:12px;text-align:center;transition:.2s;
}
.sp-btn:hover,.sp-btn:active{border-color:var(--p);background:var(--pm)}
.sp-btn i{font-size:22px;color:var(--p)}
.sp-btn span{font-size:12px;font-weight:700;color:#1a1a2e}
.sp-search{display:flex;gap:8px}
.sp-search input{
  flex:1;padding:12px 14px;border:2px solid #e2e8f0;border-radius:10px;
  font-size:14px;outline:none;font-family:inherit;background:#fff;
}
.sp-search input:focus{border-color:var(--p)}
.sp-search button{
  padding:12px 18px;background:var(--p);color:#fff;border:none;
  border-radius:10px;font-size:14px;font-weight:700;cursor:pointer;
  white-space:nowrap;font-family:inherit;
}

/* ========== テーマスイッチャー（開発用） ========== */
.tsw{
  position:fixed;bottom:10px;right:10px;z-index:999;
  background:#fff;border-radius:12px;box-shadow:0 4px 20px rgba(0,0,0,.15);
  padding:8px 10px;font-size:10px;
}
.tsw label{display:block;font-weight:700;margin-bottom:4px;color:#333}
.tsw button{
  display:block;width:100%;padding:4px 8px;margin-bottom:2px;
  border:none;border-radius:4px;cursor:pointer;font-size:10px;font-weight:600;
  text-align:left;color:#fff;transition:.2s;font-family:inherit;
}
.tsw button:hover{opacity:.85}

/* ========== サブページ共通 ========== */
.page-hero{
  background:linear-gradient(135deg,var(--p) 0%,var(--pd) 100%);
  padding:48px 16px 40px;text-align:center;color:#fff;
}
.page-hero h1{font-size:clamp(22px,3vw,32px);font-weight:900;margin-bottom:6px}
.page-hero p{font-size:13px;opacity:.75}
.breadcrumb-bar{
  background:#fff;border-bottom:1px solid #e2e8f0;padding:10px 16px;font-size:12px;color:#a0aec0;
}
.breadcrumb-bar a{color:var(--p);transition:.2s}
.breadcrumb-bar a:hover{text-decoration:underline}
.breadcrumb-inner{max-width:1100px;margin:0 auto;display:flex;gap:6px;align-items:center}
.breadcrumb-inner i{font-size:8px;color:#cbd5e0}
.page-body{max-width:960px;margin:0 auto;padding:40px 16px 56px}

/* ========== ガイドページ ========== */
.guide-intro{text-align:center;margin-bottom:40px}
.guide-intro h2{font-size:18px;font-weight:700;margin-bottom:6px}
.guide-intro p{font-size:13px;color:#718096}

.guide-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:48px}
.guide-card{
  background:#fff;border:1px solid #e2e8f0;border-radius:14px;
  padding:24px 16px;text-align:center;transition:.3s;display:block;
  position:relative;overflow:hidden;
}
.guide-card::before{
  content:'';position:absolute;inset:0;border-radius:14px;
  background:linear-gradient(135deg,var(--p),var(--pl));opacity:0;transition:.3s;z-index:0;
}
.guide-card:hover::before{opacity:1}
.guide-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(22,160,133,.15);border-color:transparent}
.guide-card>*{position:relative;z-index:1}
.guide-card:hover .guide-icon{background:rgba(255,255,255,.2)}
.guide-card:hover h3,.guide-card:hover p,.guide-card:hover .guide-step{color:#fff}
.guide-card:hover .guide-icon i{color:#fff}
.guide-icon{
  width:56px;height:56px;background:var(--pm);border-radius:14px;
  display:flex;align-items:center;justify-content:center;margin:0 auto 12px;transition:.3s;
}
.guide-icon i{font-size:22px;color:var(--p);transition:.3s}
.guide-step{
  display:inline-block;font-size:10px;font-weight:700;color:var(--p);
  background:var(--pm);padding:2px 10px;border-radius:50px;margin-bottom:10px;transition:.3s;
}
.guide-card h3{font-size:14px;font-weight:700;margin-bottom:4px;transition:.3s}
.guide-card p{font-size:11px;color:#a0aec0;transition:.3s}

/* ガイド動画セクション */
.guide-video{margin-bottom:48px}
.guide-video h2{font-size:18px;font-weight:700;text-align:center;margin-bottom:24px}
.video-layout{display:grid;grid-template-columns:240px 1fr;gap:16px;background:#fff;border-radius:14px;border:1px solid #e2e8f0;overflow:hidden}
.video-nav{padding:16px;display:flex;flex-direction:column;gap:4px;border-right:1px solid #e2e8f0}
.video-nav-item{
  display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:8px;
  font-size:13px;font-weight:500;color:#4a5568;cursor:pointer;transition:.2s;border:none;background:transparent;
  text-align:left;font-family:inherit;width:100%;
}
.video-nav-item:hover{background:var(--pm);color:var(--p)}
.video-nav-item.active{background:var(--pm);color:var(--p);font-weight:700}
.video-nav-item i{font-size:14px;color:var(--p);min-width:18px;text-align:center}
.video-player{padding:16px;display:flex;align-items:center;justify-content:center;min-height:360px;background:#000;border-radius:0 10px 10px 0}
.video-player iframe{width:100%;height:100%;min-height:340px;border:none;border-radius:8px}

/* ガイドPDFリスト */
.guide-pdf-list{display:flex;flex-direction:column;gap:8px;margin-bottom:48px}
.guide-pdf-item{
  display:flex;align-items:center;gap:12px;padding:14px 18px;
  background:#fff;border:1px solid #e2e8f0;border-radius:10px;transition:.2s;
}
.guide-pdf-item:hover{border-color:var(--p);background:var(--pm)}
.guide-pdf-item i{font-size:18px;color:var(--p)}
.guide-pdf-item span{font-size:13px;font-weight:600;flex:1}
.guide-pdf-item .pdf-badge{font-size:10px;background:#e2e8f0;color:#718096;padding:2px 8px;border-radius:4px;font-weight:600}

/* テキスト版リンク */
.guide-text-link{
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:16px;background:var(--pm);border-radius:10px;font-size:14px;font-weight:700;color:var(--p);transition:.2s;
}
.guide-text-link:hover{background:var(--p);color:#fff}
.guide-text-link i{font-size:16px}

/* ========== サブページ コンテンツ共通 ========== */
.page-card{
  background:#fff;border-radius:14px;border:1px solid #e2e8f0;
  padding:32px;margin-bottom:24px;box-shadow:0 2px 12px rgba(0,0,0,.03);
}
.page-card h3{font-size:16px;font-weight:700;color:var(--p);margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid var(--pm)}
.page-card h4{font-size:14px;font-weight:700;color:var(--p);margin-top:16px;margin-bottom:8px}
.page-card p{font-size:13px;color:#4a5568;margin-bottom:8px}
.page-card ul,.page-card ol{padding-left:20px;margin-bottom:8px}
.page-card li{font-size:13px;color:#4a5568;margin-bottom:4px}
.page-card a{color:var(--p);transition:.2s}
.page-card a:hover{text-decoration:underline}
.page-section-title{font-size:15px;font-weight:700;color:#1a1a2e;margin:28px 0 12px;padding-left:12px;border-left:3px solid var(--p)}

/* テーブル共通 */
.page-table{width:100%;border-collapse:collapse;margin-bottom:16px}
.page-table th,.page-table td{padding:12px 16px;border-bottom:1px solid #e2e8f0;font-size:13px;text-align:left;vertical-align:top}
.page-table th{background:var(--pp);color:#4a5568;font-weight:600;width:30%;white-space:nowrap}
.page-table td{color:#1a1a2e}
.page-table tr:last-child th,.page-table tr:last-child td{border-bottom:none}

/* ========== FAQ ========== */
.faq-category{
  display:flex;align-items:center;gap:8px;
  font-size:15px;font-weight:700;color:#fff;
  background:linear-gradient(135deg,var(--p),var(--pl));
  padding:12px 18px;border-radius:10px;margin:24px 0 12px;
}
.faq-category:first-child{margin-top:0}
.faq-category i{font-size:14px}
.faq-item{
  background:#fff;border:1px solid #e2e8f0;border-radius:10px;
  margin-bottom:8px;overflow:hidden;transition:.2s;
}
.faq-item:hover{border-color:var(--pl)}
.faq-q{
  display:flex;align-items:center;gap:10px;padding:14px 18px;
  cursor:pointer;font-size:13px;font-weight:600;color:#1a1a2e;
  background:#fff;border:none;width:100%;text-align:left;font-family:inherit;transition:.2s;
}
.faq-q:hover{background:var(--pp)}
.faq-q .q-mark{
  flex-shrink:0;width:28px;height:28px;border-radius:8px;
  background:var(--pm);color:var(--p);font-weight:900;font-size:14px;
  display:flex;align-items:center;justify-content:center;
}
.faq-q .q-text{flex:1}
.faq-q .q-arrow{color:#cbd5e0;font-size:12px;transition:.3s}
.faq-item.open .faq-q .q-arrow{transform:rotate(180deg);color:var(--p)}
.faq-a{
  display:none;padding:0 18px 16px 56px;font-size:13px;color:#4a5568;line-height:1.8;
  border-top:1px solid #e2e8f0;
}
.faq-item.open .faq-a{display:block;padding-top:14px}

/* ========== お問い合わせフォーム ========== */
.form-group{margin-bottom:16px}
.form-group label,.form-label{display:block;font-size:13px;font-weight:600;color:#4a5568;margin-bottom:6px}
.form-label .req{color:#e53e3e;font-size:11px;margin-left:4px}
.form-input,.form-textarea,.form-select{
  width:100%;padding:10px 14px;border:2px solid #e2e8f0;border-radius:8px;
  font-size:13px;font-family:inherit;background:var(--pp);outline:none;transition:.2s;
}
.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:var(--p)}
.form-textarea{min-height:120px;resize:vertical}
.form-checkbox-group{display:flex;flex-wrap:wrap;gap:12px}
.form-checkbox-group label{
  display:flex;align-items:center;gap:6px;font-size:13px;color:#4a5568;cursor:pointer;
}
.form-checkbox-group input[type="checkbox"]{accent-color:var(--p);width:16px;height:16px}
.form-agree{
  background:var(--pm);border-radius:10px;padding:16px 20px;margin-bottom:24px;
  display:flex;align-items:center;gap:10px;font-size:14px;font-weight:600;
}
.form-agree input[type="checkbox"]{accent-color:var(--p);width:20px;height:20px}
.btn-primary-rd{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  padding:12px 32px;background:var(--p);color:#fff;border:none;border-radius:10px;
  font-size:14px;font-weight:700;cursor:pointer;transition:.2s;font-family:inherit;
}
.btn-primary-rd:hover{background:var(--pd);transform:translateY(-1px)}
.btn-outline-rd{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  padding:12px 32px;background:transparent;color:var(--p);border:2px solid var(--p);border-radius:10px;
  font-size:14px;font-weight:700;cursor:pointer;transition:.2s;font-family:inherit;
}
.btn-outline-rd:hover{background:var(--pm)}

/* モーダルオーバーレイ */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:9999}
.modal-box{background:#fff;border-radius:16px;padding:2rem 2.5rem;max-width:560px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.modal-box p{font-size:14px;line-height:1.8;color:#4a5568}

.form-error{
  background:#FFF5F5;border:1px solid #FED7D7;border-radius:10px;
  padding:14px 18px;margin-bottom:20px;font-size:13px;color:#C53030;
}
.form-confirm-table{width:100%;border-collapse:collapse}
.form-confirm-table th,.form-confirm-table td{padding:12px 16px;border-bottom:1px solid #e2e8f0;font-size:13px;text-align:left;vertical-align:top}
.form-confirm-table th{background:var(--pp);font-weight:600;width:30%;color:#4a5568}
.phone-cta{
  background:var(--pm);border-radius:14px;padding:24px;text-align:center;margin-top:32px;
}
.phone-cta h3{font-size:16px;font-weight:700;color:var(--p);margin-bottom:4px}
.phone-cta .phone-num{font-size:28px;font-weight:900;color:#1a1a2e;margin-bottom:4px}
.phone-cta p{font-size:12px;color:#718096}

/* ========== サイトマップ ========== */
.sitemap-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.sitemap-col h3{font-size:14px;font-weight:700;color:var(--p);margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid var(--pm)}
.sitemap-col ul{padding:0}
.sitemap-col li{margin-bottom:6px}
.sitemap-col li a{
  display:flex;align-items:center;gap:8px;padding:8px 12px;
  font-size:13px;color:#4a5568;border-radius:6px;transition:.2s;
}
.sitemap-col li a:hover{background:var(--pm);color:var(--p)}
.sitemap-col li a i{font-size:10px;color:var(--p)}
.sitemap-col li ul{padding-left:24px;margin-top:4px}
.sitemap-col li ul li a{font-size:12px;padding:5px 12px}

/* ========== エラーページ ========== */
.error-content{text-align:center;padding:60px 16px}
.error-content .error-icon{font-size:60px;color:#cbd5e0;margin-bottom:16px}
.error-content h2{font-size:22px;font-weight:700;color:#1a1a2e;margin-bottom:8px}
.error-content p{font-size:14px;color:#718096;margin-bottom:24px}

/* ========== 会社概要テーブル ========== */
.company-grid{display:grid;grid-template-columns:2fr 1fr;gap:24px;align-items:start}
.company-photo{border-radius:14px;overflow:hidden}
.company-photo img{width:100%;height:auto;display:block;border-radius:14px}

@media(max-width:768px){
  .img-switcher{display:none !important}
  .header,.has-switcher .header{top:0 !important;position:sticky}
  .header-inner{overflow:hidden}
  .hero{display:none}
  .sp-quick{display:block;background:var(--pp);border-bottom:1px solid #e2e8f0}
  .nav-center{display:none !important}
  .hdr-right{display:none !important}
  .dual-grid{grid-template-columns:1fr}
  .f-top{grid-template-columns:1fr}
  .f-links{grid-template-columns:repeat(2,1fr)}
  .guide-grid{grid-template-columns:repeat(2,1fr)}
  .video-layout{grid-template-columns:1fr}
  .video-nav{flex-direction:row;flex-wrap:wrap;border-right:none;border-bottom:1px solid #e2e8f0}
  .video-nav-item{font-size:12px;padding:8px 10px}
  .video-player{min-height:240px;border-radius:0 0 10px 10px}
  .page-card{padding:20px 16px}
  .page-table th{width:auto;display:block;border-bottom:none;padding-bottom:4px}
  .page-table td{display:block;padding-top:0}
  .company-grid{grid-template-columns:1fr}
  .sitemap-grid{grid-template-columns:1fr}
  .form-confirm-table th{width:auto;display:block;border-bottom:none;padding-bottom:4px}
  .form-confirm-table td{display:block;padding-top:0}
  .biz-cta{min-height:280px}
  .biz-cta-inner{padding:40px 16px}
  .biz-img-switcher{top:10px;right:10px}
}

/* ========== パターンB：スイッチ風ヒーローボタン ========== */
.hero-cards--switch{display:flex;gap:18px;justify-content:center;flex-wrap:wrap}
.hero-switch{
  display:flex;align-items:center;gap:16px;
  background:linear-gradient(180deg,#fff 0%,#e8e8e8 100%);
  border:2px solid #d0d0d0;
  border-radius:60px;padding:14px 40px 14px 20px;
  min-width:240px;
  box-shadow:0 4px 0 #b0b0b0,0 6px 16px rgba(0,0,0,.18);
  transition:all .15s ease;
  position:relative;
  cursor:pointer;
}
.hero-switch:active{
  transform:translateY(3px);
  box-shadow:0 1px 0 #b0b0b0,0 2px 6px rgba(0,0,0,.12);
}
.hero-switch:hover{
  transform:translateY(1px);
  box-shadow:0 2px 0 var(--pd),0 4px 12px rgba(0,0,0,.2);
  background:linear-gradient(180deg,var(--pl) 0%,var(--p) 100%);
  border-color:var(--pd);
}
.hero-switch .sw-icon{
  width:64px;height:64px;
  background:var(--p);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  box-shadow:inset 0 -2px 4px rgba(0,0,0,.15),0 2px 6px rgba(0,0,0,.12);
  flex-shrink:0;
  transition:all .15s ease;
}
.hero-switch .sw-icon i{font-size:28px;color:#fff;transition:transform .15s ease}
.hero-switch:hover .sw-icon{
  background:#fff;
  box-shadow:inset 0 -2px 4px rgba(0,0,0,.08),0 2px 8px rgba(0,0,0,.15);
}
.hero-switch:hover .sw-icon i{color:var(--p);transform:scale(1.1)}
.hero-switch .sw-text h3{
  font-size:20px;font-weight:800;color:#1a1a2e;
  margin-bottom:2px;white-space:nowrap;transition:color .15s ease;
  text-align:center;padding-top:6px;
}
.hero-switch .sw-text p{
  font-size:12px;color:#718096;white-space:nowrap;transition:color .15s ease;
  text-align:center;
}
.hero-switch:hover .sw-text h3{color:#fff}
.hero-switch:hover .sw-text p{color:rgba(255,255,255,.8)}
.hero-switch::after{
  content:'\f054';font-family:'Font Awesome 6 Free';font-weight:900;
  position:absolute;right:20px;top:50%;transform:translateY(-50%);
  font-size:14px;color:#a0aec0;transition:all .15s ease;
}
.hero-switch:hover::after{color:rgba(255,255,255,.7);right:16px}
[data-theme="sougou"] .hero-switch-auth{display:none}
