/* styles.css — Bandori.fans Wiki/IMDB-density site */

:root {
  --bg: #f3f1ec;
  --bg-2: #ebe8e0;
  --bg-3: #e3dfd4;
  --paper: #fbfaf6;
  --ink: #1f1d1a;
  --ink-2: #45413b;
  --ink-3: #7a7569;
  --ink-4: #a8a294;
  --rule: #d8d3c5;
  --rule-2: #c5beac;
  --accent: #1f1d1a;
  --accent-soft: rgba(31,29,26,0.08);
  --accent-ink: #ffffff;
  --shadow-card: 0 1px 0 rgba(0,0,0,0.04);
  --display: "Futura BQ","Futura PT","Futura","Avenir Next","Noto Sans SC",ui-sans-serif,system-ui,sans-serif;
  --display-weight: 400;
  --serif:  "Futura BQ","Futura PT","Futura","Avenir Next","Noto Sans SC",ui-sans-serif,system-ui,sans-serif;
  --sans:   "Futura BQ","Futura PT","Futura","Avenir Next","Noto Sans SC","PingFang SC","HarmonyOS Sans SC",ui-sans-serif,system-ui,sans-serif;
  --mono:   "JetBrains Mono","Roboto Mono",ui-monospace,SFMono-Regular,Menlo,monospace;
}
[data-theme="dark"] {
  --bg: #161513;
  --bg-2: #1d1c19;
  --bg-3: #232220;
  --paper: #1a1916;
  --ink: #f1efe9;
  --ink-2: #c9c5bb;
  --ink-3: #8e887b;
  --ink-4: #5d5852;
  --rule: #2c2b27;
  --rule-2: #3a3833;
  --accent-soft: rgba(255,255,255,0.06);
  --shadow-card: 0 1px 0 rgba(255,255,255,0.02);
}

*,*::before,*::after { box-sizing: border-box; }
html,body { margin:0; padding:0; }
body {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 13.5px;
  line-height: 1.8;
  font-feature-settings: "palt";
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  letter-spacing: 0.012em;
}
a { color: inherit; text-decoration: none; }
a:hover { color: var(--accent); }
button { font-family: inherit; }

/* ───── Layout ───── */
.bf-shell { min-height: 100vh; display: flex; flex-direction: column; }
.bf-container { width: 100%; max-width: 1380px; margin: 0 auto; padding: 0 24px; }
@media (max-width: 700px){ .bf-container { padding: 0 14px; } }

/* ───── Top utility bar ───── */
.bf-utility {
  background: var(--ink);
  color: #d9d5c8;
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.04em;
}
.bf-utility .bf-container { display:flex; align-items:center; justify-content:space-between; height:28px; gap: 12px; }
.bf-utility .bf-uleft { display:flex; gap: 14px; align-items:center; opacity: 0.85; }
.bf-utility .bf-uright{ display:flex; gap: 14px; align-items:center; opacity: 0.7; }
.bf-utility .bf-pulse { width:6px; height:6px; border-radius:50%; background:#7be0a3; box-shadow:0 0 0 0 rgba(123,224,163,0.6); animation: pulse 1.8s infinite; display:inline-block; vertical-align:middle; margin-right:6px; }
@keyframes pulse { 0%{box-shadow:0 0 0 0 rgba(123,224,163,0.6);} 70%{box-shadow:0 0 0 6px rgba(123,224,163,0);} 100%{box-shadow:0 0 0 0 rgba(123,224,163,0);} }

/* ───── Masthead ───── */
.bf-mast {
  background: var(--paper);
  border-bottom: 1px solid var(--rule);
  padding: 22px 0 16px;
}
.bf-mast .bf-container { display: grid; grid-template-columns: auto 1fr auto; gap: 32px; align-items: end; }

/* Logo: clean geometric type lockup (RiNG-style) — wide-tracked tag above, heavy wordmark with accent lowercase 'i' */
.bf-logo { display: inline-flex; flex-direction: column; align-items: flex-start; gap: 4px; text-decoration: none; color: var(--ink); font-family: var(--display); }
.bf-logo .lg-words { display: flex; flex-direction: column; align-items: flex-start; gap: 6px; }
.bf-logo .lg-tag { display: inline-block; font-family: var(--display); font-weight: 600; font-size: 11px; letter-spacing: 0.42em; color: var(--ink-2); text-transform: uppercase; padding-left: 4px; }
.bf-logo .lg-1 { display: inline-flex; align-items: baseline; font-size: 46px; line-height: 0.92; letter-spacing: -0.005em; font-weight: 800; }
.bf-logo .lg-1 .lg-bandori { color: var(--ink); }
.bf-logo .lg-1 .lg-O { display: inline-block; }
.bf-logo .lg-1 .lg-i { font-style: normal; text-transform: lowercase; font-weight: 800; color: var(--accent); }
.bf-logo .lg-1 .dot { color: var(--accent); font-size: 46px; line-height: 1; margin: 0 1px; font-weight: 800; }
.bf-logo .lg-1 .lg-fans { font-weight: 800; color: var(--ink); letter-spacing: -0.005em; }
.bf-logo .lg-strip { display: inline-flex; align-items: center; gap: 8px; font-family: var(--mono); font-size: 10px; letter-spacing: 0.16em; color: var(--ink-3); text-transform: uppercase; flex-wrap: wrap; margin-top: 4px; padding-left: 4px; }
.bf-logo .lg-strip-jp { color: var(--ink-2); letter-spacing: 0.08em; font-family: var(--sans); font-size: 11px; text-transform: none; }
.bf-logo .lg-strip-sep { color: var(--ink-4); }
.bf-logo:hover .lg-1 .lg-i, .bf-logo:hover .lg-1 .dot { color: var(--ink); }
.bf-logo:hover .lg-tag { color: var(--accent); }

.bf-mast-meta { display:flex; flex-direction:column; gap:6px; align-items:flex-start; padding-bottom: 6px; max-width: 580px; }
.bf-mast-meta .ml-tag { font-family: var(--mono); font-size: 10px; letter-spacing: 0.16em; color: var(--ink-3); text-transform: uppercase; }
.bf-mast-meta .ml-desc { font-size: 13px; color: var(--ink-2); line-height:1.7; font-weight: 400; }

.bf-search { display:flex; align-items:stretch; border:1px solid var(--rule-2); background: var(--bg); padding: 0; height: 36px; min-width: 280px; }
.bf-search input { flex: 1; border: 0; background: transparent; padding: 0 12px; font: inherit; color: var(--ink); outline: none; font-size: 12px; }
.bf-search input::placeholder { color: var(--ink-4); }
.bf-search .bf-skbd { display:flex; align-items:center; padding: 0 8px; font-family: var(--mono); font-size: 10px; color: var(--ink-3); border-left: 1px solid var(--rule); background: var(--paper); }
.bf-search button { border:0; background: var(--accent); color: var(--accent-ink); padding: 0 14px; font-family: var(--mono); font-size: 11px; letter-spacing:0.1em; cursor: pointer; }

/* ───── Primary nav ───── */
.bf-nav { background: var(--paper); border-bottom: 1px solid var(--rule); position: sticky; top: 0; z-index: 30; }
.bf-nav .bf-container { display:flex; align-items:stretch; gap: 0; }
.bf-nav a { display:flex; align-items:center; gap:8px; padding: 0 18px; height: 42px; font-size: 12.5px; color: var(--ink-2); border-right: 1px solid var(--rule); position: relative; }
.bf-nav a:first-child { border-left: 1px solid var(--rule); }
.bf-nav a .nv-jp { font-weight: 600; }
.bf-nav a .nv-cn { font-family: var(--mono); font-size: 10px; color: var(--ink-3); letter-spacing: 0.06em; }
.bf-nav a:hover { background: var(--bg-2); color: var(--ink); }
.bf-nav a.active { color: var(--ink); background: var(--bg-2); }
.bf-nav a.active::after { content:""; position:absolute; left:0; right:0; bottom:-1px; height:2px; background: var(--accent); }
.bf-nav .bf-nav-spacer { flex:1; border-bottom: 1px solid transparent; }
.bf-nav .bf-nav-misc { display:flex; align-items:center; gap: 12px; font-family: var(--mono); font-size: 10.5px; color: var(--ink-3); padding: 0 4px; }

/* ───── Band switcher (sticky strip) ───── */
.bf-bands { background: var(--bg); border-bottom: 1px solid var(--rule); position: sticky; top: 42px; z-index: 25; }
.bf-bands .bf-container { display:flex; align-items: stretch; overflow-x: auto; scrollbar-width: none; }
.bf-bands .bf-container::-webkit-scrollbar { display: none; }
.bf-band {
  flex: 0 0 auto;
  display: grid; grid-template-columns: 12px auto; gap: 10px; align-items: center;
  padding: 10px 16px;
  border-right: 1px solid var(--rule);
  cursor: pointer;
  background: transparent;
  border-top: 0; border-bottom: 0; border-left: 0;
  text-align: left;
  font-family: inherit;
  color: var(--ink-2);
  position: relative;
}
.bf-band:first-child { border-left: 1px solid var(--rule); }
.bf-band:hover { background: var(--bg-2); }
.bf-band.active { background: var(--paper); color: var(--ink); }
.bf-band.active::after { content:""; position:absolute; left:0; right:0; bottom:-1px; height:2px; background: var(--band-color, var(--accent)); }
.bf-band .bf-bdot { width:10px; height:10px; background: var(--band-color); border-radius: 1px; }
.bf-band .bf-bnm { display:flex; flex-direction:column; line-height: 1.2; }
.bf-band .bf-bnm-en { font-size: 11.5px; font-weight: 600; letter-spacing: 0.01em; }
.bf-band .bf-bnm-jp { font-family: var(--mono); font-size: 9.5px; color: var(--ink-3); letter-spacing: 0.06em; margin-top: 2px; }

/* ───── Hero / featured row ───── */
.bf-hero { padding: 36px 0 30px; border-bottom: 1px solid var(--rule); background: var(--bg); }
.bf-hero-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 24px; }
.bf-hero-grid-2 { grid-template-columns: 1.35fr 1fr; gap: 28px; }
@media (max-width: 1000px){ .bf-hero-grid, .bf-hero-grid-2 { grid-template-columns: 1fr; } }

/* ───── Quick-access strip ───── */
.bf-qa { padding: 36px 0 56px; background: var(--bg); border-top: 1px solid var(--rule); }
.bf-qa-hd { display:flex; align-items:baseline; gap: 18px; padding-bottom: 16px; margin-bottom: 18px; border-bottom: 1px solid var(--rule); }
.bf-qa-tag { font-family: var(--mono); font-size: 11px; letter-spacing: .14em; color: var(--ink-3); text-transform: uppercase; }
.bf-qa-cn { font-family: var(--display); font-size: 18px; color: var(--ink); font-weight: 500; }
.bf-qa-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; border: 1px solid var(--rule); background: var(--rule); }
.bf-qa-card { background: var(--paper); padding: 22px 22px 20px; display: grid; grid-template-rows: auto auto auto; gap: 6px; position: relative; text-decoration: none; color: var(--ink); transition: background .14s ease, color .14s ease; min-height: 132px; }
.bf-qa-card .qa-k { font-family: var(--mono); font-size: 10.5px; letter-spacing: .18em; color: var(--ink-3); text-transform: uppercase; }
.bf-qa-card .qa-jp { font-family: var(--display); font-size: 22px; font-weight: 500; line-height: 1.2; letter-spacing: -.005em; color: var(--ink); }
.bf-qa-card .qa-cn { font-size: 12.5px; color: var(--ink-2); line-height: 1.5; align-self: end; }
.bf-qa-card .qa-arrow { position: absolute; top: 22px; right: 22px; font-family: var(--mono); font-size: 14px; color: var(--ink-3); transition: transform .18s ease, color .18s ease; }
.bf-qa-card:hover { background: var(--accent); color: var(--accent-ink); }
.bf-qa-card:hover .qa-k, .bf-qa-card:hover .qa-jp, .bf-qa-card:hover .qa-cn, .bf-qa-card:hover .qa-arrow { color: var(--accent-ink); }
.bf-qa-card:hover .qa-arrow { transform: translateX(4px); }
@media (max-width: 900px){ .bf-qa-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px){ .bf-qa-grid { grid-template-columns: 1fr; } }

/* Calendar: when used as the homepage main feature, give it more breathing room */
.bf-main { padding: 28px 0 8px; }
.bf-cal-cell { min-height: 104px; }

.bf-section-title {
  display:flex; align-items: baseline; justify-content: space-between; gap: 12px;
  border-bottom: 1px solid var(--ink); padding-bottom: 6px; margin-bottom: 12px;
}
.bf-section-title .st-title { font-family: var(--display); font-size: 22px; font-weight: 700; letter-spacing: -0.005em; }
.bf-section-title .st-title .st-jp { color: var(--ink-3); font-size: 11px; font-family: var(--mono); margin-left: 8px; letter-spacing: 0.12em; text-transform: uppercase; font-weight: 500; }
.bf-section-title .st-more { font-family: var(--mono); font-size: 11px; color: var(--ink-3); }
.bf-section-title .st-more:hover { color: var(--accent); }

/* "今日は何の日" hero */
.bf-whatday { background: var(--paper); border: 1px solid var(--rule); padding: 18px 18px 14px; display:flex; flex-direction:column; gap:10px; box-shadow: var(--shadow-card); }
.bf-whatday-hd { display:flex; align-items: baseline; justify-content: space-between; }
.bf-whatday-hd .wd-jp { font-family: var(--mono); font-size: 10px; letter-spacing: 0.12em; color: var(--ink-3); text-transform: uppercase; }
.bf-whatday-hd .wd-cn { font-family: var(--display); font-weight: 600; font-size: 16px; }
.bf-whatday-date { font-family: var(--display); font-weight: 600; line-height: 0.95; letter-spacing: -0.02em; display:flex; align-items: baseline; gap: 16px; padding: 6px 0 8px; border-bottom: 1px dashed var(--rule); }
.bf-whatday-date .wd-y { font-size: 18px; color: var(--ink-3); font-family: var(--mono); font-weight: 500; letter-spacing: 0.05em; font-style: normal; }
.bf-whatday-date .wd-md { font-size: 70px; }
.bf-whatday-date .wd-d { font-size: 16px; color: var(--ink-3); font-family: var(--mono); }
.bf-whatday-list { display:flex; flex-direction:column; gap: 10px; }
.bf-whatday-list .wd-row { display:grid; grid-template-columns: 50px 6px 1fr; gap: 10px; align-items: baseline; padding-bottom: 8px; border-bottom: 1px dotted var(--rule); }
.bf-whatday-list .wd-row:last-child { border-bottom: 0; }
.bf-whatday-list .wd-y2 { font-family: var(--mono); font-size: 12px; color: var(--ink-3); }
.bf-whatday-list .wd-mark { width: 6px; height: 6px; background: var(--band-color, var(--accent)); margin-top: 6px; border-radius: 1px; }
.bf-whatday-list .wd-text { font-size: 12.5px; color: var(--ink); line-height: 1.55; }
.bf-whatday-list .wd-text .wd-band { font-family: var(--mono); font-size: 10px; color: var(--band-color, var(--accent)); letter-spacing: 0.08em; text-transform: uppercase; margin-right: 6px; }

/* Live spotlight */
.bf-spotlight { background: var(--accent); color: var(--accent-ink); padding: 18px; display:flex; flex-direction:column; gap: 14px; min-height: 100%; }
.bf-spotlight .sp-tag { font-family: var(--mono); font-size: 10px; letter-spacing: 0.16em; opacity: 0.8; text-transform: uppercase; display:flex; align-items:center; gap: 8px;}
.bf-spotlight .sp-tag::before { content:""; width: 6px; height: 6px; border-radius: 50%; background: currentColor; opacity: 0.9; }
.bf-spotlight .sp-title { font-family: var(--display); font-size: 28px; line-height: 1.15; font-weight: 700; letter-spacing: -0.015em; }
.bf-spotlight .sp-meta { display:grid; grid-template-columns: auto 1fr; gap: 6px 14px; font-family: var(--mono); font-size: 11px; opacity: 0.85; }
.bf-spotlight .sp-meta dt { color: rgba(255,255,255,0.6); letter-spacing: 0.08em; text-transform: uppercase; }
.bf-spotlight .sp-meta dd { margin: 0; }
.bf-spotlight .sp-cta { display:inline-flex; gap: 6px; align-items:center; padding: 10px 14px; border:1px solid rgba(255,255,255,0.4); align-self: flex-start; font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; margin-top: auto; }
.bf-spotlight .sp-cta:hover { background: rgba(255,255,255,0.1); }

/* Quick stats column */
.bf-quick { display:flex; flex-direction:column; gap: 14px; }
.bf-quickcard { background: var(--paper); border: 1px solid var(--rule); padding: 16px 18px; display:flex; flex-direction:column; gap: 10px; box-shadow: var(--shadow-card); }
.bf-quickcard .qc-tag { font-family: var(--mono); font-size: 10px; letter-spacing: 0.12em; color: var(--ink-3); text-transform: uppercase; }
.bf-quickcard .qc-num { font-family: var(--display); font-size: 36px; line-height: 1; font-weight: 700; letter-spacing: -0.01em; }
.bf-quickcard .qc-meta { font-size: 11.5px; color: var(--ink-2); }
.bf-quickcard.qc-live { border-left: 3px solid var(--band-color, var(--accent)); }

/* ───── Main grid ───── */
.bf-main { padding: 28px 0; }
.bf-main-grid { display: grid; grid-template-columns: minmax(0, 2fr) minmax(0, 1fr); gap: 28px; }
@media (max-width: 1000px){ .bf-main-grid { grid-template-columns: 1fr; } }

/* News list */
.bf-news { background: var(--paper); border: 1px solid var(--rule); }
.bf-news-row { display: grid; grid-template-columns: 86px 64px 1fr 1fr; gap: 16px; align-items: baseline; padding: 14px 16px; border-bottom: 1px solid var(--rule); }
.bf-news-row:last-child { border-bottom: 0; }
.bf-news-row:hover { background: var(--bg-2); }
.bf-news-row .nw-d { font-family: var(--mono); font-size: 11.5px; color: var(--ink-3); }
.bf-news-row .nw-t { font-family: var(--mono); font-size: 9.5px; padding: 2px 6px; background: var(--bg-3); color: var(--ink-2); justify-self: start; letter-spacing: 0.08em; }
.bf-news-row .nw-title { font-size: 13px; color: var(--ink); font-weight: 500; line-height: 1.45; grid-column: 3 / span 2; display:flex; align-items: baseline; gap: 8px; }
.bf-news-row .nw-title .nw-band { display:inline-flex; align-items: center; gap: 6px; font-family: var(--mono); font-size: 10px; padding: 2px 6px; color: var(--accent-ink); background: var(--band-color, var(--ink)); letter-spacing: 0.06em; text-transform: uppercase; flex-shrink:0; }
.bf-news-row .nw-source { font-family: var(--mono); font-size: 10px; color: var(--ink-4); justify-self: end; }
@media (max-width: 700px){
  .bf-news-row { grid-template-columns: 70px 1fr; row-gap: 4px; }
  .bf-news-row .nw-t { grid-column: 2; }
  .bf-news-row .nw-title { grid-column: 1 / span 2; }
  .bf-news-row .nw-source { grid-column: 1 / span 2; }
}

/* Generic card */
.bf-card { background: var(--paper); border: 1px solid var(--rule); }

/* Calendar strip */
.bf-cal-grid { display:grid; grid-template-columns: repeat(7, 1fr); gap: 0; border: 1px solid var(--rule); background: var(--paper); }
.bf-cal-cell { border-right: 1px solid var(--rule); border-bottom: 1px solid var(--rule); padding: 8px 8px 10px; min-height: 88px; display:flex; flex-direction:column; gap: 4px; background: var(--paper); }
.bf-cal-cell:nth-child(7n) { border-right: 0; }
.bf-cal-head { display:flex; justify-content: space-between; align-items: baseline; }
.bf-cal-head .ch-d { font-family: var(--mono); font-size: 12px; font-weight: 600; color: var(--ink); }
.bf-cal-head .ch-w { font-family: var(--mono); font-size: 10px; color: var(--ink-3); }
.bf-cal-cell.is-today .ch-d { color: var(--accent); }
.bf-cal-cell.is-today { background: var(--accent-soft); }
.bf-cal-event { font-size: 10.5px; color: var(--ink-2); line-height: 1.35; padding: 3px 5px; border-left: 2px solid var(--band-color, var(--accent)); background: var(--bg-2); display:block; margin-top: 2px; }
.bf-cal-event:hover { background: var(--bg-3); }

/* Release table */
.bf-tbl { width:100%; border-collapse: collapse; background: var(--paper); border: 1px solid var(--rule); }
.bf-tbl th, .bf-tbl td { padding: 13px 14px; text-align: left; border-bottom: 1px solid var(--rule); vertical-align: baseline; line-height: 1.55; }
.bf-tbl th { font-family: var(--mono); font-size: 10px; letter-spacing: 0.1em; color: var(--ink-3); text-transform: uppercase; font-weight: 600; background: var(--bg-2); }
.bf-tbl tr:last-child td { border-bottom: 0; }
.bf-tbl tr:hover td { background: var(--bg-2); }
.bf-tbl .td-d { font-family: var(--mono); font-size: 11.5px; white-space: nowrap; color: var(--ink-2); }
.bf-tbl .td-band { font-family: var(--mono); font-size: 10px; padding: 2px 6px; color: var(--accent-ink); background: var(--band-color, var(--ink)); letter-spacing: 0.06em; text-transform: uppercase; display:inline-block; }
.bf-tbl .td-kind { font-family: var(--mono); font-size: 10px; padding: 2px 6px; background: var(--bg-3); color: var(--ink-2); letter-spacing: 0.08em; display:inline-block; }
.bf-tbl .td-cat { font-family: var(--mono); font-size: 10.5px; color: var(--ink-3); }
.bf-tbl .td-title { font-size: 13px; }
.bf-tbl .td-title small { color: var(--ink-3); display:block; font-size: 11px; margin-top:2px; }
.bf-tbl .td-status { font-family: var(--mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; }
.bf-tbl .td-status[data-s="open"]    { color: #2f7d4a; }
.bf-tbl .td-status[data-s="lottery"] { color: #b97a09; }
.bf-tbl .td-status[data-s="soldout"] { color: #ad2030; }

/* DB grid */
.bf-db { padding: 28px 0; border-top: 1px solid var(--rule); background: var(--bg-2); }
.bf-db-grid { display:grid; grid-template-columns: repeat(5, 1fr); gap: 12px; }
@media (max-width: 1000px){ .bf-db-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px){ .bf-db-grid { grid-template-columns: 1fr; } }
.bf-db-card { background: var(--paper); border: 1px solid var(--rule); padding: 18px 16px; display:flex; flex-direction:column; gap: 10px; min-height: 134px; position: relative; }
.bf-db-card:hover { border-color: var(--accent); }
.bf-db-card .db-num { position:absolute; top: 10px; right: 12px; font-family: var(--mono); font-size: 9.5px; color: var(--ink-4); }
.bf-db-card .db-jp { font-family: var(--display); font-size: 22px; font-weight: 700; letter-spacing: -0.01em; }
.bf-db-card .db-cn { font-family: var(--mono); font-size: 10px; color: var(--ink-3); letter-spacing: 0.08em; text-transform: uppercase; }
.bf-db-card .db-desc { font-size: 11.5px; color: var(--ink-2); line-height: 1.45; margin-top: auto; }
.bf-db-card .db-count { font-family: var(--mono); font-size: 11px; color: var(--accent); padding-top: 6px; border-top: 1px dashed var(--rule); }

/* Footer */
.bf-foot { background: var(--ink); color: rgba(255,255,255,0.72); padding: 36px 0 28px; margin-top: auto; font-size: 12px; }
.bf-foot a { color: rgba(255,255,255,0.85); text-decoration: underline; text-underline-offset: 3px; }
.bf-foot-grid { display:grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 36px; }
@media (max-width: 800px){ .bf-foot-grid { grid-template-columns: 1fr 1fr; } }
.bf-foot h4 { font-family: var(--mono); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: rgba(255,255,255,0.6); margin: 0 0 10px; font-weight: 600; }
.bf-foot ul { list-style: none; padding: 0; margin: 0; display:flex; flex-direction:column; gap: 6px; }
.bf-foot .bf-foot-mast { font-family: var(--display); font-size: 26px; color: #fff; font-weight: 700; line-height: 1; letter-spacing: -0.02em; }
.bf-foot .bf-foot-mast .dot { color: #ff5a85; }
.bf-foot .bf-foot-discl { font-family: var(--mono); font-size: 10.5px; line-height: 1.6; color: rgba(255,255,255,0.55); margin-top: 12px; max-width: 360px; }
.bf-foot-bottom { display:flex; justify-content: space-between; align-items: center; gap: 20px; flex-wrap: wrap; margin-top: 30px; padding-top: 18px; border-top: 1px solid rgba(255,255,255,0.12); font-family: var(--mono); font-size: 10.5px; color: rgba(255,255,255,0.5); }

/* small helpers */
.bf-pill {
  display:inline-flex; align-items:center; gap:6px;
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.08em;
  padding: 2px 6px; background: var(--bg-3); color: var(--ink-2); text-transform: uppercase;
}
.bf-divider { height:1px; background: var(--rule); margin: 24px 0; }
.bf-row-sub { font-family: var(--mono); font-size: 10.5px; color: var(--ink-3); }

/* Hide on mobile / desktop helpers */
@media (max-width: 700px){
  .bf-hide-mobile { display: none !important; }
  .bf-mast .bf-container { grid-template-columns: 1fr; gap: 16px; }
  .bf-mast-meta { display: none; }
  .bf-search { min-width: 0; }
  .bf-hero-grid { gap: 14px; }
}
