/*
Theme Name: cantik base
Theme URI: https://cantik.co.jp/
Author: 株式会社cantik
Author URI: https://cantik.co.jp/
Description: cantik 量産用ベーステーマ。配色はCSS変数(--primary/--accent等)で一元管理し、サイトごとにカスタマイザーで上書き可能。HP/LP/採用サイトの土台。
Version: 0.1.0
Requires at least: 6.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: cantik
*/

/* =========================================================
   デザイントークン（配色の一元管理）
   ここを変える＝サイト全体の配色が変わる。
   functions.php 経由でカスタマイザーの値が :root を上書きする。
   ========================================================= */
:root {
  /* ブランドカラー */
  --primary:        #1f6feb;   /* 主役色（ボタン/リンク/見出しアクセント） */
  --primary-dark:   #1a5fce;   /* ホバー/押下 */
  --primary-contrast:#ffffff;  /* primary上のテキスト */
  --accent:         #f5a623;   /* 差し色（強調/バッジ） */

  /* ベースカラー */
  --bg:             #ffffff;   /* 背景 */
  --bg-subtle:      #f6f8fa;   /* セクション交互背景 */
  --fg:             #1c2733;   /* 本文テキスト */
  --fg-muted:       #5b6b7b;   /* 補助テキスト */
  --border:         #e3e8ee;   /* 罫線 */

  /* タイポグラフィ */
  --font-base: -apple-system, BlinkMacSystemFont, "Hiragino Sans", "Noto Sans JP", "Yu Gothic", Meiryo, sans-serif;
  --font-heading: var(--font-base);
  --fs-base: 16px;
  --lh-base: 1.8;

  /* レイアウト */
  --container: 1120px;
  --gap: 24px;
  --radius: 10px;
  --radius-lg: 18px;
  --shadow: 0 2px 12px rgba(20, 40, 70, .08);
  --shadow-lg: 0 12px 36px rgba(20, 40, 70, .12);

  /* スペーシングスケール */
  --space-1: 8px;  --space-2: 16px; --space-3: 24px;
  --space-4: 40px; --space-5: 64px; --space-6: 96px;
}

/* =========================================================
   リセット & ベース
   ========================================================= */
*, *::before, *::after { box-sizing: border-box; }
html { font-size: var(--fs-base); -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-base);
  line-height: var(--lh-base);
  color: var(--fg);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
}
img, svg, video { max-width: 100%; height: auto; display: block; }
a { color: var(--primary); text-decoration: none; }
a:hover { color: var(--primary-dark); text-decoration: underline; }

h1, h2, h3, h4 { font-family: var(--font-heading); line-height: 1.4; margin: 0 0 var(--space-2); color: var(--fg); }
h1 { font-size: clamp(1.8rem, 4vw, 2.6rem); }
h2 { font-size: clamp(1.5rem, 3vw, 2rem); }
h3 { font-size: 1.25rem; }
p  { margin: 0 0 var(--space-2); }

/* =========================================================
   レイアウト部品
   ========================================================= */
.container { width: 100%; max-width: var(--container); margin-inline: auto; padding-inline: var(--space-3); }
.section { padding-block: var(--space-6); }
.section--subtle { background: var(--bg-subtle); }
.grid { display: grid; gap: var(--gap); }
@media (min-width: 768px) {
  .grid--2 { grid-template-columns: repeat(2, 1fr); }
  .grid--3 { grid-template-columns: repeat(3, 1fr); }
}

/* ボタン */
.btn {
  display: inline-block; padding: 14px 28px; border-radius: var(--radius);
  background: var(--primary); color: var(--primary-contrast);
  font-weight: 700; line-height: 1.2; border: 2px solid var(--primary);
  transition: background .15s, transform .05s;
}
.btn:hover { background: var(--primary-dark); border-color: var(--primary-dark); color: var(--primary-contrast); text-decoration: none; }
.btn:active { transform: translateY(1px); }
.btn--ghost { background: transparent; color: var(--primary); }
.btn--ghost:hover { background: var(--primary); color: var(--primary-contrast); }
.btn--accent { background: var(--accent); border-color: var(--accent); color: #fff; }

/* カード */
.card {
  background: var(--bg); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: var(--space-3); box-shadow: var(--shadow);
}

/* =========================================================
   ヘッダー / フッター
   ========================================================= */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: color-mix(in srgb, var(--bg) 92%, transparent);
  backdrop-filter: blur(8px); border-bottom: 1px solid var(--border);
}
.site-header__inner { display: flex; align-items: center; justify-content: space-between; gap: var(--space-2); min-height: 64px; }
.site-brand { font-weight: 800; font-size: 1.25rem; color: var(--fg); }
.site-brand:hover { text-decoration: none; }
.nav { display: flex; gap: var(--space-3); list-style: none; margin: 0; padding: 0; }
.nav a { color: var(--fg); font-weight: 600; }
.nav a:hover { color: var(--primary); text-decoration: none; }

.hero { padding-block: var(--space-6); background: linear-gradient(180deg, var(--bg-subtle), var(--bg)); }
.hero h1 { margin-bottom: var(--space-2); }
.hero__lead { font-size: 1.15rem; color: var(--fg-muted); max-width: 40em; }
.hero__cta { margin-top: var(--space-3); display: flex; gap: var(--space-2); flex-wrap: wrap; }

.site-footer { background: var(--fg); color: #fff; padding-block: var(--space-4); margin-top: var(--space-6); }
.site-footer a { color: #fff; opacity: .85; }
.site-footer__copy { opacity: .7; font-size: .9rem; margin-top: var(--space-2); }

/* 投稿本文 */
.entry { max-width: 760px; margin-inline: auto; }
.entry img { border-radius: var(--radius); margin-block: var(--space-2); }
.entry__meta { color: var(--fg-muted); font-size: .9rem; margin-bottom: var(--space-2); }

/* アクセシビリティ */
.screen-reader-text { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(1px,1px,1px,1px); }
:focus-visible { outline: 3px solid var(--accent); outline-offset: 2px; }
