/*
Theme Name: Water Karute Theme
Theme URI: https://mizumore-karute.com/
Author: 水道業者カルテ運営
Author URI: https://mizumore-karute.com/
Description: 水道工事・水漏れ修理特化口コミサイト「水道業者カルテ」専用テーマ。モバイルファースト、信頼感を重視した青系デザイン。
Version: 1.0.0
Requires at least: 6.4
Tested up to: 6.7
Requires PHP: 8.0
License: Proprietary
Text Domain: water-karute-theme
*/

/* ==========================================================================
   CSS カスタムプロパティ（カラーシステム）
   ========================================================================== */

:root {
	/* ── ブランドカラー（水道業者カルテ v4: 行政・医療・比較サイト中間トーン） ── */
	--color-primary:      #0E7490;   /* 深シアン — 検索・CTA・リンク */
	--color-primary-dark: #164E63;   /* ヘッダー・重要見出し・ホバー */
	--color-secondary:    #164E63;   /* 信頼感のあるネイビー（primary-darkと統一） */
	--color-accent:       #F59E0B;   /* アンバー — 高額請求注意・見積チェック */
	--color-bg:           #F8FAFC;   /* ページ背景（薄いグレー） */
	--color-text:         #0F172A;   /* 本文（純粋な濃色・読みやすい） */
	--color-text-light:   #475569;   /* 補足テキスト（slate-600） */
	--color-text-muted:   #64748B;   /* サブテキスト（slate-500） */
	--color-border:       #E2E8F0;   /* 境界線 */
	--color-white:        #FFFFFF;
	--color-success:      #059669;   /* 確認済み口コミ・審査済み */
	--color-warning:      #F59E0B;   /* 注意喚起（=accent） */
	--color-danger:       #DC2626;   /* 入力エラー・強い警告のみ */
	--color-info:         #0891B2;   /* 情報バッジ */

	/* カルテ専用カラー */
	--color-karute-tab:   #0E7490;   /* カード左ストライプ（通常） */
	--color-trust-badge:  #164E63;   /* 指定工事店バッジ */
	--color-pending-tab:  #A0B4BE;   /* 口コミ0件カードのストライプ */
	--color-pr-badge:     #B45309;   /* PRバッジ（ダークアンバー系） */

	/* タイポグラフィ */
	--font-base:         'Hiragino Kaku Gothic ProN', 'Hiragino Sans', 'Noto Sans JP', 'Yu Gothic', 'Meiryo', sans-serif;
	--font-size-base:    16px;
	--font-size-sm:      14px;
	--font-size-xs:      12px;
	--font-size-lg:      18px;
	--font-size-xl:      24px;
	--font-size-2xl:     32px;
	--line-height-base:  1.8;
	--line-height-tight: 1.4;

	/* スペーシング */
	--space-xs:  4px;
	--space-sm:  8px;
	--space-md:  16px;
	--space-lg:  24px;
	--space-xl:  32px;
	--space-2xl: 48px;
	--space-3xl: 64px;

	/* レイアウト */
	--container-max:  1200px;
	--content-max:    800px;
	--sidebar-width:  300px;
	--border-radius:    8px;   /* 親しみ感のため少し大きく */
	--border-radius-lg: 14px;

	/* シャドウ */
	--shadow-sm:  0 1px 3px rgba(15,61,82,0.08);
	--shadow-md:  0 2px 8px rgba(15,61,82,0.12);
	--shadow-lg:  0 4px 16px rgba(15,61,82,0.16);

	/* トランジション */
	--transition-fast: 150ms ease;
	--transition-base: 250ms ease;
}

/* ==========================================================================
   リセット・ベーススタイル
   ========================================================================== */

*, *::before, *::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

html {
	font-size: var(--font-size-base);
	-webkit-text-size-adjust: 100%;
	scroll-behavior: smooth;
}

body {
	font-family: var(--font-base);
	font-size: var(--font-size-base);
	line-height: var(--line-height-base);
	color: var(--color-text);
	background-color: var(--color-bg);
	-webkit-font-smoothing: antialiased;
}

img {
	max-width: 100%;
	height: auto;
	display: block;
}

a {
	color: var(--color-primary);
	text-decoration: none;
	transition: color var(--transition-fast);
}

a:hover,
a:focus {
	color: var(--color-secondary);
	text-decoration: underline;
}

a:focus-visible {
	outline: 3px solid var(--color-primary);
	outline-offset: 2px;
}

ul, ol {
	list-style: none;
}

button {
	cursor: pointer;
	font-family: inherit;
}

/* ==========================================================================
   レイアウト
   ========================================================================== */

.container {
	width: 100%;
	max-width: var(--container-max);
	margin-inline: auto;
	padding-inline: var(--space-md);
}

@media (min-width: 768px) {
	.container {
		padding-inline: var(--space-xl);
	}
}

.site-wrapper {
	min-height: 100vh;
	display: flex;
	flex-direction: column;
}

.site-main {
	flex: 1;
	padding-block: var(--space-xl);
}

/* トップLP専用: padding除去・フル幅 */
.site-main.wkc-top-lp {
	padding: 0;
}

/* コンテンツ + サイドバー */
.content-sidebar-wrap {
	display: grid;
	gap: var(--space-xl);
}

@media (min-width: 1024px) {
	.content-sidebar-wrap {
		grid-template-columns: 1fr var(--sidebar-width);
		align-items: start;
	}
}

/* ==========================================================================
   サイトヘッダー
   ========================================================================== */

#site-header {
	background-color: var(--color-white);
	border-bottom: 3px solid var(--color-primary);
	position: sticky;
	top: 0;
	z-index: 1000;
	box-shadow: var(--shadow-md);
}

.header-inner {
	display: flex;
	align-items: center;
	gap: var(--space-md);
	padding-block: var(--space-sm);
}

/* サイトブランディング */
.site-branding {
	flex-shrink: 0;
}

.site-branding a {
	display: flex;
	align-items: center;
	gap: var(--space-sm);
	text-decoration: none;
}

.site-branding .custom-logo {
	height: 48px;
	width: auto;
}

.site-title {
	font-size: var(--font-size-lg);
	font-weight: 700;
	color: var(--color-primary);
	line-height: 1.2;
}

.site-description {
	font-size: var(--font-size-xs);
	color: var(--color-text-light);
}

/* グローバルナビ */
.primary-nav {
	display: none;
	flex: 1;
	min-width: 0;
}

@media (min-width: 1024px) {
	.primary-nav {
		display: flex;
	}
}

.primary-nav ul {
	display: flex;
	gap: var(--space-xs);
}

.primary-nav a {
	display: block;
	padding: var(--space-sm) var(--space-md);
	color: var(--color-text);
	font-weight: 500;
	border-radius: var(--border-radius);
	transition: background-color var(--transition-fast), color var(--transition-fast);
	white-space: nowrap;
}

.primary-nav a:hover {
	background-color: rgba(14,116,144,0.08);
	color: var(--color-primary);
	text-decoration: none;
}
.primary-nav .current-menu-item > a,
.primary-nav .current-page-ancestor > a {
	color: var(--color-primary);
	font-weight: 700;
	border-bottom: 2px solid var(--color-primary);
	background-color: transparent;
}

/* ヘッダー検索 */
.header-search {
	display: none;
}

@media (min-width: 1024px) {
	.header-search {
		display: flex;
	}
}

.header-search .search-form {
	display: flex;
}

.header-search .search-field {
	padding: var(--space-sm) var(--space-md);
	border: 1px solid var(--color-border);
	border-right: none;
	border-radius: var(--border-radius) 0 0 var(--border-radius);
	font-size: var(--font-size-sm);
	width: 200px;
	outline: none;
}

.header-search .search-field:focus {
	border-color: var(--color-primary);
}

.header-search .search-submit {
	padding: var(--space-sm) var(--space-md);
	background-color: var(--color-primary);
	color: var(--color-white);
	border: none;
	border-radius: 0 var(--border-radius) var(--border-radius) 0;
	font-size: var(--font-size-sm);
	transition: background-color var(--transition-fast);
}

.header-search .search-submit:hover {
	background-color: var(--color-secondary);
}

/* ハンバーガーメニュー */
.menu-toggle {
	display: flex;
	align-items: center;
	gap: var(--space-xs);
	padding: var(--space-sm) var(--space-md);
	background: none;
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius);
	font-size: var(--font-size-sm);
	color: var(--color-text);
	margin-left: auto;
	white-space: nowrap;
	min-width: 72px;
	flex-shrink: 0;
}

@media (max-width: 767px) {
	.site-branding {
		flex-shrink: 1;
		min-width: 0;
		overflow: hidden;
	}
	.site-description {
		display: none;
	}
}

@media (min-width: 1024px) {
	.menu-toggle {
		display: none;
	}
}

/* モバイルメニュー */
#mobile-nav {
	display: none;
	background-color: var(--color-white);
	border-top: 1px solid var(--color-border);
	padding: var(--space-md) 0;
}

#mobile-nav.is-open {
	display: block;
}

#mobile-nav ul {
	display: flex;
	flex-direction: column;
}

#mobile-nav a {
	display: block;
	padding: var(--space-sm) var(--space-xl);
	color: var(--color-text);
	border-bottom: 1px solid var(--color-bg);
	font-weight: 500;
}

#mobile-nav a:hover {
	background-color: var(--color-bg);
	text-decoration: none;
}

/* ==========================================================================
   フッター
   ========================================================================== */

#site-footer {
	background-color: var(--color-secondary);
	color: var(--color-white);
	margin-top: auto;
}

.footer-widgets {
	padding-block: var(--space-2xl);
}

.footer-widget-area {
	display: grid;
	gap: var(--space-xl);
}

@media (min-width: 768px) {
	.footer-widget-area {
		grid-template-columns: repeat(3, 1fr);
	}
}

.footer-widget-area .widget-title {
	font-size: var(--font-size-base);
	font-weight: 700;
	border-bottom: 2px solid var(--color-primary);
	padding-bottom: var(--space-sm);
	margin-bottom: var(--space-md);
	color: var(--color-white);
}

.footer-widget-area a {
	color: rgba(255,255,255,0.85);
}

.footer-widget-area a:hover {
	color: var(--color-white);
}

.footer-widget-area ul {
	display: flex;
	flex-direction: column;
	gap: var(--space-xs);
}

.footer-widget-area li::before {
	content: "▸ ";
	color: var(--color-accent);
}

.footer-bottom {
	background-color: #0A3547;
	padding-block: var(--space-md);
}

.footer-bottom-inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--space-sm);
	text-align: center;
}

@media (min-width: 768px) {
	.footer-bottom-inner {
		flex-direction: row;
		justify-content: space-between;
	}
}

.footer-nav ul {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-md);
}

.footer-nav a {
	font-size: var(--font-size-sm);
	color: rgba(255,255,255,0.75);
}

.footer-nav a:hover {
	color: var(--color-white);
}

.site-info {
	font-size: var(--font-size-sm);
	color: rgba(255,255,255,0.6);
}

/* ==========================================================================
   サイドバー
   ========================================================================== */

.widget-area .widget {
	background-color: var(--color-white);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius);
	padding: var(--space-lg);
	margin-bottom: var(--space-lg);
}

.widget-area .widget-title {
	font-size: var(--font-size-base);
	font-weight: 700;
	color: var(--color-primary);
	border-left: 4px solid var(--color-primary);
	padding-left: var(--space-sm);
	margin-bottom: var(--space-md);
}

/* ==========================================================================
   404・検索・アーカイブ ページ
   ========================================================================== */

.page-header {
	background-color: var(--color-white);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius);
	padding: var(--space-xl);
	margin-bottom: var(--space-xl);
}

.page-title {
	font-size: var(--font-size-2xl);
	color: var(--color-primary);
	font-weight: 700;
}

.page-description {
	color: var(--color-text-light);
	margin-top: var(--space-sm);
}

.not-found .page-content,
.search-no-results .page-content {
	margin-top: var(--space-xl);
}

/* ==========================================================================
   スクリーンリーダー専用
   ========================================================================== */

.screen-reader-text {
	border: 0;
	clip: rect(1px,1px,1px,1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	width: 1px;
	word-wrap: normal !important;
}

.screen-reader-text:focus {
	background-color: var(--color-bg);
	clip: auto !important;
	clip-path: none;
	color: var(--color-text);
	display: block;
	font-size: var(--font-size-sm);
	font-weight: 700;
	height: auto;
	left: 5px;
	line-height: normal;
	padding: 15px 23px 14px;
	text-decoration: none;
	top: 5px;
	width: auto;
	z-index: 100000;
}
