/* =============================================
   Freedom Salon - フロントエンドCSS
   ============================================= */

:root {
	--salon-primary: #1b4faa;
	--salon-primary-light: #e8f0fd;
	--salon-accent: #0073aa;
	--salon-text: #1d2327;
	--salon-text-light: #666;
	--salon-border: #e2e4e7;
	--salon-radius: 12px;
	--salon-font: 'Noto Sans JP', sans-serif;
}

/* ─── 共通ユーティリティ ─────────────────────── */

.salon-notice {
	padding: 16px 20px;
	background: #f8f9fa;
	border: 1px solid var(--salon-border);
	border-radius: var(--salon-radius);
	text-align: center;
	font-family: var(--salon-font);
	color: var(--salon-text-light);
}
.salon-notice .salon-plan-btn {
	display: inline-block;
	margin-top: 12px;
}
.salon-error {
	padding: 12px 16px;
	background: #fdf2f2;
	border: 1px solid #f5c6cb;
	border-radius: 6px;
	color: #721c24;
	font-size: 14px;
	margin-bottom: 16px;
}
.salon-required { color: #d63638; margin-left: 2px; }
.salon-field-note { display: block; font-size: 12px; color: var(--salon-text-light); margin-top: 4px; }

.salon-plan-btn {
	display: inline-block;
	padding: 12px 28px;
	background: linear-gradient(135deg, var(--salon-primary), var(--salon-accent));
	color: #fff !important;
	text-decoration: none !important;
	border-radius: 8px;
	font-size: 15px;
	font-weight: bold;
	font-family: var(--salon-font);
	transition: opacity .2s, transform .1s;
	border: none;
	cursor: pointer;
}
.salon-plan-btn:hover,
.salon-plan-btn:visited,
.salon-plan-btn:active {
	opacity: .9;
	transform: translateY(-1px);
	color: #fff !important;
	text-decoration: none !important;
}

/* ─── プラン一覧 [salon_plans] ─────────────────── */

.salon-plans-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 24px;
	max-width: 960px;
	margin: 30px auto;
	font-family: var(--salon-font);
}
.salon-plan-card {
	background: #fff;
	border: 2px solid var(--salon-border);
	border-radius: var(--salon-radius);
	padding: 28px 24px;
	display: flex;
	flex-direction: column;
	transition: transform .2s, box-shadow .2s;
}
.salon-plan-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 8px 24px rgba(0,0,0,.08);
}
.salon-plan-level-2 { border-color: var(--salon-accent); }
.salon-plan-level-3 {
	border-color: #d4af37;
	background: linear-gradient(135deg, #fffef7 0%, #fff 100%);
}
.salon-plan-header {
	text-align: center;
	margin-bottom: 16px;
	padding-bottom: 16px;
	border-bottom: 1px solid var(--salon-border);
}
.salon-plan-name {
	font-size: 20px;
	font-weight: bold;
	color: var(--salon-text);
	margin: 0 0 12px 0;
}
.salon-plan-price { text-align: center; }
.salon-plan-amount {
	font-size: 32px;
	font-weight: bold;
	color: var(--salon-primary);
}
.salon-plan-period {
	font-size: 14px;
	color: var(--salon-text-light);
}
.salon-plan-desc {
	font-size: 14px;
	color: var(--salon-text-light);
	line-height: 1.6;
	margin-bottom: 16px;
}
.salon-plan-features {
	list-style: none;
	padding: 0;
	margin: 0 0 20px 0;
	flex: 1;
}
.salon-plan-features li {
	padding: 8px 0 8px 24px;
	position: relative;
	font-size: 14px;
	color: var(--salon-text);
	border-bottom: 1px solid #f0f0f0;
}
.salon-plan-features li:last-child { border-bottom: none; }
.salon-plan-features li::before {
	content: '\2713';
	position: absolute;
	left: 0;
	color: #28a745;
	font-weight: bold;
}
.salon-plan-card .salon-plan-btn {
	display: block;
	text-align: center;
	margin-top: auto;
}

/* 現在のプラン */
.salon-plan-current {
	border-color: #28a745 !important;
	position: relative;
}
.salon-plan-current-badge {
	position: absolute;
	top: -1px;
	left: 50%;
	transform: translateX(-50%);
	background: #28a745;
	color: #fff;
	font-size: 12px;
	font-weight: bold;
	padding: 4px 16px;
	border-radius: 0 0 8px 8px;
	font-family: var(--salon-font);
}
.salon-plan-current .salon-plan-btn-current {
	display: none !important;
}
.salon-plan-status {
	margin-top: auto;
	padding-top: 12px;
	text-align: center;
	color: #28a745;
	font-weight: bold;
	font-family: var(--salon-font);
}
.salon-plan-btn-current {
	background: #e9ecef !important;
	color: #28a745 !important;
	cursor: default;
	font-weight: bold;
	border: 2px solid #28a745;
}
.salon-plan-btn-current:hover {
	opacity: 1 !important;
	transform: none !important;
}
.salon-plan-btn-cancel {
	background: linear-gradient(135deg, #dc3545, #c82333) !important;
	font-size: 13px;
}
.salon-plan-btn-disabled {
	background: #ccc !important;
	color: #888 !important;
	cursor: default;
	pointer-events: none;
}
.salon-plan-btn-disabled:hover {
	opacity: 1 !important;
	transform: none !important;
}

/* ─── チェックアウト [salon_checkout] ────────────── */

.salon-checkout {
	max-width: 520px;
	margin: 30px auto;
	font-family: var(--salon-font);
}
.salon-checkout-summary {
	background: linear-gradient(135deg, #f8f9fa 0%, #fff 100%);
	border: 1px solid var(--salon-border);
	border-radius: var(--salon-radius);
	padding: 20px 24px;
	margin-bottom: 24px;
	text-align: center;
}
.salon-checkout-summary h3 {
	margin: 0 0 8px 0;
	font-size: 20px;
	color: var(--salon-text);
}
.salon-checkout-price {
	font-size: 18px;
	font-weight: bold;
	color: var(--salon-primary);
	margin: 0;
}
.salon-checkout-form {
	background: #fff;
	border: 1px solid var(--salon-border);
	border-radius: var(--salon-radius);
	padding: 24px;
}
.salon-form-group {
	margin-bottom: 18px;
}
.salon-form-group label {
	display: block;
	font-weight: bold;
	font-size: 14px;
	margin-bottom: 6px;
	color: var(--salon-text);
}
.salon-form-group input[type="text"],
.salon-form-group input[type="email"],
.salon-form-group input[type="password"],
.salon-form-group input[type="url"],
.salon-form-group textarea {
	width: 100%;
	padding: 10px 14px;
	border: 1px solid #c8ccd0;
	border-radius: 6px;
	font-size: 15px;
	box-sizing: border-box;
	font-family: inherit;
	transition: border-color .2s, box-shadow .2s;
}
.salon-form-group input:focus,
.salon-form-group textarea:focus {
	outline: none;
	border-color: var(--salon-accent);
	box-shadow: 0 0 0 3px rgba(0,115,170,.1);
}
.salon-input-error { border-color: #d63638 !important; }
.salon-logged-in-msg {
	padding: 12px 16px;
	background: var(--salon-primary-light);
	border-radius: 6px;
	font-size: 14px;
	color: var(--salon-text);
	margin: 0;
}
.salon-form-errors {
	background: #fdf2f2;
	border: 1px solid #f5c6cb;
	border-radius: 6px;
	padding: 12px 16px;
	margin-bottom: 16px;
	color: #721c24;
	font-size: 14px;
}
.salon-submit-btn {
	width: 100%;
	padding: 14px 20px;
	background: linear-gradient(135deg, var(--salon-primary), var(--salon-accent));
	color: #fff;
	border: none;
	border-radius: 8px;
	font-size: 16px;
	font-weight: bold;
	cursor: pointer;
	font-family: inherit;
	transition: opacity .2s, transform .1s;
}
.salon-submit-btn:hover { opacity: .9; transform: translateY(-1px); }
.salon-submit-btn:disabled { opacity: .6; cursor: not-allowed; transform: none; }

.salon-paypal-area {
	margin-top: 20px;
	padding-top: 20px;
	border-top: 1px dashed #ddd;
}
.salon-paypal-label {
	font-size: 14px;
	color: #444;
	margin-bottom: 12px;
	font-weight: bold;
}
.salon-success-msg {
	max-width: 520px;
	margin: 30px auto;
	padding: 32px;
	background: #d4edda;
	border: 1px solid #c3e6cb;
	border-radius: var(--salon-radius);
	text-align: center;
	font-family: var(--salon-font);
}
.salon-success-msg h3 {
	color: #155724;
	margin: 0 0 12px 0;
}
.salon-success-msg p { color: #155724; }
.salon-success-msg .salon-plan-btn { margin-top: 16px; }

/* ─── ダッシュボード [salon_dashboard] ─────────── */

.salon-dashboard {
	max-width: 700px;
	margin: 30px auto;
	font-family: var(--salon-font);
}
.salon-dash-header {
	margin-bottom: 24px;
}
.salon-dash-header h3 {
	font-size: 22px;
	color: var(--salon-text);
	margin: 0;
}
.salon-dash-plan {
	background: var(--salon-primary-light);
	border: 1px solid #c6d9f1;
	border-radius: var(--salon-radius);
	padding: 20px 24px;
	margin-bottom: 24px;
}
.salon-dash-plan-name {
	font-size: 16px;
	color: var(--salon-text);
	margin: 0 0 6px 0;
}
.salon-dash-since {
	font-size: 13px;
	color: var(--salon-text-light);
	margin: 0;
}
.salon-dash-content h4 {
	font-size: 18px;
	margin: 0 0 16px 0;
	color: var(--salon-text);
}
.salon-content-items {
	list-style: none;
	padding: 0;
	margin: 0;
}
.salon-content-items li {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 10px 0;
	border-bottom: 1px solid #f0f0f0;
}
.salon-content-items li:last-child { border-bottom: none; }
.salon-content-items a {
	flex: 1;
	text-decoration: none;
	color: var(--salon-text);
	font-size: 14px;
}
.salon-content-items a:hover { color: var(--salon-accent); }
.salon-dash-no-plan {
	text-align: center;
	padding: 32px;
	background: #f8f9fa;
	border-radius: var(--salon-radius);
}
.salon-dash-logout {
	margin-top: 24px;
	text-align: right;
}
.salon-dash-logout a {
	color: var(--salon-text-light);
	font-size: 13px;
}

/* ─── コンテンツ一覧 / アーカイブ ──────────────── */

.salon-archive-container {
	max-width: 960px;
	margin: 30px auto;
	padding: 0 16px;
	font-family: var(--salon-font);
}
.salon-archive-header {
	margin-bottom: 24px;
}
.salon-archive-header h1 {
	font-size: 24px;
	color: var(--salon-text);
	margin: 0 0 8px 0;
}
.salon-content-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
	gap: 20px;
}
.salon-content-card {
	background: #fff;
	border: 1px solid var(--salon-border);
	border-radius: var(--salon-radius);
	overflow: hidden;
	transition: transform .2s, box-shadow .2s;
}
.salon-content-card:hover {
	transform: translateY(-3px);
	box-shadow: 0 6px 18px rgba(0,0,0,.08);
}
.salon-content-card.salon-locked { opacity: .7; }
.salon-content-card a {
	text-decoration: none;
	color: inherit;
	display: block;
}
.salon-content-thumb {
	width: 100%;
	height: 160px;
	background-size: cover;
	background-position: center;
	position: relative;
}
.salon-video-icon {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 48px;
	height: 48px;
	background: rgba(0,0,0,.6);
	color: #fff;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 20px;
}
.salon-lock-overlay {
	position: absolute;
	top: 10px;
	right: 10px;
	font-size: 24px;
	background: rgba(0,0,0,.5);
	border-radius: 50%;
	width: 36px;
	height: 36px;
	display: flex;
	align-items: center;
	justify-content: center;
}
.salon-content-info {
	padding: 14px 16px;
}
.salon-content-info h4 {
	margin: 6px 0;
	font-size: 15px;
	color: var(--salon-text);
	line-height: 1.4;
}
.salon-cat-badge {
	display: inline-block;
	padding: 2px 10px;
	background: #f0f4f8;
	border-radius: 12px;
	font-size: 11px;
	color: var(--salon-accent);
	font-weight: bold;
}
.salon-level-badge {
	display: inline-block;
	padding: 2px 8px;
	border-radius: 4px;
	font-size: 11px;
	font-weight: bold;
	color: #fff;
}
.salon-level-badge.lv-1 { background: #6c757d; }
.salon-level-badge.lv-2 { background: var(--salon-accent); }
.salon-level-badge.lv-3 { background: #d4af37; }

/* ─── 個別コンテンツ [single-salon_content] ──────── */

.salon-single-container {
	max-width: 760px;
	margin: 30px auto;
	padding: 0 16px;
	font-family: var(--salon-font);
}
.salon-single-container h1 {
	font-size: 24px;
	color: var(--salon-text);
	margin-bottom: 16px;
}
.salon-single-meta {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 24px;
}
.salon-video-embed {
	margin-bottom: 24px;
}
.salon-video-embed iframe {
	width: 100%;
	aspect-ratio: 16/9;
	border: none;
	border-radius: 8px;
}
.salon-single-body {
	line-height: 1.8;
	font-size: 15px;
	color: var(--salon-text);
}
.salon-single-body p { margin-bottom: 16px; }
.salon-single-body img { max-width: 100%; height: auto; border-radius: 8px; }

.salon-restricted {
	text-align: center;
	padding: 40px 24px;
	background: #f8f9fa;
	border: 1px solid var(--salon-border);
	border-radius: var(--salon-radius);
	margin-top: 24px;
}
.salon-restricted p {
	color: var(--salon-text-light);
	margin-bottom: 16px;
}
.salon-upgrade-box {
	text-align: center;
	padding: 32px 24px;
	background: #fff9e6;
	border: 1px solid #ffe69c;
	border-radius: var(--salon-radius);
	margin-top: 24px;
}
.salon-upgrade-box p {
	color: #856404;
	margin-bottom: 16px;
}

/* ─── ログインフォーム [salon_login] ─────────────── */

.salon-login-form {
	max-width: 420px;
	margin: 30px auto;
	padding: 28px;
	background: #fff;
	border: 1px solid var(--salon-border);
	border-radius: var(--salon-radius);
	font-family: var(--salon-font);
}
.salon-login-form h3 {
	font-size: 20px;
	text-align: center;
	margin: 0 0 20px 0;
	color: var(--salon-text);
}
.salon-checkbox-label {
	display: flex !important;
	align-items: center;
	gap: 8px;
	font-weight: normal !important;
	cursor: pointer;
}
.salon-checkbox-label input[type="checkbox"] {
	width: 18px;
	height: 18px;
	accent-color: var(--salon-accent);
	cursor: pointer;
}
.salon-checkbox-label span {
	font-size: 14px;
	color: #333;
}
.salon-login-links {
	text-align: center;
	margin-top: 16px;
}
.salon-login-links a {
	color: var(--salon-accent);
	font-size: 13px;
}

/* ─── ページネーション ─────────────────────── */

.salon-pagination {
	margin-top: 32px;
	text-align: center;
}
.salon-pagination .nav-links { display: flex; justify-content: center; gap: 4px; }
.salon-pagination .page-numbers {
	display: inline-block;
	padding: 8px 14px;
	border: 1px solid var(--salon-border);
	border-radius: 6px;
	font-size: 14px;
	color: var(--salon-text);
	text-decoration: none;
}
.salon-pagination .page-numbers.current {
	background: var(--salon-primary);
	color: #fff;
	border-color: var(--salon-primary);
}
.salon-pagination .page-numbers:hover:not(.current) {
	background: #f0f4f8;
}

/* ─── レスポンシブ ──────────────────────── */

@media (max-width: 640px) {
	.salon-plans-grid { grid-template-columns: 1fr; }
	.salon-content-grid { grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); }
	.salon-checkout { max-width: 100%; }
	.salon-checkout-form { padding: 16px; }
	.salon-plan-amount { font-size: 26px; }
	.salon-login-form { padding: 20px; }
}
