/* ============================================================
   JERAFLARE OFFICE — works.css
   施工例ページ（works.html）専用スタイル
   ============================================================ */

/* ===== FILTER BAR ===== */
.filter-bar {
  padding: 36px 80px;
  background: var(--white);
  border-bottom: 1px solid rgba(184,146,74,0.1);
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  align-items: center;
}
.filter-label {
  font-family: var(--font-en-sub);
  font-size: 10px;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: var(--ink-light);
  margin-right: 6px;
}
.filter-btn {
  padding: 8px 20px;
  border: 1px solid rgba(26,24,18,0.14);
  background: transparent;
  font-family: var(--font-jp);
  font-size: 12px;
  color: var(--ink-light);
  cursor: pointer;
  letter-spacing: 0.04em;
  transition: all 0.25s;
}
.filter-btn:hover, .filter-btn.active {
  background: var(--ink);
  color: var(--cream);
  border-color: var(--ink);
}

/* ===== AI NOTICE ===== */
.ai-notice {
  margin: 0 80px 36px;
  padding: 18px 26px;
  border: 1px solid rgba(184,146,74,0.2);
  background: rgba(184,146,74,0.03);
  display: flex;
  gap: 14px;
  align-items: center;
  font-size: 12px;
  color: var(--ink-light);
  line-height: 1.8;
}
.ai-notice-icon { font-size: 18px; color: var(--gold); flex-shrink: 0; }

/* ===== WORKS GRID ===== */
.works-container { padding: 48px 80px 120px; }

.works-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}

.work-card {
  background: var(--white);
  border: 1px solid rgba(184,146,74,0.1);
  overflow: hidden;
  text-decoration: none;
  display: block;
  transition: transform 0.4s ease, box-shadow 0.4s ease;
}
.work-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 22px 60px rgba(26,24,18,0.09);
}
.work-card.large { grid-column: span 2; }

.work-img-wrap {
  position: relative;
  overflow: hidden;
}
.work-img {
  width: 100%;
  height: 256px;
  object-fit: cover;
  display: block;
  transition: transform 0.65s ease;
}
.work-card.large .work-img { height: 380px; }
.work-card:hover .work-img { transform: scale(1.05); }

.work-style-badge {
  position: absolute;
  top: 18px; left: 18px;
  background: rgba(26,24,18,0.78);
  color: var(--gold-light);
  font-family: var(--font-en-sub);
  font-size: 9.5px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  padding: 6px 14px;
  backdrop-filter: blur(4px);
}

.work-info { padding: 26px 26px 30px; }
.work-meta {
  display: flex;
  gap: 14px;
  margin-bottom: 10px;
  flex-wrap: wrap;
}
.work-meta-item {
  font-family: var(--font-en-sub);
  font-size: 10.5px;
  letter-spacing: 0.14em;
  color: var(--ink-light);
  display: flex;
  align-items: center;
  gap: 6px;
}
.work-meta-item::before { content: '—'; color: var(--gold); }

.work-name {
  font-size: 15.5px;
  font-weight: 400;
  color: var(--ink);
  letter-spacing: 0.03em;
  margin-bottom: 8px;
}
.work-desc {
  font-size: 12.5px;
  color: var(--ink-light);
  line-height: 1.95;
}
.work-price {
  display: inline-block;
  margin-top: 14px;
  font-family: var(--font-en);
  font-size: 22px;
  color: var(--gold);
  font-weight: 300;
}
.work-price-unit { font-size: 11px; }

/* ===== CTA BAR ===== */
.cta-bar {
  background: var(--ink);
  padding: 68px 80px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 40px;
}
.cta-bar-text h2 {
  font-family: var(--font-en);
  font-size: clamp(26px, 3vw, 38px);
  font-weight: 300;
  color: var(--cream);
  letter-spacing: 0.03em;
  margin-bottom: 8px;
}
.cta-bar-text p {
  font-size: 13.5px;
  color: rgba(237,232,224,0.5);
}

/* ===== RESPONSIVE (WORKS) ===== */
@media (max-width: 1024px) {
  .filter-bar { padding-left: 36px; padding-right: 36px; }
  .ai-notice { margin-left: 36px; margin-right: 36px; }
  .works-container { padding-left: 36px; padding-right: 36px; }
  .works-grid { grid-template-columns: repeat(2, 1fr); }
  .work-card.large { grid-column: span 2; }
  .cta-bar { padding-left: 36px; padding-right: 36px; flex-direction: column; text-align: center; }
}

@media (max-width: 768px) {
  .filter-bar { padding-left: 24px; padding-right: 24px; }
  .ai-notice { margin-left: 24px; margin-right: 24px; }
  .works-container { padding-left: 24px; padding-right: 24px; }
  .works-grid { grid-template-columns: 1fr; }
  .work-card.large { grid-column: span 1; }
  .work-card.large .work-img { height: 256px; }
  .cta-bar { padding: 48px 24px; }
}
