/* =========================================
   1. カラーパレット & タイポグラフィ 
   ========================================= */
:root {
    --mattun-c-base: #f8f9fa;
    --mattun-c-contrast: #212121;
    --mattun-c-accent1: #fad02c;
    --mattun-c-accent2: #b7282e;
    --mattun-c-accent3: #90adc6;
    --mattun-c-accent4: #333652;
    --mattun-c-accent5: #ffffff;
    --mattun-c-accent6: #8e8e93;
    --mattun-c-custom: #e9eaec;

    --mattun-fs-s: 0.875rem;
    --mattun-fs-m: 1.125rem;
    --mattun-fs-l: 1.375rem;
    --mattun-fs-xl: 1.875rem;
    --mattun-fs-xxl: 2.5rem;
    
    --mattun-lh-body: 1.8;
    --mattun-lh-heading: 1.3;

    --mattun-w-content: 50rem;
    --mattun-w-wide: 75rem;

    --mattun-space-xs: 0.5rem;
    --mattun-space-s: 1rem;
    --mattun-space-m: 2rem;
    --mattun-space-l: 4rem;
    --mattun-space-xl: 6rem;
    
    --mattun-radius-s: 0.5rem;
    --mattun-radius-m: 1rem;
    --mattun-radius-l: 2rem;
    --mattun-radius-full: 9999rem;
    
    --mattun-border-width: 0.125rem;
}

/* =========================================
   ベース・ユーティリティ
   ========================================= */
.mattun-container { max-width: var(--mattun-w-content); margin: 0 auto; padding: 0 var(--mattun-space-s); }
.mattun-container-wide { max-width: var(--mattun-w-wide); margin: 0 auto; padding: 0 var(--mattun-space-s); }

.mattun-section-padding { padding-top: var(--mattun-space-xl); padding-bottom: var(--mattun-space-xl); }

.mattun-text-center { text-align: center; }
.mattun-text-right { text-align: right; }
.mattun-font-bold { font-weight: 700; }
.mattun-font-black { font-weight: 900; }

.mattun-c-contrast { color: var(--mattun-c-contrast); }
.mattun-c-accent1 { color: var(--mattun-c-accent1); }
.mattun-c-accent2 { color: var(--mattun-c-accent2); }
.mattun-c-accent3 { color: var(--mattun-c-accent3); }
.mattun-c-accent4 { color: var(--mattun-c-accent4); }
.mattun-c-accent5 { color: var(--mattun-c-accent5); }
.mattun-c-accent6 { color: var(--mattun-c-accent6); }

.mattun-bg-base { background-color: var(--mattun-c-base); }
.mattun-bg-accent1 { background-color: var(--mattun-c-accent1); }
.mattun-bg-accent2 { background-color: var(--mattun-c-accent2); }
.mattun-bg-accent4 { background-color: var(--mattun-c-accent4); }
.mattun-bg-accent5 { background-color: var(--mattun-c-accent5); }
.mattun-bg-custom { background-color: var(--mattun-c-custom); }

.mattun-fs-s { font-size: var(--mattun-fs-s); }
.mattun-fs-m { font-size: var(--mattun-fs-m); }
.mattun-fs-l { font-size: var(--mattun-fs-l); }
.mattun-fs-xl { font-size: var(--mattun-fs-xl); }
.mattun-fs-xxl { font-size: var(--mattun-fs-xxl); }
.mattun-lh-body { line-height: var(--mattun-lh-body); }

.mattun-mb-0 { margin-bottom: 0; }
.mattun-mb-s { margin-bottom: var(--mattun-space-s); }
.mattun-mb-m { margin-bottom: var(--mattun-space-m); }
.mattun-mb-l { margin-bottom: var(--mattun-space-l); }
.mattun-mb-xl { margin-bottom: var(--mattun-space-xl); }
.mattun-mt-m { margin-top: var(--mattun-space-m); }
.mattun-ml-s { margin-left: var(--mattun-space-s); }
.mattun-p-m { padding: var(--mattun-space-m); }

/* =========================================
   コンポーネント (カード、ボタン、装飾)
   ========================================= */
.mattun-hero-bg {
    background-image: linear-gradient(rgba(51, 54, 82, 0.4), rgba(51, 54, 82, 0.4)), url('https://mattun.jp/wp-content/uploads/2025/07/top1.jpg');
    background-size: cover;
    background-position: center;
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
}
.mattun-text-shadow-strong {
    text-shadow: 0.125rem 0.125rem 0.25rem rgba(0, 0, 0, 0.7);
}
.mattun-hero-badge {
    display: inline-block;
    background-color: var(--mattun-c-accent1);
    color: var(--mattun-c-accent4) !important;
    font-weight: bold;
    padding: 0.5rem 1.5rem;
    border-radius: var(--mattun-radius-full);
    margin-bottom: var(--mattun-space-m);
    font-size: var(--mattun-fs-s);
    border: 0.125rem solid rgba(255,255,255,0.3);
}
.mattun-hero-h1 {
    font-size: var(--mattun-fs-xxl);
    color: var(--mattun-c-accent5) !important;
    margin-bottom: var(--mattun-space-m);
}
.mattun-hero-desc {
    font-size: var(--mattun-fs-l);
    margin-bottom: var(--mattun-space-l);
    color: var(--mattun-c-base) !important;
}
.mattun-highlight-border {
    color: var(--mattun-c-accent1);
    border-bottom: 0.25rem solid var(--mattun-c-accent1);
    padding-bottom: 0.25rem;
}
.mattun-btn-danger, .mattun-btn-danger a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    text-decoration: none;
    font-weight: 700;
    padding: 1rem 2.5rem;
    border-radius: var(--mattun-radius-full);
    transition: opacity 0.3s, transform 0.3s;
    background-color: var(--mattun-c-accent2) !important;
    color: var(--mattun-c-accent5) !important;
    font-size: var(--mattun-fs-l);
    border: 0.25rem solid rgba(255,255,255,0.2) !important;
    box-shadow: 0 0.5rem 1.5rem rgba(183, 40, 46, 0.4);
}
.mattun-btn-danger:hover, .mattun-btn-danger a:hover {
    opacity: 0.9;
    transform: scale(1.02);
}

.mattun-highlight-marker {
    background: linear-gradient(transparent 60%, var(--mattun-c-accent1) 60%);
    display: inline;
    padding-bottom: 0.125rem;
}

/* カード */
.mattun-card {
    background-color: var(--mattun-c-accent5);
    border: var(--mattun-border-width) solid var(--mattun-c-custom);
    border-radius: var(--mattun-radius-m);
    padding: var(--mattun-space-m);
    height: 100%;
    box-sizing: border-box;
    box-shadow: 0 0.25rem 0.5rem rgba(0,0,0,0.05);
    transition: transform 0.3s;
}
.mattun-card:hover { transform: translateY(-0.25rem); }
.mattun-icon-large { font-size: var(--mattun-fs-xxl); color: var(--mattun-c-accent4); margin-bottom: var(--mattun-space-s); }

/* レイアウト */
.mattun-grid-3 { display: grid; grid-template-columns: repeat(auto-fit, minmax(16rem, 1fr)); gap: var(--mattun-space-m); }
.mattun-grid-4 { display: grid; grid-template-columns: repeat(auto-fit, minmax(12rem, 1fr)); gap: var(--mattun-space-m); }
.mattun-flex-col-md-row { display: flex; flex-direction: column; gap: var(--mattun-space-m); align-items: inherit; justify-content: space-between; }
@media (min-width: 48rem) {
    .mattun-flex-col-md-row { flex-direction: row; }
    .mattun-flex-col-md-row-reverse { flex-direction: row-reverse; }
    .mattun-w-half { width: 50%; }
}

/* 特殊装飾 */
.mattun-reason-badge {
    display: inline-block;
    background-color: var(--mattun-c-accent4);
    color: var(--mattun-c-accent5);
    font-size: var(--mattun-fs-s);
    font-weight: bold;
    padding: 0.25rem 1rem;
    border-radius: var(--mattun-radius-full);
    margin-bottom: var(--mattun-space-s);
}
.mattun-reason-h3 { font-size: var(--mattun-fs-l); }
.mattun-reason-border { font-weight: bold; color: var(--mattun-c-accent4); border-bottom: 0.125rem solid var(--mattun-c-accent1); }
.mattun-image-wrapper { position: relative; width: 100%; aspect-ratio: 16/9; }
.mattun-image-bg-accent1 { position: absolute; inset: 0; background-color: var(--mattun-c-accent1); transform: translate(1rem, 1rem); border-radius: var(--mattun-radius-m); }
.mattun-image-bg-accent4 { position: absolute; inset: 0; background-color: var(--mattun-c-accent4); transform: translate(-1rem, 1rem); border-radius: var(--mattun-radius-m); }
.mattun-image-card { position: relative; z-index: 1; display: flex; align-items: center; justify-content: center; background-color: var(--mattun-c-accent5); border: var(--mattun-border-width) solid var(--mattun-c-custom); border-radius: var(--mattun-radius-m); aspect-ratio: 16/9; font-size: 4rem; color: var(--mattun-c-custom); }

.mattun-rep-img { background-color: var(--mattun-c-custom); aspect-ratio: 1/1; border-radius: var(--mattun-radius-m); display: flex; align-items: center; justify-content: center; font-size: 5rem; color: var(--mattun-c-accent5); }
.mattun-step-icon { flex-shrink: 0; width: 4rem; height: 4rem; background-color: var(--mattun-c-accent1); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-weight: bold; font-size: var(--mattun-fs-l); color: var(--mattun-c-accent4); }

.mattun-details {
    background-color: var(--mattun-c-accent5);
    border: var(--mattun-border-width) solid var(--mattun-c-custom);
    border-left: 0.5rem solid var(--mattun-c-accent4);
    border-radius: var(--mattun-radius-m);
    margin-bottom: var(--mattun-space-s);
    padding: var(--mattun-space-s) var(--mattun-space-m);
}
.mattun-details-summary { font-weight: 700; color: var(--mattun-c-accent4); font-size: var(--mattun-fs-m); cursor: pointer; padding: 0.5rem 0; list-style: none; display: flex; justify-content: space-between; align-items: center; }
.mattun-details-summary::-webkit-details-marker { display: none; }
.mattun-details p { margin-top: var(--mattun-space-s); margin-bottom: 0; padding-top: var(--mattun-space-s); border-top: 1px dashed var(--mattun-c-custom); color: var(--mattun-c-contrast); }

.mattun-pricing-card { max-width: 50rem; margin: 0 auto 4rem auto; border: 0.25rem solid var(--mattun-c-accent1); background: var(--mattun-c-accent5); border-radius: var(--mattun-radius-m); overflow: hidden; }
.mattun-pricing-badge { background-color: var(--mattun-c-accent1); color: var(--mattun-c-accent4); padding: 1rem; text-align: center; font-weight: bold; font-size: var(--mattun-fs-m); }
.mattun-pricing-price { background-color: var(--mattun-c-base); padding: var(--mattun-space-m); border-radius: var(--mattun-radius-m); border: 0.125rem solid var(--mattun-c-accent2); display: inline-block; }
.mattun-plan-card { display: flex; flex-direction: column; background: var(--mattun-c-accent5); border: var(--mattun-border-width) solid var(--mattun-c-custom); border-radius: var(--mattun-radius-m); padding: var(--mattun-space-m); height: 100%; box-sizing: border-box; }
.mattun-plan-card-popular { border: 0.25rem solid var(--mattun-c-accent1); position: relative; }
.mattun-plan-badge { position: absolute; top: 0; right: 0; background-color: var(--mattun-c-accent1); color: var(--mattun-c-accent4); font-size: 0.75rem; font-weight: bold; padding: 0.25rem 0.5rem; border-bottom-left-radius: var(--mattun-radius-s); }
.mattun-plan-ul { list-style: none; padding: 0; margin-bottom: var(--mattun-space-m); flex-grow: 1; }
.mattun-plan-btn { display: block; text-align: center; padding: 0.75rem; border: var(--mattun-border-width) solid var(--mattun-c-accent4); border-radius: var(--mattun-radius-s); color: var(--mattun-c-accent4); font-weight: bold; text-decoration: none; }
