/* ============================================
   しゅわっと炭酸かき氷 LP — メインスタイルシート
   使い方：HTMLの<head>内で
   <link rel="stylesheet" href="shuwatto-lp-main.css">
   として読み込む
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;700;900&display=swap');

  *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
  html { scroll-behavior: smooth; }
  body { font-family: 'Noto Sans JP', sans-serif; background: #0A1628; color: #fff; -webkit-font-smoothing: antialiased; }

  /* HERO */
  .hero { position: relative; min-height: 600px; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; padding: 80px 24px 64px; overflow: hidden; }
  .hero-stripe { position: absolute; top: 0; left: 0; right: 0; height: 4px; background: #E24B4A; z-index: 3; }

  /* 商品画像ラッパー — 中央より少し左 */
 .hero-img-wrap {
    position: absolute;
    right: 5%;
    top: 50%; transform: translateY(-50%);
	left: 50%; margin-left: -80px;
    height: auto;
    z-index: 1;
    display: flex; align-items: center; justify-content: center;
  }
  .hero-img {
    height: auto;
    width: 280px;
    max-width: 280px;
    object-fit: contain;
    opacity: 0.93;
    position: relative; z-index: 2;
    filter: drop-shadow(0 0 32px rgba(0,200,255,0.28));
  }

  /* 炭酸アニメーション — 商品画像の背後 */
  .carbonation {
    position: absolute; inset: 0;
    z-index: 1; pointer-events: none;
  }
  .carb-ring {
    position: absolute;
    border-radius: 50%;
    border: 1.5px solid rgba(0,200,255,0.4);
    animation: carbExpand 3s ease-out infinite;
    transform: translate(-50%, -50%);
  }
  @keyframes carbExpand {
    0%   { width: 16px; height: 16px; opacity: 1; border-color: rgba(0,200,255,0.55); }
    100% { width: 280px; height: 280px; opacity: 0; border-color: rgba(0,200,255,0); }
  }
  .carb-dot {
    position: absolute;
    border-radius: 50%;
    background: rgba(0,200,255,0.65);
    animation: carbRise 2.6s ease-in infinite;
  }
  @keyframes carbRise {
    0%   { transform: translateY(0) scale(1); opacity: 0.8; }
    100% { transform: translateY(-360px) scale(0.05); opacity: 0; }
  }
  .carb-sparkle {
    position: absolute;
    width: 3px; height: 3px;
    border-radius: 50%;
    background: rgba(255,255,255,0.8);
    animation: sparkle 1.8s ease-in-out infinite;
  }
  @keyframes sparkle {
    0%,100% { opacity: 0; transform: scale(0.5); }
    50%     { opacity: 1; transform: scale(1.4); }
  }

  /* 背景の大きめ泡 */
  .bubble { position: absolute; border-radius: 50%; background: rgba(0,200,255,0.10); animation: rise 5s ease-in infinite; z-index: 0; }
  @keyframes rise { 0%{transform:translateY(0) scale(1);opacity:.5} 100%{transform:translateY(-580px) scale(.15);opacity:0} }

  .hero-eyebrow { position: relative; z-index: 2; font-size: 11px; letter-spacing: .22em; color: #E24B4A; text-transform: uppercase; margin-bottom: 22px; display: flex; align-items: center; gap: 12px; justify-content: center; }
  .hero-eyebrow::before,.hero-eyebrow::after { content:''; display:block; width:36px; height:1px; background:#E24B4A; opacity:.6; }

  .hero h1 { position: relative; z-index: 2; font-size: 50px; font-weight: 900; line-height: 1.22; margin-bottom: 12px; text-align: left;  color:#FFFFFF; }

  .hero h1 .accent { color: #E24B4A; }
  .hero-sub { position: relative; z-index: 2; font-size: 13px; color: rgba(255,255,255,.5); letter-spacing: .1em; margin-bottom: 28px; text-align: left; }
  .hero-body { position: relative; z-index: 2; font-size: 15px; color: rgba(255,255,255,.72); max-width: 420px; line-height: 2; margin-bottom: 40px; text-align: left; }
  .hero-body strong { color: #fff; font-weight: 700; }

  .hero-content { position: relative; z-index: 2; display: flex; flex-direction: column; align-items: flex-start; max-width: 480px; margin-right: auto; margin-left: 48px; }

  .cta-row { display: flex; gap: 14px; flex-wrap: wrap; }
  .btn-main { background: #E24B4A; color: #fff; font-weight: 700; font-size: 15px; border: none; border-radius: 4px; padding: 16px 38px; cursor: pointer; letter-spacing: .04em; text-decoration: none; display: inline-block; transition: opacity .15s; font-family: 'Noto Sans JP', sans-serif; }
  .btn-main:hover { opacity: .85; }
  .btn-sub { background: transparent; color: rgba(255,255,255,.75); font-size: 14px; border: 1px solid rgba(255,255,255,.25); border-radius: 4px; padding: 15px 28px; cursor: pointer; text-decoration: none; display: inline-block; transition: border-color .2s; font-family: 'Noto Sans JP', sans-serif; }
  .btn-sub:hover { border-color: rgba(255,255,255,.55); }

  /* 行列実績バナー */
  .queue-banner { position: relative; overflow: hidden; height: 220px; }
  .queue-banner img { width: 100%; height: 100%; object-fit: cover; object-position: center 40%; display: block; }
  .queue-overlay { position: absolute; inset: 0; background: rgba(10,22,40,0.55); display: flex; align-items: center; justify-content: center; gap: 40px; }
  .queue-stat { text-align: center; }
  .queue-stat .q-num { font-size: 38px; font-weight: 900; color: #E24B4A; line-height: 1; }
  .queue-stat .q-label { font-size: 11px; color: rgba(255,255,255,.65); margin-top: 6px; letter-spacing: .08em; }
  .queue-divider { width: 1px; height: 60px; background: rgba(255,255,255,.2); }

  /* TRUST BAR */
  .trust-bar { display: flex; justify-content: center; border-top: .5px solid rgba(255,255,255,.08); border-bottom: .5px solid rgba(255,255,255,.08); }
  .trust-item { flex: 1; text-align: center; padding: 20px 8px; border-right: .5px solid rgba(255,255,255,.08); max-width: 220px; }
  .trust-item:last-child { border-right: none; }
  .trust-num { font-size: 26px; font-weight: 900; color: #E24B4A; line-height: 1; }
  .trust-label { font-size: 10px; color: rgba(255,255,255,.4); margin-top: 6px; letter-spacing: .05em; }

  /* SECTIONS */
  .divider { height: .5px; background: rgba(255,255,255,.07); margin: 0 24px; }
  .sec { padding: 60px 24px; max-width: 720px; margin: 0 auto; }
  .sec-ey { font-size: 10px; letter-spacing: .22em; color: #E24B4A; text-transform: uppercase; margin-bottom: 12px; }
  .sec h2 { font-size: 28px; font-weight: 900; line-height: 1.35; margin-bottom: 14px; }
  .lead { font-size: 14px; color: rgba(255,255,255,.6); line-height: 2; margin-bottom: 32px; }

  /* 3 STAGES — with product image */
  .stages-wrap { display: flex; gap: 24px; align-items: center; }
  .stages-img { flex: 0 0 260px; border-radius: 16px; overflow: hidden; }
  .stages-img img { width: 100%; height: 340px; object-fit: cover; object-position: center top; display: block; }
  .stages { display: flex; flex-direction: column; gap: 10px; flex: 1; }
  .stg { display: flex; align-items: center; gap: 14px; background: #152338; border: 1px solid rgba(255,255,255,.07); border-radius: 12px; padding: 16px 18px; }
  .stg-left { text-align: center; flex-shrink: 0; }
  .stg-n { font-size: 9px; color: #E24B4A; letter-spacing: .15em; margin-bottom: 4px; }
  .stg-ico { font-size: 24px; }
  .stg-t { font-size: 13px; font-weight: 700; margin-bottom: 4px; }
  .stg-d { font-size: 11px; color: rgba(255,255,255,.5); line-height: 1.6; }

  /* REASONS */
  .reasons { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 28px; }
  .rsn { background: #152338; border: .5px solid rgba(255,255,255,.08); border-radius: 14px; padding: 22px 20px; transition: border-color .2s; }
  .rsn:hover { border-color: rgba(226,75,74,.35); }
  .rsn.wide { grid-column: 1 / -1; display: flex; gap: 20px; align-items: flex-start; }
  .rsn-ico { font-size: 24px; margin-bottom: 10px; flex-shrink: 0; }
  .rsn-tag { font-size: 9px; color: #E24B4A; background: rgba(226,75,74,.1); border: .5px solid rgba(226,75,74,.3); border-radius: 10px; padding: 2px 10px; display: inline-block; margin-bottom: 8px; letter-spacing: .06em; }
  .rsn h3 { font-size: 14px; font-weight: 700; margin-bottom: 7px; line-height: 1.45;  color:#FFFFFF; }
  .rsn p { font-size: 12px; color: rgba(255,255,255,.55); line-height: 1.9; }

  /* PLANS */
  .plans { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 28px; }
  .plan { background: #152338; border: .5px solid rgba(255,255,255,.1); border-radius: 16px; padding: 28px 22px; position: relative; }
  .plan.hot { border-color: rgba(226,75,74,.5); }
  .plan-badge { position: absolute; top: -12px; left: 18px; background: #E24B4A; color: #fff; font-size: 10px; font-weight: 700; border-radius: 10px; padding: 3px 14px; }
  .plan-ico { font-size: 28px; margin-bottom: 12px; }
  .plan h3 { font-size: 20px; font-weight: 900; margin-bottom: 5px;  color:#FFFFFF;}
  .plan-sub { font-size: 11px; color: rgba(255,255,255,.4); margin-bottom: 18px; }
  .plan-list { list-style: none; }
  .plan-list li { font-size: 12px; color: rgba(255,255,255,.75); padding: 6px 0; border-bottom: .5px solid rgba(255,255,255,.06); display: flex; align-items: flex-start; gap: 9px; line-height: 1.55; }
  .plan-list li:last-child { border-bottom: none; }
  .chk { color: #E24B4A; flex-shrink: 0; }

  /* COMPARE わからん*/
  .cmp-wrap { background: #152338; border-radius: 14px; overflow: hidden; border: .5px solid rgba(255,255,255,.08); margin-top: 24px; }
  .cmp-wrap table { width: 100%; border-collapse: collapse; font-size: 13px; }
  .cmp-wrap th { background: rgba(226,75,74,.08); color: rgba(255,255,255,.5); font-size: 11px; letter border: 1px solid rgba(226,75,74,.3);-spacing: .1em; padding: 12px 16px; text-align: left; border-bottom: .5px solid rgba(255,255,255,.08); }
  .cmp-wrap td { padding: 11px 16px; border-bottom: .5px solid rgba(255,255,255,.05); color: rgba(255,255,255,.8); }
  .cmp-wrap tr:last-child td { border-bottom: none; }
  .yes { color: #E24B4A; font-weight: 700; }
  .no { color: rgba(255,255,255,.25); }

  /* INSURANCE */
  .ins { background: #152338; border: 1px solid rgba(226,75,74,.3); border-radius: 16px; padding: 22px 26px; display: flex; align-items: center; gap: 18px; margin-top: 24px; }
  .ins-e { font-size: 36px; flex-shrink: 0; }
  .ins h3 { font-size: 15px; font-weight: 700; color: #E24B4A; margin-bottom: 6px; }
  .ins p { font-size: 12px; color: rgba(255,255,255,.55); line-height: 1.85; }

  /* STEPS */
  .steps { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 28px; }
  .step { display: flex; gap: 14px; background: #152338; border-radius: 12px; padding: 20px; }
  .step-n { font-size: 28px; font-weight: 900; color: #E24B4A; line-height: 1; flex-shrink: 0; }
  .step h4 { font-size: 13px; font-weight: 700; margin-bottom: 5px;  color:#FFFFFF; }
  .step p { font-size: 11px; color: rgba(255,255,255,.5); line-height: 1.75; }

  /* FAQ */
  .faq-item { background: #152338; border-radius: 12px; padding: 20px 22px; margin-bottom: 10px; cursor: pointer; border: .5px solid rgba(255,255,255,.07); transition: border-color .2s; }
  .faq-item:hover { border-color: rgba(226,75,74,.3); }
  .faq-q { font-size: 14px; font-weight: 700; display: flex; justify-content: space-between; align-items: center; gap: 12px; }
  .faq-arr { color: #E24B4A; font-size: 20px; transition: transform .2s; flex-shrink: 0; }
  .faq-a { font-size: 13px; color: rgba(255,255,255,.55); line-height: 1.9; margin-top: 12px; display: none; }
  .faq-item.open .faq-a { display: block; }
  .faq-item.open .faq-arr { transform: rotate(45deg); }

  /* FINAL CTA border-top: .5px solid rgba(255,255,255,.07); */
  .final { text-align: center; padding: 80px 24px 88px; background: #0d1e35; }
  .final-ey { font-size: 10px; letter-spacing: .22em; color: #E24B4A; text-transform: uppercase; margin-bottom: 18px; }
  .final h2 { font-size: 36px; font-weight: 900; line-height: 1.3; margin-bottom: 16px; }
  .final h2 span { color: #E24B4A; }
  .final p { font-size: 14px; color: rgba(255,255,255,.55); line-height: 2; margin-bottom: 36px; }
  .final-note { font-size: 11px; color: rgba(255,255,255,.25); margin-top: 18px; }

  /* 儲かる・行列セクション */
  .profit-sec { padding: 60px 24px; max-width: 720px; margin: 0 auto; }
  .hero-stat { background: #152338; border-radius: 16px; padding: 32px 28px; display: flex; align-items: center; gap: 28px; margin-bottom: 16px; position: relative; overflow: hidden; border: 1px solid rgba(226,75,74,.35); }
  .hero-stat::before { content:''; position:absolute; left:0; top:0; bottom:0; width:4px; background:#E24B4A; }
  .hero-stat-num { font-size: 64px; font-weight: 900; color: #E24B4A; line-height: 1; flex-shrink: 0; }
  .hero-stat-unit { font-size: 22px; font-weight: 900; color: #E24B4A; }
  .hero-stat-label { font-size: 18px; font-weight: 700; color: #fff; margin-bottom: 6px; line-height: 1.4; }
  .hero-stat-sub { font-size: 12px; color: rgba(255,255,255,.55); line-height: 1.85; }
  .p-metrics { display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; margin-bottom: 16px; }
  .p-metric { background: #152338; border-radius: 10px; padding: 18px 16px; text-align: center; border: .5px solid rgba(255,255,255,.08); }
  .p-metric-num { font-size: 22px; font-weight: 900; color: #E24B4A; line-height: 1.2; margin-bottom: 6px; }
  .p-metric-label { font-size: 11px; color: rgba(255,255,255,.5); line-height: 1.6; }
  .profit-card { background: #152338; border-radius: 14px; padding: 22px 24px; border: .5px solid rgba(255,255,255,.08); margin-bottom: 16px; }
  .profit-card-title { font-size: 13px; font-weight: 700; color: #fff; margin-bottom: 16px; }
  .p-row { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
  .p-row:last-child { margin-bottom: 0; }
  .p-key { font-size: 12px; color: rgba(255,255,255,.55); min-width: 130px; flex-shrink: 0; }
  .p-bar-wrap { flex: 1; height: 8px; background: rgba(255,255,255,.08); border-radius: 4px; overflow: hidden; }
  .p-bar { height: 100%; border-radius: 4px; background: #E24B4A; }
  .p-val { font-size: 12px; font-weight: 700; color: #fff; min-width: 64px; text-align: right; }
  .queue-reason { background: #152338; border-radius: 14px; padding: 22px 24px; border: .5px solid rgba(255,255,255,.08); display: flex; gap: 20px; align-items: flex-start; }
  .queue-reason-ico { font-size: 36px; flex-shrink: 0; }
  .queue-reason h3 { font-size: 16px; font-weight: 700; color: #fff; margin-bottom: 8px; }
  .queue-reason p { font-size: 12px; color: rgba(255,255,255,.55); line-height: 1.9; }
  .qtags { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 12px; }
  .qtag { font-size: 10px; padding: 3px 10px; border-radius: 20px; background: rgba(226,75,74,.1); color: #E24B4A; border: .5px solid rgba(226,75,74,.3); }

  /* RESPONSIVE */
  @media (max-width: 640px) {
    .hero h1 { font-size: 32px; }
    .hero-img-wrap { left: 50%; margin-left: -40px; height: 55%; }
    .hero-img { opacity: 0.3; }
    .hero-content { margin-left: 0; max-width: 100%; align-items: center; text-align: center; }
    .hero h1, .hero-sub, .hero-body { text-align: center; }
    .cta-row { justify-content: center; }
    .queue-banner { height: 160px; }
    .queue-overlay { gap: 20px; }
    .queue-stat .q-num { font-size: 28px; }
    .stages-wrap { flex-direction: column; }
    .stages-img { flex: none; width: 100%; }
    .stages-img img { height: 200px; }
    .hero-stat { flex-direction: column; gap: 16px; text-align: center; }
    .hero-stat-num { font-size: 48px; }
    .p-metrics { grid-template-columns: 1fr; }
    .queue-reason { flex-direction: column; }
    .reasons { grid-template-columns: 1fr; }
    .rsn.wide { flex-direction: column; }
    .plans { grid-template-columns: 1fr; }
    .steps { grid-template-columns: 1fr; }
    .final h2 { font-size: 26px;  color:#FFFFFF;}
  }
    .profit-sec h2 { color:#FFFFFF; }
    .sec h2 { color:#FFFFFF; }
    .sec h3 { color:#FFFFFF; }
    .final h2 { color:#FFFFFF; }
    .sec-eys { font-size: 10px; letter-spacing: .22em; color: #E24B4A; text-transform: uppercase; margin-bottom: 12px; align-items: center; }