/*

　ベース

　使い方（デザインカンプから下記情報を読み取る）
　1.フォントの指定
　2.色の指定
　3.余白のサイズ


*/

/* ========== Layer: base ========== */
@layer base {
    :root {
        /* ビューポート境界 */
        --vw-min: 320;
        /* px */
        --vw-max: 600;
        /* px */

        /*フォント*/
        --font-family: "Noto Serif JP", serif;

        /*カラー*/
        --color-bg: #C7C7C7;
        --color-text: #4A4A4A;
        --color-accent: #B7B7B7;
        --color-border: #707070;
        --color-white: #fff;

        /* 文字サイズ（pxベース → clamp化） */
        /* 親和性の高い段階：12 / 14 / 16 / 18 / 20 / 24 / 28 / 32 */
        --fz-12: clamp(12px, calc(12px + (14 - 12) * ((100vw - var(--vw-min)*1px) / (var(--vw-max) - var(--vw-min)))), 14px);
        --fz-14: clamp(13px, calc(13px + (14 - 13) * ((100vw - var(--vw-min)*1px) / (var(--vw-max) - var(--vw-min)))), 14px);
        --fz-16: clamp(15px, calc(15px + (16 - 15) * ((100vw - var(--vw-min)*1px) / (var(--vw-max) - var(--vw-min)))), 16px);
        --fz-18: clamp(16px, calc(16px + (18 - 16) * ((100vw - var(--vw-min)*1px) / (var(--vw-max) - var(--vw-min)))), 18px);
        --fz-20: clamp(18px, calc(18px + (20 - 18) * ((100vw - var(--vw-min)*1px) / (var(--vw-max) - var(--vw-min)))), 20px);
        --fz-22: clamp(20px, calc(20px + (22 - 20) * ((100vw - var(--vw-min)*1px) / (var(--vw-max) - var(--vw-min)))), 22px);
        --fz-24: clamp(20px, calc(20px + (24 - 20) * ((100vw - var(--vw-min)*1px) / (var(--vw-max) - var(--vw-min)))), 24px);
        --fz-28: clamp(22px, calc(22px + (28 - 22) * ((100vw - var(--vw-min)*1px) / (var(--vw-max) - var(--vw-min)))), 28px);
        --fz-32: clamp(24px, calc(24px + (32 - 24) * ((100vw - var(--vw-min)*1px) / (var(--vw-max) - var(--vw-min)))), 32px);

        /* 行間の推奨（日本語は広め）：本文1.7 / 見出し1.3〜1.4 */
        --lh-body: 1.7;
        --lh-heading: 1.35;

        /* 余白 */
        --space-4: 0.25rem;
        /* 4px */
        --space-8: 0.5rem;
        /* 8px */
        --space-12: 0.75rem;
        /* 12px */
        --space-16: 1rem;
        /* 16px */
        --space-24: 1.5rem;
        /* 24px */
        --space-32: 2rem;
        /* 32px */
        --space-40: 2.5rem;
        /* 40px */
        --space-56: 3.5rem;
        /* 56px */
        --space-64: 4rem;
        /* 64px */
        --space-80: 5rem;
        /* 80px */
    }

    @media (min-width: 1024px) {
        :root {
            /* PCでの設定 */
            --space-40: 3rem;
            /* 16px × 3 = 48px */
            --space-56: 4rem;
            /* 16px × 4 = 64px */
            --space-80: 6rem;
            /* 16px × 6 = 96px */
        }
    }

    /* ベース文字（16pxベース、実測は--fz-16で流体） */
    html {
        font-size: 16px;
        font-family: var(--font-family);
    }

    body {
        font-size: var(--fz-16);
        line-height: var(--lh-body);
        letter-spacing: 0.1em;
    }
}

/* ========== Layer: components ========== */
@layer components {
    .photo-item--empty {
        text-align: center;
        padding: 40px 20px;
        color: var(--color-text);
        background-color: rgba(255, 255, 255, 0.6);
        border: 1px solid var(--color-border);
        border-radius: 8px;
    }

    .photo-archive-grid {
        display: grid;
        gap: clamp(24px, 4vw, 40px);
        grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    }

    .photo-archive-item img {
        width: 100%;
        height: auto;
        display: block;
        border-radius: 12px;
    }

    .photo-archive-title {
        margin-top: 12px;
        font-size: var(--fz-18);
        text-align: center;
    }

    .button {
        display: inline-block;
        padding: 12px 32px;
        background-color: var(--color-text);
        color: var(--color-white);
        text-decoration: none;
        border-radius: 999px;
        transition: opacity 0.3s ease;
    }

    .button:hover,
    .button:focus-visible {
        opacity: 0.8;
    }
}

/* ========== Layer: components ========== */
@layer components {

    h1,
    h2,
    h3,
    h4 {
        line-height: var(--lh-heading);
        margin: 0 0 .75em;
    }

    h1 {
        font-size: var(--fz-24) !important;
        font-weight: 700;
    }

    h2 {
        font-size: var(--fz-22) !important;
        font-weight: 500;
        color: var(--color-text);
        text-align: center;
    }

    h3 {
        font-size: var(--fz-16) !important;
        font-weight: 700;
        color: var(--color-text);
        text-align: center;
    }

    h4 {
        font-size: var(--fz-24);
        font-weight: 700;
    }

    p,
    li {
        font-size: var(--fz-14);
        color: var(--color-text);
    }

    small {
        font-size: var(--fz-12);
        display: block;
        text-align: center;
    }
}

/* ========== Layer: utilities ========== */
@layer utilities {

    /* テキスト位置 */
    .text-left {
        text-align: left !important;
    }

    .text-center {
        text-align: center !important;
    }

    .text-right {
        text-align: right !important;
    }

    /* フォントサイズ */
    .text-12 {
        font-size: var(--fz-12) !important;
    }

    .text-14 {
        font-size: var(--fz-14) !important;
    }

    .text-16 {
        font-size: var(--fz-16) !important;
    }

    .text-18 {
        font-size: var(--fz-18) !important;
    }

    .text-20 {
        font-size: var(--fz-20) !important;
    }

    .text-22 {
        font-size: var(--fz-20) !important;
    }

    .text-24 {
        font-size: var(--fz-24) !important;
    }

    .text-28 {
        font-size: var(--fz-28) !important;
    }

    .text-32 {
        font-size: var(--fz-32) !important;
    }

    /* 行間ユーティリティ */
    .lh-tight {
        line-height: 1.2 !important;
    }

    .lh-normal {
        line-height: 1.6 !important;
    }

    .lh-loose {
        line-height: 1.8 !important;
    }

    /* margin-bottom */
    .mb-8 {
        margin-bottom: var(--space-8) !important;
    }

    .mb-16 {
        margin-bottom: var(--space-16) !important;
    }

    .mb-24 {
        margin-bottom: var(--space-24) !important;
    }

    .mb-32 {
        margin-bottom: var(--space-32) !important;
    }

    .mb-40 {
        margin-bottom: var(--space-40) !important;
    }

    .mb-56 {
        margin-bottom: var(--space-56) !important;
    }

    .mb-80 {
        margin-bottom: var(--space-80) !important;
    }
}