:root{
  --bg: #fff7fb;
  --panel: #ffffff;
  --text: #2b2b2b;
  --muted: rgba(43,43,43,.68);

  --border: rgba(43,43,43,.12);
  --shadow: 0 10px 30px rgba(43,43,43,.08);

  --radius: 18px;

  --accent: #ff7fb2;     /* ピンク寄り */
  --accent2: #7fd3ff;    /* 水色寄り */
  --accent3: #a7f0c2;    /* ミント寄り */
  --accent4: #ffe08a;    /* レモン寄り */

  --openBg: #e9fbf1;
  --limitedBg: #fff6e3;
  --closedBg: #ffe9f1;

  --openLine: #52c28b;
  --limitedLine: #ffb84d;
  --closedLine: #ff6fa6;
}

*{ box-sizing: border-box; }
body{
  margin: 0;
  font-family: ui-rounded, system-ui, -apple-system, "Segoe UI", sans-serif;
  color: var(--text);
  background:
    radial-gradient(900px 500px at 10% 5%, rgba(255,127,178,.22), transparent 60%),
    radial-gradient(900px 500px at 90% 10%, rgba(127,211,255,.22), transparent 60%),
    radial-gradient(900px 500px at 50% 95%, rgba(167,240,194,.22), transparent 60%),
    var(--bg);
}

.container{
  max-width: 980px;
  margin: 0 auto;
  padding: 28px 16px 72px;
}

.header{
  background: rgba(255,255,255,.7);
  border: 1px solid rgba(43,43,43,.08);
  border-radius: calc(var(--radius) + 4px);
  padding: 18px 18px 14px;
  box-shadow: var(--shadow);
  backdrop-filter: blur(6px);
}

.header h1{
  margin: 0 0 8px;
  font-size: 26px;
  letter-spacing: .01em;
}

.sub{
  margin: 0;
  color: var(--muted);
  font-size: 14px;
}

.grid{
  margin-top: 16px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); /* ← ここを変更 */
  gap: 14px;
}


.card{
  position: relative;
  border-radius: var(--radius);
  background: var(--panel);
  border: 1px solid rgba(43,43,43,.10);
  box-shadow: 0 10px 22px rgba(43,43,43,.07);
  padding: 14px 14px 12px 22px;  /* ← 左だけ増やす（重要） */
  display: flex;
  flex-direction: column;
  gap: 10px;
  transition: transform .12s ease, box-shadow .12s ease;
  overflow: hidden;              /* ← はみ出しを防ぐ */
}


.card:hover{
  transform: translateY(-2px);
  box-shadow: 0 16px 32px rgba(43,43,43,.10);
}

.month{
  font-weight: 800;
  font-size: 18px;
  display: flex;
  align-items: flex-start; /* ← 上に揃える */
  justify-content: space-between;
  gap: 10px;               /* ← 隙間 */
  flex-wrap: wrap;         /* ← 狭い時は折り返す */
}
.statusPill{
  flex: 0 0 auto;          /* ← つぶれない */
  white-space: nowrap;     /* ← 1行固定 */
}


.badge{
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.statusPill{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 7px 10px;
  border-radius: 999px;
  font-weight: 800;
  font-size: 14px;
  border: 1px solid rgba(43,43,43,.08);
}

.meta{
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
}

.small{
  color: rgba(43,43,43,.55);
  font-size: 12px;
}

.btn{
  margin-top: 6px;
  width: 100%;    
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 10px 12px;
  border-radius: 14px;
  text-decoration: none;
  font-weight: 800;
  border: 1px solid rgba(43,43,43,.12);
  background:
    linear-gradient(135deg, rgba(255,127,178,.22), rgba(127,211,255,.18), rgba(167,240,194,.18));
  color: var(--text);
  transition: filter .12s ease, transform .12s ease;
}

.btn:hover{ filter: brightness(1.02); transform: translateY(-1px); }
.btn:active{ transform: translateY(0); }

.howto{
  margin-top: 22px;
  padding: 16px 16px 14px;
  border-radius: calc(var(--radius) + 4px);
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(43,43,43,.08);
  box-shadow: var(--shadow);
  backdrop-filter: blur(6px);
}

.howto h2{
  margin: 0 0 10px;
  font-size: 17px;
}

.howto ul{
  margin: 0;
  padding-left: 18px;
  line-height: 1.7;
}

.note{
  margin: 10px 0 0;
  color: rgba(43,43,43,.60);
}

/* ステータス別（カード左のライン＋ピル背景） */
.card[data-status="open"]{
  background: linear-gradient(180deg, var(--openBg), #fff);
}
.card[data-status="limited"]{
  background: linear-gradient(180deg, var(--limitedBg), #fff);
}
.card[data-status="closed"]{
  background: linear-gradient(180deg, var(--closedBg), #fff);
}

.card::before{
  content:"";
  position:absolute;
  left: 8px;      /* ← 少し左へ */
  top: 12px;
  bottom: 12px;
  width: 6px;
  border-radius: 999px;
  background: rgba(43,43,43,.06);
}


.card[data-status="open"]::before{ background: var(--openLine); }
.card[data-status="limited"]::before{ background: var(--limitedLine); }
.card[data-status="closed"]::before{ background: var(--closedLine); }
