/* ======================================
   Global
====================================== */
body {
    margin: 0;
    padding: 0;
    font-family: 'Helvetica', 'Arial', sans-serif;
    color: #222;
    background: #f5f8fc;   /* 寒色系の淡いブルー背景 */
    line-height: 1.7;
}

/* ======================================
   Header
====================================== */
header {
    background: #ffffff;
    border-bottom: 1px solid #dce3ee;
    position: sticky;
    top: 0;
    z-index: 50;
}

.header-inner {
    max-width: 1100px;
    margin: 0 auto;
    padding: 18px 20px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.logo {
    font-size: 26px;
    font-weight: 900;
    color: #E60033; /* 赤アクセント */
    letter-spacing: 1.5px;
}

.logo span {
    display: block;
    font-size: 11px;
    color: #597a96;
    letter-spacing: 2px;
    margin-top: -4px;
}

.nav-links a {
    margin-left: 22px;
    text-decoration: none;
    color: #334;
    font-weight: 500;
    transition: 0.2s;
}

.nav-links a:hover {
    color: #E60033;
}

/* ======================================
   Hero Section
====================================== */
.hero {
    padding: 90px 20px 80px;
    text-align: center;
}

.hero-tag {
    display: inline-block;
    background: #E60033;
    color: white;
    padding: 6px 12px;
    border-radius: 4px;
    font-size: 12px;
    margin-bottom: 20px;
}

.hero-title {
    font-size: 40px;
    font-weight: 800;
    color: #1a1d21;
    line-height: 1.3;
}

.hero-text {
    font-size: 17px;
    max-width: 650px;
    margin: 20px auto;
    color: #445;
}

.hero-badge {
    display: inline-block;
    margin-top: 16px;
    background: #ffffff;
    padding: 10px 20px;
    border: 1px solid #ccd6e3;
    border-radius: 6px;
    font-size: 14px;
    color: #333;
}

/* ======================================
   Sections
====================================== */
.section {
    max-width: 1100px;
    margin: 70px auto;
    padding: 0 20px;
}

.section h2 {
    text-align: center;
    font-size: 28px;
    color: #1f2a37;
    margin-bottom: 10px;
}

.section-lead {
    text-align: center;
    font-size: 15px;
    color: #445;
    margin-bottom: 40px;
}

/* ======================================
   Cards
====================================== */
.card-grid {
    display: grid;
    gap: 28px;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    margin-top: 40px;
}

.card {
    background: white;
    padding: 24px;
    border-radius: 10px;
    border: 1px solid #dce3ee;
    box-shadow: 0 3px 8px rgba(0,0,0,0.04);
}

.card-label {
    font-size: 12px;
    font-weight: bold;
    color: #E60033;
    margin-bottom: 6px;
}

.card-title {
    font-size: 20px;
    font-weight: bold;
    margin-bottom: 8px;
    color: #222;
}

.card-text {
    font-size: 14px;
    color: #445;
}


/* ======================================
   CTA BOX
====================================== */
.cta-box {
    margin-top: 40px;
    padding: 28px;
    background: #ffffff;
    border: 2px solid #E60033;
    border-radius: 12px;
    text-align: center;
}

.cta-text {
    font-size: 15px;
    margin-bottom: 20px;
}

.cta-button {
    display: inline-block;
    background: #E60033;
    color: white;
    padding: 10px 22px;
    font-size: 16px;
    text-decoration: none;
    border-radius: 6px;
    transition: 0.2s;
}

.cta-button:hover {
    background: #c00028;
}

.cta-note {
    margin-top: 16px;
    font-size: 12px;
    color: #667;
}

/* ======================================
   FOOTER
====================================== */
.footer-note {
    margin-top: 70px;
    padding: 20px;
    text-align: center;
    color: #667;
    font-size: 12px;
}

/* =====================================
   SAMPLE STORES (表示イメージ)
====================================== */

.store-grid {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

/* 1店舗ごとのカード */
.store-card {
    display: flex;
    background: #ffffff;
    padding: 18px 20px;
    border-radius: 10px;
    border: 1px solid #dce3ee;
    box-shadow: 0 4px 12px rgba(0,0,0,0.04);
}

/* 左側・順位カラム */
.store-rank {
    width: 70px;
    text-align: center;
    border-right: 1px solid #edf2fb;
    margin-right: 18px;
    padding-right: 10px;
    flex-shrink: 0;
}

.store-rank-no {
    font-size: 22px;
    font-weight: 800;
    color: #E60033;
    line-height: 1.1;
}

.store-rank-label {
    margin-top: 4px;
    font-size: 11px;
    color: #899;
    letter-spacing: 1px;
}

/* 右側：店舗情報本体 */
.store-body {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

/* エリア・業態などの1行 */
.store-header-line {
    border: none !important;
}

.store-name {
    font-size: 18px;
    margin: 2px 0 4px;
    font-weight: 700;
}

.store-concept {
    font-size: 13px;
    color: #445;
    margin: 0 0 4px;
}

/* メタ情報（本日の出勤・在籍など） */
.store-meta-row {
    display: flex;
    flex-wrap: wrap;
    gap: 10px 20px;
    margin-top: 4px;
}

.store-meta-item {
    font-size: 12px;
    color: #556;
}

.store-meta-item .meta-label {
    font-weight: 600;
    margin-right: 4px;
}

/* フッター：推しセラピスト+アクション */
.store-footer {
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px dashed #e0e6f2;
}

.store-cast-heading {
    font-size: 13px;
    font-weight: 600;
    color: #334;
    margin-bottom: 8px;
}

.store-cast-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
}

.cast-card {
    flex: 1;
    background: #ffffff;
    border-radius: 8px;
    border: 1px solid #e2e7f2;
    padding: 8px 8px 10px;
    text-align: center;
    font-size: 12px;
}

.cast-photo {
    width: 100%;
    border-radius: 6px;
    overflow: hidden;
    margin-bottom: 6px;
}

.cast-photo img {
    width: 100%;
    height: 260px;
    object-fit: cover;
    border-radius: 8px;
}

.cast-name {
    font-weight: 700;
    font-size: 13px;
    margin-bottom: 2px;
    color: #222;
}

.cast-meta {
    font-size: 12px;
    color: #556;
    margin-bottom: 2px;;
}

.cast-tagline {
    font-size: 11px;
    color: #E60033;
}

.store-cast-list {
    flex: 1;
    margin: 0;
    padding-left: 18px;
    font-size: 12px;
    color: #445;
}

.store-cast-list li + li {
    margin-top: 2px;
}

/* ボタン類 */
.store-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: flex-end;
}

.store-actions a {
    display: inline-block;
    font-size: 12px;
    padding: 8px 14px;
    border-radius: 6px;
    text-decoration: none;
    font-weight: 600;
}

.btn-detail {
    border: 1px solid #dec3ee;
    color: #334;
    background: #fff;
}

.btn-call {
    background: #E60033;
    color: #fff;
}

/* 変更ポイント */
.today-btn {
    display: block;
    background: #e53935;
    color: #fff;
    padding: 14px 22px;
    border-radius: 10px;
    font-size: 18px;
    font-weight: 700;
    text-align: center;
    margin: 25px auto;
    width: 92%;
    box-shadow: 0 4px 12px rgba(229, 57, 53, 0.35);
}

.store-stats {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 16px;
    width: 100%;
    margin: 20px auto 10px;
}

.stat-box {
    max-width: 220px;
    flex: 1 1 160px;
    background: linear-gradient(90deg, #d0ac48, #ac9138);
    color: #fff;
    padding: 12px 10px;
    text-align: center;
    border-radius: 8px;
    font-size: 13px;
    font-weight: 500;
    box-shadow: 0 2px 6px rgba(200, 169, 81, 0.45);
}

.store-rank-top {
    background: linear-gradient(90deg, #C8A951, #E8D28B);
    color: #fff;
    padding: 6px 18px;
    display: inline-block;
    border-radius: 8px;
    font-size: 20px;
    font-weight: 800;
    margin-bottom: 12px;
    box-shadow: 0 3px 8px rgba(200, 169, 81, 0.4);
}

.rank-badge-wrap {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 12px;
    padding-bottom: 8px;
    border-bottom: 1px solid #ddd;
}

.rank-badge,
.rank-sample {
    display: inline-block;
}

.rank-badge {
    display: inline-block;
    background: #f7d86b;
    color: #000;
    padding: 4px 10px;
    border-radius: 4px;
    font-weight: 700;
    font-size: 13px;
}

.store-rank,
.store-rank-no,
.store-rank-label {
    display: none !important;
}

.store-rank,
.store-rank * {
    display: none !important;
}

html, body {
    max-width: 100%;
    overflow-x: hidden;
}

.rank-badge.rank-gold {
    background: linear-gradient(90deg, #d4af37, #f7d774);
    color: #000;
}

.rank-badge.rank-silver {
    background: linear-gradient(90deg, #c0c0c0, #e6e6e6);
    color: #000;
}

.rank-badge.rank-bronze {
    background: linear-gradient(90deg, #cd7f32, #e7a46e);
    color: #000;
}

.rank-sample {
    color: #555;
}

/* ==============================
   スマホ最適化（〜768px）
   ここから下を上書きしてOK
============================== */
@media (max-width: 768px) {

  /* テストしやすいように、背景色を少しだけ濃くしておく */
  body {
    font-size: 16px;
    line-height: 1.7;
  }

  header {
    position: sticky;
    top: 0;
  }

  .header-inner {
    padding: 14px 16px;
    flex-wrap: wrap;
    row-gap: 8px;
  }

  .logo {
    font-size: 22px;
  }

  .logo span {
    font-size: 10px;
  }

  .nav-links a {
    font-size: 13px;
    margin-left: 14px;
  }

  /* --- ヒーローエリア --- */
  .hero {
    padding: 60px 16px 40px;
    text-align: center;
  }

  .hero-title {
    font-size: 32px;
    line-height: 1.35;
  }

  .hero-text {
    font-size: 15px;
    max-width: 90%;
  }

  .hero-badge {
    font-size: 13px;
    padding: 9px 16px;
  }

  /* --- セクション --- */
  .section {
    margin: 50px auto;
    padding: 18px 20px;
  }

  .section h2 {
    font-size: 24px;
    margin-bottom: 18px;
  }

  .section-lead {
    font-size: 14px;
    margin-bottom: 28px;
  }

  /* --- 「ZUKANとは」カード --- */
  .card-grid {
    grid-template-columns: 1fr;
    gap: 18px;
    margin-top: 28px;
  }

  .card {
    padding: 18px 16px;
  }

  .card-title {
    font-size: 18px;
  }

  .card-text {
    font-size: 14px;
  }

  /* --- 店舗ランキングカード --- */
  .store-grid {
    gap: 16px;
  }

  .store-card {
    margin: 0 -10px;          /* 画面いっぱいに近づける */
    border-radius: 14px;
    padding: 18px 20px;
  }

  .store-rank {
    width: 100%;
    border-right: none;
    border-bottom: 1px solid #edf2fb;
    margin-right: 0;
    margin-bottom: 10px;
    padding-bottom: 6px;
    text-align: left;
    display: flex;
    align-items: baseline;
    gap: 8px;
  }

  .store-rank-no {
    font-size: 20px;
  }

  .store-rank-label {
    font-size: 11px;
  }

  .store-header-line {
    font-size: 13px;
  }

  .store-name {
    font-size: 24px;
    margin-top: 6px;
    margin-bottom: 12px;
  }

  .store-concept {
    font-size: 15px;
  }

  .store-meta-row {
    margin-top: 12px;
    margin-bottom: 20px;
  }

  .store-meta-item {
    font-size: 13px;
  }

  .store-meta-item .meta-label {
    display: block;
    margin-right: 0;
  }

  .store-meta-item .meta-value {
    font-weight: 600;
  }

  /* --- 推しセラピスト --- */
  .store-cast-heading {
    font-size: 13px;
    margin-bottom: 10px;
  }

  .store-cast-grid {
    display: grid;
    grid-template-columns: 1fr;  /* 1列表示にして写真大きく */
    gap: 10px;
  }

  .cast-card {
    text-align: left;
    padding: 10px 10px 12px;
  }

  .cast-photo img {
    width: 100%;
    height: 210px;
    object-fit: cover;
    display: block;
  }

  .cast-name {
    font-size: 14px;
    margin-top: 6px;
  }

  .cast-meta {
    font-size: 13px;
  }

  .cast-tagline {
    font-size: 12px;
  }

  /* --- ボタン --- */
  .store-actions {
    margin-top: 10px;
    gap: 8px;
  }

  .store-actions a {
    flex: 1;
    text-align: center;
    font-size: 13px;
    padding: 9px 0;
  }

  /* --- CTA --- */
  .cta-box {
    padding: 22px 16px;
  }

  .cta-text {
    font-size: 14px;
  }

  .cta-button {
    width: 100%;
    text-align: center;
    font-size: 15px;
  }

  .cta-note {
    font-size: 11px;
  }

  /* --- フッター --- */
  .footer-note {
    font-size: 11px;
    padding: 16px;
  }

  /*-- 小さいから改善 --*/
  h1, h2 {
    font-size: 26px;
    line-height: 1.3;
  }

  h3 {
    font-size: 22px;
    line-height: 1.4;
  }

  /* ステータスのボタン */
  .stat-box {
    font-size: 15px;
    padding: 14px 10px;
  }

  .cast-card img {
    height: 180px;
    object-fit: cover;
  }

  /*-- ランキングタグを大きく --*/
  .rank-badge {
    font-size: 16px;
    padding: 6px 12px;
  }

  .store-stats {
    justify-content: center;
    flex-wrap: wrap;
    gap: 8px;
    margin: 16px 0 10px;
  }

  .stat-box {
    min-width: auto;
    padding: 8px 6px;
    font-size: 11px;
    line-height: 1.4;
  }
}