/* =========================================================================
 * Components：按鈕 / 卡片 / 區塊容器 / 分段切換 / badge / 規格表 / 降級佔位
 * ====================================================================== */

/* ---- Container & Section ---- */
.bnes-container { width: 100%; margin-inline: auto; padding-inline: var(--sp-40); }
.bnes-container--content { max-width: var(--container-content); }
.bnes-container--wide { max-width: var(--container-wide); }
.bnes-container--full { max-width: none; padding-inline: 0; }

.bnes-section { padding-block: var(--sp-70); }
.bnes-section--bg-base { background: var(--c-bg); }
.bnes-section--bg-surface { background: var(--c-surface); }
.bnes-section--bg-surface-muted { background: var(--c-surface-muted); }
.bnes-section--bg-dark {
  background: var(--c-dark);
  color: var(--c-text-on-dark);
}
.bnes-section--bg-dark :is(h1,h2,h3,h4) { color: var(--c-text-on-dark); }

/* ---- Button ---- */
.bnes-btn {
  --_bg: var(--c-accent);
  --_fg: #fff;
  --_bd: transparent;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  font-family: var(--font-body);
  font-weight: 600;
  line-height: 1;
  text-align: center;
  border: 1.5px solid var(--_bd);
  border-radius: var(--r-pill);
  background: var(--_bg);
  color: var(--_fg);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease),
              border-color var(--dur-fast) var(--ease),
              transform var(--dur-fast) var(--ease),
              box-shadow var(--dur-fast) var(--ease);
}
.bnes-btn:hover { color: var(--_fg); transform: translateY(-1px); }
.bnes-btn:active { transform: translateY(0); }
.bnes-btn__label { display: inline-block; }

/* sizes */
.bnes-btn--sm { padding: 0.5rem 1rem; font-size: var(--fs-sm); }
.bnes-btn--md { padding: 0.75rem 1.5rem; font-size: var(--fs-base); }
.bnes-btn--lg { padding: 1rem 2rem; font-size: var(--fs-lg); }
.bnes-btn--full { width: 100%; }

/* variants */
.bnes-btn--primary { --_bg: var(--c-accent); --_fg: #fff; box-shadow: var(--shadow-sm); }
.bnes-btn--primary:hover { --_bg: var(--c-accent-strong); box-shadow: var(--shadow-md); }

.bnes-btn--secondary { --_bg: transparent; --_fg: var(--c-accent-strong); --_bd: var(--c-accent); }
.bnes-btn--secondary:hover { --_bg: var(--c-accent-soft); --_fg: var(--c-accent-strong); }

.bnes-btn--ghost { --_bg: transparent; --_fg: var(--c-text); --_bd: var(--c-border-strong); }
.bnes-btn--ghost:hover { --_bg: var(--c-surface); --_fg: var(--c-text); }

.bnes-btn--dark { --_bg: var(--c-dark); --_fg: #fff; }
.bnes-btn--dark:hover { --_bg: var(--c-dark-2); }

/* ---- Card ---- */
.bnes-card {
  background: var(--c-bg);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  padding: var(--sp-40);
  box-shadow: var(--shadow-xs);
  transition: box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.bnes-card--default:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.bnes-card--outline { box-shadow: none; }
.bnes-card--dark {
  background: var(--c-dark);
  color: var(--c-text-on-dark);
  border-color: transparent;
}
.bnes-card--dark :is(h1,h2,h3,h4) { color: var(--c-text-on-dark); }

/* ---- Segmented toggle（Local / Regional / Unlimited，對應截圖珊瑚分頁）---- */
.bnes-segmented {
  display: inline-flex;
  gap: 0.25rem;
  padding: 0.35rem;
  background: var(--c-surface);
  border-radius: var(--r-pill);
  border: 1px solid var(--c-border);
}
.bnes-segmented__item {
  appearance: none;
  border: 0;
  background: transparent;
  color: var(--c-text-muted);
  font-weight: 600;
  padding: 0.6rem 1.4rem;
  border-radius: var(--r-pill);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease);
}
.bnes-segmented__item[aria-selected="true"],
.bnes-segmented__item.is-active {
  background: var(--c-accent);
  color: #fff;
}
.bnes-segmented__item:hover:not([aria-selected="true"]):not(.is-active) {
  color: var(--c-text);
}

/* ---- Badge / Pill ---- */
.bnes-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-size: var(--fs-xs);
  font-weight: 600;
  padding: 0.3rem 0.7rem;
  border-radius: var(--r-pill);
  background: var(--c-accent-soft);
  color: var(--c-accent-strong);
}
.bnes-badge--gold { background: #F7EFD6; color: var(--c-gold); }
.bnes-badge--success { background: #E4F6EC; color: var(--c-success); }
.bnes-badge--dark { background: var(--c-dark); color: #fff; }

/* ---- Check list（青/珊瑚勾選清單）---- */
.bnes-checklist { list-style: none; margin: 0; padding: 0; display: grid; gap: var(--sp-30); }
.bnes-checklist li { display: flex; gap: 0.6rem; align-items: flex-start; }
.bnes-checklist .bnes-icon--check { color: var(--c-accent); flex: 0 0 auto; margin-top: 2px; }

/* ---- Icon ---- */
.bnes-icon { display: inline-block; vertical-align: middle; }

/* ---- Spec table（商品 eSIM 規格降級用）---- */
.bnes-spec { display: grid; gap: 0.75rem; margin: 0; }
.bnes-spec__row {
  display: flex; justify-content: space-between; gap: 1rem;
  padding-bottom: 0.75rem; border-bottom: 1px solid var(--c-border);
}
.bnes-spec__row:last-child { border-bottom: 0; padding-bottom: 0; }
.bnes-spec dt { color: var(--c-text-muted); margin: 0; }
.bnes-spec dd { font-weight: 600; margin: 0; text-align: right; }

/* ---- Fallback 佔位（缺插件時）---- */
.bnes-fallback {
  border: 1px dashed var(--c-border-strong);
  border-radius: var(--r-md);
  background: var(--c-surface);
  color: var(--c-text-muted);
  padding: var(--sp-30) var(--sp-40);
  font-size: var(--fs-sm);
}
.bnes-fallback p { margin: 0; }

/* ---- Search field（對應截圖珊瑚框搜尋）---- */
.bnes-search {
  display: flex; align-items: center; gap: 0.6rem;
  border: 1.5px solid var(--c-accent-border);
  border-radius: var(--r-lg);
  padding: 0.4rem 1rem;
  background: var(--c-bg);
}
.bnes-search:focus-within { border-color: var(--c-accent); box-shadow: 0 0 0 3px var(--c-accent-soft); }
.bnes-search input { border: 0; padding: 0.5rem 0; box-shadow: none; }
.bnes-search input:focus { box-shadow: none; }
.bnes-search .bnes-icon { color: var(--c-accent); flex: 0 0 auto; }

/* ---- Header ---- */
.bnes-header {
  position: sticky; top: 0; z-index: 100;
  background: rgba(255,255,255,0.92);
  backdrop-filter: saturate(140%) blur(8px);
  border-bottom: 1px solid var(--c-border);
}
.bnes-header__inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--sp-30); min-height: var(--header-h);
}
.bnes-header__title { font-weight: 800; font-size: var(--fs-xl); color: var(--c-text); }
.bnes-header__title:hover { color: var(--c-accent-strong); }
.bnes-header__toggle { padding: 0.5rem; }

.bnes-menu { list-style: none; display: flex; gap: var(--sp-40); margin: 0; padding: 0; }
.bnes-menu a { color: var(--c-text); font-weight: 600; }
.bnes-menu a:hover { color: var(--c-accent-strong); }

@media (max-width: 899px) {
  .bnes-header__nav {
    display: none; width: 100%; order: 3;
    padding-block: var(--sp-30);
  }
  .bnes-header__nav.is-open { display: block; }
  .bnes-menu { flex-direction: column; gap: var(--sp-20); }
  .bnes-header__inner { flex-wrap: wrap; }
}

/* ---- Footer ---- */
.bnes-footer { padding-block: var(--sp-60); }
.bnes-footer a { color: var(--c-text-on-dark-muted); }
.bnes-footer a:hover { color: var(--c-text-on-dark); }
.bnes-footer .widget__title { font-size: var(--fs-base); color: var(--c-text-on-dark); margin-bottom: var(--sp-20); }
.bnes-footer__cols { margin-bottom: var(--sp-50); }
.bnes-footer__copy { font-size: var(--fs-sm); margin: 0; padding-top: var(--sp-40); border-top: 1px solid rgba(255,255,255,0.12); }

/* ---- Design-system preview hero spacing ---- */
.bnes-ds-hero { padding-block: var(--sp-80) var(--sp-60); }

/* ---- Footer layout（Phase 2）---- */
.bnes-footer__top {
  display: grid; gap: var(--sp-50);
  grid-template-columns: 1fr;
  padding-bottom: var(--sp-50);
}
@media (min-width: 900px) {
  .bnes-footer__top { grid-template-columns: 1.2fr 2fr; }
}
.bnes-footer__title { font-size: var(--fs-xl); font-weight: 800; color: var(--c-text-on-dark); }
.bnes-footer__tagline { margin-top: var(--sp-20); max-width: 36ch; }
.bnes-footer__menus {
  display: grid; gap: var(--sp-40);
  grid-template-columns: repeat(2, 1fr);
}
@media (min-width: 700px) { .bnes-footer__menus { grid-template-columns: repeat(4, 1fr); } }
.bnes-footer__heading { font-size: var(--fs-base); color: var(--c-text-on-dark); margin: 0 0 var(--sp-20); }
.bnes-footer__list, .bnes-footer__social-list { list-style: none; margin: 0; padding: 0; display: grid; gap: var(--sp-20); }
.bnes-footer__social-list { grid-auto-flow: column; justify-content: start; gap: var(--sp-30); margin-top: var(--sp-30); }
.bnes-footer__widgets { padding-block: var(--sp-50) 0; }
