/*
Theme Name: momonote-theme
Theme URI: https://momonote.jp
Author: もものて
Author URI: https://momonote.jp
Description: もものて（momonote）のオリジナルテーマ。発信を、一人で抱えなくていい。やさしいピンクの世界観で、個人事業主の発信を並走サポートするサイト用テーマ。
Version: 1.6
Text Domain: momonote-theme
*/

/*
変更履歴
1.6 (2026-05-29) SEO SIMPLE PACK 導入につき、テーマ側の meta description/OGP/Twitterカード出力（functions.php の momonote_meta_tags）をコメントアウトで無効化。title-tag サポートは据え置き。
*/

/* =========================================================
   1. グローバル base（吸い出し _global.css）
   ========================================================= */
@import url('https://fonts.googleapis.com/css2?family=Klee+One:wght@400;600&family=Zen+Maru+Gothic:wght@400;500;700&family=Noto+Serif+JP:wght@400;500&display=swap');
:root{--pink:#D88B9C;--pink-deep:#C47585;--pink-soft:#F4D4DC;--pink-bg:#FBE9EE;--cream:#FFF8F2;--cream-2:#FAF1E8;--text:#5C4F4A;--text-soft:#8A7A73;--green:#A9C49A;--green-deep:#8AAC7A;--line:#EBDDD3;}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'Zen Maru Gothic','Hiragino Maru Gothic ProN','Hiragino Kaku Gothic ProN',sans-serif;color:var(--text);background:var(--cream);font-size:15px;line-height:1.9;-webkit-font-smoothing:antialiased;}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
.container{max-width:1180px;margin:0 auto;padding:0 32px;}
.narrow{max-width:880px;margin:0 auto;padding:0 32px;}
header{position:sticky;top:0;z-index:100;background:rgba(255,248,242,0.92);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-bottom:1px solid rgba(235,221,211,0.4);}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 40px;max-width:1320px;margin:0 auto;}
.brand{display:flex;align-items:center;gap:12px;}
.brand img{width:44px;height:44px;object-fit:contain;}
.brand-text .brand-name{font-family:'Klee One',serif;font-size:22px;color:var(--pink-deep);font-weight:600;line-height:1;}
.brand-text .brand-tagline{font-size:11px;color:var(--text-soft);margin-top:4px;letter-spacing:0.05em;}
nav.gnav{display:flex;align-items:center;gap:30px;}
nav.gnav a{font-size:14px;color:var(--text);transition:color .2s;}
nav.gnav a:hover{color:var(--pink-deep);}
.btn-cta{display:inline-flex;align-items:center;gap:8px;background:var(--pink);color:#fff !important;padding:11px 24px;border-radius:30px;font-size:14px;font-weight:500;transition:all .25s;box-shadow:0 4px 14px rgba(216,139,156,0.25);}
.btn-cta:hover{background:var(--pink-deep);transform:translateY(-1px);box-shadow:0 6px 18px rgba(216,139,156,0.35);}
.btn-cta::after{content:"›";font-size:18px;line-height:1;}
.hero{background:linear-gradient(180deg,var(--cream) 0%,#FCEFE8 100%);padding:70px 0 60px;position:relative;overflow:hidden;}
.hero.hero-with-fv{padding:0 0 50px;background:transparent;}
.hero-fv-wrap{width:100%;max-width:1400px;margin:0 auto;}
.hero-fv-image{width:100%;height:auto;display:block;}
.hero-inner-compact{padding-top:40px;}
.hero-inner{max-width:980px;margin:0 auto;padding:0 40px;text-align:center;}
.hero-eyebrow{display:inline-block;font-family:'Klee One',serif;font-size:14px;color:var(--pink-deep);letter-spacing:0.1em;margin-bottom:24px;padding:6px 18px;background:rgba(255,255,255,0.7);border-radius:30px;}
.hero h1{font-family:'Zen Maru Gothic',sans-serif;font-size:38px;font-weight:500;line-height:1.6;color:var(--text);letter-spacing:0.03em;margin-bottom:18px;}
.hero h1 .em{color:var(--pink-deep);}
.hero h1 .small{display:block;font-size:26px;margin-top:14px;color:var(--text);font-weight:500;}
.hero-lead{font-size:16px;line-height:2.1;color:var(--text-soft);margin:28px auto 32px;max-width:620px;}
.hero-lead strong{color:var(--pink-deep);font-weight:600;}
.hero-facts{display:flex;justify-content:center;gap:0;flex-wrap:wrap;max-width:680px;margin:0 auto 36px;background:#fff;border-radius:14px;box-shadow:0 4px 18px rgba(196,117,133,0.08);overflow:hidden;}
.hero-fact{flex:1;min-width:160px;padding:18px 16px;border-right:1px solid var(--line);text-align:center;}
.hero-fact:last-child{border-right:none;}
.hero-fact-label{font-size:11px;color:var(--text-soft);letter-spacing:0.1em;margin-bottom:6px;}
.hero-fact-value{font-size:17px;font-weight:600;color:var(--pink-deep);font-family:'Klee One',serif;line-height:1.4;}
.hero-fact-value .small{font-size:13px;font-weight:400;color:var(--text-soft);margin-left:2px;}
.hero-actions{display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap;}
.hero-handnote{font-family:'Klee One',serif;font-size:13px;color:var(--pink-deep);display:inline-flex;align-items:center;gap:6px;line-height:1.6;}
.hero-handnote::before{content:"〈";color:var(--pink);}
.hero-handnote::after{content:"〉";color:var(--pink);}
.image-placeholder{width:100%;max-width:880px;margin:48px auto;aspect-ratio:16/7;background:linear-gradient(135deg,#FBE9EE 0%,#FCEFE8 50%,#F4D4DC 100%);border-radius:14px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 18px rgba(196,117,133,0.10);position:relative;overflow:hidden;}
.image-placeholder::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 30%, rgba(255,255,255,0.5) 0%, transparent 35%),radial-gradient(circle at 80% 70%, rgba(216,139,156,0.15) 0%, transparent 40%);}
.placeholder-label{position:relative;font-family:'Klee One',serif;font-size:13px;color:var(--text-soft);padding:10px 22px;background:rgba(255,255,255,0.85);border-radius:24px;letter-spacing:0.05em;text-align:center;line-height:1.7;max-width:80%;}
.placeholder-label .em{display:block;color:var(--pink-deep);font-size:14px;margin-bottom:4px;}
.hero-image-test{max-width:1400px;margin:48px auto;text-align:center;}
.hero-image-test img{width:100%;aspect-ratio:16/6;object-fit:cover;object-position:center bottom;border-radius:14px;box-shadow:0 4px 18px rgba(196,117,133,0.10);}
section.block{padding:70px 0;}
.section-title{text-align:center;font-size:26px;font-weight:500;color:var(--text);margin-bottom:42px;letter-spacing:0.05em;line-height:1.7;}
.section-title::after{content:"";display:block;width:46px;height:2px;background:var(--pink);margin:14px auto 0;}
.section-lead{text-align:center;font-size:14.5px;color:var(--text-soft);line-height:2.0;max-width:680px;margin:-20px auto 36px;}
.reasons{background:var(--cream-2);}
.reasons-wrap{background:#fff;border-radius:18px;padding:44px 40px 40px;box-shadow:0 4px 24px rgba(196,117,133,0.06);max-width:880px;margin:0 auto;}
.reasons-list{display:flex;flex-direction:column;gap:18px;}
.reason-item{display:flex;align-items:flex-start;gap:18px;padding:18px 22px;background:var(--cream);border-radius:12px;}
.reason-icon{flex-shrink:0;width:40px;height:40px;background:var(--pink-soft);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--pink-deep);font-weight:600;font-family:'Klee One',serif;font-size:15px;}
.reason-text{font-size:15px;line-height:1.95;color:var(--text);}
.reason-text .em{color:var(--pink-deep);font-weight:600;}
.solution{background:var(--cream);}
.solution-wrap{max-width:880px;margin:0 auto;text-align:center;}
.solution-lead{font-size:17px;line-height:2.1;color:var(--text);margin-bottom:24px;}
.solution-lead .em{color:var(--pink-deep);font-weight:600;}
.solution-sub{font-size:14.5px;color:var(--text-soft);line-height:2.0;max-width:680px;margin:0 auto;}
.benefits{background:var(--cream-2);}
.benefits-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;max-width:880px;margin:0 auto;}
.benefit-card{background:#fff;border-radius:14px;padding:28px 26px;box-shadow:0 3px 14px rgba(196,117,133,0.06);display:flex;gap:18px;align-items:flex-start;}
.benefit-num{flex-shrink:0;width:32px;height:32px;background:var(--pink);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Klee One',serif;font-size:14px;font-weight:600;}
.benefit-body{flex:1;}
.benefit-title{font-size:16px;font-weight:600;color:var(--pink-deep);margin-bottom:6px;line-height:1.6;}
.benefit-desc{font-size:13.5px;color:var(--text-soft);line-height:1.95;}
.recommend{background:var(--cream);}
.recommend-wrap{max-width:780px;margin:0 auto;}
.recommend-list{display:flex;flex-direction:column;gap:14px;}
.recommend-item{background:#fff;border-radius:12px;padding:18px 24px 18px 56px;position:relative;font-size:15px;color:var(--text);line-height:1.85;box-shadow:0 2px 10px rgba(196,117,133,0.05);}
.recommend-item::before{content:"◎";position:absolute;left:22px;top:18px;color:var(--pink-deep);font-size:18px;font-weight:600;}
.cta-bar{background:linear-gradient(180deg,#FCEFE8 0%,var(--pink-bg) 100%);padding:44px 0;}
.cta-bar-inner{max-width:780px;margin:0 auto;padding:0 32px;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;}
.cta-bar-text{flex:1;min-width:240px;}
.cta-bar-title{font-size:18px;font-weight:600;color:var(--text);margin-bottom:6px;line-height:1.6;}
.cta-bar-sub{font-size:13px;color:var(--text-soft);line-height:1.7;}
.cta-bar-actions{display:flex;gap:12px;flex-wrap:wrap;}
.cta-button{display:inline-flex;align-items:center;gap:10px;background:var(--pink);color:#fff !important;padding:14px 30px;border-radius:30px;font-size:14.5px;font-weight:600;box-shadow:0 6px 18px rgba(216,139,156,0.3);transition:all .25s;}
.cta-button:hover{background:var(--pink-deep);transform:translateY(-1px);box-shadow:0 8px 22px rgba(216,139,156,0.4);}
.cta-button::after{content:"›";font-size:18px;}
.cta-button.sub{background:#fff;color:var(--pink-deep) !important;border:1.5px solid var(--pink);box-shadow:0 4px 12px rgba(216,139,156,0.15);}
.cta-button.sub:hover{background:var(--pink-bg);}
.three{background:var(--cream-2);}
.three-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1080px;margin:0 auto;}
.three-card{background:#fff;border-radius:14px;padding:36px 28px 32px;box-shadow:0 3px 16px rgba(180,120,100,0.07);position:relative;}
.three-num{position:absolute;top:-14px;left:24px;width:36px;height:36px;background:var(--pink);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Klee One',serif;font-size:16px;font-weight:600;box-shadow:0 4px 12px rgba(216,139,156,0.3);}
.three-name{font-size:18px;font-weight:700;color:var(--pink-deep);margin:6px 0 16px;line-height:1.6;}
.three-desc{font-size:14px;color:var(--text-soft);line-height:2.0;}
.compare{background:var(--cream);}
.compare-wrap{max-width:880px;margin:0 auto;overflow-x:auto;}
.compare-table{width:100%;border-collapse:separate;border-spacing:0;background:#fff;border-radius:14px;overflow:hidden;box-shadow:0 4px 24px rgba(196,117,133,0.06);}
.compare-table th,.compare-table td{padding:18px 20px;text-align:left;font-size:13.5px;line-height:1.85;border-bottom:1px solid var(--line);vertical-align:top;}
.compare-table th{background:var(--cream-2);font-weight:600;color:var(--text);white-space:nowrap;}
.compare-table thead th{font-size:13px;letter-spacing:0.04em;text-align:center;}
.compare-table thead th.col-momo{background:var(--pink-bg);color:var(--pink-deep);}
.compare-table td.col-momo{background:rgba(251,233,238,0.4);color:var(--text);font-weight:500;}
.compare-table tr:last-child th,.compare-table tr:last-child td{border-bottom:none;}
.case{background:var(--cream-2);}
.case-wrap{background:#fff;border-radius:18px;padding:44px 40px;max-width:880px;margin:0 auto;box-shadow:0 4px 24px rgba(196,117,133,0.06);}
.case-thumb{width:100%;aspect-ratio:3/2;background-image:url("https://momonote.jp/wp-content/uploads/2026/05/6iq838.jpg");background-size:cover;background-position:center;background-color:var(--cream-2);border-radius:10px;margin-bottom:24px;position:relative;box-shadow:0 4px 14px rgba(180,120,100,0.10);}
.case-head{text-align:center;margin-bottom:30px;}
.case-eyebrow{display:inline-block;font-size:12px;color:var(--pink-deep);letter-spacing:0.15em;background:var(--pink-bg);padding:5px 14px;border-radius:20px;margin-bottom:14px;}
.case-name{font-size:20px;font-weight:600;color:var(--text);line-height:1.7;}
.case-name .sub{display:block;font-size:13px;color:var(--text-soft);font-weight:400;margin-top:6px;letter-spacing:0.04em;}
.case-body{font-size:14.5px;line-height:2.0;color:var(--text);}
.case-body p{margin-bottom:14px;}
.flow{background:var(--cream-2);}
.flow-list{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:0;position:relative;}
.flow-step{display:flex;gap:24px;align-items:flex-start;padding:24px 0;position:relative;}
.flow-step:not(:last-child)::after{content:"";position:absolute;left:29px;top:78px;bottom:-12px;width:2px;background:var(--pink-soft);}
.flow-num{flex-shrink:0;width:60px;height:60px;background:#fff;border:2px solid var(--pink);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--pink-deep);font-family:'Klee One',serif;font-size:20px;font-weight:600;box-shadow:0 4px 14px rgba(216,139,156,0.15);z-index:1;}
.flow-body{flex:1;padding-top:6px;}
.flow-title{font-size:17px;font-weight:600;color:var(--text);margin-bottom:8px;}
.flow-desc{font-size:14px;color:var(--text-soft);line-height:1.95;}
.pricing{background:var(--cream);}
.pricing-card{background:#fff;border-radius:18px;padding:44px 40px;max-width:720px;margin:0 auto;box-shadow:0 4px 24px rgba(196,117,133,0.06);text-align:center;border:1px solid var(--line);}
.pricing-name{font-size:18px;font-weight:600;color:var(--pink-deep);margin-bottom:10px;letter-spacing:0.04em;}
.pricing-price{font-size:36px;font-weight:500;color:var(--text);letter-spacing:0.04em;margin-bottom:6px;}
.pricing-price .yen{font-size:20px;color:var(--text-soft);margin-left:2px;}
.pricing-tax{font-size:12px;color:var(--text-soft);margin-bottom:30px;}
.pricing-divider{width:46px;height:2px;background:var(--pink-soft);margin:0 auto 26px;}
.pricing-includes-title{font-size:13.5px;font-weight:600;color:var(--text);margin-bottom:14px;letter-spacing:0.06em;}
.pricing-includes{display:flex;flex-direction:column;gap:10px;text-align:left;max-width:480px;margin:0 auto;}
.pricing-includes li{list-style:none;font-size:14px;color:var(--text);padding-left:24px;position:relative;line-height:1.8;}
.pricing-includes li::before{content:"";position:absolute;left:0;top:7px;width:14px;height:14px;border:1.5px solid var(--pink);border-radius:3px;background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 14'><polyline points='3,7 6,10 11,4' fill='none' stroke='%23D88B9C' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/></svg>") center/10px no-repeat;}
.pricing-note{font-size:12.5px;color:var(--text-soft);margin-top:24px;line-height:1.85;text-align:left;max-width:480px;margin-left:auto;margin-right:auto;}
.profile{background:var(--cream-2);}
.profile-wrap{max-width:780px;margin:0 auto;background:#fff;border-radius:18px;padding:40px 36px;box-shadow:0 4px 24px rgba(196,117,133,0.06);display:flex;gap:32px;align-items:flex-start;}
.profile-photo{flex-shrink:0;width:140px;height:140px;background-image:url("https://momonote.jp/wp-content/uploads/2026/05/profile.jpg");background-size:cover;background-position:60% 35%;background-color:var(--pink-bg);border-radius:50%;border:3px solid #fff;box-shadow:0 4px 14px rgba(196,117,133,0.15);}
.profile-body{flex:1;}
.profile-name{font-size:20px;font-weight:600;color:var(--pink-deep);margin-bottom:6px;}
.profile-role{font-size:13px;color:var(--text-soft);margin-bottom:18px;letter-spacing:0.04em;}
.profile-text{font-size:14px;color:var(--text);line-height:2.0;margin-bottom:16px;}
.profile-link{display:inline-flex;align-items:center;gap:8px;margin-top:22px;background:var(--pink-bg);color:var(--pink-deep);padding:12px 28px;border-radius:24px;font-size:13.5px;font-weight:600;border:1px solid var(--pink-soft);transition:all .25s;box-shadow:0 2px 8px rgba(216,139,156,0.10);}
.profile-link::after{content:"›";font-size:18px;line-height:1;color:var(--pink-deep);}
.profile-link:hover{background:var(--pink);color:#fff;border-color:var(--pink);transform:translateY(-1px);box-shadow:0 6px 18px rgba(216,139,156,0.30);}
.profile-link:hover::after{color:#fff;}
.faq{background:var(--cream);}
.faq-list{max-width:780px;margin:0 auto;display:flex;flex-direction:column;gap:14px;}
.faq-item{background:#fff;border-radius:12px;box-shadow:0 2px 10px rgba(196,117,133,0.05);overflow:hidden;}
.faq-q{padding:20px 24px;font-size:15px;font-weight:600;color:var(--text);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px;list-style:none;line-height:1.6;}
.faq-q::-webkit-details-marker{display:none;}
.faq-q::after{content:"+";flex-shrink:0;color:var(--pink-deep);font-size:22px;font-weight:400;transition:transform .25s;}
.faq-item[open] .faq-q::after{transform:rotate(45deg);}
.faq-a{padding:0 24px 22px;font-size:14px;color:var(--text-soft);line-height:2.0;}
.faq-q-label{font-family:'Klee One',serif;color:var(--pink-deep);margin-right:10px;font-size:14px;}
.cta-block{background:linear-gradient(180deg,#FCEFE8 0%,var(--pink-bg) 100%);padding:80px 0;}
.cta-inner{max-width:640px;margin:0 auto;padding:0 32px;text-align:center;}
.cta-inner-wide{max-width:1400px;padding:0;}
.cta-final-image{max-width:1400px;width:100%;margin:0 auto 28px;display:block;}
.cta-form-wrap{max-width:1400px;width:100%;margin:0 auto;padding:0;}
footer{background:var(--cream);border-top:1px solid var(--line);padding:30px 0 28px;}
.footer-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:24px;max-width:1240px;margin:0 auto;padding:0 40px;}
.footer-brand{display:flex;align-items:center;gap:10px;}
.footer-brand img{width:32px;height:32px;}
.footer-brand .name{font-family:'Klee One',serif;color:var(--pink-deep);font-size:17px;font-weight:600;}
.footer-brand .tag{font-size:11px;color:var(--text-soft);margin-left:8px;}
.footer-nav{display:flex;gap:24px;flex-wrap:wrap;}
.footer-nav a{font-size:13px;color:var(--text-soft);}
.footer-nav a:hover{color:var(--pink-deep);}
.footer-actions{display:flex;gap:10px;}
.footer-btn{border:1px solid var(--line);color:var(--text-soft);padding:8px 18px;border-radius:30px;font-size:12.5px;background:#fff;}
.footer-btn:hover{border-color:var(--pink);color:var(--pink-deep);}
.copyright{text-align:center;font-size:11px;color:var(--text-soft);margin-top:24px;padding-top:18px;border-top:1px solid var(--line);}
@media (max-width:860px){.hero{padding:50px 0 40px;}.hero h1{font-size:28px;}.hero h1 .small{font-size:20px;}.hero-fact{min-width:140px;padding:14px 12px;border-right:none;border-bottom:1px solid var(--line);}.hero-fact:last-child{border-bottom:none;}.three-grid{grid-template-columns:1fr;}.benefits-grid{grid-template-columns:1fr;}nav.gnav{display:none;}.pricing-card{padding:36px 24px;}.case-wrap{padding:32px 24px;}.reasons-wrap{padding:36px 24px;}.profile-wrap{flex-direction:column;align-items:center;padding:32px 22px;}.profile-body{text-align:left;width:100%;}.profile-name,.profile-role{text-align:center;}.compare-wrap{padding:0 12px;}.compare-table th,.compare-table td{padding:14px 12px;font-size:12.5px;}.flow-step{gap:16px;}.flow-num{width:50px;height:50px;font-size:17px;}.flow-step:not(:last-child)::after{left:24px;top:66px;}.cta-bar-inner{flex-direction:column;text-align:center;}section.block{padding:54px 0;}}


/* =========================================================
   2. ブログ確定デザイン（_統合プレビュー_ブログ_確定.html）
   ========================================================= */
body{
  font-family:'Noto Sans JP','Hiragino Kaku Gothic ProN','Hiragino Sans',sans-serif;
  color:var(--text);
  background:var(--cream);
  font-size:15px;
  line-height:1.9;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4,h5,h6{font-family:'Zen Maru Gothic','Hiragino Maru Gothic ProN',sans-serif;}

/* ===== HEADER（サイト統一形 / 2026-05-21確定） ===== */
header{
  position:sticky;top:0;z-index:100;
  background:rgba(255,248,242,0.92);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  border-bottom:1px solid rgba(235,221,211,0.4);
}
.header-inner{
  display:flex;align-items:center;
  padding:14px 24px;
  max-width:none;gap:24px;
}
.brand{display:flex;align-items:center;gap:12px;}
.brand img{height:52px;width:auto;}
.brand-text{display:none;}
.brand-text .brand-name{
  font-family:'Klee One',serif;
  font-size:22px;color:var(--pink-deep);font-weight:600;line-height:1;
}
.brand-text .brand-tagline{
  font-size:11px;color:var(--text-soft);margin-top:4px;letter-spacing:0.05em;
}
nav.gnav{display:flex;align-items:center;margin-left:auto;gap:2px;flex-wrap:nowrap;}
nav.gnav a{
  font-size:13.5px;color:#C47585;font-weight:500;
  padding:8px 12px;letter-spacing:0;
  transition:color .2s;
  position:relative;
}
nav.gnav a:hover{color:#A9C49A;font-weight:700;text-shadow:0 0 0.5px currentColor;}
nav.gnav a.current{color:var(--pink-deep);font-weight:700;}
nav.gnav a.current::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--pink);border-radius:1px;}

/* ===== BUTTON ===== */
.btn-cta{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:12px 28px;border-radius:30px;
  font-size:14px;font-weight:500;
  min-height:44px;
  line-height:1.4;
  transition:all .25s;
  white-space:nowrap;
  background:var(--pink);color:#fff !important;
  box-shadow:0 4px 14px rgba(216,139,156,0.25);
}
.btn-cta::after{content:"›";font-size:18px;line-height:1;}
.btn-cta:hover{background:#A9C49A;transform:translateY(-1px);box-shadow:0 6px 18px rgba(216,139,156,0.35);}
header .btn-cta{margin-left:8px;}
header .btn-cta:hover{background:#A9C49A;color:#fff;text-shadow:none;}

/* ===== FOOTER（サイト統一形 / 2026-05-21確定） ===== */
footer{
  background:var(--cream);
  border-top:1px solid var(--line);
  padding:30px 0 28px;
}
.footer-inner{
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:24px;
  max-width:1240px;margin:0 auto;padding:0 40px;
}
.footer-brand{display:flex;align-items:center;gap:10px;}
.footer-brand img{height:34px;width:auto;}
.footer-brand .name{display:none;}
.footer-brand .name{
  font-family:'Klee One',serif;
  color:var(--pink-deep);font-size:17px;font-weight:600;
}
.footer-brand .tag{
  font-size:11px;color:var(--text-soft);margin-left:8px;
}
.footer-nav{display:flex;gap:24px;flex-wrap:wrap;}
.footer-nav a{font-size:13px;color:var(--text-soft);}
.footer-nav a:hover{color:var(--pink-deep);}
.copyright{
  text-align:center;
  font-size:11px;color:var(--text-soft);
  margin-top:24px;
  padding-top:18px;
  border-top:1px solid var(--line);
}

/* ===== 記事本体 ===== */
.article-wrap{max-width:720px;margin:0 auto;padding:64px 32px 80px;}
.article-meta-top{display:flex;gap:14px;align-items:center;margin-bottom:14px;font-size:12.5px;color:var(--text-soft);}
.article-meta-top .cat{color:var(--pink-deep);font-weight:500;}
.article-meta-top .sep{color:var(--line);}
.article-title{
  font-family:'Zen Maru Gothic',sans-serif;
  font-weight:500;font-size:28px;color:var(--text);
  line-height:1.55;letter-spacing:0.04em;
  margin:0 0 32px;
  overflow-wrap:break-word;
}

/* アイキャッチ */
.article-eyecatch{margin:0 0 56px;}
.article-eyecatch img{width:100%;border-radius:10px;display:block;}

/* 本文 */
.article-body{font-size:15.5px;line-height:2.1;color:var(--text);}
.article-body p{margin:0 0 1.7em;}

/* H2：ピンク背景＋白文字の見出し帯（確定） */
.article-body h2{
  font-family:'Zen Maru Gothic',sans-serif;
  font-size:22px;font-weight:600;color:#fff;
  background:var(--pink);
  margin:72px 0 30px;padding:16px 26px;
  line-height:1.55;letter-spacing:0.05em;
  border-radius:8px;
  overflow-wrap:break-word;
}
.article-body h2:first-child{margin-top:0;}

/* H3：黒文字＋太字＋下に細いピンク線（装飾でメリハリ） */
.article-body h3{
  font-family:'Zen Maru Gothic',sans-serif;
  font-size:19px;font-weight:700;color:var(--text);
  margin:44px 0 18px;padding-bottom:10px;
  line-height:1.6;letter-spacing:0.03em;
  border-bottom:1.5px solid var(--pink-soft);
  overflow-wrap:break-word;
}

/* H4：黒文字＋太字＋ピンクの短いダッシュ */
.article-body h4{
  font-family:'Zen Maru Gothic',sans-serif;
  font-size:15.5px;font-weight:700;color:var(--text);
  margin:30px 0 12px;line-height:1.6;
  padding-left:18px;position:relative;
}
.article-body h4::before{
  content:'';position:absolute;left:0;top:0.65em;
  width:10px;height:2px;background:var(--pink);
  border-radius:2px;
}

/* リスト */
.article-body ul,.article-body ol{list-style:none;padding:0;margin:0 0 1.8em;}
.article-body ul li{padding:5px 0 5px 20px;position:relative;line-height:2;}
.article-body ul li::before{content:'';position:absolute;left:4px;top:18px;width:6px;height:6px;border-radius:50%;background:var(--pink-soft);border:1.5px solid var(--pink);}
.article-body ol{counter-reset:ol-counter;}
.article-body ol li{padding:5px 0 5px 26px;position:relative;line-height:2;counter-increment:ol-counter;}
.article-body ol li::before{content:counter(ol-counter)'.';position:absolute;left:0;top:5px;color:var(--pink-deep);font-family:'Klee One',serif;font-weight:600;}

/* 引用：装飾なし・控えめインデントだけ（万が一使われた時用） */
.article-body blockquote{
  margin:1.7em 0;padding:0 1.5em;
  color:var(--text-soft);font-style:normal;
}
.article-body blockquote p{margin:0 0 1em;}
.article-body blockquote p:last-child{margin:0;}

/* 強調 */
.article-body strong{font-weight:700;color:var(--pink-deep);}

/* リンク */
.article-body a{color:var(--pink-deep);text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--pink-soft);}
.article-body a:hover{text-decoration-color:var(--pink);}

/* 画像 */
.article-body figure{margin:32px 0;}
.article-body figure img{width:100%;border-radius:8px;}
.article-body figcaption{margin-top:8px;font-size:12.5px;color:var(--text-soft);text-align:center;font-family:'Klee One',serif;}

/* 水平線 */
.article-body hr{border:0;height:1px;background:var(--line);margin:48px auto;max-width:80px;}

/* ===== 記事下：前後記事ナビ ===== */
.article-end{margin-top:56px;}

/* ===== 記事末尾CTA（叩き台：もものてver.） ===== */
.article-cta{
  background:linear-gradient(180deg,transparent 0%,#FFF6F2 35%,#FFF6F2 65%,transparent 100%);
  border-top:1px dashed var(--pink-soft);
  border-bottom:1px dashed var(--pink-soft);
  padding:42px 24px 36px;
  margin:64px 0 0;
  text-align:center;
  position:relative;
}
.article-cta h3{
  font-family:'Zen Maru Gothic',sans-serif;
  font-size:21px;font-weight:500;
  line-height:1.65;
  color:var(--text);
  letter-spacing:0.04em;
  margin:0 0 6px;
}
.article-cta h3 .em{color:var(--pink-deep);}
.article-cta h3::after{
  content:"・ ・ ・";
  display:block;
  font-size:12px;
  color:var(--pink-soft);
  letter-spacing:0.45em;
  margin-top:14px;
  font-weight:400;
}
.article-cta p{
  font-size:13.5px;line-height:1.95;
  color:var(--text-soft);
  margin:0 auto 24px;
  max-width:480px;
  word-break:keep-all;
  overflow-wrap:break-word;
  text-wrap:balance;
}
.article-cta .btn-cta-article{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 32px;border-radius:30px;
  font-size:14px;font-weight:500;
  min-height:48px;
  line-height:1.4;
  background:var(--pink);color:#fff !important;
  box-shadow:0 4px 14px rgba(216,139,156,0.25);
  transition:all .25s;
  text-decoration:none;
  min-width:240px;
}
.article-cta .btn-cta-article::after{content:"›";font-size:18px;line-height:1;}
.article-cta .btn-cta-article:hover{background:#A9C49A;transform:translateY(-1px);box-shadow:0 6px 18px rgba(216,139,156,0.35);}
.article-cta-note{
  font-family:'Klee One',serif;
  font-size:12px;
  margin-top:16px;
  color:var(--text-soft);
  display:block;
}
.article-cta-note::before{content:"〈 ";color:var(--pink);}
.article-cta-note::after{content:" 〉";color:var(--pink);}

@media(max-width:640px){
  .article-cta{padding:34px 18px 28px;margin-top:48px;}
  .article-cta h3{font-size:18px;}
  .article-cta p{font-size:13px;}
  .article-cta .btn-cta-article{width:100%;min-width:0;}
}
/* ===== 前後記事ナビ（PC：中央ドット＋ベージュ／SP：左右ズレ＋ベージュなし） ===== */
.article-nav{
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  gap:20px;
  background:rgba(250,241,232,0.55);
  border-radius:8px;
  padding:22px 24px;
}
.article-nav .nav-divider{
  color:var(--pink);
  font-size:15px;
  line-height:1.4;
  text-align:center;
  letter-spacing:0;
  user-select:none;
  opacity:0.7;
}
.article-nav a{
  display:flex;
  align-items:center;
  gap:14px;
  padding:0;
  background:transparent;
  border:none;
  border-radius:0;
  text-decoration:none;
  transition:opacity .25s;
  min-width:0;
}
.article-nav .nav-prev{flex-direction:row;}
.article-nav .nav-next{flex-direction:row-reverse;}
.article-nav a:hover{opacity:0.75;background:transparent;border:none;transform:none;box-shadow:none;}
.article-nav a:hover .nav-title{color:var(--pink-deep);}
.article-nav .nav-thumb{
  width:120px;height:68px;
  border-radius:6px;
  background:linear-gradient(135deg,#FBE9EE 0%,#FCEFE8 100%);
  overflow:hidden;
  flex-shrink:0;
}
.article-nav .nav-thumb img{
  width:100%;height:100%;
  object-fit:cover;
  display:block;
}
.article-nav .nav-text{
  display:flex;
  flex-direction:column;
  gap:4px;
  min-width:0;
}
.article-nav .nav-next .nav-text{align-items:flex-end;}
.article-nav .nav-label{
  font-family:'Klee One',serif;
  font-size:13px;
  color:var(--pink-deep);
  letter-spacing:0.06em;
  font-weight:600;
  margin-bottom:2px;
}
.article-nav .nav-title{
  font-size:13px;
  color:var(--text);
  line-height:1.55;
  font-family:'Zen Maru Gothic','Hiragino Maru Gothic ProN',sans-serif;
  letter-spacing:0.02em;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  transition:color .2s;
  word-break:break-all;
}
.article-nav .nav-next .nav-title{text-align:right;}

/* ===== 一覧画面 ===== */
.divider{max-width:720px;margin:80px auto 0;padding:24px 32px;border-top:1px dashed var(--line);}
.divider p{text-align:center;font-size:12px;color:var(--text-soft);font-family:'Klee One',serif;letter-spacing:0.15em;}

.list-wrap{max-width:720px;margin:0 auto;padding:24px 32px 80px;}
.list-hero{text-align:center;margin-bottom:48px;}
.list-hero .eyebrow{font-family:'Klee One',serif;color:var(--pink-deep);letter-spacing:0.25em;font-size:12px;margin-bottom:10px;}
.list-hero h1{font-family:'Zen Maru Gothic',sans-serif;font-weight:500;font-size:26px;color:var(--text);letter-spacing:0.04em;line-height:1.5;}
.post-list{display:flex;flex-direction:column;gap:36px;}
.post-card{display:block;text-decoration:none;color:inherit;padding-bottom:32px;border-bottom:1px solid var(--line);}
.post-card:last-child{border-bottom:none;}
.post-card-meta{display:flex;gap:12px;align-items:center;margin-bottom:8px;font-size:12px;color:var(--text-soft);}
.post-card-meta .cat{color:var(--pink-deep);}
.post-card-title{font-family:'Zen Maru Gothic',sans-serif;font-weight:500;font-size:17px;line-height:1.6;color:var(--text);margin:0 0 8px;letter-spacing:0.03em;}
.post-card:hover .post-card-title{color:var(--pink-deep);}
.post-card-excerpt{font-size:13.5px;color:var(--text-soft);line-height:1.95;margin:0;}

/* ===== ページネーション（丸ボタンに戻す） ===== */
.pagination{display:flex;justify-content:center;gap:8px;margin-top:56px;flex-wrap:wrap;}
.pagination a,.pagination span{display:inline-flex;align-items:center;justify-content:center;min-width:40px;height:40px;padding:0 14px;border-radius:30px;font-family:'Klee One',serif;font-size:14px;color:var(--text);background:#fff;border:1px solid var(--line);text-decoration:none;transition:all .25s;}
.pagination a:hover{background:var(--pink-bg);border-color:var(--pink-soft);color:var(--pink-deep);}
.pagination .current{background:var(--pink);color:#fff;border-color:var(--pink);font-weight:600;}

/* ===== RESPONSIVE（ヘッダー・フッター） ===== */
@media (max-width:860px){
  header .header-inner{padding:10px 16px;gap:12px;}
  .brand img{height:42px;}
  nav.gnav{gap:0;}
  nav.gnav a:not(.btn-cta){display:none;}
  header .btn-cta,nav.gnav a.btn-cta{padding:9px 14px;font-size:12.5px;min-height:0;margin-left:0;}
  .footer-inner{flex-direction:column;text-align:center;padding:0 24px;gap:18px;}
  .footer-brand{justify-content:center;flex-wrap:wrap;}
  .footer-nav{justify-content:center;}
}
@media(max-width:680px){
  .article-wrap,.list-wrap{padding:48px 24px 60px;}
  /* 見出し折り返し：スマホのみ文節改行（PCはブラウザ標準） */
  .article-title{font-size:22px;line-height:1.65;letter-spacing:0.02em;word-break:auto-phrase;}
  .article-body{font-size:15px;}
  .article-body h2{font-size:18px;padding:14px 18px;margin:56px 0 24px;line-height:1.7;letter-spacing:0.02em;word-break:auto-phrase;}
  .article-body h3{font-size:16.5px;margin:36px 0 14px;line-height:1.65;letter-spacing:0.02em;word-break:auto-phrase;}
  .article-body h4{font-size:15px;}
  .list-hero h1{font-size:22px;}
  .article-nav{
    grid-template-columns:1fr 1fr;
    grid-template-areas:
      "prev   ."
      ".      next";
    gap:24px;
    background:transparent;
    border-radius:0;
    padding:8px 4px;
  }
  .article-nav .nav-prev{grid-area:prev;justify-self:start;}
  .article-nav .nav-next{grid-area:next;justify-self:end;}
  .article-nav .nav-divider{display:none;}
}

/* ===== 目次（TOC：控えめ版） ===== */
.toc{
  background:transparent;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  margin:36px 0 48px;
  padding:0;
}
.toc summary{
  list-style:none;
  cursor:pointer;
  padding:14px 4px;
  display:flex;
  align-items:center;
  gap:10px;
  font-family:'Noto Sans JP','Hiragino Kaku Gothic ProN',sans-serif;
  font-size:13px;
  color:var(--text-soft);
  letter-spacing:0.08em;
  user-select:none;
  font-weight:500;
}
.toc summary::-webkit-details-marker{display:none;}
.toc summary::marker{display:none;}
.toc summary .toc-arrow{
  margin-left:auto;
  font-size:10px;
  color:var(--text-soft);
  transition:transform .25s;
  letter-spacing:0;
  opacity:0.7;
}
.toc[open] summary .toc-arrow{transform:rotate(180deg);}
.toc-list{
  list-style:none;
  padding:4px 4px 16px;
  margin:0;
  counter-reset:toc-num;
}
.toc-list li{
  counter-increment:toc-num;
  padding:5px 0;
  display:flex;
  gap:10px;
  font-family:'Noto Sans JP','Hiragino Kaku Gothic ProN',sans-serif;
  font-size:13.5px;
  line-height:1.75;
  align-items:baseline;
}
.toc-list li::before{
  content:counter(toc-num) ".";
  color:var(--text-soft);
  flex-shrink:0;
  min-width:20px;
  font-size:13px;
  font-weight:400;
}
.toc-list a{
  color:var(--text);
  text-decoration:none;
  transition:color .2s;
}
.toc-list a:hover{color:var(--pink-deep);}

@media(max-width:640px){
  .toc{margin:28px 0 36px;}
  .toc summary{font-size:12.5px;padding:12px 2px;}
  .toc-list{padding:2px 2px 14px;}
  .toc-list li{font-size:13px;gap:8px;}
  .toc-list li::before{min-width:18px;font-size:12.5px;}
}

/* =========================================================
   ページ固有：サイトTOP（フロントページ）（index.html）
   ========================================================= */
:root{
  --pink:#D88B9C;
  --pink-deep:#C47585;
  --pink-soft:#F4D4DC;
  --pink-bg:#FBE9EE;
  --cream:#FFF8F2;
  --cream-2:#FAF1E8;
  --text:#5C4F4A;
  --text-soft:#8A7A73;
  --green:#A9C49A;
  --line:#EBDDD3;
}

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

html{scroll-behavior:smooth;}
body{
  font-family:'Noto Sans JP','Hiragino Kaku Gothic ProN','Hiragino Sans',sans-serif;
  color:var(--text);
  background:var(--cream);
  font-size:15px;
  line-height:1.9;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4,h5,h6{font-family:'Zen Maru Gothic','Hiragino Maru Gothic ProN',sans-serif;}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}

.container{max-width:1180px;margin:0 auto;padding:0 32px;}

/* ===== HEADER ===== */
header{
  position:sticky;top:0;z-index:100;
  background:rgba(255,248,242,0.92);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  border-bottom:1px solid rgba(235,221,211,0.4);
}
.header-inner{
  display:flex;align-items:center;
  padding:14px 24px;
  max-width:none;gap:24px;
}
.brand{display:flex;align-items:center;gap:12px;}
.brand img{height:52px;width:auto;}.brand-text{display:none;}
.brand-text .brand-name{
  font-family:'Klee One',serif;
  font-size:22px;color:var(--pink-deep);font-weight:600;line-height:1;
}
.brand-text .brand-tagline{
  font-size:11px;color:var(--text-soft);margin-top:4px;letter-spacing:0.05em;
}
nav.gnav{display:flex;align-items:center;margin-left:auto;gap:2px;flex-wrap:nowrap;}
nav.gnav a{
  font-size:13.5px;color:#C47585;font-weight:500;
  padding:8px 12px;letter-spacing:0;
  transition:color .2s;
  position:relative;
}
nav.gnav a:hover{color:#A9C49A;font-weight:700;text-shadow:0 0 0.5px currentColor;}
nav.gnav a.current{color:var(--pink-deep);font-weight:700;}
nav.gnav a.current::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--pink);border-radius:1px;}
/* ===== BUTTON SYSTEM (2026-05-21 統一) =====
   Primary  = .btn-cta   ピンク塗り＋白文字（コンバージョン用）
   Secondary= .btn-more  白塗り＋ピンク枠（回遊用）
   Tertiary = .service-more テキストリンク（カード内補助）
   寸法は全層揃え：PC padding:12px 28px / font:14px / min-height:44px
                  SP padding:14px 32px / font:14px / min-height:48px
*/
.btn-cta,
.btn-more,
.btn-white{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:12px 28px;border-radius:30px;
  font-size:14px;font-weight:500;
  min-height:44px;
  line-height:1.4;
  transition:all .25s;
  white-space:nowrap;
}
.btn-cta::after,
.btn-more::after,
.btn-white::after{content:"›";font-size:18px;line-height:1;}

/* Primary */
.btn-cta{
  background:var(--pink);color:#fff !important;
  box-shadow:0 4px 14px rgba(216,139,156,0.25);
}
.btn-cta:hover{background:#A9C49A;transform:translateY(-1px);box-shadow:0 6px 18px rgba(216,139,156,0.35);}
header .btn-cta{margin-left:8px;}
header .btn-cta:hover{background:#A9C49A;color:#fff;text-shadow:none;}

/* ===== HERO ===== */
.hero{
  background:linear-gradient(180deg,var(--cream) 0%,#FCEFE8 100%);
  padding:48px 0 60px;
  position:relative;overflow:hidden;
}
.hero-grid{
  display:grid;
  grid-template-columns:1fr 1.15fr;
  grid-template-areas:
    "copy visual"
    "actions visual";
  gap:0 60px;
  align-items:center;
  max-width:1240px;margin:0 auto;padding:0 40px;
}
.hero-copy{grid-area:copy;align-self:end;}
.hero-copy h1{
  font-family:'Zen Maru Gothic',sans-serif;
  font-size:54px;font-weight:500;
  line-height:1.45;color:var(--text);
  letter-spacing:0.02em;
  margin-bottom:28px;
}
.hero-copy h1 .em{color:var(--pink-deep);}
.hero-lead{
  font-size:16px;line-height:2.1;color:var(--text-soft);
  margin-bottom:0;
}
.hero-actions{
  grid-area:actions;align-self:start;
  display:flex;align-items:center;gap:18px;flex-wrap:wrap;
  margin-top:28px;
}
.hero-handnote{
  font-family:'Klee One',serif;
  font-size:13px;color:var(--pink-deep);
  display:inline-flex;align-items:center;gap:6px;
  line-height:1.6;
}
.hero-handnote::before{content:"〈";color:var(--pink);}
.hero-handnote::after{content:"〉";color:var(--pink);}

.hero-visual{
  grid-area:visual;
  position:relative;
  border-radius:14px;
  overflow:visible;
}
.hero-visual .photo{
  width:100%;height:440px;
  background-image:url('assets/images/hero-photo.jpg');
  background-size:cover;background-position:center;
  border-radius:12px;
  box-shadow:0 8px 30px rgba(180,120,100,0.10);
}
.hero-badge{
  position:absolute;
  right:-20px;bottom:30px;
  width:130px;height:130px;
  background:var(--pink);
  color:#fff;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  text-align:center;
  font-size:13px;line-height:1.7;
  font-weight:500;
  box-shadow:0 6px 20px rgba(216,139,156,0.35);
}

/* ===== SECTION COMMON ===== */
section{padding:60px 0;}
.section-title{
  font-family:'Zen Maru Gothic','Hiragino Maru Gothic ProN',sans-serif;
  text-align:center;
  font-size:26px;font-weight:500;
  color:var(--text);
  margin-bottom:48px;
  position:relative;
  letter-spacing:0.05em;
  text-wrap:balance;
  word-break:keep-all;
  overflow-wrap:break-word;
}
.section-title::after{
  content:"";display:block;
  width:46px;height:2px;
  background:var(--pink);
  margin:14px auto 0;
}
.section-title .leaf{
  display:inline-block;
  color:var(--green);font-size:18px;
  margin:0 6px;
  transform:translateY(-3px);
}

/* ===== PROBLEMS ===== */
.problems{background:var(--cream);}
.problems-wrap{
  background:#fff;
  border-radius:18px;
  padding:48px 40px 40px;
  box-shadow:0 4px 24px rgba(196,117,133,0.06);
  max-width:1080px;margin:0 auto;
}
.problems-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:18px;margin-top:8px;
}
.problem-item{
  text-align:center;
}
.problem-check{
  display:inline-flex;align-items:flex-start;gap:8px;
  font-size:15px;color:var(--text);
  font-weight:500;
  margin-bottom:18px;
  line-height:1.7;
  text-align:left;
}
.problem-check::before{
  content:"";display:inline-block;
  width:16px;height:16px;
  border:1.5px solid var(--pink);border-radius:3px;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 14'><polyline points='3,7 6,10 11,4' fill='none' stroke='%23D88B9C' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/></svg>") center/12px no-repeat;
  flex-shrink:0;
  margin-top:3px;
}
.problem-illust{
  max-width:220px;
  margin:0 auto;
}
.problem-illust img{
  width:100%;height:auto;
  display:block;
}

/* ===== SERVICES ===== */
.services{background:var(--cream);}
.services-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:22px;
}
.service-card{
  background:#fff;
  border-radius:14px;
  overflow:hidden;
  box-shadow:0 3px 16px rgba(180,120,100,0.07);
  transition:transform .25s,box-shadow .25s;
}
.service-card:hover{
  transform:translateY(-4px);
  box-shadow:0 10px 28px rgba(180,120,100,0.13);
}
.service-thumb{
  width:100%;height:180px;
  background-size:cover;background-position:center;
}
.service-card:nth-child(1) .service-thumb{background-image:url('assets/images/service-sns.jpg');}
.service-card:nth-child(2) .service-thumb{background-image:url('assets/images/service-gmap.jpg');}
.service-card:nth-child(3) .service-thumb{background-image:url('assets/images/service-hp.jpg');}
.service-card:nth-child(4) .service-thumb{background-image:url('assets/images/service-lp.jpg');}
.service-body{padding:22px 22px 24px;}
.service-name{
  font-size:16px;font-weight:700;color:var(--text);
  margin-bottom:8px;
  display:flex;align-items:center;gap:8px;
}
.service-icon{
  width:22px;height:22px;flex-shrink:0;
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--pink-deep);
}
.service-desc{
  font-size:13px;color:var(--text-soft);
  line-height:1.85;
  margin-bottom:14px;
}
.service-more{
  font-size:12.5px;color:var(--pink-deep);
  display:inline-flex;align-items:center;gap:4px;
  font-weight:500;
}
.service-more::after{content:"›";font-size:14px;}
.services-foot{
  text-align:center;
  margin-top:40px;
}
/* Secondary */
.btn-more{
  background:#fff;
  border:1.5px solid var(--pink);
  color:var(--pink-deep);
  box-shadow:0 3px 12px rgba(216,139,156,0.10);
}
.btn-more:hover{
  background:var(--pink);color:#fff;
  transform:translateY(-1px);
  box-shadow:0 6px 18px rgba(216,139,156,0.25);
}
.services-foot-note{
  font-family:'Klee One',serif;
  font-size:12.5px;color:var(--text-soft);
  margin-top:14px;
  display:flex;align-items:center;justify-content:center;gap:4px;
}
.services-foot-note::before{content:"〈";color:var(--pink);}
.services-foot-note::after{content:"〉";color:var(--pink);}

/* ===== VALUES (大切にしていること) ===== */
.values{
  background-image:linear-gradient(rgba(255,248,242,0.55),rgba(255,248,242,0.55)),url('assets/images/values-main.jpg');
  background-size:cover;background-position:center;
  padding:80px 0 90px;
}
.values-wrap{
  display:block;
  max-width:1080px;margin:0 auto;padding:0 40px;
}
.values-photo{display:none;}
.values-content .section-title{
  text-align:center;margin-bottom:48px;
}
.values-content .section-title::after{margin-left:auto;margin-right:auto;}
.values-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:20px;
}
.value-item{
  text-align:center;
  background:rgba(255,255,255,0.82);
  padding:28px 18px 24px;
  border-radius:14px;
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
  box-shadow:0 4px 16px rgba(180,120,100,0.08);
}
.value-icon{
  width:54px;height:54px;
  margin:0 auto 14px;
  color:var(--pink);
}
.value-icon svg{width:100%;height:100%;}
.value-name{
  font-size:14px;font-weight:700;
  color:var(--text);margin-bottom:10px;
}
.value-desc{
  font-size:12px;color:var(--text-soft);
  line-height:1.85;
}

/* ===== WORKS ===== */
.works{background:var(--cream);}
.works-head{display:block;margin-bottom:0;}
.works-head .section-title{margin-bottom:24px;text-align:center;}
.works-foot{text-align:center;margin-top:40px;}
.works-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:20px;align-items:start;
}
.work-card{
  display:block;
  background:#fff;
  border-radius:10px;overflow:hidden;
  box-shadow:0 3px 14px rgba(180,120,100,0.07);
  color:inherit;text-decoration:none;
  transition:transform .2s, box-shadow .2s;
}
.work-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(180,120,100,0.14);}
.work-thumb,.work-body,.work-cat,.work-name{display:block;}
.work-thumb{height:160px;background-size:contain;background-position:center;background-repeat:no-repeat;background-color:#FFF3EC;}
.work-card:nth-child(1) .work-thumb{background-image:url('assets/images/work-abe.jpg');}
.work-card:nth-child(2) .work-thumb{background-image:url('assets/images/work-toshu.jpg');}
.work-card:nth-child(3) .work-thumb{background-image:url('assets/images/work-chanoma-v7.jpg');}
.work-card:nth-child(4) .work-thumb{background-image:url('assets/images/work-yona.jpg');}
.work-body{padding:14px 16px 18px;}
.work-cat{font-size:11px;color:var(--text-soft);margin-bottom:4px;letter-spacing:-0.01em;}
.work-name{font-size:13px;color:var(--text);font-weight:500;letter-spacing:-0.01em;}
.btn-outline{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--pink);color:#fff;
  padding:11px 28px;border-radius:30px;
  font-size:13.5px;font-weight:500;
  white-space:nowrap;
  transition:all .25s;
}
.btn-outline:hover{background:var(--pink-deep);}
.works-foot{
  text-align:center;margin-top:40px;
}

/* ===== INTRO + CTA ===== */
.intro{background:var(--cream);padding-bottom:90px;}
.intro-wrap{
  display:grid;grid-template-columns:1fr 1.3fr 1fr;
  gap:30px;align-items:stretch;
  max-width:1180px;margin:0 auto;padding:0 40px;
}
.intro-photo{
  border-radius:12px;
  background-image:url('assets/images/profile.jpg');
  background-size:cover;background-position:70% top;
  min-height:340px;
}
.intro-text h3{
  font-size:22px;font-weight:500;
  color:var(--text);margin-bottom:20px;
  letter-spacing:0.04em;
}
.intro-text h3 .em{color:var(--pink-deep);}
.intro-text p{
  font-size:14px;line-height:2.0;color:var(--text-soft);
  margin-bottom:24px;
}
.intro-text .btn-more{margin-top:0;}
/* .btn-line は .btn-more に統合（2026-05-21） */

.intro-cta{
  background:var(--pink);
  border-radius:14px;
  padding:34px 30px 30px;
  color:#fff;
  position:relative;
  overflow:hidden;
}
.intro-cta::before{
  content:"";position:absolute;
  width:120px;height:120px;
  right:-30px;top:-30px;
  background:rgba(255,255,255,0.08);
  border-radius:50%;
}
.intro-cta h4{
  font-size:18px;font-weight:600;
  line-height:1.6;margin-bottom:14px;
  position:relative;
}
.intro-cta p{
  font-size:12.5px;line-height:1.85;
  margin-bottom:22px;
  opacity:0.95;
  position:relative;
}
/* Primary on pink card */
.btn-white{
  background:#fff;color:var(--pink-deep) !important;
  font-weight:600;
  min-width:240px;
  position:relative;
  box-shadow:0 4px 14px rgba(0,0,0,0.08);
}
.btn-white:hover{background:#FFF5F8;transform:translateY(-1px);box-shadow:0 6px 18px rgba(0,0,0,0.12);}
.intro-cta{text-align:center;}
.intro-cta h4,.intro-cta p{text-align:left;}
.intro-cta .btn-white{margin:4px auto 0;}
.intro-cta-note{
  font-family:'Klee One',serif;
  font-size:11.5px;color:#fff;opacity:0.95;
  text-align:center;margin-top:12px;
  position:relative;
  display:flex;align-items:center;justify-content:center;gap:4px;
}
.intro-cta-note::before{content:"〈";}
.intro-cta-note::after{content:"〉";}
.intro-cta-illust{
  position:absolute;
  bottom:-10px;right:14px;
  width:80px;height:80px;
  background:#fff;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:34px;
  opacity:0.9;
}

/* ===== FOOTER ===== */
footer{
  background:var(--cream);
  border-top:1px solid var(--line);
  padding:30px 0 28px;
}
.footer-inner{
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:24px;
  max-width:1240px;margin:0 auto;padding:0 40px;
}
.footer-brand{display:flex;align-items:center;gap:10px;}
.footer-brand img{height:34px;width:auto;}.footer-brand .name{display:none;}
.footer-brand .name{
  font-family:'Klee One',serif;
  color:var(--pink-deep);font-size:17px;font-weight:600;
}
.footer-brand .tag{
  font-size:11px;color:var(--text-soft);margin-left:8px;
}
.footer-nav{display:flex;gap:24px;flex-wrap:wrap;}
.footer-nav a{font-size:13px;color:var(--text-soft);}
.footer-nav a:hover{color:var(--pink-deep);}
.footer-actions{display:flex;gap:10px;}
.footer-btn{
  border:1px solid var(--line);
  color:var(--text-soft);
  padding:8px 18px;border-radius:30px;
  font-size:12.5px;
  background:#fff;
}
.footer-btn:hover{border-color:var(--pink);color:var(--pink-deep);}
.copyright{
  text-align:center;
  font-size:11px;color:var(--text-soft);
  margin-top:24px;
  padding-top:18px;
  border-top:1px solid var(--line);
}

/* ===== RESPONSIVE ===== */
@media (max-width:980px){
  .hero-grid{grid-template-columns:1fr;}
  .hero-copy h1{font-size:38px;}
  .problems-grid{grid-template-columns:repeat(2,1fr);gap:20px;}
  .services-grid{grid-template-columns:repeat(2,1fr);}
  .values-wrap{grid-template-columns:1fr;}
  .values-grid{grid-template-columns:repeat(2,1fr);}
  .works-grid{grid-template-columns:repeat(2,1fr);}
  .intro-wrap{grid-template-columns:1fr;}
  .intro-text{text-align:center !important;}
  .intro-text h3,.intro-text p{text-align:left !important;}
  .intro-text .btn-more{margin-left:auto;margin-right:auto;}
  nav.gnav{display:none;}
}
/* ===== SP用br（タイトル改行制御） ===== */
.sp-only{display:none;}
@media (max-width:560px){.sp-only{display:inline;}}
/* ===== SP共通（2026-05-20統一） ===== */
@media (max-width:860px){
  header .header-inner{padding:10px 16px;gap:12px;}
  .brand img{height:42px;}
  nav.gnav{gap:0;}
  nav.gnav a:not(.btn-cta){display:none;}
  /* ヘッダー内btn-ctaだけは省スペース版（システム共通寸法を上書き） */
  header .btn-cta,nav.gnav a.btn-cta{padding:9px 14px;font-size:12.5px;min-height:0;margin-left:0;}
  .footer-inner{flex-direction:column;text-align:center;padding:0 24px;gap:18px;}
  .footer-brand{justify-content:center;flex-wrap:wrap;}
  .footer-nav{justify-content:center;}
  /* SPボタン共通：タップ領域48px・存在感のあるピル */
  .hero-actions .btn-cta,
  .btn-more,
  .intro-cta .btn-white{
    padding:14px 32px;
    min-height:48px;
    font-size:14px;
  }
  .services-foot,.works-foot{margin-top:36px;}
}
/* ===== TOP ヒーロー SP調整（写真の上にコピー、写真の下にCTA） ===== */
@media (max-width:860px){
  .hero{padding:0 0 40px;background:linear-gradient(180deg,var(--cream) 0%,#FCEFE8 100%);}
  .hero-grid{display:flex;flex-direction:column;padding:0;gap:0;grid-template-areas:none;align-items:stretch;position:relative;}
  .hero-visual{order:1;position:relative;width:100%;border-radius:0;overflow:visible;}
  .hero-visual .photo{width:100%;height:380px;border-radius:0;box-shadow:none;}
  .hero-visual::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,248,242,0.78) 0%,rgba(255,248,242,0.42) 60%,rgba(255,248,242,0.18) 100%);z-index:1;pointer-events:none;}
  .hero-copy{order:0;position:absolute;top:24px;left:24px;right:24px;z-index:3;align-self:auto;padding-top:60px;}
  .hero-copy h1{font-size:28px;line-height:1.55;letter-spacing:0;margin-bottom:14px;text-shadow:0 1px 2px rgba(255,255,255,0.65);}
  .hero-lead{font-size:14.5px;line-height:1.9;color:var(--text);text-shadow:0 1px 2px rgba(255,255,255,0.55);}
  .hero-actions{order:2;flex-direction:column;align-items:center;gap:14px;padding:60px 24px 0;margin-top:0;text-align:center;}
  .hero-handnote{font-size:12.5px;}
  .hero-badge{width:92px;height:92px;font-size:10.5px;line-height:1.55;right:16px;bottom:-46px;z-index:4;}
}
@media (max-width:560px){
  .hero-visual .photo{height:340px;}
  .hero-copy{padding-top:40px;}
  .hero-copy h1{font-size:26px;}
  .values-grid{grid-template-columns:1fr;gap:14px;}
  .value-item{padding:22px 20px 20px;}
}

/* =========================================================
   ページ固有：もものてについて（about.html）
   ========================================================= */
:root{
  --pink:#D88B9C;
  --pink-deep:#C47585;
  --pink-soft:#F4D4DC;
  --pink-bg:#FBE9EE;
  --cream:#FFF8F2;
  --cream-2:#FAF1E8;
  --text:#5C4F4A;
  --text-soft:#8A7A73;
  --green:#A9C49A;
  --line:#EBDDD3;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  font-family:'Noto Sans JP','Hiragino Kaku Gothic ProN','Hiragino Sans',sans-serif;
  color:var(--text);background:var(--cream);
  font-size:15px;line-height:2.0;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
h1,h2,h3,h4,h5,h6{font-family:'Zen Maru Gothic','Hiragino Maru Gothic ProN',sans-serif;font-weight:500;line-height:1.5;}

/* ===== ヘッダー（既存サイト準拠の簡易版） ===== */
header{
  position:sticky;top:0;z-index:100;
  background:rgba(255,248,242,0.92);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border-bottom:1px solid rgba(235,221,211,0.4);
}
.header-inner{
  display:flex;align-items:center;
  padding:14px 24px;max-width:none;margin:0 auto;gap:24px;
}
.brand{display:flex;align-items:center;gap:12px;}
.brand img{height:52px;width:auto;}.brand-text{display:none;}
.brand-text .brand-name{font-family:'Klee One',serif;font-size:22px;color:var(--pink-deep);font-weight:600;line-height:1;}
.brand-text .brand-tagline{font-size:11px;color:var(--text-soft);margin-top:4px;letter-spacing:0.05em;}
nav.gnav{display:flex;align-items:center;margin-left:auto;gap:2px;flex-wrap:nowrap;}
nav.gnav a{
  font-size:13.5px;color:#C47585;
  padding:8px 12px;font-weight:500;letter-spacing:0;
  transition:color .2s;
  position:relative;
}
nav.gnav a:hover{color:#A9C49A;font-weight:700;text-shadow:0 0 0.5px currentColor;}
nav.gnav a.current{color:var(--pink-deep);font-weight:700;}
nav.gnav a.current::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--pink);border-radius:1px;}
nav.gnav a.btn-cta{
  background:var(--pink);color:#fff;
  padding:11px 22px;border-radius:30px;font-size:14px;
  box-shadow:0 4px 14px rgba(216,139,156,0.25);
  margin-left:8px;
  transition:all .25s;
}
nav.gnav a.btn-cta:hover{background:#A9C49A;color:#fff;text-shadow:none;font-weight:500;transform:translateY(-1px);box-shadow:0 6px 18px rgba(216,139,156,0.35);}

/* ===== 共通 ===== */
.about-inner{max-width:760px;margin:0 auto;padding:0 32px;}

/* ===== ページヘッド ===== */
.about-head{
  background:linear-gradient(180deg,var(--cream) 0%,#FCEFE8 100%);
  padding:60px 0 50px;text-align:center;
}
.about-head-wrap{max-width:760px;margin:0 auto;padding:0 32px;}
.about-head h1{
  font-size:32px;font-weight:500;color:var(--text);
  letter-spacing:0.08em;margin-bottom:10px;
}
.about-head h1::after{
  content:"";display:block;width:46px;height:2px;
  background:var(--pink);margin:14px auto 0;
}
.about-head-sub{
  font-family:'Klee One',serif;font-size:13px;color:var(--pink-deep);
  letter-spacing:0.15em;margin-bottom:24px;text-transform:uppercase;
}
.about-head-lead{font-size:15px;color:var(--text-soft);line-height:2.0;}

/* ===== イントロ ===== */
.about-intro{padding:50px 0 40px;background:var(--cream);}
.about-intro p{
  font-size:15px;line-height:2.1;color:var(--text);
  margin-bottom:18px;
}
.about-intro p:last-child{margin-bottom:0;}

/* ===== セクション共通 ===== */
.about-section{padding:50px 0;background:var(--cream);}
.about-section-alt{background:#FCEFE8;}
.about-section h2{
  font-size:22px;font-weight:500;color:var(--text);
  margin-bottom:24px;letter-spacing:0.04em;
  text-align:left;position:relative;padding-left:18px;
}
.about-section h2::before{
  content:"";position:absolute;left:0;top:50%;
  transform:translateY(-50%);width:6px;height:22px;
  background:var(--pink);border-radius:3px;
}
.about-section p{
  font-size:14.5px;line-height:2.1;color:var(--text);
  margin-bottom:18px;
}
.about-section p.about-soft{color:var(--text-soft);}

.about-quote{
  font-family:'Klee One',serif;font-size:16px;color:var(--pink-deep);
  background:var(--pink-bg);padding:22px 26px;border-radius:12px;
  margin:24px 0;line-height:2.0;letter-spacing:0.03em;text-align:center;
}
.about-quote::before{content:"〈 ";}
.about-quote::after{content:" 〉";}

/* ===== 大切にしていること ===== */
.about-value{
  margin-bottom:34px;padding-bottom:34px;
  border-bottom:1px dashed var(--line);
}
.about-value:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none;}
.about-value h3{
  font-size:16px;font-weight:600;color:var(--pink-deep);
  margin-bottom:14px;letter-spacing:0.02em;line-height:1.6;
}
.about-value p{font-size:14px;line-height:2.0;margin-bottom:14px;}
.about-value p:last-child{margin-bottom:0;}

/* ===== ももnote リスト ===== */
.about-list{
  list-style:none;margin:18px 0;padding:18px 22px;
  background:#fff;border-radius:10px;
  box-shadow:0 2px 10px rgba(180,120,100,0.05);
}
.about-list li{
  padding:10px 0;font-size:14.5px;color:var(--text);
  line-height:1.9;border-bottom:1px dashed var(--line);
}
.about-list li:last-child{border-bottom:none;}
.about-list li strong{color:var(--pink-deep);font-weight:600;}

/* ===== プロフィールブロック ===== */
.about-profile-block{max-width:880px;}
.about-profile-grid{
  display:grid;grid-template-columns:1fr 1.4fr;gap:36px;align-items:start;
}
.about-profile-photo{
  width:100%;aspect-ratio:4/5;
  background-image:url('assets/images/profile.jpg');
  background-size:cover;background-position:70% top;
  border-radius:14px;box-shadow:0 8px 28px rgba(180,120,100,0.12);
}
.about-profile-name{
  font-size:24px;font-weight:500;color:var(--text);
  line-height:1.5;margin-bottom:18px;letter-spacing:0.03em;
}
.about-profile-ruby{
  font-size:13px;color:var(--text-soft);
  letter-spacing:0.12em;display:inline-block;margin-top:4px;font-weight:400;
}
.about-profile-text p{font-size:14px;line-height:2.0;margin-bottom:14px;}
.about-btn-line{
  display:inline-flex;align-items:center;gap:8px;
  border:1.5px solid var(--pink);color:var(--pink-deep);
  padding:10px 26px;border-radius:30px;
  font-size:13.5px;font-weight:500;background:#fff;margin-top:10px;
  transition:all .25s;
}
.about-btn-line::after{content:" ›";font-size:15px;}
.about-btn-line:hover{background:var(--pink);color:#fff;}

/* ===== CTA ===== */
.about-cta-wrap{padding:30px 0 70px;background:var(--cream);}
.about-cta{
  background:var(--pink);border-radius:16px;
  padding:38px 32px 32px;color:#fff;text-align:center;
  max-width:680px;margin:0 auto;
  box-shadow:0 8px 24px rgba(216,139,156,0.20);
  position:relative;overflow:hidden;
}
.about-cta::before{
  content:"";position:absolute;width:140px;height:140px;
  right:-40px;top:-40px;background:rgba(255,255,255,0.08);border-radius:50%;
}
.about-cta h3{
  font-size:20px;font-weight:600;line-height:1.7;
  margin-bottom:14px;color:#fff;position:relative;
}
.about-cta p{
  font-size:13px;line-height:1.95;margin-bottom:22px;
  color:#fff;opacity:0.95;position:relative;
}
.about-btn-white{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  background:#fff;color:var(--pink-deep);
  padding:14px 36px;border-radius:30px;
  font-size:14px;font-weight:600;position:relative;
  box-shadow:0 4px 14px rgba(0,0,0,0.08);
  transition:all .25s;
}
.about-btn-white::after{content:"›";font-size:16px;}
.about-btn-white:hover{transform:translateY(-1px);}
.about-cta-note{
  font-family:'Klee One',serif;font-size:12px;color:#fff;opacity:0.95;
  text-align:center;margin-top:14px;position:relative;
}
.about-cta-note::before{content:"〈 ";}
.about-cta-note::after{content:" 〉";}

/* ===== フッター ===== */
footer{background:var(--cream);border-top:1px solid var(--line);padding:30px 0 28px;}
.footer-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:24px;max-width:1240px;margin:0 auto;padding:0 40px;}
.footer-brand{display:flex;align-items:center;gap:10px;}
.footer-brand img{height:34px;width:auto;}.footer-brand .name{display:none;}
.footer-brand .name{font-family:'Klee One',serif;color:var(--pink-deep);font-size:17px;font-weight:600;}
.footer-brand .tag{font-size:11px;color:var(--text-soft);margin-left:8px;}
.footer-nav{display:flex;gap:24px;flex-wrap:wrap;}
.footer-nav a{font-size:13px;color:var(--text-soft);}
.footer-nav a:hover{color:var(--pink-deep);}
.copyright{text-align:center;font-size:11px;color:var(--text-soft);margin-top:24px;padding-top:18px;border-top:1px solid var(--line);}

/* ===== レスポンシブ改行ヘルパー ===== */
.sp-only{display:none;}

@media (max-width:880px){
  .about-profile-grid{grid-template-columns:1fr;gap:24px;}
  .about-profile-photo{max-width:320px;margin:0 auto;}
}
@media (max-width:680px){
  .sp-only{display:inline;}
  .about-head{padding:44px 0 36px;}
  .about-head h1{font-size:26px;}
  .about-intro{padding:36px 0 28px;}
  .about-section{padding:36px 0;}
  .about-section h2{font-size:19px;}
  .about-quote{font-size:14.5px;padding:18px 20px;}
  .about-value{margin-bottom:26px;padding-bottom:26px;}
  .about-cta-wrap{padding:24px 0 50px;}
  .about-cta{padding:30px 22px 26px;}
  .about-cta h3{font-size:17px;}
  nav.gnav a:not(.cta){display:none;}
}
/* ===== SP共通（2026-05-20統一） ===== */
@media (max-width:860px){
  header .header-inner{padding:10px 16px;gap:12px;}
  .brand img{height:42px;}
  nav.gnav{gap:0;}
  nav.gnav a:not(.btn-cta){display:none;}
  header .btn-cta,nav.gnav a.btn-cta{padding:9px 16px;font-size:13px;margin-left:0;}
  .footer-inner{flex-direction:column;text-align:center;padding:0 24px;gap:18px;}
  .footer-brand{justify-content:center;flex-wrap:wrap;}
  .footer-nav{justify-content:center;}
}

/* =========================================================
   ページ固有：サービス（services.html）
   ========================================================= */
:root{
  --pink:#D88B9C;
  --pink-deep:#C47585;
  --pink-soft:#F4D4DC;
  --pink-bg:#FBE9EE;
  --cream:#FFF8F2;
  --cream-2:#FAF1E8;
  --text:#5C4F4A;
  --text-soft:#8A7A73;
  --green:#A9C49A;
  --line:#EBDDD3;
}

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

html{scroll-behavior:smooth;}
body{
  font-family:'Noto Sans JP','Hiragino Kaku Gothic ProN','Hiragino Sans',sans-serif;
  color:var(--text);
  background:var(--cream);
  font-size:15px;
  line-height:1.9;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4,h5,h6{font-family:'Zen Maru Gothic','Hiragino Maru Gothic ProN',sans-serif;}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}

.container{max-width:1180px;margin:0 auto;padding:0 32px;}

/* ===== HEADER ===== */
header{
  position:sticky;top:0;z-index:100;
  background:rgba(255,248,242,0.92);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  border-bottom:1px solid rgba(235,221,211,0.4);
}
.header-inner{
  display:flex;align-items:center;
  padding:14px 24px;
  max-width:none;margin:0 auto;gap:24px;
}
.brand{display:flex;align-items:center;gap:12px;}
.brand img{height:52px;width:auto;}.brand-text{display:none;}
.brand-text .brand-name{
  font-family:'Klee One',serif;
  font-size:22px;color:var(--pink-deep);font-weight:600;line-height:1;
}
.brand-text .brand-tagline{
  font-size:11px;color:var(--text-soft);margin-top:4px;letter-spacing:0.05em;
}
nav.gnav{display:flex;align-items:center;margin-left:auto;gap:2px;flex-wrap:nowrap;}
nav.gnav a{
  font-size:13.5px;color:#C47585;font-weight:500;
  padding:8px 12px;letter-spacing:0;
  transition:color .2s;
  position:relative;
}
nav.gnav a:hover{color:#A9C49A;font-weight:700;text-shadow:0 0 0.5px currentColor;}
nav.gnav a.current{color:var(--pink-deep);font-weight:700;}
nav.gnav a.current::after{
  content:"";position:absolute;
  left:0;right:0;bottom:-6px;
  height:2px;background:var(--pink);
  border-radius:1px;
}
.btn-cta{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--pink);color:#fff !important;
  padding:11px 22px;border-radius:30px;
  font-size:14px;font-weight:500;
  transition:all .25s;
  box-shadow:0 4px 14px rgba(216,139,156,0.25);
}
header .btn-cta{margin-left:8px;}
.btn-cta:hover{background:#A9C49A;transform:translateY(-1px);box-shadow:0 6px 18px rgba(216,139,156,0.35);}
header .btn-cta:hover{background:#A9C49A;color:#fff;text-shadow:none;}
.btn-cta::after{content:"›";font-size:18px;line-height:1;}

/* ===== PAGE HEAD ===== */
.page-head{
  background:linear-gradient(180deg,var(--cream) 0%,#FCEFE8 100%);
  padding:60px 0 64px;
  text-align:center;
}
.page-head h1{
  font-size:38px;font-weight:500;
  color:var(--text);
  line-height:1.5;
  letter-spacing:0.04em;
  margin-bottom:16px;
}
.page-head h1 .em{color:var(--pink-deep);}
.page-head .lead{
  font-size:15px;color:var(--text-soft);
  line-height:2.0;
}
.page-head .handnote{
  font-family:'Klee One',serif;
  font-size:13px;color:var(--pink-deep);
  display:inline-flex;align-items:center;gap:6px;
  margin-top:18px;
}
.page-head .handnote::before{content:"〈";color:var(--pink);}
.page-head .handnote::after{content:"〉";color:var(--pink);}

/* ===== SECTION COMMON ===== */
section{padding:70px 0;}
.section-label{
  text-align:center;
  font-size:13px;color:var(--pink-deep);
  letter-spacing:0.2em;
  margin-bottom:10px;
}
.section-title{
  text-align:center;
  font-size:26px;font-weight:500;
  color:var(--text);
  margin-bottom:14px;
  letter-spacing:0.05em;
}
.section-sub{
  text-align:center;
  font-size:13.5px;color:var(--text-soft);
  margin-bottom:42px;
  line-height:1.9;
}
.section-title::after{
  content:"";display:block;
  width:46px;height:2px;
  background:var(--pink);
  margin:14px auto 0;
}

/* ===== SERVICE LIST ===== */
.svc-block{background:var(--cream);}
.svc-block.alt{background:#FFF3EC;}

.svc-list{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:22px;
  max-width:1080px;margin:0 auto;
}
.svc-card{
  background:#fff;
  border-radius:14px;
  padding:28px 30px 26px;
  box-shadow:0 4px 18px rgba(180,120,100,0.07);
  transition:transform .25s,box-shadow .25s;
  display:flex;flex-direction:column;
}
.svc-card:hover{
  transform:translateY(-3px);
  box-shadow:0 10px 26px rgba(180,120,100,0.12);
}
a.svc-card{color:inherit;text-decoration:none;}
a.svc-card:hover{box-shadow:0 10px 26px rgba(180,120,100,0.18);}
.svc-card-link-hint{
  display:flex;align-items:center;justify-content:flex-end;gap:4px;
  margin-top:12px;font-size:12px;color:var(--pink-deep);
  font-weight:500;letter-spacing:0.04em;
  transition:gap .2s;
}
a.svc-card:hover .svc-card-link-hint{gap:8px;color:#A9C49A;}
.svc-card-link-hint::after{content:"›";font-size:14px;line-height:1;}
.svc-card.featured{
  background:linear-gradient(180deg,#FFF6F8 0%,#FDE8EC 100%);
  border:1.5px solid var(--pink-soft);
}
/* 2カラム時、最後が奇数番目（単独行）になるカードは横幅いっぱいに */
.svc-list > .svc-card:last-child:nth-child(odd){
  grid-column:1 / -1;
}
.svc-card-head{
  display:flex;align-items:center;gap:10px;
  margin-bottom:14px;
  flex-wrap:wrap;
}
.svc-card-name{
  font-size:17px;font-weight:700;color:var(--text);
  letter-spacing:0.03em;
}
.svc-card-tag{
  display:inline-block;
  background:var(--pink);color:#fff;
  font-size:11px;font-weight:500;
  padding:2px 10px;border-radius:30px;
  letter-spacing:0.08em;
  vertical-align:middle;line-height:1.6;
}
.svc-card-desc{
  font-size:13.5px;color:var(--text-soft);
  line-height:1.9;
  margin-bottom:18px;
  flex:1;
}
.svc-card-price{
  display:flex;align-items:baseline;justify-content:space-between;
  gap:12px;
  padding-top:16px;
  border-top:1px dashed var(--line);
}
.svc-card-price .label{
  font-size:12px;color:var(--text-soft);
  letter-spacing:0.05em;
}
.svc-card-price .amount{display:inline-block;}
.svc-card-price .num{
  font-size:22px;font-weight:700;color:var(--pink-deep);
}
.svc-card-price .unit{
  font-size:12px;color:var(--text-soft);
  font-weight:400;margin-left:3px;
}
.svc-card-price .num.small{font-size:15px;}

/* ===== NOTE BLOCK ===== */
.policy{
  background:var(--cream);padding-bottom:90px;
}
.policy-wrap{
  background:#fff;
  max-width:880px;margin:0 auto;
  border-radius:18px;
  padding:40px 44px;
  box-shadow:0 4px 24px rgba(196,117,133,0.06);
  text-align:left;
}
.policy-wrap h3{
  font-size:18px;font-weight:600;color:var(--pink-deep);
  margin-bottom:18px;letter-spacing:0.05em;
}
.policy-wrap p{
  font-size:14px;color:var(--text-soft);
  line-height:2.0;
}

/* ===== CTA ===== */
.cta{
  background:linear-gradient(180deg,#FCEFE8 0%,var(--cream) 100%);
  padding:80px 0 90px;
}
.cta-wrap{
  background:var(--pink);
  max-width:880px;margin:0 auto;
  border-radius:18px;
  padding:46px 40px 42px;
  color:#fff;
  text-align:center;
  position:relative;
  overflow:hidden;
  box-shadow:0 8px 30px rgba(216,139,156,0.25);
}
.cta-wrap::before{
  content:"";position:absolute;
  width:160px;height:160px;
  right:-40px;top:-40px;
  background:rgba(255,255,255,0.08);
  border-radius:50%;
}
.cta-wrap::after{
  content:"";position:absolute;
  width:120px;height:120px;
  left:-30px;bottom:-30px;
  background:rgba(255,255,255,0.08);
  border-radius:50%;
}
.cta-wrap h3{
  font-size:24px;font-weight:600;
  line-height:1.6;margin-bottom:14px;
  position:relative;
}
.cta-wrap p{
  font-size:14px;line-height:1.9;
  margin-bottom:26px;
  opacity:0.95;
  position:relative;
}
.btn-white{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  background:#fff;color:var(--pink-deep) !important;
  min-width:280px;
  padding:14px 32px;border-radius:30px;
  font-size:15px;font-weight:600;
  transition:all .25s;
  position:relative;
}
.btn-white:hover{background:#FFF5F8;transform:translateY(-1px);}
.btn-white::after{content:"›";font-size:18px;}
.cta-note{
  font-family:'Klee One',serif;
  font-size:12.5px;color:#fff;opacity:0.95;
  margin-top:14px;
  position:relative;
  display:flex;align-items:center;justify-content:center;gap:4px;
}
.cta-note::before{content:"〈";}
.cta-note::after{content:"〉";}

/* ===== FOOTER ===== */
footer{
  background:var(--cream);
  border-top:1px solid var(--line);
  padding:30px 0 28px;
}
.footer-inner{
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:24px;
  max-width:1240px;margin:0 auto;padding:0 40px;
}
.footer-brand{display:flex;align-items:center;gap:10px;}
.footer-brand img{height:34px;width:auto;}.footer-brand .name{display:none;}
.footer-brand .name{
  font-family:'Klee One',serif;
  color:var(--pink-deep);font-size:17px;font-weight:600;
}
.footer-brand .tag{
  font-size:11px;color:var(--text-soft);margin-left:8px;
}
.footer-nav{display:flex;gap:24px;flex-wrap:wrap;}
.footer-nav a{font-size:13px;color:var(--text-soft);}
.footer-nav a:hover{color:var(--pink-deep);}
.footer-actions{display:flex;gap:10px;}
.footer-btn{
  border:1px solid var(--line);
  color:var(--text-soft);
  padding:8px 18px;border-radius:30px;
  font-size:12.5px;
  background:#fff;
}
.footer-btn:hover{border-color:var(--pink);color:var(--pink-deep);}
.copyright{
  text-align:center;
  font-size:11px;color:var(--text-soft);
  margin-top:24px;
  padding-top:18px;
  border-top:1px solid var(--line);
}

/* ===== RESPONSIVE: スマホ用コンパクトリスト ===== */
@media (max-width:780px){
  nav.gnav{display:none;}

  .page-head{padding:44px 18px 48px;}
  .page-head h1{font-size:26px;}
  .page-head .lead{font-size:13.5px;line-height:1.9;}

  section{padding:48px 0 44px;}
  .section-title{font-size:20px;margin-bottom:10px;}
  .section-sub{font-size:12.5px;margin-bottom:24px;padding:0 12px;}

  /* スマホ：1カラム＆ぎゅっとコンパクト */
  .svc-list{grid-template-columns:1fr;gap:10px;padding:0 16px;}
  /* スマホ時は1カラムなので末尾横幅化はリセット */
  .svc-list > .svc-card:last-child:nth-child(odd){grid-column:auto;}
  .svc-card{
    padding:16px 18px 14px;
    border-radius:10px;
  }
  .svc-card-head{margin-bottom:6px;gap:8px;}
  .svc-card-name{font-size:14.5px;}
  .svc-card-tag{font-size:10px;padding:1px 7px;}
  .svc-card-desc{font-size:12px;line-height:1.75;margin-bottom:10px;}
  .svc-card-price{padding-top:10px;}
  .svc-card-price .label{font-size:10.5px;}
  .svc-card-price .num{font-size:17px;}
  .svc-card-price .num.small{font-size:12.5px;}
  .svc-card-price .unit{font-size:10.5px;}

  .policy{padding-bottom:60px;}
  .policy-wrap{padding:24px 20px;margin:0 16px;}
  .policy-wrap h3{font-size:15px;}
  .policy-wrap p{font-size:13px;}

  .cta{padding:44px 0 56px;}
  .cta-wrap{padding:28px 20px 30px;margin:0 16px;}
  .cta-wrap h3{font-size:18px;}
  .cta-wrap p{font-size:13px;}
  .btn-white{min-width:0;width:100%;padding:12px 20px;font-size:14px;}
}
/* ===== SP共通（2026-05-20統一） ===== */
@media (max-width:860px){
  header .header-inner{padding:10px 16px;gap:12px;}
  .brand img{height:42px;}
  nav.gnav{gap:0;}
  nav.gnav a:not(.btn-cta){display:none;}
  header .btn-cta,nav.gnav a.btn-cta{padding:9px 16px;font-size:13px;margin-left:0;}
  .footer-inner{flex-direction:column;text-align:center;padding:0 24px;gap:18px;}
  .footer-brand{justify-content:center;flex-wrap:wrap;}
  .footer-nav{justify-content:center;}
}

/* =========================================================
   ページ固有：料金プラン（price.html）
   ========================================================= */
:root{--pink:#D88B9C;--pink-deep:#C47585;--pink-soft:#E8B5C0;--pink-bg:#FBE9EE;--cream:#FFF8F2;--cream-2:#FFF3EC;--text:#5C4F4A;--text-soft:#8A7A73;--line:#EBDDD3;}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
body{font-family:'Noto Sans JP','Hiragino Kaku Gothic ProN','Hiragino Sans',sans-serif;color:var(--text);background:var(--cream);font-size:15px;line-height:1.9;-webkit-font-smoothing:antialiased;}
h1,h2,h3,h4,h5,h6{font-family:'Zen Maru Gothic','Hiragino Maru Gothic ProN',sans-serif;}
a{color:inherit;text-decoration:none;}

/* ===== HEADER ===== */
header{position:sticky;top:0;background:rgba(255,248,242,0.92);backdrop-filter:blur(8px);border-bottom:1px solid rgba(235,221,211,0.4);z-index:100;}
.header-inner{display:flex;align-items:center;padding:14px 24px;max-width:none;margin:0 auto;gap:24px;}
.brand{display:flex;align-items:center;gap:12px;}
.brand img{height:52px;width:auto;}.brand-text{display:none;}
.brand-name{font-family:'Klee One',serif;font-size:22px;color:var(--pink-deep);font-weight:600;line-height:1;}
.brand-tagline{font-size:11px;color:var(--text-soft);margin-top:4px;letter-spacing:0.05em;}
nav.gnav{display:flex;align-items:center;margin-left:auto;gap:2px;flex-wrap:nowrap;}
nav.gnav a{font-size:13.5px;color:#C47585;font-weight:500;padding:8px 12px;letter-spacing:0;transition:color .2s;position:relative;}
nav.gnav a:hover{color:#A9C49A;font-weight:700;text-shadow:0 0 0.5px currentColor;}
nav.gnav a.current{color:var(--pink-deep);font-weight:700;}
nav.gnav a.current::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--pink);border-radius:1px;}
.btn-cta{display:inline-flex;align-items:center;gap:8px;background:var(--pink);color:#fff !important;padding:11px 22px;border-radius:30px;font-size:14px;font-weight:500;transition:all .25s;box-shadow:0 4px 14px rgba(216,139,156,0.25);}
header .btn-cta{margin-left:8px;}
.btn-cta:hover{background:#A9C49A;transform:translateY(-1px);box-shadow:0 6px 18px rgba(216,139,156,0.35);}
header .btn-cta:hover{background:#A9C49A;color:#fff;text-shadow:none;}
.btn-cta::after{content:"›";font-size:18px;line-height:1;}

/* ===== PAGE HEAD ===== */
.page-head{
  background:linear-gradient(180deg,var(--cream) 0%,#FCEFE8 100%);
  padding:64px 0 60px;text-align:center;
}
.page-head h1{
  font-size:38px;font-weight:500;color:var(--text);
  line-height:1.5;letter-spacing:0.04em;margin-bottom:18px;
}
.page-head h1 .em{color:var(--pink-deep);}
.page-head .lead{
  font-size:15px;color:var(--text-soft);line-height:2.0;
  max-width:640px;margin:0 auto;padding:0 20px;
}
.page-head .handnote{
  font-family:'Klee One',serif;font-size:13px;color:var(--pink-deep);
  display:inline-flex;align-items:center;gap:6px;margin-top:20px;
}
.page-head .handnote::before{content:"〈";color:var(--pink);}
.page-head .handnote::after{content:"〉";color:var(--pink);}

/* ===== SECTION COMMON ===== */
section{padding:70px 0;}
.price-block{background:var(--cream);}
.price-block.alt{background:var(--cream-2);}
.section-label{
  text-align:center;font-size:13px;color:var(--pink-deep);
  letter-spacing:0.2em;margin-bottom:10px;
}
.section-title{
  text-align:center;font-size:26px;font-weight:500;color:var(--text);
  margin-bottom:14px;letter-spacing:0.05em;
}
.section-title::after{
  content:"";display:block;width:46px;height:2px;
  background:var(--pink);margin:14px auto 0;
}
.section-sub{
  text-align:center;font-size:13.5px;color:var(--text-soft);
  margin-bottom:42px;line-height:1.9;
}

/* ===== PRICE TABLE ===== */
.price-table{
  max-width:880px;margin:0 auto;
  background:#fff;border-radius:18px;
  box-shadow:0 4px 22px rgba(180,120,100,0.08);
  overflow:hidden;
}
.price-row{
  display:grid;grid-template-columns:200px 1fr 180px;
  gap:24px;align-items:center;
  padding:22px 32px;
  border-bottom:1px dashed var(--line);
  transition:background .2s;
}
.price-row:last-child{border-bottom:none;}
.price-row:hover{background:#FFFAF5;}
.price-row.featured{background:linear-gradient(180deg,#FFF6F8 0%,#FDE8EC 100%);}
.price-row.featured:hover{background:linear-gradient(180deg,#FFEEF1 0%,#FBDBE2 100%);}
.price-name{
  font-size:16px;font-weight:700;color:var(--text);
  letter-spacing:0.03em;
  display:flex;align-items:center;gap:8px;flex-wrap:wrap;
}
.price-tag{
  display:inline-block;background:var(--pink);color:#fff;
  font-size:10.5px;font-weight:500;
  padding:2px 9px;border-radius:30px;letter-spacing:0.08em;
}
.price-desc{
  font-size:13.5px;color:var(--text-soft);
  line-height:1.85;
}
.price-amount{
  text-align:right;
  font-size:24px;font-weight:700;color:var(--pink-deep);
  font-family:'Noto Sans JP',sans-serif;
}
.price-amount .unit{
  font-size:12px;color:var(--text-soft);font-weight:400;margin-left:3px;
}
.price-amount.small{font-size:15px;font-weight:500;}

/* ===== POLICY ===== */
.policy{background:var(--cream);padding:50px 0 90px;}
.policy-wrap{
  background:#fff;max-width:880px;margin:0 auto;
  border-radius:18px;padding:36px 44px;
  box-shadow:0 4px 24px rgba(196,117,133,0.06);
}
.policy h3{
  font-size:17px;color:var(--pink-deep);
  margin-bottom:18px;letter-spacing:0.05em;
  display:flex;align-items:center;gap:10px;
}
.policy h3::before{
  content:"";width:5px;height:18px;
  background:var(--pink);border-radius:2px;
}
.policy ul{list-style:none;padding:0;}
.policy ul li{
  font-size:13.5px;color:var(--text);line-height:2.0;
  padding-left:18px;position:relative;
}
.policy ul li::before{
  content:"●";color:var(--pink-soft);
  position:absolute;left:0;top:0;font-size:8px;
  line-height:2.5;
}
.policy ul li strong{color:var(--pink-deep);font-weight:600;}

/* ===== CTA ===== */
.cta{
  background:linear-gradient(180deg,#FCEFE8 0%,var(--cream) 100%);
  padding:70px 0 90px;text-align:center;
}
.cta-wrap{
  max-width:680px;margin:0 auto;padding:0 24px;
}
.cta-wrap h3{
  font-size:24px;font-weight:500;color:var(--text);
  margin-bottom:14px;letter-spacing:0.05em;
}
.cta-wrap p{
  font-size:14.5px;color:var(--text-soft);
  margin-bottom:30px;line-height:1.9;
}
.cta-wrap .handnote{
  font-family:'Klee One',serif;font-size:13px;
  color:var(--pink-deep);display:block;margin-top:14px;
}

/* ===== FOOTER ===== */
footer{background:var(--cream);border-top:1px solid var(--line);padding:30px 0 28px;}
.footer-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:24px;max-width:1240px;margin:0 auto;padding:0 40px;}
.footer-brand{display:flex;align-items:center;gap:10px;}
.footer-brand img{height:34px;width:auto;}.footer-brand .name{display:none;}
.footer-brand .name{font-family:'Klee One',serif;color:var(--pink-deep);font-size:17px;font-weight:600;}
.footer-brand .tag{font-size:11px;color:var(--text-soft);margin-left:8px;}
.footer-nav{display:flex;gap:24px;flex-wrap:wrap;}
.footer-nav a{font-size:13px;color:var(--text-soft);}
.footer-nav a:hover{color:var(--pink-deep);}
.copyright{text-align:center;font-size:11px;color:var(--text-soft);margin-top:24px;padding-top:18px;border-top:1px solid var(--line);}

/* ===== SP ===== */
@media (max-width:780px){
  .page-head{padding:44px 18px 48px;}
  .page-head h1{font-size:26px;}
  .page-head .lead{font-size:13.5px;line-height:1.95;}
  section{padding:48px 0 44px;}
  .section-title{font-size:20px;}
  .section-sub{font-size:12.5px;margin-bottom:24px;padding:0 20px;}
  .price-table{margin:0 16px;border-radius:12px;}
  .price-row{
    grid-template-columns:1fr;
    gap:6px;padding:18px 20px 16px;
  }
  .price-name{font-size:14.5px;}
  .price-tag{font-size:10px;padding:1px 8px;}
  .price-desc{font-size:12.5px;line-height:1.8;}
  .price-amount{text-align:left;font-size:20px;margin-top:4px;}
  .price-amount.small{font-size:14px;}
  .policy{padding:30px 0 60px;}
  .policy-wrap{padding:24px 22px;margin:0 16px;}
  .policy h3{font-size:15px;}
  .policy ul li{font-size:12.5px;line-height:1.95;}
  .cta{padding:48px 0 64px;}
  .cta-wrap h3{font-size:19px;}
  .cta-wrap p{font-size:13px;}
}

/* ===== SP共通（2026-05-20統一） ===== */
@media (max-width:860px){
  header .header-inner{padding:10px 16px;gap:12px;}
  .brand img{height:42px;}
  nav.gnav{gap:0;}
  nav.gnav a:not(.btn-cta){display:none;}
  header .btn-cta,nav.gnav a.btn-cta{padding:9px 16px;font-size:13px;margin-left:0;}
  .footer-inner{flex-direction:column;text-align:center;padding:0 24px;gap:18px;}
  .footer-brand{justify-content:center;flex-wrap:wrap;}
  .footer-nav{justify-content:center;}
}

/* =========================================================
   ページ固有：制作事例（works.html）
   ========================================================= */
:root{
  --pink:#D88B9C;--pink-deep:#C47585;--pink-soft:#F4D4DC;--pink-bg:#FBE9EE;
  --cream:#FFF8F2;--cream-2:#FAF1E8;--text:#5C4F4A;--text-soft:#8A7A73;
  --green:#A9C49A;--line:#EBDDD3;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'Noto Sans JP','Hiragino Kaku Gothic ProN','Hiragino Sans',sans-serif;color:var(--text);background:var(--cream);font-size:15px;line-height:1.9;-webkit-font-smoothing:antialiased;}
h1,h2,h3,h4,h5,h6{font-family:'Zen Maru Gothic','Hiragino Maru Gothic ProN',sans-serif;}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
.container{max-width:1180px;margin:0 auto;padding:0 32px;}

/* ===== HEADER ===== */
header{position:sticky;top:0;z-index:100;background:rgba(255,248,242,0.92);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-bottom:1px solid rgba(235,221,211,0.4);}
.header-inner{display:flex;align-items:center;padding:14px 24px;max-width:none;margin:0 auto;gap:24px;}
.brand{display:flex;align-items:center;gap:12px;}
.brand img{height:52px;width:auto;}.brand-text{display:none;}
.brand-text .brand-name{font-family:'Klee One',serif;font-size:22px;color:var(--pink-deep);font-weight:600;line-height:1;}
.brand-text .brand-tagline{font-size:11px;color:var(--text-soft);margin-top:4px;letter-spacing:0.05em;}
nav.gnav{display:flex;align-items:center;margin-left:auto;gap:2px;flex-wrap:nowrap;}
nav.gnav a{font-size:13.5px;color:#C47585;font-weight:500;padding:8px 12px;letter-spacing:0;transition:color .2s;position:relative;}
nav.gnav a:hover{color:#A9C49A;font-weight:700;text-shadow:0 0 0.5px currentColor;}
nav.gnav a.current{color:var(--pink-deep);font-weight:700;}
nav.gnav a.current::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--pink);border-radius:1px;}
.btn-cta{display:inline-flex;align-items:center;gap:8px;background:var(--pink);color:#fff !important;padding:11px 22px;border-radius:30px;font-size:14px;font-weight:500;transition:all .25s;box-shadow:0 4px 14px rgba(216,139,156,0.25);}
header .btn-cta{margin-left:8px;}
.btn-cta:hover{background:#A9C49A;transform:translateY(-1px);box-shadow:0 6px 18px rgba(216,139,156,0.35);}
header .btn-cta:hover{background:#A9C49A;color:#fff;text-shadow:none;}
.btn-cta::after{content:"›";font-size:18px;line-height:1;}

/* ===== WORKS HERO ===== */
.works-hero{background:linear-gradient(180deg,var(--cream) 0%,#FCEFE8 100%);padding:64px 0 40px;text-align:center;}
.works-hero h1{font-size:32px;font-weight:500;color:var(--text);position:relative;padding-bottom:14px;margin-bottom:14px;letter-spacing:0.05em;}
.works-hero h1::after{content:"";display:block;position:absolute;left:50%;bottom:0;transform:translateX(-50%);width:46px;height:2px;background:var(--pink);}
.works-hero p{font-size:14.5px;color:var(--text-soft);line-height:2;}

/* ===== CASE LIST ===== */
.works-list{padding:48px 0 80px;}
.case{background:#fff;border-radius:14px;overflow:hidden;box-shadow:0 4px 22px rgba(180,120,100,0.08);margin-bottom:48px;max-width:880px;margin-left:auto;margin-right:auto;}
.case-hero{position:relative;background:#FCEFE8;aspect-ratio:16/10;}
.case-thumb{position:absolute;inset:0;background-size:cover;background-position:center;background-repeat:no-repeat;}
.case:nth-child(1) .case-thumb{background-image:url('assets/images/work-abe.jpg');}
.case:nth-child(2) .case-thumb{background-image:url('assets/images/work-toshu.jpg');}
.case:nth-child(3) .case-thumb{background-image:url('assets/images/work-chanoma-v7.jpg');}
.case:nth-child(4) .case-thumb{background-image:url('assets/images/work-yona.jpg');}
.case-body{padding:38px 36px;display:flex;flex-direction:column;gap:18px;}
.case-meta{padding-bottom:14px;border-bottom:1px solid var(--line);}
.case-cat{display:inline-block;font-size:11.5px;color:var(--pink-deep);background:var(--pink-soft);padding:3px 12px;border-radius:30px;margin-bottom:10px;}
.case-meta h2{font-size:22px;font-weight:500;color:var(--text);}
.case-block h3{font-size:13.5px;color:var(--pink-deep);font-weight:700;margin-bottom:8px;display:flex;align-items:center;gap:10px;}
.case-block h3::before{content:"";display:inline-block;width:16px;height:2px;background:var(--pink);}
.case-block p{font-size:14px;color:var(--text);line-height:1.95;}
.case-block ul{font-size:14px;color:var(--text);line-height:1.95;padding-left:20px;}
.case-block.voice .voice-quote{background:#FCEFE8;border-radius:12px;padding:24px 26px 20px;position:relative;border-left:3px solid var(--pink-soft);}
.case-block.voice .voice-quote p{font-size:13.5px;color:var(--text);line-height:1.95;margin-bottom:10px;}
.case-block.voice .voice-quote p:last-child{margin-bottom:0;}
.case-block.voice .voice-attribution{font-size:12.5px;color:var(--text-soft);text-align:right;margin-top:10px;font-family:'Klee One',serif;}
.case-cta{margin-top:auto;padding-top:6px;}
.case-cta .btn-line{display:inline-flex;align-items:center;gap:8px;border:1.5px solid var(--pink);color:var(--pink-deep);padding:10px 26px;border-radius:30px;font-size:13.5px;font-weight:500;transition:background .2s;}
.case-cta .btn-line:hover{background:var(--pink-soft);}
.case-cta .btn-line::after{content:" ›";}

/* ===== FOOTER ===== */
footer{background:var(--cream);border-top:1px solid var(--line);padding:30px 0 28px;}
.footer-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:24px;max-width:1240px;margin:0 auto;padding:0 40px;}
.footer-brand{display:flex;align-items:center;gap:10px;}
.footer-brand img{height:34px;width:auto;}.footer-brand .name{display:none;}
.footer-brand .name{font-family:'Klee One',serif;color:var(--pink-deep);font-size:17px;font-weight:600;}
.footer-brand .tag{font-size:11px;color:var(--text-soft);margin-left:8px;}
.footer-nav{display:flex;gap:24px;flex-wrap:wrap;}
.footer-nav a{font-size:13px;color:var(--text-soft);}
.footer-nav a:hover{color:var(--pink-deep);}
.footer-actions{display:flex;gap:10px;}
.footer-btn{border:1px solid var(--line);color:var(--text-soft);padding:8px 18px;border-radius:30px;font-size:12.5px;background:#fff;}
.footer-btn:hover{border-color:var(--pink);color:var(--pink-deep);}
.copyright{text-align:center;font-size:11px;color:var(--text-soft);margin-top:24px;padding-top:18px;border-top:1px solid var(--line);}

/* ===== RESPONSIVE ===== */
@media (max-width:980px){
  .header-inner{flex-direction:column;gap:14px;padding:14px 20px;}
  nav.gnav{gap:18px;flex-wrap:wrap;justify-content:center;}
  .works-hero{padding:48px 0 28px;}
  .case-body{padding:28px 24px;}
}
@media (max-width:560px){
  .works-hero h1{font-size:26px;}
  .case{margin-bottom:26px;border-radius:10px;}
  .case-meta h2{font-size:19px;}
  .case-body{padding:24px 20px;gap:14px;}
}
/* ===== SP共通（2026-05-20統一） ===== */
@media (max-width:860px){
  header .header-inner{padding:10px 16px;gap:12px;}
  .brand img{height:42px;}
  nav.gnav{gap:0;}
  nav.gnav a:not(.btn-cta){display:none;}
  header .btn-cta,nav.gnav a.btn-cta{padding:9px 16px;font-size:13px;margin-left:0;}
  .footer-inner{flex-direction:column;text-align:center;padding:0 24px;gap:18px;}
  .footer-brand{justify-content:center;flex-wrap:wrap;}
  .footer-nav{justify-content:center;}
}

/* =========================================================
   ページ固有：プロフィール（profile.html）
   ========================================================= */
:root{
  --pink:#D88B9C;
  --pink-deep:#C47585;
  --pink-soft:#F4D4DC;
  --pink-bg:#FBE9EE;
  --cream:#FFF8F2;
  --cream-2:#FAF1E8;
  --text:#5C4F4A;
  --text-soft:#8A7A73;
  --green:#A9C49A;
  --line:#EBDDD3;
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  font-family:'Noto Sans JP','Hiragino Kaku Gothic ProN','Hiragino Sans',sans-serif;
  color:var(--text);
  background:var(--cream);
  font-size:15px;
  line-height:1.95;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4,h5,h6{font-family:'Zen Maru Gothic','Hiragino Maru Gothic ProN',sans-serif;}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}

.container{max-width:1180px;margin:0 auto;padding:0 32px;}

/* ===== HEADER（index.htmlと同じ） ===== */
header{
  position:sticky;top:0;z-index:100;
  background:rgba(255,248,242,0.92);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  border-bottom:1px solid rgba(235,221,211,0.4);
}
.header-inner{
  display:flex;align-items:center;
  padding:14px 24px;
  max-width:none;margin:0 auto;gap:24px;
}
.brand{display:flex;align-items:center;gap:12px;}
.brand img{height:52px;width:auto;}.brand-text{display:none;}
.brand-text .brand-name{
  font-family:'Klee One',serif;
  font-size:22px;color:var(--pink-deep);font-weight:600;line-height:1;
}
.brand-text .brand-tagline{
  font-size:11px;color:var(--text-soft);margin-top:4px;letter-spacing:0.05em;
}
nav.gnav{display:flex;align-items:center;margin-left:auto;gap:2px;flex-wrap:nowrap;}
nav.gnav a{
  font-size:13.5px;color:#C47585;font-weight:500;
  padding:8px 12px;letter-spacing:0;
  transition:color .2s;
  position:relative;
}
nav.gnav a:hover{color:#A9C49A;font-weight:700;text-shadow:0 0 0.5px currentColor;}
nav.gnav a.is-current{color:var(--pink-deep);font-weight:700;}
nav.gnav a.is-current::after{
  content:"";
  position:absolute;
  left:0;right:0;bottom:-6px;
  height:2px;
  background:var(--pink);
  border-radius:1px;
}
.btn-cta{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--pink);color:#fff !important;
  padding:11px 22px;border-radius:30px;
  font-size:14px;font-weight:500;
  transition:all .25s;
  box-shadow:0 4px 14px rgba(216,139,156,0.25);
}
header .btn-cta{margin-left:8px;}
.btn-cta:hover{background:#A9C49A;transform:translateY(-1px);box-shadow:0 6px 18px rgba(216,139,156,0.35);}
header .btn-cta:hover{background:#A9C49A;color:#fff;text-shadow:none;}
.btn-cta::after{content:"›";font-size:18px;line-height:1;}

/* ===== ページタイトル ===== */
.page-head{
  background:linear-gradient(180deg,var(--cream) 0%,#FCEFE8 100%);
  padding:56px 0 40px;
  text-align:center;
}
.page-head h1{
  font-family:'Zen Maru Gothic',sans-serif;
  font-size:30px;font-weight:500;
  color:var(--text);
  letter-spacing:0.08em;
  margin-bottom:10px;
}
.page-head h1::after{
  content:"";display:block;
  width:46px;height:2px;
  background:var(--pink);
  margin:14px auto 0;
}
.page-head .sub{
  font-family:'Klee One',serif;
  font-size:14px;color:var(--pink-deep);
  letter-spacing:0.05em;
}

/* ===== プロフィールヒーロー ===== */
.profile-hero{padding:60px 0 40px;}
.profile-hero-wrap{
  display:grid;grid-template-columns:1fr 1.2fr;
  gap:56px;align-items:center;
  max-width:1080px;margin:0 auto;padding:0 40px;
}
.profile-photo{
  position:relative;
}
.profile-photo .photo{
  width:100%;
  aspect-ratio:4/5;
  background-image:url('assets/images/profile.jpg');
  background-size:cover;
  background-position:70% top;
  border-radius:14px;
  box-shadow:0 8px 30px rgba(180,120,100,0.12);
}
.profile-name-block .greet{
  font-family:'Klee One',serif;
  font-size:15px;color:var(--pink-deep);
  letter-spacing:0.05em;
  margin-bottom:14px;
}
.profile-name-block .name{
  font-family:'Zen Maru Gothic',sans-serif;
  font-size:38px;font-weight:500;
  color:var(--text);
  line-height:1.5;
  letter-spacing:0.04em;
  margin-bottom:6px;
}
.profile-name-block .name .ruby{
  font-size:14px;color:var(--text-soft);
  letter-spacing:0.1em;
  display:block;
  margin-top:6px;
  font-weight:400;
}
.profile-name-block .role{
  font-size:14px;color:var(--text-soft);
  margin-top:22px;
  line-height:2.0;
}
.profile-name-block .role .em{color:var(--pink-deep);}

/* ===== セクション共通 ===== */
.profile-section{
  padding:50px 0;
}
.profile-section + .profile-section{
  border-top:1px solid var(--line);
}
.profile-section .inner{
  max-width:780px;margin:0 auto;padding:0 40px;
}
body.page .profile-section h2,
.profile-section h2{
  font-family:'Zen Maru Gothic',sans-serif !important;
  font-size:22px !important;
  font-weight:500 !important;
  color:var(--text) !important;
  margin-bottom:28px !important;
  letter-spacing:0.05em !important;
  position:relative !important;
  padding-left:30px !important;
  padding-right:0 !important;
  text-align:left !important;
  text-indent:0 !important;
  line-height:1.5 !important;
}
.profile-section h2::before{
  content:"" !important;
  position:absolute !important;
  left:0 !important;
  top:0.35em !important;
  width:6px !important;
  height:1em !important;
  background:var(--pink) !important;
  border-radius:3px !important;
  padding:0 !important;
  margin:0 !important;
}
.profile-section h2::after{
  display:none !important;
  content:none !important;
}
.profile-section h2 .leaf{
  color:var(--green);
  font-size:16px;
  margin-left:8px;
  transform:translateY(-2px);
  display:inline-block;
}
.profile-section p{
  font-size:14.5px;
  line-height:2.1;
  color:var(--text);
  margin-bottom:18px;
}
.profile-section p.soft{color:var(--text-soft);}
.profile-section .quote{
  font-family:'Klee One',serif;
  font-size:17px;
  color:var(--pink-deep);
  background:transparent;
  border-top:1px solid var(--pink-soft);
  border-bottom:1px solid var(--pink-soft);
  padding:30px 24px;
  margin:24px 0;
  line-height:1.95;
  letter-spacing:0.09em;
  display:block;
  column-count:1;
  columns:auto;
  text-align:center;
  white-space:normal;
}
.profile-section .quote::before{content:"〈 ";}
.profile-section .quote::after{content:" 〉";}
.profile-section .quote .quote-br-sp{display:none;}
@media (max-width:880px){
  .profile-section .quote .quote-br-sp{display:inline;}
}

/* これまで（仕事の積み重ね） */
.work-list{
  list-style:none;
  margin:0;padding:0;
}
.work-list li{
  position:relative;
  padding:12px 0 12px 26px;
  font-size:14.5px;
  color:var(--text);
  border-bottom:1px dashed var(--line);
}
.work-list li:last-child{border-bottom:none;}
.work-list li::before{
  content:"";
  position:absolute;
  left:4px;top:22px;
  width:8px;height:8px;
  border-radius:50%;
  background:var(--pink-soft);
  border:1.5px solid var(--pink);
}

/* 暮らしのかけら */
.life-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:18px;
  margin-top:14px;
}
.life-item{
  background:#fff;
  border-radius:10px;
  padding:18px 16px;
  text-align:center;
  box-shadow:0 2px 10px rgba(180,120,100,0.05);
}
.life-item .icon{
  font-size:26px;
  margin-bottom:8px;
}
.life-item .label{
  font-size:13px;
  color:var(--text-soft);
  line-height:1.7;
}

/* プレースホルダー（本人に聞く） */
.placeholder{
  background:#FFF5E6;
  border:1px dashed #E5C690;
  border-radius:10px;
  padding:18px 22px;
  margin:20px 0;
  font-size:13.5px;
  color:#A6802F;
  line-height:1.85;
}
.placeholder strong{
  display:block;
  font-size:12px;
  letter-spacing:0.1em;
  color:#A6802F;
  margin-bottom:6px;
  font-weight:600;
}

/* ===== CTA小 ===== */
.profile-cta{
  text-align:center;
  padding:60px 0 80px;
  background:linear-gradient(180deg,var(--cream) 0%,var(--pink-bg) 100%);
  position:relative;
}
.profile-cta::before{
  content:"";
  display:block;
  width:42px;
  height:6px;
  margin:0 auto 28px;
  background-image:radial-gradient(circle,var(--pink) 2px,transparent 2.5px);
  background-size:14px 6px;
  background-repeat:repeat-x;
  background-position:center;
  opacity:0.85;
}
.profile-cta p{
  font-size:14.5px;
  color:var(--text-soft);
  margin-bottom:24px;
  line-height:2.0;
}
.profile-cta .btn-cta{
  padding:14px 32px;
  font-size:15px;
}
.btn-line{
  display:inline-flex;align-items:center;gap:8px;
  border:1.5px solid var(--pink);
  color:var(--pink-deep);
  padding:12px 32px;border-radius:30px;
  font-size:14px;font-weight:500;
  transition:all .25s;
  background:#fff;
}
.btn-line:hover{background:var(--pink);color:#fff;}
.btn-line::after{content:"›";font-size:16px;}

/* ===== FOOTER ===== */
footer{
  background:var(--cream);
  border-top:1px solid var(--line);
  padding:30px 0 28px;
}
.footer-inner{
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:24px;
  max-width:1240px;margin:0 auto;padding:0 40px;
}
.footer-brand{display:flex;align-items:center;gap:10px;}
.footer-brand img{height:34px;width:auto;}.footer-brand .name{display:none;}
.footer-brand .name{
  font-family:'Klee One',serif;
  color:var(--pink-deep);font-size:17px;font-weight:600;
}
.footer-brand .tag{
  font-size:11px;color:var(--text-soft);margin-left:8px;
}
.footer-nav{display:flex;gap:24px;flex-wrap:wrap;}
.footer-nav a{font-size:13px;color:var(--text-soft);}
.footer-nav a:hover{color:var(--pink-deep);}
.copyright{
  text-align:center;
  font-size:11px;color:var(--text-soft);
  margin-top:24px;
  padding-top:18px;
  border-top:1px solid var(--line);
}

/* ===== レスポンシブ ===== */
@media (max-width:880px){
  .profile-hero-wrap{grid-template-columns:1fr;gap:30px;}
  .profile-name-block{text-align:center;}
  .profile-name-block .name{font-size:30px;}
  .life-grid{grid-template-columns:repeat(2,1fr);}
  nav.gnav{display:none;}
}
/* ===== SP共通（2026-05-20統一） ===== */
@media (max-width:860px){
  header .header-inner{padding:10px 16px;gap:12px;}
  .brand img{height:42px;}
  nav.gnav{gap:0;}
  nav.gnav a:not(.btn-cta){display:none;}
  header .btn-cta,nav.gnav a.btn-cta{padding:9px 16px;font-size:13px;margin-left:0;}
  .footer-inner{flex-direction:column;text-align:center;padding:0 24px;gap:18px;}
  .footer-brand{justify-content:center;flex-wrap:wrap;}
  .footer-nav{justify-content:center;}
}

/* =========================================================
   ページ固有：お問い合わせ（contact.html）
   ========================================================= */
:root{--pink:#D88B9C;--pink-deep:#C47585;--pink-soft:#E8B5C0;--pink-bg:#FBE9EE;--cream:#FFF8F2;--cream-2:#FFF3EC;--text:#5C4F4A;--text-soft:#8A7A73;--line:#EBDDD3;}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
body{font-family:'Noto Sans JP','Hiragino Kaku Gothic ProN','Hiragino Sans',sans-serif;color:var(--text);background:var(--cream);font-size:15px;line-height:1.9;-webkit-font-smoothing:antialiased;}
h1,h2,h3,h4,h5,h6{font-family:'Zen Maru Gothic','Hiragino Maru Gothic ProN',sans-serif;}
a{color:inherit;text-decoration:none;}

/* ===== HEADER ===== */
header{position:sticky;top:0;background:rgba(255,248,242,0.92);backdrop-filter:blur(8px);border-bottom:1px solid rgba(235,221,211,0.4);z-index:100;}
.header-inner{display:flex;align-items:center;padding:14px 24px;max-width:none;margin:0 auto;gap:24px;}
.brand{display:flex;align-items:center;gap:12px;}
.brand img{height:52px;width:auto;}.brand-text{display:none;}
.brand-name{font-family:'Klee One',serif;font-size:22px;color:var(--pink-deep);font-weight:600;line-height:1;}
.brand-tagline{font-size:11px;color:var(--text-soft);margin-top:4px;letter-spacing:0.05em;}
nav.gnav{display:flex;align-items:center;margin-left:auto;gap:2px;flex-wrap:nowrap;}
nav.gnav a{font-size:13.5px;color:#C47585;font-weight:500;padding:8px 12px;letter-spacing:0;transition:color .2s;position:relative;}
nav.gnav a:hover{color:#A9C49A;font-weight:700;text-shadow:0 0 0.5px currentColor;}
nav.gnav a.current{color:var(--pink-deep);font-weight:700;}
nav.gnav a.current::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--pink);border-radius:1px;}
.btn-cta{display:inline-flex;align-items:center;gap:8px;background:var(--pink);color:#fff !important;padding:11px 22px;border-radius:30px;font-size:14px;font-weight:500;transition:all .25s;box-shadow:0 4px 14px rgba(216,139,156,0.25);}
header .btn-cta{margin-left:8px;}
.btn-cta:hover{background:#A9C49A;transform:translateY(-1px);box-shadow:0 6px 18px rgba(216,139,156,0.35);}
header .btn-cta:hover{background:#A9C49A;color:#fff;text-shadow:none;}
.btn-cta::after{content:"›";font-size:18px;line-height:1;}

/* ===== PAGE HEAD ===== */
.page-head{
  background:linear-gradient(180deg,var(--cream) 0%,#FCEFE8 100%);
  padding:64px 0 60px;text-align:center;
}
.page-head h1{
  font-size:38px;font-weight:500;color:var(--text);
  line-height:1.5;letter-spacing:0.04em;margin-bottom:18px;
}
.page-head h1 .em{color:var(--pink-deep);}
.page-head .lead{
  font-size:15px;color:var(--text-soft);line-height:2.0;
  max-width:640px;margin:0 auto;padding:0 20px;
}
.page-head .handnote{
  font-family:'Klee One',serif;font-size:13px;color:var(--pink-deep);
  display:inline-flex;align-items:center;gap:6px;margin-top:20px;
}
.page-head .handnote::before{content:"〈";color:var(--pink);}
.page-head .handnote::after{content:"〉";color:var(--pink);}

/* ===== FORM SECTION ===== */
.form-block{padding:70px 0 50px;}
.form-wrap{max-width:680px;margin:0 auto;padding:0 24px;}
.form-intro{
  background:#fff;border-radius:14px;
  padding:24px 28px;margin-bottom:36px;
  box-shadow:0 4px 18px rgba(180,120,100,0.07);
}
.form-intro p{font-size:13.5px;color:var(--text);line-height:1.95;}
.form-intro p + p{margin-top:10px;}
.form-intro strong{color:var(--pink-deep);}

.cf7-placeholder{
  background:#fff;border-radius:14px;
  padding:36px 36px 30px;
  box-shadow:0 4px 22px rgba(180,120,100,0.08);
}
.cf7-placeholder .field{margin-bottom:22px;}
.cf7-placeholder .field:last-of-type{margin-bottom:0;}
.cf7-placeholder label{
  display:block;
  font-size:13.5px;font-weight:600;color:var(--text);
  margin-bottom:8px;letter-spacing:0.03em;
}
.cf7-placeholder .req{
  display:inline-block;
  background:var(--pink);color:#fff;
  font-size:10px;font-weight:500;
  padding:1px 7px;border-radius:30px;
  margin-left:6px;letter-spacing:0.08em;vertical-align:middle;
}
.cf7-placeholder .opt{
  display:inline-block;
  background:var(--line);color:var(--text-soft);
  font-size:10px;font-weight:500;
  padding:1px 7px;border-radius:30px;
  margin-left:6px;letter-spacing:0.08em;vertical-align:middle;
}
.cf7-placeholder input[type="text"],
.cf7-placeholder input[type="email"],
.cf7-placeholder input[type="tel"],
.cf7-placeholder select,
.cf7-placeholder textarea{
  width:100%;border:1px solid var(--line);border-radius:8px;
  padding:12px 14px;font-size:14px;font-family:inherit;
  background:var(--cream);color:var(--text);
  transition:border-color .2s, background .2s;
}
.cf7-placeholder input:focus,
.cf7-placeholder select:focus,
.cf7-placeholder textarea:focus{
  outline:none;border-color:var(--pink);background:#fff;
}
.cf7-placeholder textarea{min-height:130px;resize:vertical;line-height:1.8;}
.cf7-placeholder .checks{display:flex;gap:18px;flex-wrap:wrap;padding-top:4px;}
.cf7-placeholder .checks label{
  display:inline-flex;align-items:center;gap:8px;
  font-size:13.5px;font-weight:400;color:var(--text);
  margin-bottom:0;cursor:pointer;
}
.cf7-placeholder .checks input{accent-color:var(--pink);width:16px;height:16px;}
.cf7-placeholder .submit-area{
  text-align:center;margin-top:32px;padding-top:24px;
  border-top:1px dashed var(--line);
}
.cf7-placeholder button[type="submit"]{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--pink);color:#fff;border:none;cursor:pointer;
  padding:14px 36px;border-radius:30px;
  font-size:15px;font-weight:500;font-family:inherit;
  letter-spacing:0.05em;
  box-shadow:0 4px 14px rgba(216,139,156,0.25);
  transition:all .25s;
}
.cf7-placeholder button[type="submit"]:hover{
  background:#A9C49A;transform:translateY(-1px);
  box-shadow:0 6px 18px rgba(216,139,156,0.35);
}
.cf7-placeholder button[type="submit"]::after{content:"›";font-size:18px;}
.cf7-placeholder .submit-note{
  font-family:'Klee One',serif;
  font-size:12.5px;color:var(--pink-deep);margin-top:14px;
}

/* ===== INFO ===== */
.info-block{padding:30px 0 90px;}
.info-wrap{max-width:680px;margin:0 auto;padding:0 24px;}
.info-card{
  background:var(--cream-2);border-radius:14px;
  padding:24px 28px;text-align:center;
}
.info-card h3{font-size:15px;color:var(--pink-deep);margin-bottom:12px;letter-spacing:0.05em;}
.info-card p{font-size:13.5px;color:var(--text);line-height:1.9;}
.info-card a{
  color:var(--pink-deep);font-weight:600;
  text-decoration:underline;text-decoration-thickness:1px;
  text-underline-offset:3px;
}

/* ===== FOOTER ===== */
footer{background:var(--cream);border-top:1px solid var(--line);padding:30px 0 28px;}
.footer-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:24px;max-width:1240px;margin:0 auto;padding:0 40px;}
.footer-brand{display:flex;align-items:center;gap:10px;}
.footer-brand img{height:34px;width:auto;}.footer-brand .name{display:none;}
.footer-brand .name{font-family:'Klee One',serif;color:var(--pink-deep);font-size:17px;font-weight:600;}
.footer-brand .tag{font-size:11px;color:var(--text-soft);margin-left:8px;}
.footer-nav{display:flex;gap:24px;flex-wrap:wrap;}
.footer-nav a{font-size:13px;color:var(--text-soft);}
.footer-nav a:hover{color:var(--pink-deep);}
.copyright{text-align:center;font-size:11px;color:var(--text-soft);margin-top:24px;padding-top:18px;border-top:1px solid var(--line);}

/* ===== SP ===== */
@media (max-width:780px){
  .page-head{padding:44px 18px 48px;}
  .page-head h1{font-size:26px;}
  .page-head .lead{font-size:13.5px;line-height:1.95;}
  .form-block{padding:36px 0 32px;}
  .form-wrap{padding:0 16px;}
  .form-intro{padding:18px 20px;margin-bottom:24px;}
  .form-intro p{font-size:12.5px;}
  .cf7-placeholder{padding:24px 22px 22px;}
  .cf7-placeholder label{font-size:13px;}
  .cf7-placeholder input,
  .cf7-placeholder select,
  .cf7-placeholder textarea{font-size:13.5px;padding:10px 12px;}
  .info-block{padding:20px 0 64px;}
  .info-wrap{padding:0 16px;}
  .info-card{padding:20px 22px;}
}

@media (max-width:860px){
  header .header-inner{padding:10px 16px;gap:12px;}
  .brand img{height:42px;}
  nav.gnav{gap:0;}
  nav.gnav a:not(.btn-cta){display:none;}
  header .btn-cta,nav.gnav a.btn-cta{padding:9px 16px;font-size:13px;margin-left:0;}
  .footer-inner{flex-direction:column;text-align:center;padding:0 24px;gap:18px;}
  .footer-brand{justify-content:center;flex-wrap:wrap;}
  .footer-nav{justify-content:center;}
}

/* =========================================================
   ページ固有：運営者情報（administrator.html）
   ========================================================= */
:root{--pink:#D88B9C;--pink-deep:#C47585;--pink-soft:#E8B5C0;--pink-bg:#FBE9EE;--cream:#FFF8F2;--cream-2:#FFF3EC;--text:#5C4F4A;--text-soft:#8A7A73;--line:#EBDDD3;}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
body{font-family:'Noto Sans JP','Hiragino Kaku Gothic ProN','Hiragino Sans',sans-serif;color:var(--text);background:var(--cream);font-size:15px;line-height:1.9;-webkit-font-smoothing:antialiased;}
h1,h2,h3,h4,h5,h6{font-family:'Zen Maru Gothic','Hiragino Maru Gothic ProN',sans-serif;}
a{color:inherit;text-decoration:none;}

header{position:sticky;top:0;background:rgba(255,248,242,0.92);backdrop-filter:blur(8px);border-bottom:1px solid rgba(235,221,211,0.4);z-index:100;}
.header-inner{display:flex;align-items:center;padding:14px 24px;max-width:none;margin:0 auto;gap:24px;}
.brand{display:flex;align-items:center;gap:12px;}
.brand img{height:52px;width:auto;}.brand-text{display:none;}
.brand-name{font-family:'Klee One',serif;font-size:22px;color:var(--pink-deep);font-weight:600;line-height:1;}
.brand-tagline{font-size:11px;color:var(--text-soft);margin-top:4px;letter-spacing:0.05em;}
nav.gnav{display:flex;align-items:center;margin-left:auto;gap:2px;flex-wrap:nowrap;}
nav.gnav a{font-size:13.5px;color:#C47585;font-weight:500;padding:8px 12px;letter-spacing:0;transition:color .2s;position:relative;}
nav.gnav a:hover{color:#A9C49A;font-weight:700;text-shadow:0 0 0.5px currentColor;}
nav.gnav a.current{color:var(--pink-deep);font-weight:700;}
nav.gnav a.current::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--pink);border-radius:1px;}
.btn-cta{display:inline-flex;align-items:center;gap:8px;background:var(--pink);color:#fff !important;padding:11px 22px;border-radius:30px;font-size:14px;font-weight:500;transition:all .25s;box-shadow:0 4px 14px rgba(216,139,156,0.25);}
header .btn-cta{margin-left:8px;}
.btn-cta:hover{background:#A9C49A;transform:translateY(-1px);box-shadow:0 6px 18px rgba(216,139,156,0.35);}
header .btn-cta:hover{background:#A9C49A;color:#fff;text-shadow:none;}
.btn-cta::after{content:"›";font-size:18px;line-height:1;}

.page-head{background:linear-gradient(180deg,var(--cream) 0%,#FCEFE8 100%);padding:60px 0 56px;text-align:center;}
.page-head h1{font-size:34px;font-weight:500;color:var(--text);line-height:1.5;letter-spacing:0.04em;margin-bottom:14px;}
.page-head h1 .em{color:var(--pink-deep);}
.page-head .lead{font-size:14px;color:var(--text-soft);}

.admin-content{padding:64px 0 90px;}
.admin-wrap{max-width:760px;margin:0 auto;padding:0 24px;}
.admin-card{background:#fff;border-radius:18px;padding:44px 48px 40px;box-shadow:0 4px 24px rgba(196,117,133,0.06);}
.admin-table{width:100%;border-collapse:collapse;}
.admin-table tr{border-bottom:1px dashed var(--line);}
.admin-table tr:last-child{border-bottom:none;}
.admin-table th,
.admin-table td{text-align:left;vertical-align:top;padding:18px 12px;font-size:14px;line-height:1.85;}
.admin-table th{width:200px;color:var(--pink-deep);font-weight:600;letter-spacing:0.05em;position:relative;padding-left:18px;}
.admin-table th::before{content:"";position:absolute;left:0;top:24px;width:4px;height:14px;background:var(--pink-soft);border-radius:2px;}
.admin-table td{color:var(--text);}
.admin-table td a{color:var(--pink-deep);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px;}

footer{background:var(--cream);border-top:1px solid var(--line);padding:30px 0 28px;}
.footer-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:24px;max-width:1240px;margin:0 auto;padding:0 40px;}
.footer-brand{display:flex;align-items:center;gap:10px;}
.footer-brand img{height:34px;width:auto;}.footer-brand .name{display:none;}
.footer-brand .name{font-family:'Klee One',serif;color:var(--pink-deep);font-size:17px;font-weight:600;}
.footer-brand .tag{font-size:11px;color:var(--text-soft);margin-left:8px;}
.footer-nav{display:flex;gap:24px;flex-wrap:wrap;}
.footer-nav a{font-size:13px;color:var(--text-soft);}
.footer-nav a:hover{color:var(--pink-deep);}
.copyright{text-align:center;font-size:11px;color:var(--text-soft);margin-top:24px;padding-top:18px;border-top:1px solid var(--line);}

@media (max-width:780px){
  .page-head{padding:44px 18px 40px;}
  .page-head h1{font-size:23px;}
  .admin-content{padding:36px 0 64px;}
  .admin-wrap{padding:0 16px;}
  .admin-card{padding:24px 22px;border-radius:12px;}
  .admin-table th,
  .admin-table td{display:block;width:auto;padding:10px 0;}
  .admin-table th{padding-left:14px;padding-top:18px;font-size:13px;}
  .admin-table th::before{top:22px;height:13px;}
  .admin-table td{padding-left:14px;padding-bottom:14px;font-size:13.5px;}
  .admin-table tr{border-bottom:1px dashed var(--line);}
  .admin-table tr:last-child td{padding-bottom:0;}
}
@media (max-width:860px){
  header .header-inner{padding:10px 16px;gap:12px;}
  .brand img{height:42px;}
  nav.gnav{gap:0;}
  nav.gnav a:not(.btn-cta){display:none;}
  header .btn-cta,nav.gnav a.btn-cta{padding:9px 16px;font-size:13px;margin-left:0;}
  .footer-inner{flex-direction:column;text-align:center;padding:0 24px;gap:18px;}
  .footer-brand{justify-content:center;flex-wrap:wrap;}
  .footer-nav{justify-content:center;}
}

/* =========================================================
   ページ固有：プライバシーポリシー（privacy.html）
   ========================================================= */
:root{--pink:#D88B9C;--pink-deep:#C47585;--pink-soft:#E8B5C0;--pink-bg:#FBE9EE;--cream:#FFF8F2;--cream-2:#FFF3EC;--text:#5C4F4A;--text-soft:#8A7A73;--line:#EBDDD3;}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
body{font-family:'Noto Sans JP','Hiragino Kaku Gothic ProN','Hiragino Sans',sans-serif;color:var(--text);background:var(--cream);font-size:15px;line-height:1.9;-webkit-font-smoothing:antialiased;}
h1,h2,h3,h4,h5,h6{font-family:'Zen Maru Gothic','Hiragino Maru Gothic ProN',sans-serif;}
a{color:inherit;text-decoration:none;}

header{position:sticky;top:0;background:rgba(255,248,242,0.92);backdrop-filter:blur(8px);border-bottom:1px solid rgba(235,221,211,0.4);z-index:100;}
.header-inner{display:flex;align-items:center;padding:14px 24px;max-width:none;margin:0 auto;gap:24px;}
.brand{display:flex;align-items:center;gap:12px;}
.brand img{height:52px;width:auto;}.brand-text{display:none;}
.brand-name{font-family:'Klee One',serif;font-size:22px;color:var(--pink-deep);font-weight:600;line-height:1;}
.brand-tagline{font-size:11px;color:var(--text-soft);margin-top:4px;letter-spacing:0.05em;}
nav.gnav{display:flex;align-items:center;margin-left:auto;gap:2px;flex-wrap:nowrap;}
nav.gnav a{font-size:13.5px;color:#C47585;font-weight:500;padding:8px 12px;letter-spacing:0;transition:color .2s;position:relative;}
nav.gnav a:hover{color:#A9C49A;font-weight:700;text-shadow:0 0 0.5px currentColor;}
nav.gnav a.current{color:var(--pink-deep);font-weight:700;}
nav.gnav a.current::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--pink);border-radius:1px;}
.btn-cta{display:inline-flex;align-items:center;gap:8px;background:var(--pink);color:#fff !important;padding:11px 22px;border-radius:30px;font-size:14px;font-weight:500;transition:all .25s;box-shadow:0 4px 14px rgba(216,139,156,0.25);}
header .btn-cta{margin-left:8px;}
.btn-cta:hover{background:#A9C49A;transform:translateY(-1px);box-shadow:0 6px 18px rgba(216,139,156,0.35);}
header .btn-cta:hover{background:#A9C49A;color:#fff;text-shadow:none;}
.btn-cta::after{content:"›";font-size:18px;line-height:1;}

.page-head{background:linear-gradient(180deg,var(--cream) 0%,#FCEFE8 100%);padding:60px 0 56px;text-align:center;}
.page-head h1{font-size:34px;font-weight:500;color:var(--text);line-height:1.5;letter-spacing:0.04em;margin-bottom:14px;}
.page-head h1 .em{color:var(--pink-deep);}
.page-head .lead{font-size:14px;color:var(--text-soft);}

.policy-content{padding:64px 0 90px;}
.policy-wrap{max-width:760px;margin:0 auto;padding:0 24px;}
.policy-card{background:#fff;border-radius:18px;padding:48px 52px 40px;box-shadow:0 4px 24px rgba(196,117,133,0.06);}
.policy-intro{font-size:14.5px;color:var(--text);line-height:2.0;margin-bottom:36px;padding-bottom:30px;border-bottom:1px dashed var(--line);}
.policy-card h2{font-size:18px;color:var(--pink-deep);letter-spacing:0.05em;margin:32px 0 12px;display:flex;align-items:center;gap:10px;}
.policy-card h2::before{content:"";width:5px;height:18px;background:var(--pink);border-radius:2px;}
.policy-card h2:first-of-type{margin-top:0;}
.policy-card p{font-size:14px;color:var(--text);line-height:2.0;margin-bottom:14px;}
.policy-card ul{list-style:none;padding:0;margin:8px 0 14px;}
.policy-card ul li{font-size:13.5px;color:var(--text);line-height:1.95;padding-left:18px;position:relative;margin-bottom:4px;}
.policy-card ul li::before{content:"●";color:var(--pink-soft);position:absolute;left:0;top:0;font-size:7px;line-height:3.2;}
.policy-card a{color:var(--pink-deep);font-weight:600;text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px;}
.policy-meta{margin-top:36px;padding-top:24px;border-top:1px dashed var(--line);text-align:right;font-size:12.5px;color:var(--text-soft);font-family:'Klee One',serif;letter-spacing:0.05em;}

footer{background:var(--cream);border-top:1px solid var(--line);padding:30px 0 28px;}
.footer-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:24px;max-width:1240px;margin:0 auto;padding:0 40px;}
.footer-brand{display:flex;align-items:center;gap:10px;}
.footer-brand img{height:34px;width:auto;}.footer-brand .name{display:none;}
.footer-brand .name{font-family:'Klee One',serif;color:var(--pink-deep);font-size:17px;font-weight:600;}
.footer-brand .tag{font-size:11px;color:var(--text-soft);margin-left:8px;}
.footer-nav{display:flex;gap:24px;flex-wrap:wrap;}
.footer-nav a{font-size:13px;color:var(--text-soft);}
.footer-nav a:hover{color:var(--pink-deep);}
.copyright{text-align:center;font-size:11px;color:var(--text-soft);margin-top:24px;padding-top:18px;border-top:1px solid var(--line);}

@media (max-width:780px){
  .page-head{padding:44px 18px 40px;}
  .page-head h1{font-size:23px;}
  .policy-content{padding:36px 0 64px;}
  .policy-wrap{padding:0 16px;}
  .policy-card{padding:28px 24px 24px;border-radius:12px;}
  .policy-intro{font-size:13px;margin-bottom:24px;padding-bottom:20px;}
  .policy-card h2{font-size:15.5px;margin:22px 0 8px;}
  .policy-card p{font-size:13px;}
  .policy-card ul li{font-size:12.5px;}
  .policy-meta{font-size:11.5px;}
}
@media (max-width:860px){
  header .header-inner{padding:10px 16px;gap:12px;}
  .brand img{height:42px;}
  nav.gnav{gap:0;}
  nav.gnav a:not(.btn-cta){display:none;}
  header .btn-cta,nav.gnav a.btn-cta{padding:9px 16px;font-size:13px;margin-left:0;}
  .footer-inner{flex-direction:column;text-align:center;padding:0 24px;gap:18px;}
  .footer-brand{justify-content:center;flex-wrap:wrap;}
  .footer-nav{justify-content:center;}
}

/* =========================================================
   ページ固有：LP制作（甲府）（lp.html）
   ========================================================= */
:root{--pink:#D88B9C;--pink-deep:#C47585;--pink-soft:#F4D4DC;--pink-bg:#FBE9EE;--cream:#FFF8F2;--cream-2:#FAF1E8;--text:#5C4F4A;--text-soft:#8A7A73;--green:#A9C49A;--green-deep:#8AAC7A;--line:#EBDDD3;}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'Noto Sans JP','Hiragino Kaku Gothic ProN','Hiragino Sans',sans-serif;color:var(--text);background:var(--cream);font-size:15px;line-height:1.9;-webkit-font-smoothing:antialiased;}
h1,h2,h3,h4,h5,h6{font-family:'Zen Maru Gothic','Hiragino Maru Gothic ProN',sans-serif;}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
.container{max-width:1180px;margin:0 auto;padding:0 32px;}
.narrow{max-width:880px;margin:0 auto;padding:0 32px;}

header{position:sticky;top:0;z-index:100;background:rgba(255,248,242,0.92);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-bottom:1px solid rgba(235,221,211,0.4);}
.header-inner{display:flex;align-items:center;padding:14px 24px;max-width:none;margin:0 auto;gap:24px;}
.brand{display:flex;align-items:center;gap:12px;}
.brand img{height:52px;width:auto;}.brand-text{display:none;}
.brand-text .brand-name{font-family:'Klee One',serif;font-size:22px;color:var(--pink-deep);font-weight:600;line-height:1;}
.brand-text .brand-tagline{font-size:11px;color:var(--text-soft);margin-top:4px;letter-spacing:0.05em;}
nav.gnav{display:flex;align-items:center;margin-left:auto;gap:2px;flex-wrap:nowrap;}
nav.gnav a{font-size:13.5px;color:#C47585;font-weight:500;padding:8px 12px;letter-spacing:0;transition:color .2s;position:relative;}
nav.gnav a:hover{color:#A9C49A;font-weight:700;text-shadow:0 0 0.5px currentColor;}
.btn-cta{display:inline-flex;align-items:center;gap:8px;background:var(--pink);color:#fff !important;padding:11px 22px;border-radius:30px;font-size:14px;font-weight:500;transition:all .25s;box-shadow:0 4px 14px rgba(216,139,156,0.25);}
header .btn-cta{margin-left:8px;}
.btn-cta:hover{background:#A9C49A;transform:translateY(-1px);box-shadow:0 6px 18px rgba(216,139,156,0.35);}
header .btn-cta:hover{background:#A9C49A;color:#fff;text-shadow:none;}
.btn-cta::after{content:"›";font-size:18px;line-height:1;}

/* ===== HERO ===== */
.hero{background:linear-gradient(180deg,var(--cream) 0%,#FCEFE8 100%);padding:48px 0 44px;position:relative;overflow:hidden;}
.hero.hero-with-fv{padding:0 0 36px;background:transparent;}
.hero-fv-wrap{width:100%;max-width:1400px;margin:0 auto;}
.hero-fv-image{width:100%;height:auto;display:block;}
.hero-inner-compact{padding-top:28px;}
.hero-inner{max-width:980px;margin:0 auto;padding:0 40px;text-align:center;}
.hero-facts{display:flex;justify-content:center;gap:0;flex-wrap:wrap;max-width:680px;margin:0 auto 28px;background:#fff;border-radius:14px;box-shadow:0 4px 18px rgba(196,117,133,0.08);overflow:hidden;}
.hero-fact{flex:1;min-width:160px;padding:18px 16px;border-right:1px solid var(--line);text-align:center;}
.hero-fact:last-child{border-right:none;}
.hero-fact-label{font-size:11px;color:var(--text-soft);letter-spacing:0.1em;margin-bottom:6px;}
.hero-fact-value{font-size:17px;font-weight:600;color:var(--pink-deep);font-family:'Klee One',serif;line-height:1.4;}
.hero-fact-value .small{font-size:13px;font-weight:400;color:var(--text-soft);margin-left:2px;}
.hero-actions{display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap;}
.hero-handnote{font-family:'Klee One',serif;font-size:13px;color:var(--pink-deep);display:inline-flex;align-items:center;gap:6px;line-height:1.6;}
.hero-handnote::before{content:"〈";color:var(--pink);}
.hero-handnote::after{content:"〉";color:var(--pink);}

.hero-image-test{max-width:1400px;margin:32px auto;text-align:center;}
.hero-image-test img{width:100%;aspect-ratio:16/6;object-fit:cover;object-position:center bottom;border-radius:14px;box-shadow:0 4px 18px rgba(196,117,133,0.10);}

/* ===== 共通 ===== */
section.block{padding:52px 0;}
.section-title{text-align:center;font-size:26px;font-weight:500;color:var(--text);margin-bottom:30px;letter-spacing:0.05em;line-height:1.7;}
.section-title::after{content:"";display:block;width:46px;height:2px;background:var(--pink);margin:14px auto 0;}
.section-lead{text-align:center;font-size:14.5px;color:var(--text-soft);line-height:2.0;max-width:680px;margin:-12px auto 28px;}

/* ===== REASONS ===== */
.reasons{background:var(--cream-2);}
.reasons-wrap{background:#fff;border-radius:18px;padding:36px 36px 32px;box-shadow:0 4px 24px rgba(196,117,133,0.06);max-width:880px;margin:0 auto;}
.reasons-list{display:flex;flex-direction:column;gap:14px;}
.reason-item{display:flex;align-items:flex-start;gap:18px;padding:16px 20px;background:var(--cream);border-radius:12px;}
.reason-icon{flex-shrink:0;width:40px;height:40px;background:var(--pink-soft);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--pink-deep);font-weight:600;font-family:'Klee One',serif;font-size:15px;}
.reason-text{font-size:15px;line-height:1.95;color:var(--text);}
.reason-text .em{color:var(--pink-deep);font-weight:600;}

/* ===== SOLUTION ===== */
.solution{background:var(--cream);}
.solution-wrap{max-width:880px;margin:0 auto;text-align:center;}
.solution-lead{font-size:17px;line-height:2.1;color:var(--text);margin-bottom:20px;}
.solution-lead .em{color:var(--pink-deep);font-weight:600;}
.solution-sub{font-size:14.5px;color:var(--text-soft);line-height:2.0;max-width:680px;margin:0 auto;}

/* ===== BENEFITS ===== */
.benefits{background:var(--cream-2);}
.benefits-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;max-width:880px;margin:0 auto;}
.benefit-card{background:#fff;border-radius:14px;padding:26px 24px;box-shadow:0 3px 14px rgba(196,117,133,0.06);display:flex;gap:18px;align-items:flex-start;}
.benefit-num{flex-shrink:0;width:32px;height:32px;background:var(--pink);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Klee One',serif;font-size:14px;font-weight:600;}
.benefit-body{flex:1;}
.benefit-title{font-size:16px;font-weight:600;color:var(--pink-deep);margin-bottom:6px;line-height:1.6;}
.benefit-desc{font-size:13.5px;color:var(--text-soft);line-height:1.95;}

/* ===== RECOMMEND ===== */
.recommend{background:var(--cream);}
.recommend-wrap{max-width:780px;margin:0 auto;}
.recommend-list{display:flex;flex-direction:column;gap:12px;}
.recommend-item{background:#fff;border-radius:12px;padding:16px 24px 16px 56px;position:relative;font-size:15px;color:var(--text);line-height:1.85;box-shadow:0 2px 10px rgba(196,117,133,0.05);}
.recommend-item::before{content:"◎";position:absolute;left:22px;top:16px;color:var(--pink-deep);font-size:18px;font-weight:600;}

/* ===== CTA-BAR ===== */
.cta-bar{background:linear-gradient(180deg,#FCEFE8 0%,var(--pink-bg) 100%);padding:32px 0;}
.cta-bar-inner{max-width:880px;margin:0 auto;padding:0 32px;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;}
.cta-bar-text{flex:1;min-width:240px;}
.cta-bar-title{font-size:18px;font-weight:600;color:var(--text);margin-bottom:6px;line-height:1.6;}
.cta-bar-sub{font-size:13px;color:var(--text-soft);line-height:1.7;}
.cta-bar-actions{display:flex;gap:12px;flex-wrap:wrap;}
.cta-button{display:inline-flex;align-items:center;gap:10px;background:var(--pink);color:#fff !important;padding:14px 30px;border-radius:30px;font-size:14.5px;font-weight:600;box-shadow:0 6px 18px rgba(216,139,156,0.3);transition:all .25s;}
.cta-button:hover{background:var(--pink-deep);transform:translateY(-1px);box-shadow:0 8px 22px rgba(216,139,156,0.4);}
.cta-button::after{content:"›";font-size:18px;}

/* ===== THREE ===== */
.three{background:var(--cream-2);}
.three-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1080px;margin:0 auto;}
.three-card{background:#fff;border-radius:14px;padding:32px 26px 28px;box-shadow:0 3px 16px rgba(180,120,100,0.07);position:relative;}
.three-num{position:absolute;top:-14px;left:24px;width:36px;height:36px;background:var(--pink);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Klee One',serif;font-size:16px;font-weight:600;box-shadow:0 4px 12px rgba(216,139,156,0.3);}
.three-name{font-size:18px;font-weight:700;color:var(--pink-deep);margin:6px 0 14px;line-height:1.6;}
.three-desc{font-size:14px;color:var(--text-soft);line-height:2.0;}

/* ===== COMPARE ===== */
.compare{background:var(--cream);}
.compare-wrap{max-width:880px;margin:0 auto;overflow-x:auto;}
.compare-table{width:100%;border-collapse:separate;border-spacing:0;background:#fff;border-radius:14px;overflow:hidden;box-shadow:0 4px 24px rgba(196,117,133,0.06);}
.compare-table th,.compare-table td{padding:18px 20px;text-align:left;font-size:13.5px;line-height:1.85;border-bottom:1px solid var(--line);vertical-align:top;}
.compare-table th{background:var(--cream-2);font-weight:600;color:var(--text);white-space:nowrap;}
.compare-table thead th{font-size:13px;letter-spacing:0.04em;text-align:center;}
.compare-table thead th.col-momo{background:var(--pink-bg);color:var(--pink-deep);}
.compare-table td.col-momo{background:rgba(251,233,238,0.4);color:var(--text);font-weight:500;}
.compare-table tr:last-child th,.compare-table tr:last-child td{border-bottom:none;}

/* ===== CASE ===== */
.case{background:var(--cream-2);}
.case-wrap{background:#fff;border-radius:18px;padding:36px 36px;max-width:880px;margin:0 auto;box-shadow:0 4px 24px rgba(196,117,133,0.06);}
.case-thumb{width:100%;aspect-ratio:3/2;background-image:url('assets/images/6iq838.jpg');background-size:cover;background-position:center;background-color:var(--cream-2);border-radius:10px;margin-bottom:20px;position:relative;box-shadow:0 4px 14px rgba(180,120,100,0.10);}
.case-thumb-caption{font-family:'Klee One',serif;font-size:12.5px;color:var(--text-soft);text-align:center;margin:-8px 0 18px;letter-spacing:0.05em;}
.case-head{text-align:center;margin-bottom:24px;}
.case-eyebrow{display:inline-block;font-size:12px;color:var(--pink-deep);letter-spacing:0.15em;background:var(--pink-bg);padding:5px 14px;border-radius:20px;margin-bottom:14px;}
.case-name{font-size:20px;font-weight:600;color:var(--text);line-height:1.7;}
.case-name .sub{display:block;font-size:13px;color:var(--text-soft);font-weight:400;margin-top:6px;letter-spacing:0.04em;}
.case-body{font-size:14.5px;line-height:2.0;color:var(--text);}
.case-body p{margin-bottom:14px;}
.case-thumb-link{display:block;text-decoration:none;color:inherit;}
.case-thumb-link .case-thumb{transition:all .25s;}
.case-thumb-link:hover .case-thumb{box-shadow:0 8px 24px rgba(180,120,100,0.20);transform:translateY(-2px);}
.case-thumb-link:hover .case-thumb-caption{color:var(--pink-deep);}
.case-cta{text-align:center;margin-top:20px;}
.case-cta-link{display:inline-flex;align-items:center;gap:6px;color:var(--pink-deep);border-bottom:1px solid var(--pink-soft);padding:6px 0;font-size:14px;font-weight:600;transition:all .25s;}
.case-cta-link:hover{color:var(--pink);border-color:var(--pink);}

/* ===== FLOW ===== */
.flow{background:var(--cream-2);}
.flow-list{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:0;position:relative;}
.flow-step{display:flex;gap:24px;align-items:flex-start;padding:20px 0;position:relative;}
.flow-step:not(:last-child)::after{content:"";position:absolute;left:29px;top:74px;bottom:-8px;width:2px;background:var(--pink-soft);}
.flow-num{flex-shrink:0;width:60px;height:60px;background:#fff;border:2px solid var(--pink);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--pink-deep);font-family:'Klee One',serif;font-size:20px;font-weight:600;box-shadow:0 4px 14px rgba(216,139,156,0.15);z-index:1;}
.flow-body{flex:1;padding-top:6px;}
.flow-title{font-size:17px;font-weight:600;color:var(--text);margin-bottom:8px;}
.flow-desc{font-size:14px;color:var(--text-soft);line-height:1.95;}

/* ===== PRICING ===== */
.pricing{background:var(--cream);}
.pricing-card{background:#fff;border-radius:18px;padding:36px 36px;max-width:720px;margin:0 auto;box-shadow:0 4px 24px rgba(196,117,133,0.06);text-align:center;border:1px solid var(--line);}
.pricing-name{font-size:18px;font-weight:600;color:var(--pink-deep);margin-bottom:10px;letter-spacing:0.04em;}
.pricing-price{font-size:36px;font-weight:500;color:var(--text);letter-spacing:0.04em;margin-bottom:6px;}
.pricing-price .yen{font-size:20px;color:var(--text-soft);margin-left:2px;}
.pricing-tax{font-size:12px;color:var(--text-soft);margin-bottom:24px;}
.pricing-divider{width:46px;height:2px;background:var(--pink-soft);margin:0 auto 22px;}
.pricing-includes-title{font-size:13.5px;font-weight:600;color:var(--text);margin-bottom:14px;letter-spacing:0.06em;}
.pricing-includes{display:flex;flex-direction:column;gap:10px;text-align:left;max-width:480px;margin:0 auto;}
.pricing-includes li{list-style:none;font-size:14px;color:var(--text);padding-left:24px;position:relative;line-height:1.8;}
.pricing-includes li::before{content:"";position:absolute;left:0;top:7px;width:14px;height:14px;border:1.5px solid var(--pink);border-radius:3px;background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 14'><polyline points='3,7 6,10 11,4' fill='none' stroke='%23D88B9C' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/></svg>") center/10px no-repeat;}
.pricing-note{font-size:12.5px;color:var(--text-soft);margin-top:20px;line-height:1.85;text-align:left;max-width:480px;margin-left:auto;margin-right:auto;}

/* ===== PROFILE ===== */
.profile{background:var(--cream-2);}
.profile-wrap{max-width:780px;margin:0 auto;background:#fff;border-radius:18px;padding:36px 32px;box-shadow:0 4px 24px rgba(196,117,133,0.06);display:flex;gap:32px;align-items:flex-start;}
.profile-photo{flex-shrink:0;width:140px;height:140px;background-image:url('assets/images/profile.jpg');background-size:cover;background-position:60% 35%;background-color:var(--pink-bg);border-radius:50%;border:3px solid #fff;box-shadow:0 4px 14px rgba(196,117,133,0.15);}
.profile-body{flex:1;}
.profile-name{font-size:20px;font-weight:600;color:var(--pink-deep);margin-bottom:6px;}
.profile-role{font-size:13px;color:var(--text-soft);margin-bottom:16px;letter-spacing:0.04em;}
.profile-text{font-size:14px;color:var(--text);line-height:2.0;margin-bottom:14px;}
.profile-link{display:inline-flex;align-items:center;gap:8px;margin-top:22px;background:var(--pink-bg);color:var(--pink-deep);padding:12px 28px;border-radius:24px;font-size:13.5px;font-weight:600;border:1px solid var(--pink-soft);transition:all .25s;box-shadow:0 2px 8px rgba(216,139,156,0.10);text-decoration:none;}
.profile-link::after{content:"›";font-size:18px;line-height:1;color:var(--pink-deep);transition:color .25s;}
.profile-link:hover{background:var(--pink);color:#fff;border-color:var(--pink);transform:translateY(-1px);box-shadow:0 6px 18px rgba(216,139,156,0.30);}
.profile-link:hover::after{color:#fff;}

/* ===== FAQ ===== */
.faq{background:var(--cream);}
.faq-list{max-width:780px;margin:0 auto;display:flex;flex-direction:column;gap:12px;}
.faq-item{background:#fff;border-radius:12px;box-shadow:0 2px 10px rgba(196,117,133,0.05);overflow:hidden;}
.faq-q{padding:18px 24px;font-size:15px;font-weight:600;color:var(--text);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px;list-style:none;line-height:1.6;}
.faq-q::-webkit-details-marker{display:none;}
.faq-q::after{content:"+";flex-shrink:0;color:var(--pink-deep);font-size:22px;font-weight:400;transition:transform .25s;}
.faq-item[open] .faq-q::after{transform:rotate(45deg);}
.faq-a{padding:0 24px 20px;font-size:14px;color:var(--text-soft);line-height:2.0;}
.faq-q-label{font-family:'Klee One',serif;color:var(--pink-deep);margin-right:10px;font-size:14px;}

/* ===== CTA-BLOCK（最終CTA・お問い合わせフォーム） ===== */
.cta-block{background:linear-gradient(180deg,#FCEFE8 0%,var(--pink-bg) 100%);padding:56px 0;}
.cta-inner{max-width:640px;margin:0 auto;padding:0 32px;text-align:center;}
.cta-inner-wide{max-width:1400px;padding:0;}
.cta-final-image{max-width:1400px;width:100%;margin:0 auto 28px;display:block;}
.cta-form-wrap{max-width:1400px;width:100%;margin:0 auto;padding:0;}
.cta-form-wrap .mmt-contact-page{padding:0 !important;background:transparent !important;}

/* ローカル確認用フォームプレースホルダー */
.local-form-placeholder{background:#fff;border-radius:14px;padding:32px 32px;box-shadow:0 4px 18px rgba(196,117,133,0.08);text-align:left;}
.local-form-placeholder .form-row{display:flex;flex-direction:column;gap:6px;margin-bottom:18px;}
.local-form-placeholder label{font-size:13px;color:var(--text);font-weight:600;}
.local-form-placeholder input,.local-form-placeholder textarea{font-family:inherit;font-size:14px;color:var(--text);padding:12px 14px;border:1px solid var(--line);border-radius:8px;background:var(--cream);outline:none;}
.local-form-placeholder textarea{min-height:120px;resize:vertical;}
.local-form-placeholder .form-submit{text-align:center;margin-top:8px;}
.local-form-placeholder .form-submit button{font-family:inherit;background:var(--pink);color:#fff;border:none;padding:14px 40px;border-radius:30px;font-size:15px;font-weight:600;cursor:pointer;box-shadow:0 6px 18px rgba(216,139,156,0.3);}
.local-form-placeholder .form-note{text-align:center;font-size:11px;color:var(--text-soft);margin-top:14px;letter-spacing:0.04em;}

/* ===== FOOTER ===== */
footer{background:var(--cream);border-top:1px solid var(--line);padding:30px 0 28px;}
.footer-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:24px;max-width:1240px;margin:0 auto;padding:0 40px;}
.footer-brand{display:flex;align-items:center;gap:10px;}
.footer-brand img{height:34px;width:auto;}.footer-brand .name{display:none;}
.footer-brand .name{font-family:'Klee One',serif;color:var(--pink-deep);font-size:17px;font-weight:600;}
.footer-brand .tag{font-size:11px;color:var(--text-soft);margin-left:8px;}
.footer-nav{display:flex;gap:24px;flex-wrap:wrap;}
.footer-nav a{font-size:13px;color:var(--text-soft);}
.footer-nav a:hover{color:var(--pink-deep);}
.footer-actions{display:flex;gap:10px;}
.footer-btn{border:1px solid var(--line);color:var(--text-soft);padding:8px 18px;border-radius:30px;font-size:12.5px;background:#fff;}
.footer-btn:hover{border-color:var(--pink);color:var(--pink-deep);}
.copyright{text-align:center;font-size:11px;color:var(--text-soft);margin-top:24px;padding-top:18px;border-top:1px solid var(--line);}

@media (max-width:860px){
  .hero{padding:36px 0 30px;}
  .hero-fact{min-width:140px;padding:14px 12px;border-right:none;border-bottom:1px solid var(--line);}
  .hero-fact:last-child{border-bottom:none;}
  .three-grid{grid-template-columns:1fr;}
  .benefits-grid{grid-template-columns:1fr;}
  nav.gnav{display:none;}
  .pricing-card{padding:30px 22px;}
  .case-wrap{padding:28px 22px;}
  .reasons-wrap{padding:28px 22px;}
  .profile-wrap{flex-direction:column;align-items:center;padding:28px 22px;}
  .profile-body{text-align:left;width:100%;}
  .profile-name,.profile-role{text-align:center;}
  .compare-wrap{padding:0 12px;}
  .compare-table th,.compare-table td{padding:14px 12px;font-size:12.5px;}
  .flow-step{gap:16px;}
  .flow-num{width:50px;height:50px;font-size:17px;}
  .flow-step:not(:last-child)::after{left:24px;top:62px;}
  .cta-bar-inner{flex-direction:column;text-align:center;}
  section.block{padding:40px 0;}
  .local-form-placeholder{padding:24px 20px;}
  .pc-only{display:none !important;}
}
br.pc-only{display:inline;}
@media screen and (max-width:1024px){br.pc-only,.pc-only{display:none !important;}}
/* ===== SP共通（2026-05-20統一） ===== */
@media (max-width:860px){
  header .header-inner{padding:10px 16px;gap:12px;}
  .brand img{height:42px;}
  nav.gnav{gap:0;}
  nav.gnav a:not(.btn-cta){display:none;}
  header .btn-cta,nav.gnav a.btn-cta{padding:9px 16px;font-size:13px;margin-left:0;}
  .footer-inner{flex-direction:column;text-align:center;padding:0 24px;gap:18px;}
  .footer-brand{justify-content:center;flex-wrap:wrap;}
  .footer-nav{justify-content:center;}
}

/* =========================================================
   ページ固有：LP制作（甲府・単発）（lp-imasugu.html）
   ========================================================= */
:root{
  --pink:#D88B9C;
  --pink-deep:#C47585;
  --pink-soft:#F4D4DC;
  --pink-bg:#FBE9EE;
  --cream:#FFF8F2;
  --cream-2:#FAF1E8;
  --text:#5C4F4A;
  --text-soft:#8A7A73;
  --green:#A9C49A;
  --green-deep:#8AAC7A;
  --line:#EBDDD3;
}

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

html{scroll-behavior:smooth;}
body{
  font-family:'Noto Sans JP','Hiragino Kaku Gothic ProN','Hiragino Sans',sans-serif;
  color:var(--text);
  background:var(--cream);
  font-size:15px;
  line-height:1.9;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4,h5,h6{font-family:'Zen Maru Gothic','Hiragino Maru Gothic ProN',sans-serif;}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}

.container{max-width:1180px;margin:0 auto;padding:0 32px;}
.narrow{max-width:880px;margin:0 auto;padding:0 32px;}

/* ===== HEADER ===== */
header{
  position:sticky;top:0;z-index:100;
  background:rgba(255,248,242,0.92);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  border-bottom:1px solid rgba(235,221,211,0.4);
}
.header-inner{
  display:flex;align-items:center;
  padding:14px 24px;
  max-width:none;margin:0 auto;gap:24px;
}
.brand{display:flex;align-items:center;gap:12px;}
.brand img{height:52px;width:auto;}.brand-text{display:none;}
.brand-text .brand-name{
  font-family:'Klee One',serif;
  font-size:22px;color:var(--pink-deep);font-weight:600;line-height:1;
}
.brand-text .brand-tagline{
  font-size:11px;color:var(--text-soft);margin-top:4px;letter-spacing:0.05em;
}
nav.gnav{display:flex;align-items:center;margin-left:auto;gap:2px;flex-wrap:nowrap;}
nav.gnav a{
  font-size:13.5px;color:#C47585;font-weight:500;
  padding:8px 12px;letter-spacing:0;
  transition:color .2s;
  position:relative;
}
nav.gnav a:hover{color:#A9C49A;font-weight:700;text-shadow:0 0 0.5px currentColor;}
.btn-cta{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--pink);color:#fff !important;
  padding:11px 22px;border-radius:30px;
  font-size:14px;font-weight:500;
  transition:all .25s;
  box-shadow:0 4px 14px rgba(216,139,156,0.25);
}
header .btn-cta{margin-left:8px;}
.btn-cta:hover{background:#A9C49A;transform:translateY(-1px);box-shadow:0 6px 18px rgba(216,139,156,0.35);}
header .btn-cta:hover{background:#A9C49A;color:#fff;text-shadow:none;}
.btn-cta::after{content:"›";font-size:18px;line-height:1;}

/* ===== HERO ===== */
.hero{
  background:linear-gradient(180deg,var(--cream) 0%,#FCEFE8 100%);
  padding:70px 0 60px;
  position:relative;overflow:hidden;
}
.hero.hero-with-fv{
  padding:0 0 50px;
  background:transparent;
}
.hero-fv-wrap{
  width:100%;
  max-width:1400px;
  margin:0 auto;
}
.hero-fv-image{
  width:100%;
  height:auto;
  display:block;
}
.hero-inner-compact{
  padding-top:40px;
}
.cta-block-with-image{padding:60px 0;}
.cta-inner-wide{max-width:880px;}
.cta-final-image{
  width:100%;
  max-width:880px;
  display:block;
  margin:0 auto 32px;
  border-radius:14px;
  box-shadow:0 4px 18px rgba(196,117,133,0.10);
}
.pricing-banner{
  max-width:880px;
  margin:48px auto 0;
  text-align:center;
}
.pricing-banner img{
  width:100%;
  height:auto;
  display:block;
  border-radius:14px;
  box-shadow:0 4px 18px rgba(196,117,133,0.10);
}
.hero-inner{
  max-width:980px;margin:0 auto;padding:0 40px;
  text-align:center;
}
.hero-eyebrow{
  display:inline-block;
  font-family:'Klee One',serif;
  font-size:14px;color:var(--pink-deep);
  letter-spacing:0.1em;
  margin-bottom:24px;
  padding:6px 18px;
  background:rgba(255,255,255,0.7);
  border-radius:30px;
}
.hero h1{
  font-family:'Zen Maru Gothic',sans-serif;
  font-size:38px;font-weight:500;
  line-height:1.6;color:var(--text);
  letter-spacing:0.03em;
  margin-bottom:18px;
}
.hero h1 .em{color:var(--pink-deep);}
.hero h1 .small{
  display:block;
  font-size:26px;
  margin-top:14px;
  color:var(--text);
  font-weight:500;
}
.hero-lead{
  font-size:16px;line-height:2.1;color:var(--text-soft);
  margin:28px auto 32px;
  max-width:620px;
}
.hero-lead strong{color:var(--pink-deep);font-weight:600;}
.hero-facts{
  display:flex;justify-content:center;gap:0;flex-wrap:wrap;
  max-width:680px;margin:0 auto 36px;
  background:#fff;border-radius:14px;
  box-shadow:0 4px 18px rgba(196,117,133,0.08);
  overflow:hidden;
}
.hero-fact{
  flex:1;min-width:160px;
  padding:18px 16px;
  border-right:1px solid var(--line);
  text-align:center;
}
.hero-fact:last-child{border-right:none;}
.hero-fact-label{
  font-size:11px;color:var(--text-soft);
  letter-spacing:0.1em;margin-bottom:6px;
}
.hero-fact-value{
  font-size:17px;font-weight:600;color:var(--pink-deep);
  font-family:'Klee One',serif;
  line-height:1.4;
}
.hero-fact-value .small{font-size:13px;font-weight:400;color:var(--text-soft);margin-left:2px;}
.hero-actions{display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap;}
.hero-handnote{
  font-family:'Klee One',serif;
  font-size:13px;color:var(--pink-deep);
  display:inline-flex;align-items:center;gap:6px;
  line-height:1.6;
}
.hero-handnote::before{content:"〈";color:var(--pink);}
.hero-handnote::after{content:"〉";color:var(--pink);}

/* ===== IMAGE PLACEHOLDER（仮画像枠・後日差し替え） ===== */
.image-placeholder{
  width:100%;
  max-width:880px;
  margin:48px auto;
  aspect-ratio:16/7;
  background:linear-gradient(135deg,#FBE9EE 0%,#FCEFE8 50%,#F4D4DC 100%);
  border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 18px rgba(196,117,133,0.10);
  position:relative;
  overflow:hidden;
}
.image-placeholder::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 20% 30%, rgba(255,255,255,0.5) 0%, transparent 35%),
    radial-gradient(circle at 80% 70%, rgba(216,139,156,0.15) 0%, transparent 40%);
}
.placeholder-label{
  position:relative;
  font-family:'Klee One',serif;
  font-size:13px;
  color:var(--text-soft);
  padding:10px 22px;
  background:rgba(255,255,255,0.85);
  border-radius:24px;
  letter-spacing:0.05em;
  text-align:center;
  line-height:1.7;
  max-width:80%;
}
.placeholder-label .em{
  display:block;
  color:var(--pink-deep);
  font-size:14px;
  margin-bottom:4px;
}

/* ===== HERO直下：仮イメージ画像表示 ===== */
.hero-image-test{
  max-width:880px;
  margin:48px auto;
  text-align:center;
}
.hero-image-test img{
  width:100%;
  aspect-ratio:16/6;
  object-fit:cover;
  object-position:center bottom;
  border-radius:14px;
  box-shadow:0 4px 18px rgba(196,117,133,0.10);
}
.hero-image-note{
  font-family:'Klee One',serif;
  font-size:12px;
  color:var(--text-soft);
  margin-top:10px;
  letter-spacing:0.05em;
}

/* ===== SECTION COMMON ===== */
section.block{padding:70px 0;}
.section-title{
  text-align:center;
  font-size:26px;font-weight:500;
  color:var(--text);
  margin-bottom:42px;
  letter-spacing:0.05em;
  line-height:1.7;
}
.section-title::after{
  content:"";display:block;
  width:46px;height:2px;
  background:var(--pink);
  margin:14px auto 0;
}
.section-lead{
  text-align:center;
  font-size:14.5px;color:var(--text-soft);
  line-height:2.0;
  max-width:680px;margin:-20px auto 36px;
}

/* ===== REASONS（こんなときに頼ってください） ===== */
.reasons{background:var(--cream-2);}
.reasons-wrap{
  background:#fff;
  border-radius:18px;
  padding:44px 40px 40px;
  box-shadow:0 4px 24px rgba(196,117,133,0.06);
  max-width:880px;margin:0 auto;
}
.reasons-list{
  display:flex;flex-direction:column;gap:18px;
}
.reason-item{
  display:flex;align-items:flex-start;gap:18px;
  padding:18px 22px;
  background:var(--cream);
  border-radius:12px;
}
.reason-icon{
  flex-shrink:0;
  width:40px;height:40px;
  background:var(--pink-soft);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--pink-deep);
  font-weight:600;
  font-family:'Klee One',serif;
  font-size:15px;
}
.reason-text{font-size:15px;line-height:1.95;color:var(--text);}
.reason-text .em{color:var(--pink-deep);font-weight:600;}

/* ===== SOLUTION（解決方法） ===== */
.solution{background:var(--cream);}
.solution-wrap{
  max-width:880px;margin:0 auto;
  text-align:center;
}
.solution-lead{
  font-size:17px;line-height:2.1;color:var(--text);
  margin-bottom:24px;
}
.solution-lead .em{
  color:var(--pink-deep);font-weight:600;
}
.solution-sub{
  font-size:14.5px;color:var(--text-soft);
  line-height:2.0;
  max-width:680px;margin:0 auto;
}

/* ===== BENEFITS（得られる4つのこと） ===== */
.benefits{background:var(--cream-2);}
.benefits-grid{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:20px;
  max-width:880px;margin:0 auto;
}
.benefit-card{
  background:#fff;
  border-radius:14px;
  padding:28px 26px;
  box-shadow:0 3px 14px rgba(196,117,133,0.06);
  display:flex;gap:18px;align-items:flex-start;
}
.benefit-num{
  flex-shrink:0;
  width:32px;height:32px;
  background:var(--pink);color:#fff;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:'Klee One',serif;
  font-size:14px;font-weight:600;
}
.benefit-body{flex:1;}
.benefit-title{
  font-size:16px;font-weight:600;
  color:var(--pink-deep);
  margin-bottom:6px;
  line-height:1.6;
}
.benefit-desc{
  font-size:13.5px;color:var(--text-soft);
  line-height:1.95;
}

/* ===== RECOMMEND（こんな方におすすめ） ===== */
.recommend{background:var(--cream);}
.recommend-wrap{
  max-width:780px;margin:0 auto;
}
.recommend-list{
  display:flex;flex-direction:column;gap:14px;
}
.recommend-item{
  background:#fff;
  border-radius:12px;
  padding:18px 24px 18px 56px;
  position:relative;
  font-size:15px;color:var(--text);
  line-height:1.85;
  box-shadow:0 2px 10px rgba(196,117,133,0.05);
}
.recommend-item::before{
  content:"◎";
  position:absolute;left:22px;top:18px;
  color:var(--pink-deep);
  font-size:18px;
  font-weight:600;
}

/* ===== CTA INLINE BAR ===== */
.cta-bar{
  background:linear-gradient(180deg,#FCEFE8 0%,var(--pink-bg) 100%);
  padding:44px 0;
}
.cta-bar-inner{
  max-width:780px;margin:0 auto;padding:0 32px;
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;flex-wrap:wrap;
}
.cta-bar-text{
  flex:1;min-width:240px;
}
.cta-bar-title{
  font-size:18px;font-weight:600;color:var(--text);
  margin-bottom:6px;line-height:1.6;
}
.cta-bar-sub{
  font-size:13px;color:var(--text-soft);
  line-height:1.7;
}
.cta-bar-actions{
  display:flex;gap:12px;flex-wrap:wrap;
}
.cta-button{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--pink);
  color:#fff !important;
  padding:14px 30px;
  border-radius:30px;
  font-size:14.5px;font-weight:600;
  box-shadow:0 6px 18px rgba(216,139,156,0.3);
  transition:all .25s;
}
.cta-button:hover{
  background:var(--pink-deep);
  transform:translateY(-1px);
  box-shadow:0 8px 22px rgba(216,139,156,0.4);
}
.cta-button::after{content:"›";font-size:18px;}
.cta-button.sub{
  background:#fff;color:var(--pink-deep) !important;
  border:1.5px solid var(--pink);
  box-shadow:0 4px 12px rgba(216,139,156,0.15);
}
.cta-button.sub:hover{background:var(--pink-bg);}

/* ===== THREE（大事にしている3つ） ===== */
.three{background:var(--cream-2);}
.three-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:24px;
  max-width:1080px;margin:0 auto;
}
.three-card{
  background:#fff;
  border-radius:14px;
  padding:36px 28px 32px;
  box-shadow:0 3px 16px rgba(180,120,100,0.07);
  position:relative;
}
.three-num{
  position:absolute;top:-14px;left:24px;
  width:36px;height:36px;
  background:var(--pink);color:#fff;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:'Klee One',serif;
  font-size:16px;font-weight:600;
  box-shadow:0 4px 12px rgba(216,139,156,0.3);
}
.three-name{
  font-size:18px;font-weight:700;
  color:var(--pink-deep);
  margin:6px 0 16px;
  line-height:1.6;
}
.three-desc{
  font-size:14px;color:var(--text-soft);
  line-height:2.0;
}

/* ===== COMPARE（比較表） ===== */
.compare{background:var(--cream);}
.compare-wrap{
  max-width:880px;margin:0 auto;
  overflow-x:auto;
}
.compare-table{
  width:100%;
  border-collapse:separate;border-spacing:0;
  background:#fff;
  border-radius:14px;
  overflow:hidden;
  box-shadow:0 4px 24px rgba(196,117,133,0.06);
}
.compare-table th,
.compare-table td{
  padding:18px 20px;
  text-align:left;
  font-size:13.5px;
  line-height:1.85;
  border-bottom:1px solid var(--line);
  vertical-align:top;
}
.compare-table th{
  background:var(--cream-2);
  font-weight:600;
  color:var(--text);
  white-space:nowrap;
}
.compare-table thead th{
  font-size:13px;
  letter-spacing:0.04em;
  text-align:center;
}
.compare-table thead th.col-momo{
  background:var(--pink-bg);
  color:var(--pink-deep);
}
.compare-table td.col-momo{
  background:rgba(251,233,238,0.4);
  color:var(--text);
  font-weight:500;
}
.compare-table tr:last-child th,
.compare-table tr:last-child td{
  border-bottom:none;
}

/* ===== CASE（実例） ===== */
.case{background:var(--cream-2);}
.case-wrap{
  background:#fff;
  border-radius:18px;
  padding:44px 40px;
  max-width:880px;margin:0 auto;
  box-shadow:0 4px 24px rgba(196,117,133,0.06);
}
.case-thumb{
  width:100%;
  aspect-ratio:3/2;
  background-image:url('assets/images/case-abe-niwa-lp.jpg');
  background-size:cover;
  background-position:center;
  background-color:var(--cream-2);
  border-radius:10px;
  margin-bottom:24px;
  position:relative;
  box-shadow:0 4px 14px rgba(180,120,100,0.10);
}
.case-thumb-caption{
  font-family:'Klee One',serif;
  font-size:12.5px;color:var(--text-soft);
  text-align:center;
  margin:-12px 0 22px;
  letter-spacing:0.05em;
}
.case-head{
  text-align:center;
  margin-bottom:30px;
}
.case-eyebrow{
  display:inline-block;
  font-size:12px;color:var(--pink-deep);
  letter-spacing:0.15em;
  background:var(--pink-bg);
  padding:5px 14px;border-radius:20px;
  margin-bottom:14px;
}
.case-name{
  font-size:20px;font-weight:600;
  color:var(--text);
  line-height:1.7;
}
.case-name .sub{
  display:block;
  font-size:13px;color:var(--text-soft);
  font-weight:400;
  margin-top:6px;
  letter-spacing:0.04em;
}
.case-body{
  font-size:14.5px;
  line-height:2.0;
  color:var(--text);
}
.case-body p{margin-bottom:14px;}

/* ===== FLOW（流れ） ===== */
.flow{background:var(--cream-2);}
.flow-list{
  max-width:760px;margin:0 auto;
  display:flex;flex-direction:column;gap:0;
  position:relative;
}
.flow-step{
  display:flex;gap:24px;align-items:flex-start;
  padding:24px 0;
  position:relative;
}
.flow-step:not(:last-child)::after{
  content:"";
  position:absolute;
  left:29px;top:78px;bottom:-12px;
  width:2px;
  background:var(--pink-soft);
}
.flow-num{
  flex-shrink:0;
  width:60px;height:60px;
  background:#fff;
  border:2px solid var(--pink);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--pink-deep);
  font-family:'Klee One',serif;
  font-size:20px;font-weight:600;
  box-shadow:0 4px 14px rgba(216,139,156,0.15);
  z-index:1;
}
.flow-body{flex:1;padding-top:6px;}
.flow-title{
  font-size:17px;font-weight:600;
  color:var(--text);
  margin-bottom:8px;
}
.flow-desc{
  font-size:14px;color:var(--text-soft);
  line-height:1.95;
}

/* ===== PRICING（料金） ===== */
.pricing{background:var(--cream);}
.pricing-card{
  background:#fff;
  border-radius:18px;
  padding:44px 40px;
  max-width:720px;margin:0 auto;
  box-shadow:0 4px 24px rgba(196,117,133,0.06);
  text-align:center;
  border:1px solid var(--line);
}
.pricing-name{
  font-size:18px;font-weight:600;
  color:var(--pink-deep);
  margin-bottom:10px;
  letter-spacing:0.04em;
}
.pricing-price{
  font-size:36px;font-weight:500;
  color:var(--text);
  letter-spacing:0.04em;
  margin-bottom:6px;
}
.pricing-price .yen{font-size:20px;color:var(--text-soft);margin-left:2px;}
.pricing-tax{
  font-size:12px;color:var(--text-soft);
  margin-bottom:30px;
}
.pricing-divider{
  width:46px;height:2px;
  background:var(--pink-soft);
  margin:0 auto 26px;
}
.pricing-includes-title{
  font-size:13.5px;font-weight:600;
  color:var(--text);
  margin-bottom:14px;
  letter-spacing:0.06em;
}
.pricing-includes{
  display:flex;flex-direction:column;gap:10px;
  text-align:left;
  max-width:480px;margin:0 auto;
}
.pricing-includes li{
  list-style:none;
  font-size:14px;color:var(--text);
  padding-left:24px;
  position:relative;
  line-height:1.8;
}
.pricing-includes li::before{
  content:"";
  position:absolute;left:0;top:7px;
  width:14px;height:14px;
  border:1.5px solid var(--pink);border-radius:3px;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 14'><polyline points='3,7 6,10 11,4' fill='none' stroke='%23D88B9C' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/></svg>") center/10px no-repeat;
}
.pricing-note{
  font-size:12.5px;color:var(--text-soft);
  margin-top:24px;
  line-height:1.85;
  text-align:left;
  max-width:480px;margin-left:auto;margin-right:auto;
}

/* ===== PROFILE（制作する人について） ===== */
.profile{background:var(--cream-2);}
.profile-wrap{
  max-width:780px;margin:0 auto;
  background:#fff;
  border-radius:18px;
  padding:40px 36px;
  box-shadow:0 4px 24px rgba(196,117,133,0.06);
  display:flex;gap:32px;align-items:flex-start;
}
.profile-photo{
  flex-shrink:0;
  width:140px;height:140px;
  background-image:url('assets/images/profile.jpg');
  background-size:cover;
  background-position:60% 35%;
  background-color:var(--pink-bg);
  border-radius:50%;
  border:3px solid #fff;
  box-shadow:0 4px 14px rgba(196,117,133,0.15);
}
.profile-body{flex:1;}
.profile-name{
  font-size:20px;font-weight:600;
  color:var(--pink-deep);
  margin-bottom:6px;
}
.profile-role{
  font-size:13px;color:var(--text-soft);
  margin-bottom:18px;
  letter-spacing:0.04em;
}
.profile-text{
  font-size:14px;color:var(--text);
  line-height:2.0;
  margin-bottom:16px;
}
.profile-tags{
  display:flex;gap:8px;flex-wrap:wrap;
  margin-top:14px;
}
.profile-tag{
  font-family:'Klee One',serif;
  font-size:12px;
  color:var(--pink-deep);
  background:var(--pink-bg);
  padding:4px 12px;
  border-radius:20px;
}
.profile-link{
  display:inline-block;
  margin-top:18px;
  font-size:13px;
  color:var(--pink-deep);
  border-bottom:1px solid var(--pink-soft);
  padding-bottom:2px;
}
.profile-link:hover{color:var(--pink);border-color:var(--pink);}

/* ===== FAQ ===== */
.faq{background:var(--cream);}
.faq-list{
  max-width:780px;margin:0 auto;
  display:flex;flex-direction:column;gap:14px;
}
.faq-item{
  background:#fff;
  border-radius:12px;
  box-shadow:0 2px 10px rgba(196,117,133,0.05);
  overflow:hidden;
}
.faq-q{
  padding:20px 24px;
  font-size:15px;font-weight:600;
  color:var(--text);
  cursor:pointer;
  display:flex;justify-content:space-between;align-items:center;
  gap:16px;
  list-style:none;
  line-height:1.6;
}
.faq-q::-webkit-details-marker{display:none;}
.faq-q::after{
  content:"+";
  flex-shrink:0;
  color:var(--pink-deep);
  font-size:22px;font-weight:400;
  transition:transform .25s;
}
.faq-item[open] .faq-q::after{transform:rotate(45deg);}
.faq-a{
  padding:0 24px 22px;
  font-size:14px;color:var(--text-soft);
  line-height:2.0;
}
.faq-q-label{
  font-family:'Klee One',serif;
  color:var(--pink-deep);
  margin-right:10px;
  font-size:14px;
}

/* ===== FINAL CTA ===== */
.cta-block{
  background:linear-gradient(180deg,#FCEFE8 0%,var(--pink-bg) 100%);
  padding:80px 0;
}
.cta-inner{
  max-width:640px;margin:0 auto;padding:0 32px;
  text-align:center;
}
.cta-title{
  font-size:26px;font-weight:500;
  color:var(--text);
  margin-bottom:18px;
  letter-spacing:0.04em;
  line-height:1.7;
}
.cta-lead{
  font-size:14.5px;color:var(--text-soft);
  line-height:1.95;
  margin-bottom:32px;
}
.cta-final-actions{
  display:flex;justify-content:center;gap:14px;flex-wrap:wrap;
  margin-bottom:18px;
}
.cta-button-lg{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--pink);
  color:#fff !important;
  padding:16px 40px;
  border-radius:30px;
  font-size:15px;font-weight:600;
  box-shadow:0 6px 18px rgba(216,139,156,0.3);
  transition:all .25s;
}
.cta-button-lg:hover{
  background:var(--pink-deep);
  transform:translateY(-1px);
  box-shadow:0 8px 22px rgba(216,139,156,0.4);
}
.cta-button-lg::after{content:"›";font-size:18px;}
.cta-button-lg.sub{
  background:#fff;color:var(--pink-deep) !important;
  border:1.5px solid var(--pink);
  box-shadow:0 4px 12px rgba(216,139,156,0.15);
}
.cta-button-lg.sub:hover{background:var(--pink-bg);}
.cta-note{
  font-family:'Klee One',serif;
  font-size:13px;color:var(--pink-deep);
  margin-top:18px;
  line-height:1.7;
}

/* ===== FOOTER ===== */
footer{
  background:var(--cream);
  border-top:1px solid var(--line);
  padding:30px 0 28px;
}
.footer-inner{
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:24px;
  max-width:1240px;margin:0 auto;padding:0 40px;
}
.footer-brand{display:flex;align-items:center;gap:10px;}
.footer-brand img{height:34px;width:auto;}.footer-brand .name{display:none;}
.footer-brand .name{
  font-family:'Klee One',serif;
  color:var(--pink-deep);font-size:17px;font-weight:600;
}
.footer-brand .tag{
  font-size:11px;color:var(--text-soft);margin-left:8px;
}
.footer-nav{display:flex;gap:24px;flex-wrap:wrap;}
.footer-nav a{font-size:13px;color:var(--text-soft);}
.footer-nav a:hover{color:var(--pink-deep);}
.footer-actions{display:flex;gap:10px;}
.footer-btn{
  border:1px solid var(--line);
  color:var(--text-soft);
  padding:8px 18px;border-radius:30px;
  font-size:12.5px;
  background:#fff;
}
.footer-btn:hover{border-color:var(--pink);color:var(--pink-deep);}
.copyright{
  text-align:center;
  font-size:11px;color:var(--text-soft);
  margin-top:24px;
  padding-top:18px;
  border-top:1px solid var(--line);
}

/* ===== RESPONSIVE ===== */
@media (max-width:860px){
  .hero{padding:50px 0 40px;}
  .hero h1{font-size:28px;}
  .hero h1 .small{font-size:20px;}
  .hero-fact{min-width:140px;padding:14px 12px;border-right:none;border-bottom:1px solid var(--line);}
  .hero-fact:last-child{border-bottom:none;}
  .three-grid{grid-template-columns:1fr;}
  .benefits-grid{grid-template-columns:1fr;}
  nav.gnav{display:none;}
  .pricing-card{padding:36px 24px;}
  .case-wrap{padding:32px 24px;}
  .reasons-wrap{padding:36px 24px;}
  .profile-wrap{flex-direction:column;align-items:center;padding:32px 22px;}
  .profile-body{text-align:left;width:100%;}
  .profile-name,.profile-role{text-align:center;}
  .profile-tags{justify-content:center;}
  .compare-wrap{padding:0 12px;}
  .compare-table th,
  .compare-table td{padding:14px 12px;font-size:12.5px;}
  .flow-step{gap:16px;}
  .flow-num{width:50px;height:50px;font-size:17px;}
  .flow-step:not(:last-child)::after{left:24px;top:66px;}
  .cta-title{font-size:22px;}
  .cta-bar-inner{flex-direction:column;text-align:center;}
  section.block{padding:54px 0;}
}
/* ===== SP共通（2026-05-20統一） ===== */
@media (max-width:860px){
  header .header-inner{padding:10px 16px;gap:12px;}
  .brand img{height:42px;}
  nav.gnav{gap:0;}
  nav.gnav a:not(.btn-cta){display:none;}
  header .btn-cta,nav.gnav a.btn-cta{padding:9px 16px;font-size:13px;margin-left:0;}
  .footer-inner{flex-direction:column;text-align:center;padding:0 24px;gap:18px;}
  .footer-brand{justify-content:center;flex-wrap:wrap;}
  .footer-nav{justify-content:center;}
}

/* =========================================================
   ページ固有：ブログ一覧（blog.html）
   ========================================================= */
:root{
  --pink:#D88B9C;
  --pink-deep:#C47585;
  --pink-soft:#F4D4DC;
  --pink-bg:#FBE9EE;
  --cream:#FFF8F2;
  --cream-2:#FAF1E8;
  --text:#5C4F4A;
  --text-soft:#8A7A73;
  --green:#A9C49A;
  --line:#EBDDD3;
}

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

html{scroll-behavior:smooth;}
body{
  font-family:'Noto Sans JP','Hiragino Kaku Gothic ProN','Hiragino Sans',sans-serif;
  color:var(--text);
  background:var(--cream);
  font-size:15px;
  line-height:1.9;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4,h5,h6{font-family:'Zen Maru Gothic','Hiragino Maru Gothic ProN',sans-serif;}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}

.container{max-width:1180px;margin:0 auto;padding:0 32px;}

/* ===== HEADER（サイト全11ページ統一形態） ===== */
header{
  position:sticky;top:0;z-index:100;
  background:rgba(255,248,242,0.92);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  border-bottom:1px solid rgba(235,221,211,0.4);
}
.header-inner{
  display:flex;align-items:center;
  padding:14px 24px;
  max-width:none;gap:24px;
}
.brand{display:flex;align-items:center;gap:12px;}
.brand img{height:52px;width:auto;}.brand-text{display:none;}
.brand-text .brand-name{
  font-family:'Klee One',serif;
  font-size:22px;color:var(--pink-deep);font-weight:600;line-height:1;
}
.brand-text .brand-tagline{
  font-size:11px;color:var(--text-soft);margin-top:4px;letter-spacing:0.05em;
}
nav.gnav{display:flex;align-items:center;margin-left:auto;gap:2px;flex-wrap:nowrap;}
nav.gnav a{
  font-size:13.5px;color:#C47585;font-weight:500;
  padding:8px 12px;letter-spacing:0;
  transition:color .2s;
  position:relative;
}
nav.gnav a:hover{color:#A9C49A;font-weight:700;text-shadow:0 0 0.5px currentColor;}
nav.gnav a.current{color:var(--pink-deep);font-weight:700;}
nav.gnav a.current::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--pink);border-radius:1px;}

/* ===== BUTTON ===== */
.btn-cta,.btn-more,.btn-white{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:12px 28px;border-radius:30px;
  font-size:14px;font-weight:500;
  min-height:44px;
  line-height:1.4;
  transition:all .25s;
  white-space:nowrap;
}
.btn-cta::after,.btn-more::after,.btn-white::after{content:"›";font-size:18px;line-height:1;}
.btn-cta{
  background:var(--pink);color:#fff !important;
  box-shadow:0 4px 14px rgba(216,139,156,0.25);
}
.btn-cta:hover{background:#A9C49A;transform:translateY(-1px);box-shadow:0 6px 18px rgba(216,139,156,0.35);}
header .btn-cta{margin-left:8px;}
header .btn-cta:hover{background:#A9C49A;color:#fff;text-shadow:none;}

/* ===== ブログ一覧 PAGE HERO ===== */
.blog-hero{
  padding:60px 0 36px;
  text-align:center;
  background:linear-gradient(180deg,var(--cream) 0%,#FCEFE8 100%);
  border-bottom:1px solid rgba(235,221,211,0.4);
}
.blog-hero .eyebrow{
  font-family:'Klee One',serif;
  color:var(--pink-deep);
  letter-spacing:0.32em;
  font-size:12.5px;
  margin-bottom:14px;
}
.blog-hero h1{
  font-family:'Zen Maru Gothic',sans-serif;
  font-weight:500;
  font-size:32px;
  color:var(--text);
  letter-spacing:0.06em;
  line-height:1.45;
  margin-bottom:18px;
}
.blog-hero h1::after{
  content:"";display:block;
  width:46px;height:2px;
  background:var(--pink);
  margin:18px auto 0;
}
.blog-hero .lead{
  max-width:580px;
  margin:24px auto 0;
  font-size:14px;line-height:2.0;
  color:var(--text-soft);
}

/* ===== ブログ一覧 ===== */
.blog-list-wrap{
  max-width:760px;
  margin:0 auto;
  padding:56px 32px 40px;
}

/* 記事カード（アイキャッチつき・1カラム・カード型） */
.post-list{
  display:flex;
  flex-direction:column;
  gap:32px;
}
.post-card{
  display:block;
  background:#fff;
  border-radius:14px;
  overflow:hidden;
  box-shadow:0 3px 14px rgba(196,117,133,0.08);
  text-decoration:none;
  color:inherit;
  transition:transform .25s, box-shadow .25s;
}
.post-card:hover{
  transform:translateY(-3px);
  box-shadow:0 10px 28px rgba(196,117,133,0.14);
}
.post-card-thumb{
  width:100%;
  aspect-ratio:16/9;
  background-color:var(--cream-2);
  background-size:cover;
  background-position:center;
  display:block;
}
.post-card-body{
  padding:24px 26px 26px;
}
.post-card-meta{
  display:flex;
  gap:12px;
  align-items:center;
  margin-bottom:10px;
  font-size:12px;
  color:var(--text-soft);
}
.post-card-meta .cat{
  color:var(--pink-deep);
  font-weight:500;
  background:var(--pink-bg);
  padding:3px 10px;
  border-radius:30px;
  font-size:11.5px;
  letter-spacing:0.04em;
}
.post-card-meta .date{
  font-family:'Klee One',serif;
  letter-spacing:0.06em;
}
.post-card-title{
  font-family:'Zen Maru Gothic',sans-serif;
  font-weight:500;
  font-size:19px;
  line-height:1.6;
  color:var(--text);
  margin:0 0 10px;
  letter-spacing:0.03em;
  transition:color .2s;
}
.post-card:hover .post-card-title{color:var(--pink-deep);}
.post-card-excerpt{
  font-size:13.5px;
  color:var(--text-soft);
  line-height:1.95;
  margin:0;
  display:-webkit-box;
  -webkit-line-clamp:3;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

/* ===== ページネーション（丸ボタン） ===== */
.pagination{
  display:flex;
  justify-content:center;
  gap:8px;
  margin-top:56px;
  flex-wrap:wrap;
}
.pagination a,.pagination span{
  display:inline-flex;
  align-items:center;justify-content:center;
  min-width:40px;height:40px;
  padding:0 14px;
  border-radius:30px;
  font-family:'Klee One',serif;
  font-size:14px;
  color:var(--text);
  background:#fff;
  border:1px solid var(--line);
  text-decoration:none;
  transition:all .25s;
}
.pagination a:hover{
  background:var(--pink-bg);
  border-color:var(--pink-soft);
  color:var(--pink-deep);
}
.pagination .current{
  background:var(--pink);
  color:#fff;
  border-color:var(--pink);
  font-weight:600;
}
.pagination .disabled{
  color:var(--line);
  background:#fff;
  border-color:var(--line);
  opacity:0.5;
  cursor:default;
}

/* ===== 記事下CTA（一覧ページ末尾用：blog1-preview流用） ===== */
.list-cta-wrap{
  max-width:760px;
  margin:0 auto;
  padding:0 32px 80px;
}
.article-cta{
  background:linear-gradient(135deg, var(--pink-bg) 0%, #FFF5F8 100%);
  border-radius:18px;
  padding:42px 36px 38px;
  text-align:center;
  margin-top:0;
  position:relative;
  overflow:hidden;
  border:1px solid var(--pink-soft);
}
.article-cta::before{
  content:"";
  position:absolute;
  width:160px;height:160px;
  right:-50px;top:-50px;
  background:rgba(216,139,156,0.08);
  border-radius:50%;
}
.article-cta h3{
  font-family:'Zen Maru Gothic',sans-serif;
  font-size:20px;
  font-weight:500;
  color:var(--text);
  line-height:1.6;
  margin:0 0 14px;
  position:relative;
  letter-spacing:0.04em;
}
.article-cta h3 .em{color:var(--pink-deep);}
.article-cta h3::after{
  content:"";display:block;
  width:36px;height:2px;
  background:var(--pink);
  margin:14px auto 0;
}
.article-cta p{
  font-size:13.5px;
  color:var(--text-soft);
  line-height:1.95;
  margin:0 auto 22px;
  max-width:480px;
  position:relative;
}
.article-cta .btn-cta-article{
  display:inline-flex;
  align-items:center;justify-content:center;
  gap:8px;
  background:var(--pink);
  color:#fff !important;
  padding:13px 36px;
  border-radius:30px;
  font-size:14px;
  font-weight:500;
  min-width:240px;
  box-shadow:0 4px 14px rgba(216,139,156,0.25);
  position:relative;
  transition:all .25s;
  text-decoration:none;
}
.article-cta .btn-cta-article::after{content:"›";font-size:18px;line-height:1;}
.article-cta .btn-cta-article:hover{
  background:#A9C49A;
  transform:translateY(-1px);
  box-shadow:0 6px 18px rgba(216,139,156,0.35);
}
.article-cta-note{
  font-family:'Klee One',serif;
  font-size:12px;
  color:var(--text-soft);
  margin-top:14px;
  position:relative;
  display:flex;
  align-items:center;justify-content:center;
  gap:4px;
}
.article-cta-note::before{content:"〈 ";color:var(--pink);}
.article-cta-note::after{content:" 〉";color:var(--pink);}

/* ===== FOOTER（サイト統一形態） ===== */
footer{
  background:var(--cream);
  border-top:1px solid var(--line);
  padding:30px 0 28px;
}
.footer-inner{
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:24px;
  max-width:1240px;margin:0 auto;padding:0 40px;
}
.footer-brand{display:flex;align-items:center;gap:10px;}
.footer-brand img{height:34px;width:auto;}
.footer-brand .name{display:none;}
.footer-brand .tag{font-size:11px;color:var(--text-soft);margin-left:8px;}
.footer-nav{display:flex;gap:24px;flex-wrap:wrap;}
.footer-nav a{font-size:13px;color:var(--text-soft);}
.footer-nav a:hover{color:var(--pink-deep);}
.copyright{text-align:center;font-size:11px;color:var(--text-soft);margin-top:24px;padding-top:18px;border-top:1px solid var(--line);}

/* ===== RESPONSIVE ===== */
@media (max-width:980px){
  nav.gnav{display:none;}
}

/* ===== SP共通（サイト統一・2026-05-20） ===== */
@media (max-width:860px){
  header .header-inner{padding:10px 16px;gap:12px;}
  .brand img{height:42px;}
  nav.gnav{gap:0;}
  nav.gnav a:not(.btn-cta){display:none;}
  header .btn-cta,nav.gnav a.btn-cta{padding:9px 14px;font-size:12.5px;min-height:0;margin-left:0;}
  .footer-inner{flex-direction:column;text-align:center;padding:0 24px;gap:18px;}
  .footer-brand{justify-content:center;flex-wrap:wrap;}
  .footer-nav{justify-content:center;}
}

@media (max-width:680px){
  .blog-hero{padding:42px 0 28px;}
  .blog-hero h1{font-size:24px;letter-spacing:0.04em;}
  .blog-hero .lead{font-size:13.5px;line-height:1.95;padding:0 24px;}
  .blog-list-wrap{padding:36px 20px 24px;}
  .post-list{gap:24px;}
  .post-card-body{padding:20px 20px 22px;}
  .post-card-title{font-size:17px;line-height:1.65;word-break:auto-phrase;}
  .post-card-excerpt{font-size:13px;line-height:1.9;}
  .post-card-meta{font-size:11.5px;gap:10px;}
  .pagination{margin-top:40px;gap:6px;}
  .pagination a,.pagination span{min-width:36px;height:36px;font-size:13px;padding:0 12px;}
  .list-cta-wrap{padding:0 20px 60px;}
  .article-cta{padding:32px 22px 28px;}
  .article-cta h3{font-size:17px;}
  .article-cta p{font-size:13px;}
  .article-cta .btn-cta-article{width:100%;min-width:0;padding:14px 24px;}
}


/* =========================================================
   末尾追加：ナビ リセット＆WP補正（2026-05-27）
   ========================================================= */
nav.gnav ul,
nav.gnav ol,
nav.gnav li,
nav.footer-nav ul,
nav.footer-nav ol,
nav.footer-nav li{
  list-style:none !important;
  margin:0 !important;
  padding:0 !important;
}
nav.gnav ul{
  display:flex;align-items:center;gap:2px;flex-wrap:nowrap;
}
nav.gnav li{display:inline-flex;}
nav.gnav li a{
  font-size:13.5px;color:#C47585;font-weight:500;
  padding:8px 12px;letter-spacing:0;
  transition:color .2s;
  position:relative;
  text-decoration:none;
}
nav.gnav li a:hover{color:#A9C49A;font-weight:700;}
nav.footer-nav ul{display:flex;gap:24px;flex-wrap:wrap;}
nav.footer-nav li{display:inline-flex;}

/* WPデフォルトの p や br 余計な余白を消す（hero-badge とかが崩れないように） */
.hero-badge br,
.hero-copy br,
.problem-check br,
.value-desc br,
.service-desc br{display:inline;}
.hero-badge p,
.hero-copy p:empty,
.service-desc p:empty{margin:0;padding:0;}
