/* ============================================
   Hub — Bento portfolio + Value props
   ============================================ */

/* Bento Grid */
.portfolio { padding: 48px 0; }

.bento {
  display: grid; gap: 8px;
  grid-template-columns: 1fr 1fr;
  padding: 0 20px;
}

.bento__card {
  position: relative; border-radius: var(--radius);
  overflow: hidden; aspect-ratio: 1;
  display: block;
}
.bento__card img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.6s var(--ease);
}
.bento__card:active img { transform: scale(1.03); }

.bento__overlay {
  position: absolute; bottom: 0; left: 0; right: 0;
  padding: 16px;
  background: linear-gradient(0deg, rgba(0,0,0,0.75) 0%, transparent 100%);
}
.bento__overlay h3 { font-size: 15px; font-weight: 600; margin-bottom: 2px; }
.bento__overlay p { font-size: 12px; color: var(--text-2); }

.bento__badge {
  display: inline-block; padding: 3px 8px;
  font-size: 10px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.05em; border-radius: 4px;
  background: #ff3b30; color: var(--white);
  margin-bottom: 6px;
}
.bento__badge--soon { background: var(--dark-surface); }

/* Large card spans full width */
.bento__card--large {
  grid-column: 1 / -1;
  aspect-ratio: 16/9;
}
/* Wide card spans full width */
.bento__card--wide {
  grid-column: 1 / -1;
  aspect-ratio: 2.2/1;
}

/* Values — editorial manifesto, no cards, no icons */
.values {
  padding: 48px 0;
  border-top: 1px solid var(--border);
}

.values__header {
  padding: 0 20px; margin-bottom: 40px;
}
.values__header h2 {
  font-size: 28px; font-weight: 600;
  letter-spacing: -0.03em; line-height: 1.1;
}

.values__list { padding: 0 20px; }

.values__item {
  position: relative;
  padding: 32px 0;
}

.values__num {
  font-size: 64px; font-weight: 700;
  letter-spacing: -0.04em; line-height: 1;
  color: rgba(255,255,255,0.04);
  position: absolute; top: 16px; left: 0;
  user-select: none; pointer-events: none;
}

.values__rule {
  width: 40px; height: 1px;
  background: var(--blue);
  margin-bottom: 16px;
  transition: width 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.values__item:hover .values__rule,
.values__item.revealed .values__rule { width: 80px; }

.values__content { position: relative; z-index: 1; }

.values__content h3 {
  font-size: 20px; font-weight: 600;
  letter-spacing: -0.02em;
  margin-bottom: 6px;
}

.values__content p {
  font-size: 14px; color: var(--text-2);
  line-height: 1.6; max-width: 400px;
}

/* Demo Overlay */
.bento__card--demo { cursor: pointer; }

.demo-overlay {
  position: fixed; inset: 0; z-index: 200;
  display: flex; align-items: center; justify-content: center;
  opacity: 0; visibility: hidden;
  transition: opacity 0.3s, visibility 0.3s;
}
.demo-overlay.open { opacity: 1; visibility: visible; }

.demo-overlay__scrim {
  position: absolute; inset: 0;
  background: rgba(0,0,0,0.7);
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
}

.demo-overlay__card {
  position: relative; z-index: 1;
  background: var(--dark-surface);
  border-radius: 16px; padding: 32px 24px;
  max-width: 380px; width: 88%;
  text-align: center;
  transform: translateY(30px) scale(0.95);
  transition: transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.demo-overlay.open .demo-overlay__card {
  transform: translateY(0) scale(1);
}

.demo-overlay__card h3 {
  font-size: 20px; font-weight: 600;
  margin-bottom: 12px;
}
.demo-overlay__card p {
  font-size: 14px; color: var(--text-2);
  line-height: 1.6; margin-bottom: 24px;
}
.demo-overlay__card .btn { margin-bottom: 12px; }

.demo-overlay__dismiss {
  font-size: 14px; color: var(--text-3);
  padding: 8px; transition: color 0.2s;
}
.demo-overlay__dismiss:hover { color: var(--white); }

/* ===== DESKTOP ===== */
@media (min-width: 769px) {
  .portfolio { padding: 80px 0; }

  .bento {
    max-width: 980px; margin: 0 auto; padding: 0 24px;
    grid-template-columns: repeat(3, 1fr); gap: 12px;
  }
  .bento__card { aspect-ratio: 4/3; }
  .bento__card--large { grid-column: span 2; grid-row: span 2; aspect-ratio: auto; }
  .bento__card--wide { grid-column: span 1; aspect-ratio: 4/3; }
  .bento__card:hover img { transform: scale(1.04); }

  .bento__overlay h3 { font-size: 21px; }
  .bento__overlay p { font-size: 14px; }

  .values { padding: 100px 0; }
  .values__header {
    max-width: 980px; margin: 0 auto 60px;
    padding: 0 24px;
  }
  .values__header h2 { font-size: 40px; }

  .values__list {
    max-width: 980px; margin: 0 auto; padding: 0 24px;
  }

  .values__item { padding: 48px 0; max-width: 520px; }

  /* Stagger: odd left, even right */
  .values__item--right {
    margin-left: auto;
    text-align: right;
  }
  .values__item--right .values__num { left: auto; right: 0; }
  .values__item--right .values__rule { margin-left: auto; }
  .values__item--right .values__content p { margin-left: auto; }

  .values__num { font-size: 96px; top: 24px; }
  .values__content h3 { font-size: 24px; }
}
