
/* === b9064: Ensure AI Analysis header sticks when embedded as a tab (no iframe) === */
#pane-analysis{
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}
#pane-analysis header{
  position: sticky;
  top: 0;
  z-index: 1000;
  background: var(--bar);
  border-bottom: 1px solid var(--border);
  box-shadow: 0 4px 10px rgba(0,0,0,.25);
}

:root{ --topbar-h:104px; }
:root{ --bg:#0a0a0a; --fg:#f2f2f2; --muted:#9ea0a4; --bar:#111; --border:#252525; --acc:#00ff00; color-scheme:dark; }
*{ box-sizing:border-box; } body{ margin:0; background:var(--bg); color:var(--fg); font-family: system-ui, -apple-system, Segoe UI, Roboto, 'Noto Sans JP', sans-serif; }
.topbar{ height:auto; z-index:1000;  flex-direction:column; align-items:stretch;  position:fixed; top:0; left:0; right:0; z-index:10; display:flex; align-items:center; gap:12px; background:var(--bar); border-bottom:1px solid var(--border); padding:8px 12px;  }
.brand{ font-size:24px;  font-weight:800; color:var(--fg); display:flex; align-items:center; gap:0; }
.tabs{ display:flex; flex:0 0 auto; justify-content:center; gap:24px; }
.tab{ word-spacing:0.25em; letter-spacing:0.02em;  appearance:none; border:1px solid var(--border); background:transparent; color:var(--fg); padding:10px 16px; border-radius:12px; cursor:pointer; }
.tab.active{ outline:2px solid var(--acc); }
.tab[disabled]{ opacity:.5; cursor:not-allowed; }
.btn.ghost{ appearance:none; border:1px solid var(--border); background:transparent; color:var(--fg); padding:8px 12px; border-radius:12px; cursor:pointer; }
.grow{ flex:1 1 auto; }

.viewport{ height: calc(100vh - var(--topbar-h)); margin-top: var(--topbar-h); }
.pane{ display:none; height:100%; }
.pane.active{ display:block; }
.frame{ width:100%; height:100%; border:0; background:#0b0b0b; }
.placeholder{ padding:18px; color:var(--muted); }

.logo-aifit{ font-size:24px;  color:#fff !important; font-weight:800; }
.logo-log{ font-size:24px;  color:var(--acc) !important; font-weight:800; margin-left:2px; }

#signout{ /* removed auto margin to keep next to bell */ }

.toprow{ display:flex; align-items:center; gap: 6px; }

.subbar{ display:flex; justify-content:center; gap:24px; padding-top:6px; border-top:1px solid var(--border); }

/* enforce left logo / right signout on top row */
.toprow{ justify-content:flex-start; width:100%; }

#build-badge{position:fixed;right:6px;bottom:6px;opacity:.35;font-size:11px;padding:2px 6px;border:1px solid var(--border);border-radius:8px;background:#0f0f0f;color:#9ea0a4;z-index:9999;}

/* --- Match Body Logs button size for Workout Logs graph/toggle buttons --- */
#btnOpenGraph, #btnWlToggle{
  font-size:14px !important;
  padding:10px 14px !important;
  border-radius:14px !important;
  min-width: initial !important;
}

/* --- Enforce Body Logs button size exactly (including line-height & weight) --- */
#btnOpenGraph, #btnWlToggle{
  font-size:14px !important;
  
  
  padding:10px 14px !important;
  border-radius:14px !important;
  min-width: initial !important;
  height:auto !important;
}

/* --- Match Body Logs button size exactly (use UA-normal line-height) --- */
#btnOpenGraph, #btnWlToggle{
  font-size:14px !important;
  line-height: normal !important;
  padding:10px 14px !important;
  border-radius:14px !important;
  min-width: initial !important;
  height:auto !important;
}

/* Force register button to Body Logs accent */
#btnRegister.btn-accent, #btnRegister.btn-accent.btn{
  background: var(--accent, #00FF00) !important;
  color: var(--accent-ink, #001b00) !important;
  border-color: #026902 !important;
}

/* Align labels to Body Logs look */
.card .row > label,
.card label{
  color: var(--muted, #9ea0a4) !important;
  font-size:18px !important;
}

/* Match Clear buttons to Register button sizing */
#btnClear{
  padding:14px 12px !important;
  font-size:18px !important;
  border-radius:16px !important;
}

/* Ensure graph/toggle button text weight matches Body Logs */
#btnOpenGraph, #btnWlToggle{
  font-weight:400 !important;
}


/* unify help '?' style */
.btn.ghost.q{ background:#0f0f0f; color:var(--fg); border:1px solid var(--border); }


/* b9018: Make tabs match Body Logs active style & prevent blue selection */
.tab{ background:#0a0a0a; border:1px solid var(--border); user-select:none; text-decoration:none; color:inherit; }
.tab:focus{ outline:none; box-shadow:0 0 0 2px rgba(0,255,0,.25); }
.tab.active{ background:#0f0f0f; border-color:var(--acc); box-shadow:0 0 0 2px rgba(0,255,0,.35); color:#fff; outline:none; }
.tab *{ user-select:none; }


/* === b9031 mobile iframe tweak === */
@media (max-width: 480px){
  .viewport, .pane, .frame{ width: 100%; max-width: 100%; overflow-x: hidden; }
  .tabs{ gap: 6px; }
}


/* ===== Patch 2025-11-03: header badge removal & right align ===== */
#build-badge, .build-badge, .badge-build { display: none !important; }
/* Top row layout: push controls to the right */
.topbar .toprow { display:flex; align-items:center; justify-content: flex-start; }
/* If an old spacer .grow exists, it isn't needed for right align */
.topbar .toprow .grow{ display:block; flex:1 1 auto; }


/* ===== header bell button (通知・リマインダー) ===== */
.iconbtn.bell{display:inline-flex;align-items:center;justify-content:center;gap:6px;
  width:auto;min-width:44px;min-height:36px;padding:6px 10px;border-radius:999px;
  background:transparent;border:1px solid var(--border);color:var(--fg);cursor:pointer}
.iconbtn.bell:hover{background:rgba(255,255,255,.06)}
.iconbtn.bell .ico{display:block}
/* keep header layout */
.topbar .toprow{display:flex;align-items:center;gap:  6px}

/* r19g modal */
.modal.hidden{ display:none; }
.modal{ position: fixed; inset:0; z-index: 4000; display:block; }
.modal-backdrop{ position:absolute; inset:0; background: rgba(0,0,0,.6); }
.modal-sheet{ position: absolute; inset:auto 0 0 0; margin:auto; width: min(880px, 96vw); max-height: 80vh; background:#0b0b0b; border:1px solid var(--border); border-radius:16px; box-shadow: 0 10px 40px rgba(0,0,0,.7); overflow:hidden; }
@media (min-width: 700px){ .modal-sheet{ inset:0; } }
.modal-bar{ display:flex; align-items:center; justify-content:space-between; gap:12px; padding:12px 16px; background: var(--bar); border-bottom:1px solid var(--border); }
.modal-title{ font-weight:700; color:#00FF00; font-size:16px; }
.modal-body{ width:100%; height: clamp(42vh, 60vh, 70vh); border:0; background:#0b0b0b; }
.iconbtn.close{ font-size:18px; line-height:1; padding:6px 10px; background:transparent; border:1px solid var(--border); border-radius:10px; color:#fff; cursor:pointer; margin-left:auto; }
.iconbtn.close:hover{ border-color: #00FF00; }
