/* ===== Reset (minimal) ===== */
*{box-sizing:border-box}
html,body{margin:0;padding:0}
img{max-width:100%;display:block}

/* ===== Variables ===== */
:root{
  --rose-50:#fff1f2; --rose-100:#ffe4e6; --rose-200:#fecdd3; --rose-500:#f43f5e;
  --rose-600:#e11d48; --rose-700:#be123c; --rose-800:#9f1239; --rose-900:#881337;
  --gray-50:#fafafa; --gray-100:#f5f5f5; --gray-200:#e5e7eb; --gray-600:#4b5563;
  --gray-700:#374151; --gray-900:#111827;
  --white:#fff;
  --container-px:16px;            /* コンテナ左右パディング */
}

/* ===== Base ===== */
body{
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial;
  color:var(--gray-900);
  background:var(--rose-50);
  line-height:1.6;
  font-size:clamp(14px,1.6vw,16px);
}
html,body{overflow-x:hidden}      /* 横スクロール抑止 */

.container{max-width:1200px;margin:0 auto;padding:0 var(--container-px)}
.section{padding:40px 0}
.section.subdued{background:var(--rose-50);border-top:1px solid var(--rose-200);border-bottom:1px solid var(--rose-200)}

.h2{font-weight:800;font-size:22px;display:flex;gap:8px;align-items:center}
.h2 .bar{width:8px;height:24px;border-radius:4px;background:var(--rose-600)}
@media(min-width:640px){.topbar{font-size:14px}}

.badge{display:inline-flex;gap:6px;align-items:center;border-radius:9999px;padding:6px 10px;border:1px solid var(--rose-200);background:var(--rose-100);color:var(--rose-800);font-size:12px;font-weight:600}
.btn{display:inline-flex;align-items:center;justify-content:center;border-radius:12px;padding:12px 20px;background:var(--rose-600);color:#fff;font-weight:700;text-decoration:none;box-shadow:0 2px 6px rgba(0,0,0,.12);white-space:nowrap}
.btn:hover{background:var(--rose-500)}
.card{background:#fff;border:1px solid var(--rose-200);border-radius:16px;padding:20px}

.grid{display:grid;gap:24px}
.grid-2{grid-template-columns:1fr}
.grid-3{grid-template-columns:1fr}
.grid-4{grid-template-columns:1fr}
@media(min-width:768px){
  .grid-2{grid-template-columns:1fr 1fr}
  .grid-3{grid-template-columns:repeat(3,1fr)}
  .grid-4{grid-template-columns:repeat(4,1fr)}
}

/* ===== Topbar ===== */
.topbar{background:#fff;border-bottom:1px solid var(--rose-200);font-size:12px}
.topbar .row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;color:var(--gray-600)}
.topbar .right{flex-wrap:nowrap;gap:clamp(8px,1.6vw,16px)}
.topbar .right span{white-space:nowrap}

/* ===== HERO ===== */
.hero{
  color:#fff;
  background:linear-gradient(to bottom,var(--rose-900),var(--rose-800));
  padding:48px 0;
  overflow:hidden;                 /* クリップ */
}
.hero .grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:center}
.hero .title{font-weight:900;font-size:clamp(22px,6.2vw,44px);line-height:1.2}
.hero .title span{display:block;white-space:nowrap}
.hero .box{margin-top:16px;border:1px solid rgba(255,255,255,.25);background:rgba(255,255,255,.08);border-radius:16px;padding:16px;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px)}
.disclaimer{font-size:12px;color:#fde2e2}

/* FV（PC） */
.hero-visual{max-width:640px;margin-left:auto}
.hero-visual picture,.hero-visual img{display:block;width:100%}
.hero-visual img{height:auto;border-radius:16px;object-fit:cover;aspect-ratio:16/9}

/* ===== FV（SP：〜640px）4:3・フルブリード・ズレ無し ===== */
@media (max-width:640px){
  .hero .grid{display:flex;flex-direction:column}
  .hero-visual{
    order:-1;                       /* 画像を上へ */
    display:block;
    /* コンテナ左右16pxを“食って”端まで広げる（丸め誤差が出ない） */
    margin-left:calc(-1 * var(--container-px));
    margin-right:calc(-1 * var(--container-px));
    width:calc(100% + (var(--container-px) * 2));
  }
  /* iOSノッチ対応 */
  @supports (padding:max(0px)){
    .hero-visual{
      margin-left:calc(-1 * (var(--container-px) + env(safe-area-inset-left)));
      margin-right:calc(-1 * (var(--container-px) + env(safe-area-inset-right)));
      width:calc(100% + (var(--container-px) * 2) + env(safe-area-inset-left) + env(safe-area-inset-right));
    }
  }
  .hero-visual picture,.hero-visual img{
    width:100%;height:auto;aspect-ratio:4/3;object-fit:contain;border-radius:0;
  }
  .hero .title{margin:10px 0 10px;line-height:1.25}
  .hero .box{margin-top:8px}
  .hero .disclaimer{margin-top:6px}
}

/* ===== Sticky CTA ===== */
.sticky-cta{position:fixed;left:16px;right:16px;bottom:0;z-index:50}
.sticky-cta .box{background:#fff;border:1px solid var(--rose-200);border-radius:16px;box-shadow:0 8px 24px rgba(0,0,0,.14);padding:12px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px;margin:12px 0}
@media(min-width:640px){.sticky-cta{left:auto;right:24px;bottom:16px;width:360px}}
.pb-safe{padding-bottom:112px}

/* ===== Misc ===== */
.gallery{display:grid;gap:12px;grid-template-columns:repeat(2,1fr)}
.imgcard{position:relative;border:1px solid var(--rose-200);border-radius:16px;background:var(--rose-50);overflow:hidden;aspect-ratio:4/3}
.imgcard>img{position:absolute;inset:0;width:100%;height:100%}
.imgcard::after{content:"";position:absolute;inset:0;background:linear-gradient(45deg,rgba(136,19,55,.08),transparent,rgba(244,63,94,.12));mix-blend:multiply;pointer-events:none}
.num{width:36px;height:36px;border-radius:9999px;background:var(--rose-500);color:#fff;font-weight:800;display:grid;place-items:center;flex:0 0 36px}
.pill-note{display:inline-block;padding:4px 8px;border-radius:8px;background:var(--rose-50);color:var(--rose-700);font-size:12px;border:1px solid var(--rose-200)}
.table{width:100%;border-collapse:separate;border-spacing:0;border:1px solid var(--rose-200);border-radius:16px;overflow:hidden;table-layout:fixed}
.table th,.table td{border:1px solid var(--rose-200);padding:10px;text-align:left;font-size:14px;word-break:break-word}
.table thead{background:var(--rose-50)}
.barbox{margin-top:12px;border:1px solid var(--rose-200);border-radius:12px;padding:12px;background:#fff}
.track{height:12px;border:1px solid var(--rose-200);border-radius:999px;background:var(--rose-100);overflow:hidden}
.fill-88,.fill-18{height:100%;border-radius:999px}
.fill-88{background:rgba(225,29,72,.85);width:88%}
.fill-18{background:rgba(244,63,94,.85);width:18%}
.note-box{background:var(--rose-50);border:1px solid var(--rose-200);border-radius:14px;padding:16px;color:var(--rose-800);font-size:12px;line-height:1.7}
.mono{font-variant-numeric:tabular-nums}
/* ==== Header(Topbar) 高さを抑える：SP優先 ==== */
.topbar{ font-size:12px; }                 /* 既定サイズを固定 */
.topbar .row{ padding:6px 0; min-height:44px; }  /* PC/タブ基準 */

@media (max-width:640px){
  .topbar{ font-size:11px; }               /* 文字を少しだけ縮小 */
  .topbar .row{ padding:4px 0; min-height:40px; } /* 上下余白を圧縮 */
  .topbar .right{ display:flex; flex-wrap:nowrap; gap:10px; }
  .topbar .right > *{ white-space:nowrap; }       /* 折り返し防止で高さ増を抑制 */
  .topbar .badge{ padding:4px 8px; }              /* 左のピルが大きい場合の緩和 */
}

/* ==== HEROの上余白も詰める（“ヘッダーが大きい”見え方対策） ==== */
@media (max-width:640px){
  .hero{ padding:16px 0 28px; }            /* 上だけ16pxに */
}
/* ====== Topbar（行折返し＆縮小） ====== */
.topbar .row{
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;flex-wrap:wrap;padding:8px 0;
}
.topbar .left{display:flex;align-items:center}
.topbar .right{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
@media (max-width:640px){
  .topbar .right{font-size:12px;gap:10px}
}
/* かなり狭い端末では3つ目の文言を非表示 */
@media (max-width:480px){
  .topbar .right span:nth-child(3){display:none}
}

/* ====== こころサポート情報（自動で短縮表示） ====== */
.badge.support-badge{position:relative}
.badge.support-badge .label{display:inline;white-space:nowrap}
.badge.support-badge .dot{
  width:8px;height:8px;border-radius:9999px;background:var(--rose-500);
  display:inline-block
}
/* 幅が狭くなったら data-short に置き換え */
@media (max-width:640px){
  .badge.support-badge .label{display:none}
  .badge.support-badge::after{
    content:attr(data-short);display:inline;white-space:nowrap;
    font-weight:600;color:var(--rose-800)
  }
}
/* さらに狭い端末では data-xs に置き換え＆ドット非表示 */
@media (max-width:380px){
  .badge.support-badge::after{content:attr(data-xs)}
  .badge.support-badge .dot{display:none}
}

/* （任意）PCでは縦ピルにしたい場合は .vertical を付与 */
@media (min-width:1024px){
  .badge.support-badge.vertical{
    writing-mode:vertical-rl;transform:rotate(180deg);
    height:120px;padding:10px 8px;border-radius:16px
  }
}
