/*
Theme Name: ZOO Custom
Theme URI: https://zooinc.co.jp
Author: ZOO株式会社
Description: zooinc.co.jp コーポレートサイト用カスタムテーマ。デザインシステム（zoo-design-system / design.md）準拠の単一ページ構成。静かな没入・熾火は一点・角丸なし・地紋署名。
Version: 2.0.0
Text Domain: zooinc
*/

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

/* ============================================================
   Tokens（design.md 正本を同梱・自己完結）
   ============================================================ */
:root {
	--paper:        #F8F7F3;
	--sumi:         #1B2430;
	--tan-zumi:     #5A646E;
	--okibi:        #AE4730;
	--paper-raised: #FCFBF8;
	--paper-sunken: #EFECE3;
	--sumi-soft:    #2A3340;
	--okibi-deep:   #963A26;
	--okibi-wash:   #F3E4DE;
	--rule:         #DED8C9;
	--rule-strong:  #C7C0AE;
	--rule-ink:     rgba(27, 36, 48, 0.12);

	--font-sans:  "Noto Sans JP", "Yu Gothic", YuGothic, "Hiragino Kaku Gothic ProN", Meiryo, system-ui, sans-serif;
	--font-serif: "Noto Serif JP", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", serif;
	--font-latin: "Jost", "Avenir Next", Avenir, "Futura", system-ui, sans-serif;

	--fs-12: 0.75rem;
	--fs-14: 0.875rem;
	--fs-16: 1rem;
	--fs-18: 1.125rem;
	--fs-20: 1.25rem;
	--fs-24: 1.5rem;
	--fs-30: 1.875rem;
	--fs-38: 2.375rem;
	--fs-48: 3rem;

	--lh-body: 1.75;
	--lh-heading: 1.25;
	--ls-wordmark: 0.22em;
	--ls-label: 0.14em;

	--content-max: 72rem;
	--grid-cell: 44px;
	--grid-line: rgba(27, 36, 48, 0.05);

	--ease: cubic-bezier(0.22, 0.61, 0.36, 1);
	--dur: 200ms;
	--focus-ring: rgba(174, 71, 48, 0.40);
}

/* ============================================================
   Base
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
	margin: 0;
	background: var(--paper);
	color: var(--sumi);
	font-family: var(--font-sans);
	font-size: var(--fs-16);
	line-height: var(--lh-body);
	letter-spacing: 0.01em;
	font-weight: 400;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
}

h1, h2, h3, h4 {
	margin: 0;
	color: var(--sumi);
	font-weight: 700;
	line-height: var(--lh-heading);
	letter-spacing: 0.02em;
}

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

a {
	color: var(--okibi);
	text-decoration: none;
	transition: color var(--dur) var(--ease), border-color var(--dur) var(--ease);
}

::selection { background: var(--okibi-wash); color: var(--sumi); }

:focus-visible {
	outline: 2px solid var(--focus-ring);
	outline-offset: 2px;
}

.zoo-wrap {
	max-width: var(--content-max);
	margin: 0 auto;
	padding: 0 32px;
}

/* 署名装置：盤面のヘアライン格子＝地紋（入れすぎ注意・hero地のみ） */
.zoo-grid {
	background-image:
		linear-gradient(var(--grid-line) 1px, transparent 1px),
		linear-gradient(90deg, var(--grid-line) 1px, transparent 1px);
	background-size: var(--grid-cell) var(--grid-cell);
}

/* ============================================================
   Header（不透明の紙＋細罫。glassmorphism なし／ワードマークが顔）
   ============================================================ */
.zoo-header {
	position: sticky;
	top: 0;
	z-index: 10;
	background: var(--paper);
	border-bottom: 1px solid var(--rule);
}
.admin-bar .zoo-header { top: 32px; }

.zoo-header-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding-top: 18px;
	padding-bottom: 18px;
}

.zoo-brand {
	font-family: var(--font-latin);
	font-weight: 600;
	font-size: 22px;
	letter-spacing: var(--ls-wordmark);
	color: var(--sumi);
	border-bottom: 0;
}
.zoo-brand span {
	font-family: var(--font-sans);
	font-weight: 500;
	font-size: 13px;
	letter-spacing: 0.08em;
	color: var(--tan-zumi);
	margin-left: 10px;
}

.zoo-navlink {
	font-size: 14px;
	color: var(--sumi);
	border: 1px solid var(--sumi);
	padding: 9px 20px;
	transition: background var(--dur) var(--ease), color var(--dur) var(--ease);
}
.zoo-navlink:hover { background: var(--sumi); color: var(--paper); }

/* ============================================================
   Hero（巨大で静かな ZOO ＋ 明朝宣言＋熾火の下線は一点）
   ============================================================ */
.zoo-hero {
	position: relative;
	padding: 52px 0 60px;
	overflow: clip;
}

.zoo-eyebrow {
	font-family: var(--font-latin);
	font-size: 12px;
	font-weight: 500;
	letter-spacing: var(--ls-label);
	text-transform: uppercase;
	color: var(--tan-zumi);
	margin-bottom: 6px;
}

.zoo-word {
	font-family: var(--font-latin);
	font-weight: 500;
	font-size: clamp(76px, 12vw, 150px);
	letter-spacing: 0.06em;
	line-height: 0.86;
	color: var(--sumi);
	user-select: none;
}

.zoo-decl {
	font-family: var(--font-serif);
	font-weight: 500;
	font-size: clamp(28px, 3.6vw, 44px);
	line-height: 1.3;
	letter-spacing: 0.02em;
	margin-top: 28px;
}
/* 熾火＝一点（このページ最上位の決定打） */
.zoo-decl u {
	text-decoration: none;
	border-bottom: 2px solid var(--okibi);
	padding-bottom: 0.04em;
}

.zoo-lead {
	font-size: var(--fs-16);
	color: var(--tan-zumi);
	line-height: 1.9;
	max-width: 38rem;
	margin-top: 18px;
	line-break: strict;
}

/* ============================================================
   Section 共通
   ============================================================ */
.zoo-sec { padding: 40px 0; }
.zoo-sec-label {
	font-family: var(--font-latin);
	font-size: 12px;
	font-weight: 500;
	letter-spacing: var(--ls-label);
	text-transform: uppercase;
	color: var(--tan-zumi);
	margin-bottom: 16px;
}
.zoo-h2 {
	font-size: var(--fs-30);
	font-weight: 700;
	letter-spacing: 0.02em;
}

/* ---- Stats（数値＝墨。熾火は使わない＝装飾的反復回避）---- */
.zoo-stats {
	display: flex;
	flex-wrap: wrap;
	border-top: 1px solid var(--rule);
	border-bottom: 1px solid var(--rule);
}
.zoo-stat {
	flex: 1 1 150px;
	padding: 26px 24px 26px 0;
}
.zoo-stat + .zoo-stat {
	padding-left: 24px;
	border-left: 1px solid var(--rule);
}
.zoo-stat .label {
	font-size: var(--fs-12);
	color: var(--tan-zumi);
	letter-spacing: 0.06em;
	margin-bottom: 12px;
}
.zoo-stat .num {
	font-family: var(--font-serif);
	font-weight: 600;
	font-size: clamp(38px, 4.6vw, 58px);
	line-height: 1;
	color: var(--sumi);
	white-space: nowrap;
}
.zoo-stat .num span {
	font-family: var(--font-sans);
	font-size: var(--fs-18);
	font-weight: 500;
	color: var(--tan-zumi);
	margin-left: 4px;
}

/* ---- About（会社概要 ＋ メディア・提携先）---- */
.zoo-about {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	gap: 48px;
}

.zoo-facts {
	margin: 0;
	border-top: 1px solid var(--rule);
}
.zoo-facts > div {
	display: grid;
	grid-template-columns: 120px 1fr;
	gap: 16px;
	padding: 14px 0;
	border-bottom: 1px solid var(--rule);
}
.zoo-facts dt {
	font-size: var(--fs-14);
	color: var(--tan-zumi);
	letter-spacing: 0.04em;
}
.zoo-facts dd {
	margin: 0;
	font-size: var(--fs-16);
	color: var(--sumi);
}

.zoo-block + .zoo-block { margin-top: 32px; }
.zoo-block-label {
	font-size: var(--fs-14);
	color: var(--tan-zumi);
	letter-spacing: 0.04em;
	margin-bottom: 12px;
}
.zoo-media-names {
	font-family: var(--font-latin);
	font-size: var(--fs-20);
	letter-spacing: 0.02em;
	color: var(--sumi);
}
.zoo-media-names a {
	color: var(--sumi);
	border-bottom: 1px solid var(--rule-strong);
	padding-bottom: 1px;
}
.zoo-media-names a:hover { border-bottom-color: var(--sumi); }
.zoo-partners-names {
	font-size: var(--fs-16);
	line-height: 2.1;
	color: var(--sumi);
}
.zoo-note {
	font-size: var(--fs-12);
	color: var(--tan-zumi);
	margin-top: 8px;
}

/* ---- Contact（CF7 を design.md トーンに）---- */
.zoo-contact { border-top: 1px solid var(--rule); margin-top: 56px; padding-top: 64px; }
.zoo-contact-lead {
	font-size: var(--fs-16);
	color: var(--tan-zumi);
	line-height: 1.85;
	max-width: 36rem;
	margin: 12px 0 28px;
}
.zoo-form { max-width: 40rem; }

.zoo-form .wpcf7 p { margin: 0 0 16px; }
.zoo-form label {
	display: block;
	font-size: var(--fs-14);
	color: var(--tan-zumi);
	letter-spacing: 0.04em;
	margin-bottom: 6px;
}
.zoo-form input[type="text"],
.zoo-form input[type="email"],
.zoo-form input[type="tel"],
.zoo-form textarea,
.zoo-form select {
	width: 100%;
	background: var(--paper-raised);
	border: 1px solid var(--rule);
	border-radius: 0;
	padding: 12px 14px;
	font-family: var(--font-sans);
	font-size: var(--fs-16);
	color: var(--sumi);
	transition: border-color var(--dur) var(--ease);
}
.zoo-form input:focus,
.zoo-form textarea:focus,
.zoo-form select:focus {
	outline: 2px solid var(--focus-ring);
	outline-offset: 2px;
	border-color: var(--rule-strong);
}
.zoo-form textarea { min-height: 160px; resize: vertical; }

/* 主CTA＝墨（熾火は塗りに使わない） */
.zoo-form .wpcf7-submit {
	background: var(--sumi);
	color: var(--paper);
	border: 0;
	border-radius: 0;
	padding: 14px 32px;
	font-family: var(--font-sans);
	font-size: var(--fs-16);
	font-weight: 500;
	letter-spacing: 0.04em;
	cursor: pointer;
	transition: background var(--dur) var(--ease);
}
.zoo-form .wpcf7-submit:hover { background: var(--sumi-soft); }
.zoo-form .wpcf7-spinner { margin: 0 0 0 12px; }
.zoo-form .wpcf7-response-output {
	border: 1px solid var(--rule);
	border-radius: 0;
	margin: 16px 0 0;
	padding: 12px 14px;
	font-size: var(--fs-14);
}

/* ============================================================
   Footer（design.md フッター：ワードマーク＋宣言＋©）
   ============================================================ */
.zoo-footer {
	border-top: 1px solid var(--rule);
	margin-top: 56px;
	background: var(--paper);
}
.zoo-footer-inner {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	flex-wrap: wrap;
	gap: 24px;
	padding-top: 48px;
	padding-bottom: 40px;
}
.zoo-foot-brand {
	font-family: var(--font-latin);
	font-weight: 600;
	font-size: var(--fs-20);
	letter-spacing: var(--ls-wordmark);
	color: var(--sumi);
}
.zoo-foot-decl {
	font-family: var(--font-serif);
	font-size: var(--fs-14);
	color: var(--tan-zumi);
	margin-top: 12px;
}
.zoo-foot-copy {
	font-family: var(--font-latin);
	font-size: var(--fs-12);
	letter-spacing: 0.04em;
	color: var(--tan-zumi);
}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 860px) {
	.zoo-wrap { padding: 0 22px; }
	.zoo-about { grid-template-columns: 1fr; gap: 36px; }
	.zoo-stat { flex-basis: 50%; }
	.zoo-stat + .zoo-stat { border-left: 0; padding-left: 0; }
	.zoo-stat:nth-child(odd) { border-right: 1px solid var(--rule); padding-right: 20px; }
}

@media (max-width: 480px) {
	.zoo-facts > div { grid-template-columns: 96px 1fr; gap: 12px; }
	.zoo-stat { flex-basis: 100%; }
	.zoo-stat:nth-child(odd) { border-right: 0; }
}

@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after { transition-duration: 0.01ms !important; }
}
