/* ==============================================
   グローバル定義 — CSS Custom Properties + リセット
   v2: Warm, gentle palette — 不安を抱える保護者に寄り添うトーン
   ============================================== */

:root {
    /* カラー（温かみのあるリーフグリーン × サーモンオレンジ） */
    --color-primary: #3D8B6F;
    --color-primary-light: #5BA88A;
    --color-primary-dark: #2A6350;
    --color-primary-pale: #EDF7F3;
    --color-primary-mid: #C8E8DC;
    --color-secondary: #F0956A;
    --color-secondary-light: #FDF3EE;
    --color-secondary-dark: #D97A52;
    --color-accent: #3D8B6F;
    --color-accent-light: #EDF7F3;
    --color-error: #C0392B;

    --color-text: #2C2C2C;
    --color-text-secondary: #666666;
    --color-text-tertiary: #AAAAAA;
    --color-border: #E8EAE6;
    --color-bg: #FBFCF9;
    --color-surface: #FFFFFF;
    --color-surface-alt: #F3F6F2;

    /* タイポグラフィ */
    --font-heading: "Noto Sans JP", "Hiragino Sans", "Yu Gothic", sans-serif;
    --font-display: "DM Serif Display", serif;
    --font-body: -apple-system, BlinkMacSystemFont, "Noto Sans JP", "Hiragino Sans", sans-serif;

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

    /* レイアウト */
    --content-max: 1080px;
    --content-narrow: 680px;
    --content-wide: 1280px;
    --header-height: 56px;

    /* 角丸 — 大きめで柔らかい印象 */
    --radius-sm: 6px;
    --radius-md: 12px;
    --radius-lg: 20px;
    --radius-xl: 28px;
    --radius-pill: 100px;

    /* シャドウ — グリーンベースで温かみ */
    --shadow-sm: 0 2px 8px rgba(61, 139, 111, 0.06);
    --shadow-md: 0 6px 24px rgba(61, 139, 111, 0.10);
    --shadow-lg: 0 16px 48px rgba(61, 139, 111, 0.14);
}

@media (min-width: 769px) {
    :root {
        --header-height: 64px;
    }
}

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

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

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

body {
    font-family: var(--font-body);
    font-size: 15px;
    line-height: 1.75;
    color: var(--color-text);
    background-color: var(--color-bg);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

@media (min-width: 769px) {
    body {
        font-size: 16px;
    }
}

/* ========== 見出し ========== */

h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-heading);
    font-weight: 700;
    line-height: 1.4;
    color: var(--color-text);
}

h1 {
    font-size: 28px;
    line-height: 1.25;
}

h2 {
    font-size: 22px;
}

h3 {
    font-size: 16px;
    line-height: 1.5;
}

@media (min-width: 769px) {
    h1 { font-size: 52px; }
    h2 { font-size: 28px; }
    h3 { font-size: 18px; }
}

/* ========== リンク ========== */

a {
    color: var(--color-accent);
    text-decoration: none;
    transition: color 0.2s;
}

a:hover {
    color: #0D47A1;
    text-decoration: underline;
}

/* ========== 画像 ========== */

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

/* ========== リスト ========== */

ul, ol {
    list-style: none;
}

/* ========== テーブル ========== */

table {
    border-collapse: collapse;
    width: 100%;
}

/* ========== フォーカス ========== */

:focus-visible {
    outline: 2px solid var(--color-accent);
    outline-offset: 2px;
    border-radius: var(--radius-sm);
}

/* ========== ユーティリティ ========== */

.visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.container {
    max-width: var(--content-max);
    margin: 0 auto;
    padding: 0 var(--space-md);
}

.container--narrow {
    max-width: var(--content-narrow);
}

.container--wide {
    max-width: var(--content-wide);
}
