*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;-webkit-text-size-adjust:100%}
body{font-family:'Noto Sans JP','Hiragino Kaku Gothic ProN',sans-serif;background:#fdf5ff;color:#2d1b36;line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}

:root{
  --pink:#ff6b9d;
  --pink-light:#ffe4f0;
  --pink-dark:#d63384;
  --lavender:#c084fc;
  --lavender-light:#f0e8ff;
  --lavender-dark:#7c3aed;
  --bg:#fdf5ff;
  --white:#fff;
  --text:#2d1b36;
  --muted:#9e8aaa;
  --border:#e9d5f8;
}

/* ===== ヘッダー ===== */
.site-header{background:linear-gradient(135deg,#ff6b9d 0%,#c084fc 100%);position:sticky;top:0;z-index:100;box-shadow:0 2px 16px rgba(192,132,252,.35)}
.nav-inner{max-width:960px;margin:0 auto;padding:0 20px;height:60px;display:flex;align-items:center}
.logo{font-size:22px;font-weight:900;color:#fff;letter-spacing:-.5px;text-shadow:0 1px 4px rgba(0,0,0,.15)}

/* ===== 検索 ===== */
.header-search{margin-left:auto;display:flex;align-items:center}
.header-search input{background:rgba(255,255,255,.22);border:2px solid rgba(255,255,255,.45);border-radius:100px;padding:7px 18px;font-size:14px;color:#fff;width:190px;outline:none;transition:all .2s;font-family:inherit}
.header-search input::placeholder{color:rgba(255,255,255,.65)}
.header-search input:focus{background:rgba(255,255,255,.32);border-color:rgba(255,255,255,.85);width:230px}

.search-hero-wrap{margin:22px auto 0;max-width:440px;position:relative}
.search-hero{width:100%;padding:15px 56px 15px 22px;border:3px solid var(--border);border-radius:100px;font-size:16px;font-family:inherit;color:var(--text);outline:none;transition:border-color .2s,box-shadow .2s;background:#fff;box-shadow:0 4px 16px rgba(192,132,252,.15)}
.search-hero:focus{border-color:var(--pink);box-shadow:0 4px 24px rgba(255,107,157,.25)}
.search-hero-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:linear-gradient(135deg,#ff6b9d,#c084fc);border:none;border-radius:100px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:opacity .15s}
.search-hero-btn:hover{opacity:.85}
.search-hero-btn svg{display:block}
.no-results{display:none;color:var(--muted);text-align:center;padding:32px 0;font-size:15px}

/* ===== 浮遊デコレーション ===== */
.deco{position:absolute;border-radius:50%;pointer-events:none;animation:float 6s ease-in-out infinite}
.deco-1{width:130px;height:130px;background:var(--pink);opacity:.15;top:-30px;left:4%;animation-delay:0s}
.deco-2{width:80px;height:80px;background:var(--lavender);opacity:.2;top:20px;right:6%;animation-delay:1.8s}
.deco-3{width:55px;height:55px;background:#f9a8d4;opacity:.25;bottom:12px;left:22%;animation-delay:3.2s}
.deco-4{width:100px;height:100px;background:#a78bfa;opacity:.15;bottom:-16px;right:18%;animation-delay:.9s}
.deco-5{width:44px;height:44px;background:var(--pink);opacity:.2;top:55%;left:50%;animation-delay:2.5s}

@keyframes float{
  0%,100%{transform:translateY(0) rotate(0deg) scale(1)}
  33%{transform:translateY(-18px) rotate(4deg) scale(1.04)}
  66%{transform:translateY(-8px) rotate(-3deg) scale(.97)}
}

/* ===== ヒーロー（トップページ） ===== */
.hero-top{position:relative;overflow:hidden;padding:64px 20px 52px;text-align:center;background:linear-gradient(160deg,#fff0f8 0%,#f5edff 100%);border-bottom:2px solid var(--border)}
.hero-top-inner{position:relative;z-index:2}
.hero-top h1{font-size:clamp(24px,5.5vw,46px);font-weight:900;line-height:1.25;letter-spacing:-1px;margin-bottom:14px;background:linear-gradient(135deg,#ff6b9d,#7c3aed);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-top p{font-size:16px;color:var(--muted);max-width:420px;margin:0 auto}

/* ===== ヒーロー（詳細ページ） ===== */
.hero{position:relative;overflow:hidden;background:linear-gradient(160deg,#fff0f8 0%,#f5edff 100%);border-bottom:2px solid var(--border);padding:52px 20px 44px;text-align:center}
.hero-label{font-size:12px;font-weight:700;letter-spacing:2px;color:var(--lavender-dark);text-transform:uppercase;margin-bottom:12px}
.hero-title{font-size:clamp(20px,4.5vw,36px);font-weight:900;line-height:1.3;letter-spacing:-1px;margin-bottom:24px;color:var(--text)}
.hero-title span{background:linear-gradient(135deg,#ff6b9d,#7c3aed);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* ベストバッジ */
.best-badge{display:inline-flex;align-items:center;gap:10px;background:linear-gradient(135deg,#ff6b9d,#c084fc);border-radius:100px;padding:12px 28px;flex-wrap:wrap;justify-content:center;box-shadow:0 6px 20px rgba(255,107,157,.4)}
.best-label{font-size:12px;font-weight:700;color:rgba(255,255,255,.85);letter-spacing:1px}
.best-rate{font-size:26px;font-weight:900;color:#fff;letter-spacing:-1px;text-shadow:0 1px 4px rgba(0,0,0,.15)}
.best-site{font-size:14px;font-weight:700;color:rgba(255,255,255,.9);background:rgba(255,255,255,.22);padding:4px 12px;border-radius:100px}

/* ===== コンテンツ ===== */
.content-wrap{max-width:960px;margin:0 auto;padding:36px 20px 80px}
.section-label{font-size:12px;font-weight:700;letter-spacing:2px;color:var(--muted);text-transform:uppercase;margin-bottom:14px}
.ad-note{font-size:12px;color:var(--muted);margin-bottom:16px}

/* ===== キーワードタグ ===== */
.keyword-grid{display:flex;flex-wrap:wrap;gap:8px}
.keyword-card{display:inline-block;background:var(--white);border:2px solid var(--border);border-radius:100px;padding:8px 18px;font-weight:700;font-size:14px;color:var(--text);white-space:nowrap;transition:all .18s;box-shadow:0 2px 8px rgba(192,132,252,.07)}
.keyword-card:hover{border-color:var(--pink);background:var(--pink-light);color:var(--pink-dark);transform:translateY(-2px);box-shadow:0 6px 16px rgba(255,107,157,.2)}

/* ===== テーブル ===== */
.table-wrap{background:var(--white);border-radius:20px;border:2px solid var(--border);overflow:hidden;overflow-x:auto;box-shadow:0 4px 28px rgba(192,132,252,.1)}
.deal-table{width:100%;border-collapse:collapse;font-size:15px}
.deal-table thead tr{background:linear-gradient(135deg,#ffe4f0,#f0e8ff)}
.deal-table th{padding:14px 16px;text-align:left;font-size:12px;font-weight:700;letter-spacing:1px;color:var(--lavender-dark);white-space:nowrap;border-bottom:2px solid var(--border)}
.th-rank{width:68px}.th-rate{width:110px}.th-site{width:120px}
.row,.row-best{border-bottom:1px solid #f5eeff;transition:background .12s}
.row:hover{background:#fdf5ff}
.row-best{background:linear-gradient(135deg,#ffe4f0,#f0e8ff)}
.row-best:hover{background:linear-gradient(135deg,#ffd6e8,#e8dcff)}
.deal-table td{padding:14px 16px;vertical-align:middle}

/* 順位バッジ */
.deal-table .td-rank{vertical-align:middle;text-align:center;width:52px}
.rank-inner{display:flex;align-items:center;justify-content:center;height:100%}
.rank-medal,.rank-circle{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;font-size:13px;font-weight:800}
.rank-gold{background:linear-gradient(135deg,#ffd700,#ffaa00);color:#6b3d00;box-shadow:0 2px 8px rgba(255,180,0,.45)}
.rank-silver{background:linear-gradient(135deg,#d4d4d4,#a8a8a8);color:#3a3a3a;box-shadow:0 2px 6px rgba(160,160,160,.4)}
.rank-bronze{background:linear-gradient(135deg,#cd7f32,#a05220);color:#fff;box-shadow:0 2px 6px rgba(160,90,30,.4)}
.rank-circle{background:var(--lavender-light);color:var(--lavender-dark);font-size:12px}
.rank-dash{font-size:14px;color:var(--muted);font-weight:600}

/* 還元率 */
.deal-table .td-rate{vertical-align:middle;width:130px;text-align:right}
.rate{font-size:18px;font-weight:900;letter-spacing:-.5px;background:linear-gradient(135deg,#ff6b9d,#7c3aed);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;white-space:nowrap}

/* サイト名（枠なし・固定幅で揃える） */
.deal-table .td-site{vertical-align:middle;width:110px;text-align:center}
.site-link{font-size:13px;font-weight:700;white-space:normal;word-break:keep-all;line-height:1.3;transition:opacity .15s;display:inline-block}
.site-link:hover{opacity:.7;text-decoration:underline}

/* 案件名＋備考（縦積み） */
.deal-table .td-deal{vertical-align:middle}
.deal-link{display:block;color:var(--lavender-dark);font-size:15px;font-weight:600;line-height:1.5;margin-bottom:5px}.deal-link:last-child{margin-bottom:0}
.deal-link:hover{color:var(--pink-dark);text-decoration:underline}
/* 行タップ */
.deal-table tbody tr{cursor:pointer;transition:background .1s}
.deal-table tbody tr:active{background:var(--pink-light) !important}
.note-badge{display:inline-block;background:rgba(192,132,252,.12);color:var(--lavender-dark);font-size:12px;font-weight:400;padding:2px 8px 3px;border-radius:3px;border-bottom:2px solid rgba(192,132,252,.45);white-space:normal;word-break:break-all}

/* 一時停止行 */
.row-suspended{opacity:.55}
.rate-suspended{font-size:13px;font-weight:700;color:var(--muted);white-space:nowrap;background:none;-webkit-text-fill-color:var(--muted)}

/* 最終更新 */
.updated{font-size:13px;color:var(--muted);text-align:right;margin-top:12px}

/* ===== サイトロゴ ===== */
.site-logo{max-width:80px;max-height:34px;object-fit:contain;display:block;margin:0 auto}

/* ===== 吹き出し ===== */
.table-outer{position:relative;padding-top:48px}
.site-bubble{position:absolute;top:6px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,#ff6b9d,#c084fc);color:#fff;font-size:11px;font-weight:700;padding:7px 14px;border-radius:100px;white-space:nowrap;box-shadow:0 4px 14px rgba(255,107,157,.35);animation:bubble-float 2.8s ease-in-out infinite;z-index:2}
.site-bubble::after{content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);border:7px solid transparent;border-top-color:#c084fc}
@keyframes bubble-float{
  0%,100%{transform:translateX(-50%) translateY(0)}
  50%{transform:translateX(-50%) translateY(-7px)}
}
@keyframes bubble-float-mobile{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-7px)}
}

/* ===== フッター ===== */
.site-footer{background:linear-gradient(135deg,#f5edff,#fff0f8);color:var(--muted);border-top:2px solid var(--border);text-align:center;padding:28px;font-size:13px}

/* ===== モバイル ===== */
@media(max-width:600px){
  .table-outer{padding-top:40px}
  .site-bubble{left:auto;right:0;transform:none;animation:bubble-float-mobile 2.8s ease-in-out infinite}
  .site-bubble::after{left:auto;right:14px;transform:none}
  .hero,.hero-top{padding:40px 16px 32px}
  .content-wrap{padding:24px 12px 60px}
  .deco-4,.deco-5{display:none}
  .header-search input{width:120px;font-size:13px;padding:6px 12px}
  .header-search input:focus{width:148px}
  .search-hero-wrap{max-width:100%}

  /* テーブルをカード化（セル解体） */
  .table-wrap{overflow-x:unset;border-radius:14px}
  .deal-table,.deal-table tbody{display:block}
  .deal-table thead{display:none}
  .deal-table tr{
    display:grid;
    grid-template-columns:60px 1fr auto;
    grid-template-rows:auto auto;
    column-gap:10px;
    row-gap:8px;
    padding:14px;
    border-bottom:1px solid var(--border);
  }
  .deal-table td{padding:0;border:none;vertical-align:unset}
  .td-rank{grid-column:1;grid-row:1/3;display:flex;align-items:center;justify-content:center}
  .td-rate{grid-column:2;grid-row:1;display:flex;align-items:center}
  .td-site{grid-column:3;grid-row:1;display:flex;align-items:center;justify-content:flex-end}
  .td-deal{grid-column:2/4;grid-row:2}
  .rate{font-size:16px}
  .site-link{font-size:13px}
  .deal-link{font-size:14px}
}
