/*
Theme Name: Akashia HP
Theme URI: https://akashia.or.jp/
Author: 一般社団法人あかしあ
Description: 一般社団法人あかしあ 公式ホームページ用WordPressテーマ
Version: 1.2
License: GPL v2 or later
Text Domain: akashia-hp
*/

:root{
    --bg-cream: #FAF6EE;
    --bg-warm: #F5EFE0;
    --bg-deep: #2D2820;
    --leaf: #5C7A4B;
    --leaf-dark: #3F5634;
    --leaf-light: #A8C492;
    --sunset: #D87344;
    --sunset-deep: #B85A2E;
    --gold: #C9A961;
    --text-main: #2D2820;
    --text-sub: #6B6256;
    --text-mute: #9A9085;
    --line: #E8DFCE;
    --white: #FFFFFF;
    --shadow-sm: 0 2px 8px rgba(45,40,32,.06);
    --shadow-md: 0 8px 24px rgba(45,40,32,.08);
    --shadow-lg: 0 20px 60px rgba(45,40,32,.12);
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
    font-family: "Noto Sans JP", sans-serif;
    color: var(--text-main);
    background: var(--bg-cream);
    line-height: 1.8;
    font-weight: 400;
    overflow-x: hidden;
}

img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}

/* タイポグラフィ基本 */
.serif{font-family:"Shippori Mincho","Noto Serif JP",serif;}
.sans{font-family:"Noto Sans JP",sans-serif;}

h1,h2,h3,h4{
    font-family:"Shippori Mincho","Noto Serif JP",serif;
    font-weight:700;
    line-height:1.5;
    letter-spacing:.02em;
}

/* レイアウト */
.container{max-width:780px;margin:0 auto;padding:0 24px;}
.container-wide{max-width:980px;margin:0 auto;padding:0 24px;}

section{padding:88px 0;position:relative;}
@media (max-width:768px){section{padding:64px 0;}}

/* ============================================
   ヘッダー
   ============================================ */
.header{
    position:sticky;top:0;z-index:100;
    background:rgba(250,246,238,.95);
    backdrop-filter:blur(10px);
    border-bottom:1px solid var(--line);
}
.header-inner{
    display:flex;justify-content:space-between;align-items:center;
    padding:14px 24px;max-width:1200px;margin:0 auto;
}
.logo{
    font-family:"Shippori Mincho",serif;
    font-size:22px;font-weight:800;
    color:var(--leaf-dark);
    letter-spacing:.1em;
}
.logo-sub{
    font-size:10px;color:var(--text-mute);
    letter-spacing:.2em;margin-top:2px;
    font-family:"Noto Sans JP",sans-serif;
    font-weight:500;
}
.header-cta{
    background:var(--sunset);
    color:var(--white)!important;
    padding:10px 20px;border-radius:50px;
    font-size:13px;font-weight:700;
    transition:all .3s;
    box-shadow:var(--shadow-sm);
}
.header-cta:hover{background:var(--sunset-deep);transform:translateY(-1px);}
@media (max-width:768px){
    .logo{font-size:18px;}
    .header-cta{padding:8px 14px;font-size:11px;}
}

/* ============================================
   FV (ファーストビュー)
   ============================================ */
.fv{
    background:
        radial-gradient(ellipse at top right, rgba(168,196,146,.25), transparent 60%),
        radial-gradient(ellipse at bottom left, rgba(216,115,68,.12), transparent 50%),
        var(--bg-cream);
    padding:80px 0 100px;
    position:relative;
    overflow:hidden;
}
.fv::before{
    content:"";position:absolute;top:0;left:0;right:0;bottom:0;
    background-image:
        radial-gradient(circle at 20% 30%, rgba(92,122,75,.04) 1px, transparent 1px),
        radial-gradient(circle at 70% 60%, rgba(216,115,68,.04) 1px, transparent 1px);
    background-size: 40px 40px, 50px 50px;
    pointer-events:none;
}
.fv-content{position:relative;text-align:center;}
.fv-eyebrow{
    display:inline-block;
    font-size:13px;
    letter-spacing:.3em;
    color:var(--leaf-dark);
    margin-bottom:32px;
    padding:8px 24px;
    border:1px solid var(--leaf-light);
    border-radius:50px;
    background:rgba(255,255,255,.6);
    font-weight:500;
}
.fv-quote{
    font-family:"Shippori Mincho",serif;
    font-size:14px;
    color:var(--text-sub);
    font-style:italic;
    margin-bottom:20px;
    letter-spacing:.05em;
}
.fv-title{
    font-size:clamp(28px,5vw,52px);
    line-height:1.4;
    font-weight:800;
    margin-bottom:32px;
    color:var(--text-main);
}
.fv-title em{
    font-style:normal;
    color:var(--leaf-dark);
    border-bottom:6px solid var(--leaf-light);
    padding-bottom:2px;
}
.fv-lead{
    font-size:clamp(15px,2vw,18px);
    color:var(--text-sub);
    max-width:560px;
    margin:0 auto 48px;
    line-height:2;
}
.fv-stat{
    display:flex;
    justify-content:center;
    align-items:center;
    gap:16px;
    margin-bottom:40px;
    flex-wrap:wrap;
}
.fv-stat-num{
    font-family:"Shippori Mincho",serif;
    font-size:clamp(40px,7vw,72px);
    font-weight:800;
    color:var(--sunset);
    line-height:1;
}
.fv-stat-unit{
    font-size:14px;
    color:var(--text-sub);
    max-width:200px;
    text-align:left;
    line-height:1.6;
}
.cta-primary{
    display:inline-block;
    background:var(--sunset);
    color:var(--white)!important;
    padding:22px 56px;
    border-radius:60px;
    font-size:18px;
    font-weight:700;
    letter-spacing:.05em;
    box-shadow:0 10px 30px rgba(216,115,68,.3);
    transition:all .3s;
    position:relative;
    overflow:hidden;
}
.cta-primary::before{
    content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;
    background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);
    transition:left .6s;
}
.cta-primary:hover{
    background:var(--sunset-deep);
    transform:translateY(-3px);
    box-shadow:0 15px 40px rgba(216,115,68,.4);
}
.cta-primary:hover::before{left:100%;}
.cta-note{
    display:block;
    font-size:12px;
    color:var(--text-mute);
    margin-top:16px;
    letter-spacing:.05em;
}
@media (max-width:768px){
    .fv{padding:48px 0 64px;}
    .fv-stat{flex-direction:column;gap:8px;}
    .fv-stat-unit{text-align:center;}
    .cta-primary{padding:18px 40px;font-size:16px;}
}

/* ============================================
   問題提起
   ============================================ */
.problem{background:var(--bg-warm);}
.section-label{
    text-align:center;
    font-size:12px;
    letter-spacing:.4em;
    color:var(--sunset);
    margin-bottom:16px;
    font-weight:600;
}
.section-title{
    text-align:center;
    font-size:clamp(24px,3.5vw,36px);
    margin-bottom:24px;
    line-height:1.5;
}
.section-title em{
    font-style:normal;
    color:var(--sunset-deep);
    position:relative;
}
.section-lead{
    text-align:center;
    max-width:600px;
    margin:0 auto 56px;
    color:var(--text-sub);
    font-size:15px;
}

.stat-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:20px;
    margin-top:48px;
}
.stat-card{
    background:var(--white);
    padding:36px 24px;
    border-radius:16px;
    text-align:center;
    box-shadow:var(--shadow-sm);
    border-top:3px solid var(--sunset);
}
.stat-card-num{
    font-family:"Shippori Mincho",serif;
    font-size:clamp(36px,5vw,52px);
    font-weight:800;
    color:var(--leaf-dark);
    line-height:1;
    margin-bottom:8px;
}
.stat-card-num small{
    font-size:20px;
    font-weight:500;
    margin-left:4px;
}
.stat-card-label{
    font-size:13px;
    color:var(--text-sub);
    line-height:1.6;
    margin-top:12px;
}
.stat-source{
    text-align:center;
    margin-top:32px;
    font-size:11px;
    color:var(--text-mute);
}
@media (max-width:768px){
    .stat-grid{grid-template-columns:1fr;gap:16px;}
    .stat-card{padding:28px 20px;}
}

/* ============================================
   ストーリー
   ============================================ */
.story{
    background:var(--bg-cream);
    position:relative;
}
.story::before{
    content:"";
    position:absolute;
    top:0;left:0;right:0;height:1px;
    background:linear-gradient(90deg,transparent,var(--line),transparent);
}
.story-intro{
    text-align:center;
    margin-bottom:60px;
}
.story-body{
    max-width:640px;
    margin:0 auto;
    font-family:"Shippori Mincho",serif;
    line-height:2.2;
    font-size:16px;
    color:var(--text-main);
}
.story-body p{margin-bottom:28px;}
.story-body .lead{
    font-size:20px;
    font-weight:700;
    color:var(--leaf-dark);
    margin:48px 0 28px;
    padding-left:16px;
    border-left:3px solid var(--leaf);
}
.story-body .quote{
    background:var(--white);
    border-left:4px solid var(--sunset);
    padding:24px 28px;
    margin:32px 0;
    font-size:18px;
    font-weight:500;
    color:var(--sunset-deep);
    border-radius:0 8px 8px 0;
    box-shadow:var(--shadow-sm);
}
.story-body .quote-mother{
    border-left-color:var(--leaf);
    color:var(--leaf-dark);
}
.story-name{
    display:block;
    text-align:center;
    font-size:14px;
    color:var(--text-mute);
    margin-top:8px;
    letter-spacing:.1em;
}
.story-note{
    max-width:600px;
    margin:48px auto 0;
    padding:20px;
    background:var(--bg-warm);
    border-radius:8px;
    font-size:11px;
    color:var(--text-sub);
    line-height:1.8;
    text-align:center;
}

/* ============================================
   CTA中間
   ============================================ */
.cta-section{
    background:
        linear-gradient(135deg, var(--leaf-dark) 0%, var(--leaf) 100%);
    color:var(--white);
    text-align:center;
    padding:72px 0;
}
.cta-section .section-label{
    color:var(--leaf-light);
}
.cta-section-title{
    font-size:clamp(22px,3.5vw,32px);
    color:var(--white);
    margin-bottom:16px;
    line-height:1.6;
}
.cta-section-lead{
    color:rgba(255,255,255,.85);
    margin-bottom:36px;
    font-size:15px;
}
.cta-secondary{
    display:inline-block;
    background:var(--white);
    color:var(--leaf-dark)!important;
    padding:20px 48px;
    border-radius:60px;
    font-size:17px;
    font-weight:700;
    letter-spacing:.05em;
    box-shadow:var(--shadow-md);
    transition:all .3s;
}
.cta-secondary:hover{
    transform:translateY(-3px);
    box-shadow:var(--shadow-lg);
}

/* ============================================
   明るい未来
   ============================================ */
.future{background:var(--bg-warm);}
.future-vision{
    max-width:680px;
    margin:0 auto;
    text-align:center;
}
.future-text{
    font-family:"Shippori Mincho",serif;
    font-size:18px;
    line-height:2.2;
    color:var(--text-main);
    margin-bottom:48px;
}
.future-list{
    display:grid;
    gap:24px;
    margin-top:48px;
    text-align:left;
}
.future-item{
    background:var(--white);
    padding:28px 32px;
    border-radius:12px;
    box-shadow:var(--shadow-sm);
    display:flex;
    gap:20px;
    align-items:flex-start;
}
.future-num{
    flex-shrink:0;
    width:44px;height:44px;
    background:var(--leaf);
    color:var(--white);
    border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    font-family:"Shippori Mincho",serif;
    font-weight:800;
    font-size:18px;
}
.future-item h4{
    font-size:17px;
    margin-bottom:6px;
    color:var(--leaf-dark);
}
.future-item p{
    color:var(--text-sub);
    font-size:14px;
    line-height:1.8;
}

/* ============================================
   会社紹介
   ============================================ */
.about{background:var(--bg-cream);}
.about-card{
    background:var(--white);
    padding:48px;
    border-radius:16px;
    max-width:720px;
    margin:0 auto;
    box-shadow:var(--shadow-md);
    border-top:4px solid var(--leaf);
}
.about-card h3{
    text-align:center;
    font-size:24px;
    color:var(--leaf-dark);
    margin-bottom:16px;
}
.about-mission{
    text-align:center;
    font-family:"Shippori Mincho",serif;
    font-size:22px;
    font-weight:700;
    color:var(--sunset-deep);
    padding:24px 0;
    border-top:1px solid var(--line);
    border-bottom:1px solid var(--line);
    margin:28px 0;
    letter-spacing:.05em;
}
.about-text{
    color:var(--text-sub);
    line-height:2;
    font-size:14px;
    margin-bottom:20px;
}
.about-badge{
    display:inline-block;
    background:var(--bg-warm);
    border:1px dashed var(--sunset);
    padding:12px 20px;
    border-radius:8px;
    font-size:13px;
    color:var(--sunset-deep);
    font-weight:500;
    margin-top:20px;
}
@media (max-width:768px){
    .about-card{padding:32px 24px;}
}

/* ============================================
   寄付金額別「できること」
   ============================================ */
.donation{background:var(--bg-warm);}
.donation-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:20px;
    margin:48px 0 32px;
}
.donation-card{
    background:var(--white);
    border-radius:16px;
    padding:32px 24px;
    text-align:center;
    box-shadow:var(--shadow-sm);
    transition:all .3s;
    position:relative;
    border:2px solid transparent;
}
.donation-card.featured{
    border-color:var(--sunset);
    transform:scale(1.04);
    box-shadow:var(--shadow-md);
}
.donation-card.featured::before{
    content:"おすすめ";
    position:absolute;
    top:-12px;left:50%;
    transform:translateX(-50%);
    background:var(--sunset);
    color:var(--white);
    padding:4px 16px;
    border-radius:50px;
    font-size:11px;
    font-weight:700;
    letter-spacing:.1em;
}
.donation-card:hover{
    transform:translateY(-4px);
    box-shadow:var(--shadow-md);
}
.donation-card.featured:hover{
    transform:scale(1.04) translateY(-4px);
}
.donation-amount{
    font-family:"Shippori Mincho",serif;
    color:var(--leaf-dark);
    margin-bottom:16px;
}
.donation-amount-prefix{
    display:block;
    font-size:13px;
    color:var(--text-mute);
    margin-bottom:4px;
    letter-spacing:.1em;
}
.donation-amount-num{
    font-size:36px;
    font-weight:800;
    line-height:1;
}
.donation-amount-suffix{
    font-size:14px;
    color:var(--text-sub);
    font-weight:500;
    margin-left:2px;
}
.donation-divider{
    width:32px;
    height:1px;
    background:var(--sunset);
    margin:24px auto;
    opacity:.5;
}
.donation-desc{
    font-size:14px;
    line-height:1.8;
    color:var(--text-main);
    margin-bottom:12px;
    font-weight:500;
}
.donation-note{
    font-size:11px;
    color:var(--text-mute);
    line-height:1.6;
}
.donation-totalbox{
    text-align:center;
    padding:24px;
    background:var(--white);
    border-radius:12px;
    margin-top:16px;
    border:1px dashed var(--line);
}
.donation-totalbox small{
    display:block;
    font-size:12px;
    color:var(--text-mute);
    margin-bottom:8px;
}
.donation-totalbox strong{
    font-family:"Shippori Mincho",serif;
    font-size:22px;
    color:var(--sunset);
}
@media (max-width:768px){
    .donation-grid{grid-template-columns:1fr;gap:24px;}
    .donation-card.featured{transform:none;}
    .donation-card.featured:hover{transform:translateY(-4px);}
}

/* ============================================
   寄付者特典
   ============================================ */
.perks{background:var(--bg-cream);}
.perks-grid{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:16px;
    margin-top:48px;
}
.perk{
    background:var(--white);
    padding:24px;
    border-radius:12px;
    display:flex;
    gap:16px;
    align-items:flex-start;
    box-shadow:var(--shadow-sm);
}
.perk-icon{
    flex-shrink:0;
    width:48px;height:48px;
    background:var(--leaf-light);
    border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    font-size:20px;
}
.perk h4{
    font-size:15px;
    margin-bottom:4px;
    color:var(--leaf-dark);
}
.perk p{
    font-size:13px;
    color:var(--text-sub);
    line-height:1.7;
}
.perks-founding{
    margin-top:32px;
    background:linear-gradient(135deg,var(--sunset),var(--gold));
    color:var(--white);
    padding:32px;
    border-radius:16px;
    text-align:center;
}
.perks-founding-label{
    display:inline-block;
    background:rgba(255,255,255,.2);
    padding:4px 16px;
    border-radius:50px;
    font-size:11px;
    letter-spacing:.2em;
    margin-bottom:12px;
}
.perks-founding h4{
    font-size:20px;
    color:var(--white);
    margin-bottom:12px;
}
.perks-founding p{
    font-size:14px;
    line-height:1.8;
    opacity:.95;
}
@media (max-width:768px){
    .perks-grid{grid-template-columns:1fr;}
}

/* ============================================
   声(利用者・支援者)
   ============================================ */
.voices{background:var(--bg-warm);}
.voice-tabs{
    display:flex;
    justify-content:center;
    gap:8px;
    margin-bottom:40px;
}
.voice-tab{
    padding:10px 24px;
    background:var(--white);
    border-radius:50px;
    font-size:13px;
    font-weight:600;
    color:var(--text-sub);
    border:1px solid var(--line);
    cursor:pointer;
    transition:all .3s;
}
.voice-tab.active{
    background:var(--leaf);
    color:var(--white);
    border-color:var(--leaf);
}
.voice-grid{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:24px;
    margin-top:32px;
}
.voice-card{
    background:var(--white);
    padding:32px;
    border-radius:12px;
    box-shadow:var(--shadow-sm);
    position:relative;
}
.voice-card::before{
    content:"\201C";
    font-family:"Shippori Mincho",serif;
    font-size:60px;
    color:var(--leaf-light);
    position:absolute;
    top:8px;left:16px;
    line-height:1;
}
.voice-text{
    font-family:"Shippori Mincho",serif;
    font-size:14px;
    line-height:2;
    color:var(--text-main);
    margin-top:32px;
    margin-bottom:20px;
    font-style:italic;
}
.voice-author{
    display:flex;
    align-items:center;
    gap:12px;
    border-top:1px solid var(--line);
    padding-top:16px;
}
.voice-avatar{
    width:40px;height:40px;
    border-radius:50%;
    background:linear-gradient(135deg,var(--leaf-light),var(--gold));
    display:flex;align-items:center;justify-content:center;
    color:var(--white);
    font-weight:700;
    font-size:14px;
}
.voice-name{
    font-size:13px;
    font-weight:600;
    color:var(--text-main);
}
.voice-meta{
    font-size:11px;
    color:var(--text-mute);
}
.voice-note{
    max-width:600px;
    margin:32px auto 0;
    padding:16px;
    background:var(--white);
    border-radius:8px;
    font-size:11px;
    color:var(--text-sub);
    text-align:center;
    border:1px dashed var(--line);
}
@media (max-width:768px){
    .voice-grid{grid-template-columns:1fr;}
    .voice-card{padding:24px;}
}

/* ============================================
   Q&A
   ============================================ */
.qa{background:var(--bg-cream);}
.qa-list{
    max-width:720px;
    margin:48px auto 0;
}
.qa-item{
    background:var(--white);
    border-radius:12px;
    margin-bottom:12px;
    overflow:hidden;
    box-shadow:var(--shadow-sm);
}
.qa-question{
    padding:20px 24px;
    cursor:pointer;
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
    gap:16px;
    font-weight:600;
    font-size:15px;
    list-style:none;
    transition:background .3s;
    position:relative;
}
.qa-question::-webkit-details-marker{display:none;}
.qa-question:hover{background:var(--bg-warm);}
.qa-q-icon{
    flex-shrink:0;
    width:32px;height:32px;
    background:var(--leaf);
    color:var(--white);
    border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    font-family:"Shippori Mincho",serif;
    font-weight:800;
    font-size:14px;
}
.qa-q-text{flex:1;}
.qa-toggle{
    flex-shrink:0;
    color:var(--text-mute);
    font-size:20px;
    transition:transform .3s;
}
.qa-item[open] .qa-toggle{transform:rotate(45deg);}
.qa-answer{
    padding:0 24px 24px 72px;
    color:var(--text-sub);
    font-size:14px;
    line-height:2;
    border-top:1px solid var(--bg-warm);
    padding-top:20px;
}
.qa-answer strong{color:var(--sunset-deep);font-weight:600;}
@media (max-width:768px){
    .qa-answer{padding-left:24px;}
}

/* ============================================
   創業者メッセージ
   ============================================ */
.founder{background:var(--bg-warm);}
.founder-card{
    max-width:720px;
    margin:0 auto;
    background:var(--white);
    border-radius:16px;
    overflow:hidden;
    box-shadow:var(--shadow-md);
}
.founder-header{
    background:linear-gradient(135deg,var(--leaf-dark),var(--leaf));
    color:var(--white);
    padding:40px 48px;
    display:flex;
    gap:24px;
    align-items:center;
}
.founder-avatar{
    width:80px;height:80px;
    border-radius:50%;
    background:linear-gradient(135deg,var(--gold),var(--sunset));
    flex-shrink:0;
    display:flex;align-items:center;justify-content:center;
    color:var(--white);
    font-family:"Shippori Mincho",serif;
    font-weight:800;
    font-size:24px;
    border:3px solid rgba(255,255,255,.3);
}
.founder-name-jp{
    font-family:"Shippori Mincho",serif;
    font-size:22px;
    font-weight:700;
    margin-bottom:4px;
}
.founder-name-title{
    font-size:13px;
    opacity:.85;
}
.founder-body{
    padding:40px 48px;
    font-family:"Shippori Mincho",serif;
    line-height:2.2;
    font-size:15px;
    color:var(--text-main);
}
.founder-body p{margin-bottom:20px;}
.founder-body .signature{
    text-align:right;
    margin-top:32px;
    color:var(--leaf-dark);
    font-weight:700;
}
@media (max-width:768px){
    .founder-header{padding:32px 24px;flex-direction:column;text-align:center;}
    .founder-body{padding:32px 24px;}
}

/* ============================================
   スタッフ紹介
   ============================================ */
.team{background:var(--bg-cream);}
.team-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:20px;
    margin-top:48px;
}
.team-card{
    background:var(--white);
    padding:32px 24px;
    border-radius:12px;
    text-align:center;
    box-shadow:var(--shadow-sm);
}
.team-avatar{
    width:80px;height:80px;
    border-radius:50%;
    background:linear-gradient(135deg,var(--leaf-light),var(--gold));
    margin:0 auto 16px;
    display:flex;align-items:center;justify-content:center;
    color:var(--white);
    font-weight:700;
    font-size:24px;
}
.team-name{
    font-family:"Shippori Mincho",serif;
    font-size:17px;
    font-weight:700;
    color:var(--leaf-dark);
    margin-bottom:4px;
}
.team-role{
    font-size:12px;
    color:var(--text-mute);
    letter-spacing:.1em;
    margin-bottom:12px;
}
.team-bio{
    font-size:12px;
    color:var(--text-sub);
    line-height:1.8;
    text-align:left;
}
@media (max-width:768px){
    .team-grid{grid-template-columns:1fr;}
}

/* ============================================
   クロージング
   ============================================ */
.closing{
    background:
        linear-gradient(180deg,var(--bg-deep) 0%,#1a1612 100%);
    color:var(--white);
    text-align:center;
    padding:96px 0;
    position:relative;
    overflow:hidden;
}
.closing::before{
    content:"";
    position:absolute;
    top:0;left:0;right:0;bottom:0;
    background:
        radial-gradient(circle at 30% 50%,rgba(216,115,68,.15),transparent 60%),
        radial-gradient(circle at 70% 50%,rgba(168,196,146,.1),transparent 60%);
}
.closing-content{position:relative;}
.closing-bystander{
    font-family:"Shippori Mincho",serif;
    font-size:clamp(16px,2.2vw,19px);
    color:rgba(255,255,255,.55);
    line-height:2.2;
    margin-bottom:40px;
    font-style:italic;
    letter-spacing:.04em;
}
.closing-title{
    font-family:"Shippori Mincho",serif;
    font-size:clamp(28px,4vw,40px);
    color:var(--white);
    margin-bottom:24px;
    line-height:1.5;
}
.closing-text{
    max-width:560px;
    margin:0 auto 40px;
    color:rgba(255,255,255,.8);
    line-height:2;
    font-size:15px;
}
.closing-signature{
    margin-top:40px;
    font-family:"Shippori Mincho",serif;
    font-size:14px;
    color:rgba(255,255,255,.6);
    letter-spacing:.2em;
}

/* ============================================
   フッター
   ============================================ */
.footer{
    background:#1a1612;
    color:rgba(255,255,255,.7);
    padding:48px 0 32px;
    font-size:13px;
}
.footer-grid{
    display:grid;
    grid-template-columns:1.5fr 1fr 1fr;
    gap:40px;
    margin-bottom:32px;
}
.footer h4{
    color:var(--white);
    font-size:14px;
    margin-bottom:16px;
    letter-spacing:.1em;
    font-family:"Noto Sans JP",sans-serif;
}
.footer-info p{margin-bottom:6px;line-height:1.8;}
.footer-links{list-style:none;}
.footer-links li{margin-bottom:8px;}
.footer-links a{
    color:rgba(255,255,255,.7);
    transition:color .3s;
    font-size:12px;
}
.footer-links a:hover{color:var(--sunset);}
.footer-bottom{
    border-top:1px solid rgba(255,255,255,.1);
    padding-top:24px;
    text-align:center;
    font-size:11px;
    color:rgba(255,255,255,.4);
}
@media (max-width:768px){
    .footer-grid{grid-template-columns:1fr;gap:24px;}
}

/* スティッキーCTA(モバイル) */
.sticky-cta{
    display:none;
    position:fixed;
    bottom:16px;left:16px;right:16px;
    z-index:99;
    background:var(--sunset);
    color:var(--white);
    text-align:center;
    padding:16px;
    border-radius:50px;
    font-weight:700;
    box-shadow:0 10px 30px rgba(216,115,68,.4);
}
@media (max-width:768px){
    .sticky-cta{display:block;}
}

/* アニメーション */
@keyframes fadeUp{
    from{opacity:0;transform:translateY(20px);}
    to{opacity:1;transform:translateY(0);}
}
.fade-up{animation:fadeUp .8s ease-out both;}
.fade-up:nth-child(2){animation-delay:.1s;}
.fade-up:nth-child(3){animation-delay:.2s;}

/* ロゴ画像 */
.logo-link{
    display:inline-block;
    text-decoration:none;
}
.logo-img{
    height:50px;
    width:auto;
    display:block;
}
@media(max-width:768px){
    .logo-img{height:42px;}
}

/* FV 2カラムレイアウト */
.fv-layout{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:48px;
    align-items:center;
}
.fv-layout .fv-content{
    text-align:left;
}
.fv-layout .fv-stat{
    justify-content:flex-start;
}
.fv-image{
    width:100%;
}
.fv-image img{
    width:100%;
    height:auto;
    display:block;
}
@media(max-width:768px){
    .fv-layout{
        grid-template-columns:1fr;
        gap:32px;
    }
    .fv-layout .fv-content{
        text-align:center;
    }
    .fv-layout .fv-stat{
        justify-content:center;
    }
    .fv-image{
        order:-1;
        max-width:400px;
        margin:0 auto;
    }
}


/* お便り画像セクション(横スクロール) */
.letters-section{
    padding:80px 0;
    background:#faf6ec;
    overflow:hidden;
}
.letters-section .section-header{
    text-align:center;
    margin-bottom:40px;
}
.letters-section .section-title{
    font-size:32px;
    margin-bottom:16px;
    color:var(--ink);
}
.letters-section .section-lead{
    font-size:14px;
    color:var(--ink-light);
    line-height:1.8;
}
.letters-scroll-wrapper{
    width:100%;
    overflow:hidden;
    padding:10px 0;
    -webkit-mask-image:linear-gradient(90deg, transparent 0%, #000 8%, #000 92%, transparent 100%);
    mask-image:linear-gradient(90deg, transparent 0%, #000 8%, #000 92%, transparent 100%);
}
.letters-scroll-track{
    display:flex;
    gap:18px;
    width:max-content;
    animation:scroll-letters 60s linear infinite;
}
.letters-scroll-track:hover{
    animation-play-state:paused;
}
.letter-item{
    flex-shrink:0;
    width:280px;
    background:#ffffff;
    padding:12px;
    border-radius:6px;
    box-shadow:0 2px 10px rgba(0,0,0,0.08);
    border:1px solid #eae3d2;
}
.letter-item img{
    width:100%;
    height:auto;
    display:block;
    border-radius:3px;
}
@keyframes scroll-letters{
    0%{transform:translateX(0);}
    100%{transform:translateX(calc(-50% - 9px));}
}
@media(max-width:768px){
    .letters-section{padding:60px 0;}
    .letters-section .section-title{font-size:22px;}
    .letter-item{width:220px !important;}
    .letters-scroll-track{
        gap:14px !important;
        animation-duration:48s !important;
    }
    @keyframes scroll-letters{
        0%{transform:translateX(0);}
        100%{transform:translateX(calc(-50% - 7px));}
    }
}


/* 新FV - ダークテキストボックス */
.fv-content-dark{
    background:#2a2a2a;
    color:#ffffff;
    padding:48px 40px;
    border-radius:6px;
    box-shadow:var(--shadow-md);
}
.fv-content-dark .fv-title-new{
    font-family:var(--font-serif);
    font-size:32px;
    line-height:1.6;
    font-weight:600;
    margin:0 0 28px;
    color:#ffffff;
    letter-spacing:0.02em;
}
.fv-content-dark .fv-quote-new{
    color:#f5d76e;
    font-weight:700;
}
.fv-content-dark .fv-lead-new{
    font-size:13px;
    line-height:1.95;
    margin:0 0 22px;
    color:#e0e0e0;
}
.fv-content-dark .fv-message-new{
    font-size:13.5px;
    line-height:1.95;
    margin:0 0 28px;
    color:#ffffff;
    font-weight:500;
}
.fv-content-dark .cta-primary{
    background:#c79a4a;
    color:#ffffff;
    margin-top:8px;
}
.fv-content-dark .cta-primary:hover{
    background:#b8893d;
}

@media(max-width:768px){
    .fv-content-dark{
        padding:32px 24px;
    }
    .fv-content-dark .fv-title-new{
        font-size:22px;
    }
    .fv-content-dark .fv-lead-new,
    .fv-content-dark .fv-message-new{
        font-size:12.5px;
    }
}


/* 寄付カードの画像 */
.donation-card-img{
    margin:16px -32px 0;
    overflow:hidden;
}
.donation-card-img img{
    width:100%;
    height:160px;
    object-fit:cover;
    display:block;
}
.donation-card{
    overflow:hidden;
}
@media(max-width:768px){
    .donation-card-img img{
        height:180px;
    }
}


/* 中間バナー(1日33円) */
.middle-banner{
    position:relative;
    height:380px;
    overflow:hidden;
    margin:0;
}
.middle-banner-bg{
    position:absolute;
    top:0;left:0;right:0;bottom:0;
    background-size:cover;
    background-position:center right;
    z-index:1;
}
.middle-banner-overlay{
    position:relative;
    z-index:2;
    height:100%;
    display:flex;
    align-items:center;
    background:linear-gradient(90deg, rgba(255,255,255,0.95) 0%, rgba(255,255,255,0.85) 40%, rgba(255,255,255,0.2) 70%, transparent 100%);
}
.middle-banner-text{
    max-width:600px;
    padding:0;
}
.middle-banner-title{
    font-family:var(--font-serif);
    font-size:30px;
    line-height:1.55;
    color:var(--ink);
    font-weight:600;
    margin:0;
    letter-spacing:0.02em;
}
@media(max-width:768px){
    .middle-banner{
        height:300px;
    }
    .middle-banner-bg{
        background-position:center;
        opacity:0.4;
    }
    .middle-banner-overlay{
        background:rgba(255,255,255,0.85);
    }
    .middle-banner-title{
        font-size:20px;
        text-align:center;
    }
    .middle-banner-text{
        text-align:center;
        margin:0 auto;
    }
}


/* あかしあとは - 画像グリッド */
.about-images{
    display:grid;
    grid-template-columns:repeat(3, 1fr);
    gap:20px;
    margin-top:40px;
    max-width:1000px;
    margin-left:auto;
    margin-right:auto;
}
.about-image{
    aspect-ratio:4/3;
    overflow:hidden;
    border-radius:8px;
    box-shadow:var(--shadow-sm);
}
.about-image img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
    transition:transform 0.5s;
}
.about-image:hover img{
    transform:scale(1.05);
}
@media(max-width:768px){
    .about-images{
        grid-template-columns:1fr;
        gap:14px;
        max-width:400px;
    }
}


/* 新FV - 画像背景オーバーレイ */
.fv-hero{
    position:relative;
    min-height:600px;
    padding:0;
    overflow:hidden;
}
.fv-hero-bg{
    position:absolute;
    top:0;left:0;right:0;bottom:0;
    background-size:cover;
    background-position:0% center;
    z-index:1;
}
.fv-hero-bg::after{
    content:'';
    position:absolute;
    top:0;left:0;right:0;bottom:0;
    background:linear-gradient(90deg, rgba(0,0,0,0) 0%, rgba(0,0,0,0) 25%, rgba(0,0,0,0.15) 45%, rgba(0,0,0,0.55) 70%, rgba(0,0,0,0.55) 100%);
}
.fv-hero .container{
    position:relative;
    z-index:2;
    min-height:600px;
    display:flex;
    align-items:center;
    justify-content:flex-end;
    padding-top:80px;
    padding-bottom:80px;
}
.fv-hero-layout{
    width:100%;
    display:flex;
    justify-content:flex-end;
}
.fv-hero-textbox{
    background:rgba(42,42,42,0.92);
    color:#ffffff;
    padding:42px 38px;
    border-radius:6px;
    box-shadow:0 10px 40px rgba(0,0,0,0.3);
    max-width:480px;
    backdrop-filter:blur(4px);
}
.fv-hero-textbox .fv-title-new{
    font-family:var(--font-serif);
    font-size:26px;
    line-height:1.6;
    font-weight:600;
    margin:0 0 24px;
    color:#ffffff;
    letter-spacing:0.02em;
}
.fv-hero-textbox .fv-quote-new{
    color:#f5d76e;
    font-weight:700;
}
.fv-hero-textbox .fv-lead-new{
    font-size:13px;
    line-height:1.95;
    margin:0 0 18px;
    color:#e0e0e0;
}
.fv-hero-textbox .fv-message-new{
    font-size:13.5px;
    line-height:1.95;
    margin:0 0 24px;
    color:#ffffff;
    font-weight:500;
}
.fv-hero-textbox .cta-primary{
    background:#c79a4a;
    color:#ffffff;
    width:100%;
    text-align:center;
}
.fv-hero-textbox .cta-primary:hover{
    background:#b8893d;
}

@media(max-width:768px){
    .fv-hero{
        min-height:auto;
    }
    .fv-hero .container{
        min-height:auto;
        padding:60px 20px;
        justify-content:center;
    }
    .fv-hero-textbox{
        padding:28px 24px;
        max-width:100%;
    }
    .fv-hero-textbox .fv-title-new{
        font-size:20px;
    }
    .fv-hero-textbox .fv-lead-new,
    .fv-hero-textbox .fv-message-new{
        font-size:12.5px;
    }
}


/* サポーター特典 - サンプル画像 */
.perks-samples{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:32px;
    margin-top:50px;
    max-width:900px;
    margin-left:auto;
    margin-right:auto;
}
.perks-sample{
    text-align:center;
}
.perks-sample img{
    width:100%;
    height:280px;
    object-fit:cover;
    object-position:top center;
    display:block;
    border-radius:8px;
    box-shadow:var(--shadow-md);
    border:1px solid #e8e3d6;
}
.perks-sample-caption{
    font-size:12px;
    color:var(--ink-light);
    margin-top:12px;
    letter-spacing:0.05em;
}
@media(max-width:768px){
    .perks-samples{
        grid-template-columns:1fr;
        gap:24px;
        max-width:400px;
    }
}


/* ============================================
   PC表示でもスマホレイアウトで固定表示
   ============================================ */
html {
    background: #e8e3d6;
}
body {
    max-width: 480px !important;
    margin: 0 auto !important;
    background: #ffffff;
    box-shadow: 0 0 40px rgba(0,0,0,0.08);
    position: relative;
    min-height: 100vh;
}

/* すべてのセクションを480px幅に固定 */
section, header, footer {
    width: 100% !important;
    max-width: 100% !important;
}

/* コンテナを内部余白用に統一 */
.container {
    max-width: 100% !important;
    width: 100% !important;
    padding-left: 20px !important;
    padding-right: 20px !important;
}

/* ヘッダーCTAを縮小 */
.header-cta {
    font-size: 11px !important;
    padding: 8px 14px !important;
}

/* FV - スマホレイアウト適用 */
.fv-hero {
    min-height: auto !important;
}
.fv-hero .container {
    min-height: auto !important;
    padding: 50px 20px !important;
    justify-content: center !important;
}
.fv-hero-textbox {
    padding: 28px 24px !important;
    max-width: 100% !important;
}
.fv-hero-textbox .fv-title-new {
    font-size: 20px !important;
}
.fv-hero-textbox .fv-lead-new,
.fv-hero-textbox .fv-message-new {
    font-size: 12.5px !important;
}

/* 統計エリア - 縦並びに */
.stat-grid {
    grid-template-columns: 1fr !important;
    gap: 14px !important;
}

/* あかしあとは - 画像3枚を縦に */
.about-images {
    grid-template-columns: 1fr !important;
    gap: 14px !important;
    max-width: 100% !important;
}

/* 中間バナー */
.middle-banner {
    height: 280px !important;
}
.middle-banner-bg {
    background-position: center !important;
    opacity: 0.4;
}
.middle-banner-overlay {
    background: rgba(255,255,255,0.85) !important;
}
.middle-banner-title {
    font-size: 20px !important;
    text-align: center !important;
}
.middle-banner-text {
    text-align: center !important;
    margin: 0 auto !important;
}

/* 寄付プランカード - 縦並び */
.donation-grid {
    grid-template-columns: 1fr !important;
    gap: 20px !important;
}
.donation-card-img img {
    height: 180px !important;
}

/* サポーター特典 - 縦並び */
.perks-grid {
    grid-template-columns: 1fr !important;
}
.perks-samples {
    grid-template-columns: 1fr !important;
    gap: 20px !important;
    max-width: 100% !important;
}
.perks-sample img {
    height: 200px !important;
}

/* 未来 3つのポイント - 縦並び */
.future-grid {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
}

/* タイトルサイズ調整 */
.section-title {
    font-size: 22px !important;
}

/* CTA */
.cta-primary {
    width: 100%;
    text-align: center;
}

/* フッター */
.footer-grid {
    grid-template-columns: 1fr !important;
    gap: 24px !important;
}


/* 新FV - 画像上+テキスト下の縦並び */
.fv-image-wrap{
    width:100%;
    overflow:hidden;
}
.fv-image-full{
    width:100%;
    height:auto;
    display:block;
}
.fv-content-below{
    background:#2a2a2a;
    color:#ffffff;
    padding:36px 28px;
    margin:24px 0 0;
    border-radius:6px;
    box-shadow:0 6px 24px rgba(0,0,0,0.12);
}
.fv-content-below .fv-title-new{
    font-family:var(--font-serif);
    font-size:22px;
    line-height:1.6;
    font-weight:600;
    margin:0 0 24px;
    color:#ffffff;
    letter-spacing:0.02em;
}
.fv-content-below .fv-quote-new{
    color:#f5d76e;
    font-weight:700;
}
.fv-content-below .fv-lead-new{
    font-size:13px;
    line-height:1.95;
    margin:0 0 18px;
    color:#e0e0e0;
}
.fv-content-below .fv-message-new{
    font-size:13.5px;
    line-height:1.95;
    margin:0 0 24px;
    color:#ffffff;
    font-weight:500;
}
.fv-content-below .cta-primary{
    background:#c79a4a;
    color:#ffffff;
    width:100%;
    text-align:center;
}
.fv-content-below .cta-primary:hover{
    background:#b8893d;
}


/* サポーター特典カード(画像入り) */
.perk-with-image{
    display:flex !important;
    flex-direction:column;
    background:#ffffff;
    padding:24px;
    border-radius:8px;
    box-shadow:var(--shadow-sm);
    gap:14px;
}
.perk-with-image .perk-header{
    display:flex;
    align-items:center;
    gap:12px;
}
.perk-with-image h4{
    margin:0;
    font-size:15px;
    color:var(--ink);
}
.perk-with-image .perk-icon{
    flex-shrink:0;
}
.perk-with-image p{
    font-size:13px;
    line-height:1.85;
    color:var(--ink-light);
    margin:0;
}
.perk-image{
    margin-top:8px;
    border-radius:6px;
    overflow:hidden;
    border:1px solid #e8e3d6;
}
.perk-image img{
    width:100%;
    height:200px;
    object-fit:cover;
    object-position:top center;
    display:block;
}

/* メルマガ画像 2枚並び */
.perk-image-pair{
    display:flex;
    gap:8px;
    margin-top:8px;
    justify-content:center;
}

/* スクリーンリーダー専用(視覚的には非表示、SEO/a11yには有効) */
.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;
}
.perk-image-pair img{
    width:50%;
    height:240px;
    object-fit:contain;
    display:block;
    border-radius:6px;
    border:1px solid #e8e3d6;
}
.perk-image-pair img:first-child{
    object-position:right center;
}
.perk-image-pair img:last-child{
    object-position:left center;
}
@media(max-width:768px){
    .perk-image-pair{gap:6px;}
    .perk-image-pair img{height:200px;}
}
