/* ========================================
   mamaganba TOP PAGE CSS v5
   カスタマイズ → 追加CSS の既存コードの下に追記
   ======================================== */
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&display=swap');
:root{--mp:#d4547a;--mp-dark:#b03060;--mp-light:#f7e8ed;--mp-pale:#fdf4f6;--mp-border:#f0c0cc;--mt:#3a2a30;--mt-sub:#6a5a60;--mt-hint:#a89298;--mborder:#eee0e4;--mshadow:0 2px 14px rgba(180,80,100,0.09);--mr-sm:6px;--mr-md:10px;--mr-lg:14px;}
.mama-top{font-family:'Noto Sans JP','Hiragino Kaku Gothic ProN',sans-serif;color:var(--mt);line-height:1.7;font-size:15px;}
.mama-top *{box-sizing:border-box;margin:0;padding:0;}
.mama-top a{text-decoration:none;color:inherit;}
.mama-top img{max-width:100%;height:auto;display:block;}
.mp-pink{color:var(--mp);font-style:normal;}

/* ① ヒーローロゴ */
.mp-hero-logo{text-align:center;margin-bottom:18px;}
.mp-logo-img{height:56px;width:auto;display:inline-block;max-width:260px;object-fit:contain;}

/* ヒーロー */
.mp-hero{background:linear-gradient(135deg,#fff5f7 0%,#fef8f0 60%,#f0f4ff 100%);border:1px solid var(--mborder);border-radius:var(--mr-lg);padding:32px 28px;margin-bottom:20px;}
.mp-hero-inner{display:grid;grid-template-columns:1fr 290px;gap:28px;align-items:start;}
.mp-hero-eyebrow{display:inline-block;background:var(--mp-light);color:var(--mp-dark);font-size:13px;font-weight:700;padding:4px 14px;border-radius:20px;margin-bottom:14px;}
.mp-hero-h2{font-size:28px;font-weight:700;line-height:1.45;color:var(--mt);margin-bottom:14px;}
.mp-hero-desc{font-size:15px;color:var(--mt-sub);line-height:1.85;margin-bottom:18px;}

/* 検索 */
.mp-search-box{display:flex;align-items:center;background:#fff;border:2px solid var(--mp);border-radius:30px;padding:6px 6px 6px 18px;gap:8px;margin-bottom:16px;box-shadow:0 2px 16px rgba(212,84,122,0.12);}
.mp-search-ico{font-size:14px;font-weight:700;color:var(--mp);flex-shrink:0;white-space:nowrap;}
.mp-search-input{border:none;background:transparent;outline:none;font-size:15px;width:100%;font-family:inherit;color:var(--mt);}
.mp-search-input::placeholder{color:var(--mt-hint);}
.mp-search-btn{background:var(--mp);color:#fff;border:none;border-radius:24px;padding:10px 24px;font-size:15px;font-weight:700;cursor:pointer;font-family:inherit;white-space:nowrap;transition:background 0.15s;}
.mp-search-btn:hover{background:var(--mp-dark);}

/* タグ */
.mp-hero-kws{display:flex;flex-wrap:wrap;gap:7px;}
.mp-kw-pill{background:#fff;border:1px solid var(--mp-border);border-radius:16px;padding:5px 14px;font-size:13px;color:var(--mp);transition:background 0.15s;text-decoration:none;display:inline-block;}
.mp-kw-pill:hover{background:var(--mp-pale);}

/* ヒーロー右ツールカード */
.mp-hero-tools{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.mp-tool-card{background:#fff;border:1px solid var(--mp-border);border-radius:var(--mr-md);padding:14px 12px;cursor:pointer;display:block;transition:box-shadow 0.15s,transform 0.15s;text-decoration:none;}
.mp-tool-card:hover{box-shadow:var(--mshadow);transform:translateY(-1px);}
.mp-tool-icon-text{display:inline-block;background:var(--mp-light);color:var(--mp-dark);font-size:11px;font-weight:700;padding:3px 8px;border-radius:8px;margin-bottom:6px;}
.mp-tool-name{font-size:14px;font-weight:700;color:var(--mt);display:block;}
.mp-tool-desc{font-size:12px;color:var(--mt-sub);margin-top:3px;display:block;}
.mp-tool-badge{display:inline-block;background:var(--mp);color:#fff;font-size:10px;font-weight:700;padding:3px 8px;border-radius:8px;margin-top:6px;}

/* セクション共通 */
.mp-section-title{display:flex;align-items:center;gap:8px;font-size:17px;font-weight:700;color:var(--mt);}
.mp-section-title::before{content:'';display:block;width:4px;height:21px;background:var(--mp);border-radius:2px;flex-shrink:0;}
.mp-section-sub{font-size:14px;color:var(--mt-sub);margin-bottom:16px;padding-left:12px;}
.mp-more{font-size:14px;color:var(--mp);font-weight:700;margin-left:auto;text-decoration:none;}
.mp-more:hover{text-decoration:underline;}
.mp-card{background:#fff;border:1px solid var(--mborder);border-radius:var(--mr-lg);padding:22px 22px 26px;margin-bottom:22px;}
.mp-card-header{display:flex;align-items:center;margin-bottom:6px;}

/* カテゴリ */
.mp-cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;}
.mp-cat-card{background:#fff;border:1px solid var(--mborder);border-radius:var(--mr-md);overflow:hidden;text-align:center;display:block;transition:box-shadow 0.15s,transform 0.15s,border-color 0.15s;text-decoration:none;}
.mp-cat-card:hover{box-shadow:var(--mshadow);transform:translateY(-2px);border-color:var(--mp-border);}
.mp-cat-img{height:85px;overflow:hidden;display:flex;align-items:center;justify-content:center;background:var(--mp-pale);font-size:14px;font-weight:700;color:var(--mp);}
.mp-cat-img img{width:100%;height:100%;object-fit:cover;}
.mp-cat-name{font-size:14px;font-weight:700;color:var(--mt);display:block;padding:8px 4px 2px;}
.mp-cat-count{font-size:12px;color:var(--mt-hint);display:block;padding-bottom:10px;}

/* 計算ツール特集 */
.mp-tools-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;}
.mp-tools-card{background:linear-gradient(135deg,#fff5f7,#fff);border:1px solid var(--mp-border);border-radius:var(--mr-md);padding:18px 14px;display:block;text-align:center;transition:box-shadow 0.15s,transform 0.15s;text-decoration:none;}
.mp-tools-card:hover{box-shadow:var(--mshadow);transform:translateY(-2px);}
.mp-tools-icon-text{display:inline-block;background:var(--mp-light);color:var(--mp-dark);font-size:12px;font-weight:700;padding:4px 12px;border-radius:12px;margin-bottom:8px;}
.mp-tools-name{font-size:14px;font-weight:700;color:var(--mt);display:block;margin-bottom:4px;}
.mp-tools-desc{font-size:12px;color:var(--mt-sub);line-height:1.5;display:block;}
.mp-tools-badge{display:inline-block;background:var(--mp);color:#fff;font-size:10px;font-weight:700;padding:3px 10px;border-radius:10px;margin-top:8px;}

/* 悩み特集 */
.mp-worry-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.mp-worry-card{border:1px solid var(--mborder);border-radius:var(--mr-md);overflow:hidden;transition:box-shadow 0.15s;}
.mp-worry-card:hover{box-shadow:var(--mshadow);}
.mp-worry-head{height:68px;display:flex;align-items:center;justify-content:center;gap:10px;padding:0 16px;}
.mp-worry-label-icon{display:inline-block;background:rgba(255,255,255,0.3);color:#fff;font-size:12px;font-weight:700;padding:2px 8px;border-radius:10px;}
.mp-worry-label{font-size:15px;font-weight:700;color:#fff;}
.mp-worry-body{background:#fff;padding:12px 14px;}
.mp-worry-links{list-style:none;padding:0;margin:0;}
.mp-worry-links li{padding:6px 0;border-bottom:1px solid var(--mborder);font-size:14px;}
.mp-worry-links li:last-child{border-bottom:none;}
.mp-worry-links a{color:var(--mt);display:flex;align-items:center;gap:6px;text-decoration:none;}
.mp-worry-links a::before{content:'›';color:var(--mp);font-weight:700;font-size:16px;}
.mp-worry-links a:hover{color:var(--mp);}

/* ショップ */
.mp-shop-tabs{display:flex;border-bottom:1px solid var(--mborder);margin-bottom:18px;overflow-x:auto;}
.mp-shop-tabs::-webkit-scrollbar{display:none;}
.mp-shop-tab{padding:10px 16px;font-size:14px;font-weight:700;color:var(--mt-sub);cursor:pointer;white-space:nowrap;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color 0.15s,border-color 0.15s;}
.mp-shop-tab.active{color:var(--mp);border-bottom-color:var(--mp);}
/* PC：5列1行=5個ぴったり */
.mp-shop-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;}
.mp-shop-card{border:1px solid var(--mborder);border-radius:var(--mr-sm);overflow:hidden;display:block;transition:border-color 0.15s,box-shadow 0.15s;text-decoration:none;}
.mp-shop-card:hover{border-color:var(--mp-border);box-shadow:var(--mshadow);}
.mp-shop-img{height:120px;background:var(--mp-pale);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:var(--mp);position:relative;overflow:hidden;}
.mp-shop-img img{width:100%;height:100%;object-fit:cover;}
.mp-shop-fb{font-size:13px;font-weight:700;color:var(--mp);}
.mp-shop-badge{position:absolute;top:6px;left:6px;font-size:9px;font-weight:700;padding:3px 7px;border-radius:8px;}
.mp-badge-new{background:var(--mp);color:#fff;}
.mp-badge-sale{background:#e24b4a;color:#fff;}
.mp-shop-info{padding:9px 10px 11px;}
.mp-shop-name{font-size:12px;font-weight:700;color:var(--mt);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.4;min-height:33px;}
.mp-shop-price{font-size:14px;font-weight:700;color:var(--mp);display:block;margin-top:4px;}
.mp-shop-footer{text-align:center;margin-top:18px;display:flex;justify-content:center;gap:10px;flex-wrap:wrap;}
.mp-btn-outline{display:inline-block;background:#fff;color:var(--mp);font-size:13px;font-weight:700;padding:8px 20px;border-radius:20px;border:1px solid var(--mp-border);transition:background 0.15s;text-decoration:none;}
.mp-btn-outline:hover{background:var(--mp-pale);color:var(--mp);}

/* 楽天＋トラベル 2列 */
.mp-ext-2col{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:22px;}
.mp-ext-box{border-radius:var(--mr-lg);overflow:hidden;border:1px solid var(--mborder);}
.mp-ext-rakuten{background:#fff5f5;border-color:#f5c0c0;}
.mp-ext-travel{background:#f0f4ff;border-color:#c0c8f5;}
.mp-ext-img-wrap{height:160px;overflow:hidden;display:flex;align-items:center;justify-content:center;background:#f9f0f0;}
.mp-ext-travel .mp-ext-img-wrap{background:#e8f0ff;}
.mp-ext-img-wrap img{width:100%;height:100%;object-fit:cover;}
.mp-ext-body{padding:16px 18px 18px;}
.mp-ext-title{font-size:16px;font-weight:700;color:var(--mt);line-height:1.4;margin-bottom:6px;}
.mp-ext-sub{font-size:13px;color:var(--mt-sub);margin-bottom:14px;line-height:1.6;}
.mp-ext-btn{display:inline-block;font-size:14px;font-weight:700;padding:10px 24px;border-radius:22px;text-decoration:none;margin-bottom:14px;}
.mp-ext-btn-pink{background:var(--mp);color:#fff;}
.mp-ext-btn-pink:hover{background:var(--mp-dark);color:#fff;}
.mp-ext-btn-blue{background:#1a6fc4;color:#fff;}
.mp-ext-btn-blue:hover{background:#0f4f9a;color:#fff;}
.mp-ext-tags{display:flex;flex-wrap:wrap;gap:6px;}
.mp-ext-tag{display:inline-block;background:#fff;border:1px solid var(--mp-border);color:var(--mp);font-size:12px;font-weight:700;padding:4px 12px;border-radius:14px;text-decoration:none;transition:background 0.15s;}
.mp-ext-tag:hover{background:var(--mp-pale);}
.mp-ext-tag-blue{border-color:#c0c8f5;color:#1a6fc4;}
.mp-ext-tag-blue:hover{background:#e8f0ff;}

/* SEO */
.mp-seo{background:#fff;border:1px solid var(--mborder);border-radius:var(--mr-md);padding:20px;margin-bottom:20px;}
.mp-seo h2{font-size:15px;font-weight:700;color:var(--mt);margin-bottom:10px;}
.mp-seo p{font-size:14px;color:var(--mt-sub);line-height:1.9;}

/* レスポンシブ */
@media (max-width:900px){
  .mp-hero-inner{grid-template-columns:1fr;}
  .mp-hero-h2{font-size:22px;}
  .mp-tools-grid{grid-template-columns:repeat(2,1fr);}
  .mp-worry-grid{grid-template-columns:repeat(2,1fr);}
  /* タブレット：3列 */
  .mp-shop-grid{grid-template-columns:repeat(3,1fr);}
  .mp-ext-2col{grid-template-columns:1fr 1fr;}
}
@media (max-width:600px){
  .mp-hero{padding:20px 16px;}
  /* ① ロゴ：スマホ小さめ */
  .mp-logo-img{height:44px;}
  .mp-hero-h2{font-size:20px;}
  .mp-cat-grid{grid-template-columns:repeat(4,1fr);gap:8px;}
  .mp-cat-img{height:60px;}
  .mp-cat-name{font-size:11px;}
  .mp-tools-grid{grid-template-columns:repeat(2,1fr);}
  .mp-worry-grid{grid-template-columns:1fr;}
  /* スマホ：2列 × 2行 = 4個表示（5個目を非表示にして揃える） */
  .mp-shop-grid{grid-template-columns:repeat(2,1fr);}
  .mp-shop-grid .mp-shop-card:nth-child(5){display:none;}
  .mp-ext-2col{grid-template-columns:1fr;}
  .mp-card{padding:16px 14px 18px;}
}

/* ====================================
   記事リスト（新着・体験談）
   ==================================== */
.mama-top-postlist{margin-top:24px;}
.mama-top-postlist .l-article-list-wrap.d--2col{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:14px;
  margin-top:16px;
  margin-bottom:32px;
}
.mama-top-postlist .p-article-list{
  background:#fff;
  border-radius:8px;
  overflow:hidden;
  border:1px solid #eee0e4;
  transition:box-shadow 0.15s;
}
.mama-top-postlist .p-article-list:hover{box-shadow:0 2px 12px rgba(180,80,100,0.1);}
.mama-top-postlist .p-article-list__link{
  display:flex;
  flex-direction:row;
  text-decoration:none;
  color:inherit;
  align-items:flex-start;
}
/* サムネイル：containで切れない表示 */
.mama-top-postlist .p-article-list__thumb{
  flex-shrink:0;
  width:140px;
  height:100px;
  background:#fdf4f6;
  display:flex;
  align-items:center;
  justify-content:center;
}
.mama-top-postlist .p-article-list__thumb img{
  width:140px !important;
  height:100px !important;
  object-fit:contain !important;
  object-position:center center;
  display:block;
}
.mama-top-postlist .p-article-list__body{padding:10px 12px;flex:1;min-width:0;}
.mama-top-postlist .p-article-list__title{
  font-size:13px;
  font-weight:700;
  color:#3a2a30;
  line-height:1.55;
  margin-bottom:6px;
  display:-webkit-box;
  -webkit-line-clamp:3;
  -webkit-box-orient:vertical;
  overflow:hidden;
  font-family:'Noto Sans JP','Hiragino Kaku Gothic ProN',sans-serif;
}
.mama-top-postlist .p-article-list__meta{
  font-size:10.5px;
  color:#a89298;
  display:flex;
  gap:6px;
  flex-wrap:wrap;
  font-family:'Noto Sans JP',sans-serif;
}
.mama-top-postlist .p-article-list__link:hover .p-article-list__title{color:#d4547a;}
.mama-top-postlist .b--jinr-h2rich{margin-top:24px;margin-bottom:0;}

@media(max-width:600px){
  .mama-top-postlist .l-article-list-wrap.d--2col{grid-template-columns:1fr;gap:8px;}
}
