/* ============================================================
   Mythox — Journaling OS  (5.5-H1 · ground-up rebuild, 2026-06-11)
   Brand-new CSS. Zero reuse of the old journaling.css (v=p3).
   100% token-driven (global brand.css tokens) → follows all 3 themes
   + light mode with no shadow palette block. Semantic accent hues
   (mood/energy/section/category) are theme-neutral and only tint
   borders / labels / ring strokes / dots — never body text or surfaces.
   ============================================================ */

.j-root {
  /* semantic accents (theme-neutral; chrome stays on global tokens) */
  --s-mood:#60a5fa; --s-energy:#f1b542; --s-self:#ec6fae;
  --s-lesson:#a78bfa; --s-problem:#34d399; --s-bridge:#2dd4bf;
  position:relative; display:flex; flex-direction:column; gap:22px;
}

/* ---------------- HERO ---------------- */
.j-hero {
  position:relative; overflow:hidden; isolation:isolate;
  padding:30px 30px 28px; border-radius:var(--radius-lg);
  border:1px solid var(--line);
  background:
    radial-gradient(120% 140% at 92% -20%, var(--gold-soft), transparent 55%),
    linear-gradient(180deg, var(--surface), var(--surface-grad-2));
}
.j-hero-in { position:relative; z-index:1; }
.j-hero h1 { font-size:clamp(26px,3.6vw,38px); margin:10px 0 8px; }
.j-hero .sub { color:var(--muted); max-width:60ch; font-size:14.5px; }
.j-hero-controls { display:flex; flex-wrap:wrap; align-items:center; gap:10px; margin-top:20px; }
.j-date { display:inline-flex; align-items:center; gap:8px; padding:7px 12px; border-radius:10px;
  background:var(--ink-2); border:1px solid var(--line-2); color:var(--muted); font-size:13px; }
.j-date input { border:none; background:transparent; padding:0; color:var(--ivory); width:140px; box-shadow:none; }
.j-date input:focus { box-shadow:none; }
.j-save { display:inline-flex; align-items:center; gap:7px; font-family:var(--mono); font-size:11.5px;
  color:var(--muted); letter-spacing:.04em; margin-left:auto; }
.j-save-dot { width:8px; height:8px; border-radius:50%; background:var(--green); box-shadow:0 0 8px var(--green); }
.j-save.saving .j-save-dot { background:var(--gold); box-shadow:0 0 8px var(--gold-glow); animation:jpulse 1s infinite; }
.j-save.error .j-save-dot { background:var(--red); box-shadow:0 0 8px var(--red); }
@keyframes jpulse { 0%,100%{opacity:1} 50%{opacity:.35} }

/* ---------------- TAB STRIP ---------------- */
.j-tabs {
  position:sticky; top:0; z-index:20; display:flex; gap:4px; padding:8px;
  overflow-x:auto; scrollbar-width:none; -webkit-overflow-scrolling:touch;
  background:var(--topbar-bg); backdrop-filter:blur(14px);
  border:1px solid var(--line); border-radius:14px;
}
.j-tabs::-webkit-scrollbar { display:none; }
.j-tab {
  flex:0 0 auto; display:inline-flex; align-items:center; gap:7px;
  padding:9px 15px; border-radius:9px; font-size:13.5px; font-weight:600;
  color:var(--muted); text-decoration:none; white-space:nowrap;
  border:1px solid transparent; transition:color .15s, background .15s, border-color .15s;
}
.j-tab:hover { color:var(--ivory); background:var(--surface-2); }
.j-tab.active { color:var(--ivory); background:var(--surface-2); border-color:var(--gold-line); }
.j-tab-dot { width:6px; height:6px; border-radius:50%; background:transparent; transition:background .2s; }
.j-tab-dot.on { background:var(--gold); box-shadow:0 0 6px var(--gold-glow); }
.j-tab.active .j-tab-dot.on { background:var(--gold-2); }

/* ---------------- PANEL ---------------- */
.j-panel { display:flex; flex-direction:column; gap:16px; animation:jfade .3s var(--ease); }
@keyframes jfade { from{opacity:0; transform:translateY(6px)} to{opacity:1; transform:translateY(0)} }
.j-section-intro { color:var(--muted); font-size:14px; max-width:64ch; margin:2px 0 4px; }

/* shared form rhythm (brand.css styles label.field>span + inputs already) */
.j-panel .field { display:block; margin:0 0 2px; }
.j-panel textarea { min-height:92px; resize:vertical; line-height:1.6; }
.j-grid1 { display:block; }
.j-grid2, .j-grid3 { display:grid; gap:14px; }
.j-grid2 { grid-template-columns:1fr 1fr; }
.j-grid3 { grid-template-columns:repeat(3,1fr); }

.j-blocktitle { font-family:var(--mono); font-size:11.5px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--gold); margin:14px 0 4px; }
.j-block { padding:20px; border-radius:var(--radius-lg); border:1px solid var(--line);
  background:linear-gradient(180deg, var(--surface), var(--surface-grad-2)); display:flex; flex-direction:column; gap:2px; }
.j-note { padding:14px 16px; border-radius:12px; font-size:13px; color:var(--muted); line-height:1.65;
  border:1px solid var(--line); border-left:3px solid var(--fa,var(--gold));
  background:color-mix(in srgb, var(--fa,var(--gold)) 7%, var(--surface)); }
.j-note b { color:var(--fa,var(--gold)); font-weight:700; margin-right:6px; }

/* ---------------- SLIDERS ---------------- */
.j-slider { padding:16px 18px; border-radius:14px; border:1px solid var(--line);
  background:linear-gradient(180deg, var(--surface), var(--surface-grad-2)); }
.j-slider-top { display:flex; align-items:center; justify-content:space-between; margin-bottom:10px; }
.j-slider-label { font-size:13px; color:var(--muted); font-family:var(--mono); letter-spacing:.04em; }
.j-slider-label em { font-style:normal; font-size:17px; margin-left:4px; }
.j-slider-val { font-family:var(--serif); font-size:26px; font-weight:700; color:var(--fa,var(--gold)); line-height:1; }
.j-slider input[type=range] { width:100%; accent-color:var(--fa,var(--gold)); }
.j-slider-hint { font-size:11px; color:var(--dim); margin-top:8px; }

/* ---------------- DASHBOARD ---------------- */
.j-dash-hero { display:flex; align-items:center; gap:26px; padding:24px 28px; }
.j-dash-ringbig { flex:0 0 auto; width:132px; height:132px; display:grid; place-items:center; }
.j-dash-hero-meta h2 { font-size:clamp(19px,2.4vw,26px); margin:6px 0 6px; }
.j-dash-hero-meta .muted { font-size:13.5px; }
.j-kpis { display:grid; grid-template-columns:repeat(auto-fit,minmax(168px,1fr)); gap:14px; }
.j-kpi { display:flex; flex-direction:column; align-items:center; text-align:center; gap:10px; padding:20px 14px; }
.j-kpi-ring { width:80px; height:80px; display:grid; place-items:center; }
.j-kpi-meta { display:flex; flex-direction:column; gap:2px; }
.j-kpi-label { font-size:13px; font-weight:700; color:var(--ivory); }
.j-kpi-sub { font-size:11px; color:var(--dim); }
.j-kpi-num { justify-content:center; }
.j-kpi-val { font-family:var(--serif); font-size:42px; font-weight:700; color:var(--gold); line-height:1; }
.j-insights { display:grid; grid-template-columns:repeat(2,1fr); gap:14px; }
.j-insight { padding:16px 18px; border-left:3px solid var(--fa,var(--gold)); }
.j-insight-label { font-family:var(--mono); font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); }
.j-insight-val { font-size:13.5px; color:var(--ivory); margin-top:7px; min-height:34px; font-style:italic; line-height:1.55; }

/* ---------------- GOALS ---------------- */
.j-goals-head { display:flex; align-items:center; justify-content:space-between; gap:12px; margin-top:8px; }
.j-goals { display:grid; grid-template-columns:repeat(auto-fill,minmax(320px,1fr)); gap:14px; }
.j-empty { grid-column:1/-1; text-align:center; padding:40px 20px; color:var(--muted);
  border:1px dashed var(--line-2); border-radius:var(--radius-lg); }
.j-empty-ic { font-size:30px; opacity:.5; margin-bottom:8px; }
.j-goal { display:flex; gap:16px; padding:18px; border-radius:var(--radius-lg); border:1px solid var(--line);
  background:linear-gradient(180deg, var(--surface), var(--surface-grad-2));
  border-top:2px solid var(--cat,var(--gold)); align-items:flex-start; }
.j-goal.cat-youtube{--cat:var(--red)} .j-goal.cat-community{--cat:var(--warn)} .j-goal.cat-fitness{--cat:var(--green)}
.j-goal.cat-income{--cat:var(--gold)} .j-goal.cat-identity{--cat:#a78bfa} .j-goal.cat-other{--cat:var(--muted)}
/* light mode: category accents are tuned for dark; darken so the badge text reads on cream */
html[data-mode="light"] .j-goal.cat-youtube{--cat:#991b1b} html[data-mode="light"] .j-goal.cat-community{--cat:#78350f} html[data-mode="light"] .j-goal.cat-fitness{--cat:#166534}
html[data-mode="light"] .j-goal.cat-identity{--cat:#6d28d9} html[data-mode="light"] .j-goal.cat-other{--cat:#4b5563}
.j-goal-ring { flex:0 0 auto; width:72px; height:72px; display:grid; place-items:center; }
.j-goal-body { flex:1; min-width:0; display:flex; flex-direction:column; gap:8px; }
.j-goal-row1 { display:flex; align-items:center; gap:8px; }
.j-goal-badge { font-family:var(--mono); font-size:10px; text-transform:uppercase; letter-spacing:.06em;
  padding:3px 8px; border-radius:6px; color:var(--cat,var(--gold));
  background:color-mix(in srgb, var(--cat,var(--gold)) 14%, transparent); border:1px solid color-mix(in srgb, var(--cat,var(--gold)) 30%, transparent); }
.j-goal-status { font-size:10.5px; font-weight:700; padding:3px 8px; border-radius:6px; }
.j-goal-status.on-track{color:var(--green); background:color-mix(in srgb,var(--green) 14%,transparent)}
.j-goal-status.complete{color:var(--blue); background:color-mix(in srgb,var(--blue) 14%,transparent)}
.j-goal-status.behind{color:var(--red); background:color-mix(in srgb,var(--red) 14%,transparent)}
.j-goal-status.needs-sys{color:var(--gold); background:var(--gold-soft)}
.j-goal-x { margin-left:auto; width:24px; height:24px; border-radius:6px; border:1px solid var(--line-2);
  background:transparent; color:var(--dim); cursor:pointer; font-size:16px; line-height:1; }
.j-goal-x:hover { color:var(--red); border-color:var(--red); }
.j-goal-name { width:100%; font-size:15px; font-weight:600; padding:8px 10px; }
.j-goal-vals { display:flex; align-items:center; gap:6px; }
.j-goal-vals input { width:72px; padding:7px 9px; text-align:center; }
.j-goal-vals input.j-goal-unit { width:64px; }
.j-goal-vals span { color:var(--dim); }
.j-goal-toggle { align-self:flex-start; background:transparent; border:none; color:var(--gold);
  font-size:12px; font-weight:600; cursor:pointer; padding:2px 0; font-family:var(--mono); letter-spacing:.04em; }
.j-goal-detail { display:flex; flex-direction:column; gap:10px; margin-top:6px; padding-top:12px; border-top:1px dashed var(--line-2); }
.j-goal-detail .field { margin:0; }
.j-goal-meta { display:flex; align-items:center; gap:14px; flex-wrap:wrap; margin-top:4px; }
.j-goal-health { font-family:var(--mono); font-size:11px; padding:4px 9px; border-radius:6px; border:1px solid var(--line-2); }
.j-goal-health.good{color:var(--green)} .j-goal-health.ok{color:var(--gold)} .j-goal-health.bad{color:var(--red)}
.j-goal-align { flex:1; min-width:160px; font-size:11px; color:var(--muted); display:flex; flex-direction:column; gap:4px; }
.j-goal-align input { width:100%; accent-color:var(--gold); }
.j-align { display:flex; align-items:center; gap:16px; margin-top:14px; padding-top:14px; border-top:1px dashed var(--line-2); }
.j-align-ring { flex:0 0 auto; width:72px; height:72px; display:grid; place-items:center; }
.j-align-body { flex:1; display:flex; flex-direction:column; gap:8px; }
.j-align-body span { font-size:12px; color:var(--muted); }
.j-align-body input { width:100%; accent-color:var(--gold); }

/* ---------------- FIVE WHYS + SWOT ---------------- */
.j-whys { display:flex; flex-direction:column; align-items:stretch; gap:0; }
.j-why { padding:14px 16px; border-radius:12px; border:1px solid var(--line); background:var(--surface);
  border-left:3px solid var(--s-problem); }
.j-why-n { font-family:var(--mono); font-size:11px; letter-spacing:.04em; color:var(--s-problem); margin-bottom:8px; }
.j-why textarea { min-height:60px; }
.j-why-arrow { text-align:center; color:var(--dim); font-size:16px; padding:5px 0; }
.j-why-root { padding:16px; border-radius:12px; border:1px solid var(--gold-line); background:var(--gold-soft); }
.j-why-root .j-why-n { color:var(--gold); }
.j-swot { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.j-swot-cell { padding:14px 16px; border-radius:12px; border:1px solid var(--line);
  border-top:2px solid var(--fa,var(--gold)); background:var(--surface); }
.j-swot-cell > span { display:block; font-size:12px; font-weight:700; color:var(--fa,var(--gold)); margin-bottom:8px; }
.j-swot-cell textarea { background:transparent; border:none; box-shadow:none; padding:0; min-height:60px; }
.j-swot-cell textarea:focus { box-shadow:none; }

/* ---------------- DECISION MATRIX ---------------- */
.j-matrix-actions { display:flex; gap:8px; flex-wrap:wrap; }
.j-matrix-scroll { overflow-x:auto; border:1px solid var(--line); border-radius:14px; }
.j-matrix { width:100%; border-collapse:collapse; min-width:480px; }
.j-matrix th, .j-matrix td { padding:9px 10px; border-bottom:1px solid var(--line); text-align:center; vertical-align:middle; }
.j-matrix thead th { background:var(--surface-2); font-weight:600; font-size:12px; color:var(--muted); }
.j-mhead { text-align:left !important; min-width:170px; }
.j-mopt { display:flex; align-items:center; gap:6px; }
.j-mopt input, .j-mhead input { font-size:13px; padding:7px 9px; }
.j-mweight { display:flex; align-items:center; gap:6px; margin-top:6px; font-size:11px; color:var(--dim); }
.j-mweight input { width:54px; padding:5px 7px; }
.j-matrix td input[type=number] { width:64px; padding:7px; text-align:center; }
.j-mx { width:22px; height:22px; border-radius:6px; border:1px solid var(--line-2); background:transparent; color:var(--dim); cursor:pointer; }
.j-mx:hover { color:var(--red); border-color:var(--red); }
.j-mwin { background:var(--gold-soft); }
.j-mtotal td { background:var(--surface-2); font-size:16px; }
.j-mtotal b { color:var(--ivory); }
.j-mtotal .j-mwin b { color:var(--gold); }
.j-mbadge { font-family:var(--mono); font-size:9px; letter-spacing:.1em; color:var(--gold); margin-top:2px; }
.j-mresult { display:flex; align-items:center; justify-content:space-between; gap:12px; margin-top:14px;
  padding:16px 20px; border-radius:14px; border:1px solid var(--gold-line); background:var(--gold-soft); }
.j-mresult span { display:block; font-family:var(--mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--dim); }
.j-mresult b { font-family:var(--serif); font-size:20px; color:var(--gold); }
.j-mscore { font-size:13px; color:var(--muted); }

/* ---------------- SIX HATS ---------------- */
.j-hats { display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:14px; }
.j-hat { padding:16px; border-radius:14px; border:1px solid var(--line); border-top:2px solid var(--fa,var(--gold));
  background:linear-gradient(180deg, var(--surface), var(--surface-grad-2)); }
.j-hat-top { display:flex; align-items:center; gap:10px; margin-bottom:10px; }
.j-hat-ic { font-size:20px; }
.j-hat-top b { display:block; font-size:14px; color:var(--ivory); }
.j-hat-top span { font-size:11px; color:var(--dim); }
.j-hat textarea { min-height:90px; }

/* ---------------- SYSTEM CARD ---------------- */
.j-syscard { margin-top:14px; padding:20px; border-radius:var(--radius-lg); border:1px solid var(--s-bridge);
  background:color-mix(in srgb, var(--s-bridge) 8%, var(--surface)); display:flex; flex-direction:column; gap:12px; }
.j-syscard-t { font-family:var(--serif); font-size:17px; color:var(--s-bridge); }
.j-syscard-tags { display:flex; gap:8px; flex-wrap:wrap; }
.j-syscard-tags span { font-family:var(--mono); font-size:11px; padding:4px 10px; border-radius:7px;
  background:var(--surface-2); color:var(--muted); border:1px solid var(--line); }
.j-syscard-sec span { font-family:var(--mono); font-size:10px; letter-spacing:.08em; text-transform:uppercase; color:var(--dim); }
.j-syscard-sec p { margin:4px 0 0; font-size:13.5px; color:var(--ivory); line-height:1.55; }

/* ---------------- FREEFORM ---------------- */
.j-free-top { display:flex; justify-content:flex-end; }
.j-free-top span { font-size:11px; color:var(--dim); font-family:var(--mono); }
.j-free { width:100%; min-height:46vh; line-height:1.8; font-size:15px; }

/* ---------------- EXPORT ---------------- */
.j-export-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:14px; }
.j-prev-wrap { display:flex; flex-direction:column; gap:6px; }
.j-prev-t { font-family:var(--mono); font-size:11px; letter-spacing:.06em; color:var(--muted); }
.j-prev { margin:0; padding:14px; height:150px; overflow:auto; border-radius:12px; border:1px solid var(--line);
  background:var(--ink-2); color:var(--muted); font-size:11px; line-height:1.5; white-space:pre-wrap; word-break:break-word; }
.j-export-group { display:flex; flex-direction:column; gap:8px; }
.j-btns { display:flex; flex-wrap:wrap; gap:8px; }
.j-btn-warn { border-color:color-mix(in srgb,var(--gold) 40%,var(--line-2)) !important; color:var(--gold) !important; }
.j-btn-danger { border-color:color-mix(in srgb,var(--red) 45%,var(--line-2)) !important; color:var(--red) !important; }
.j-btn-danger:hover { background:color-mix(in srgb,var(--red) 12%,var(--surface-2)) !important; }
.j-storage { margin-top:12px; }
.j-storage-top { display:flex; justify-content:space-between; font-size:10.5px; color:var(--dim); margin-bottom:5px; }

/* ---------------- TOAST (fallback if shell toast absent) ---------------- */
.j-toast { position:fixed; left:50%; bottom:26px; transform:translateX(-50%) translateY(16px);
  padding:11px 18px; border-radius:10px; font-size:13.5px; font-weight:600; color:var(--ivory);
  background:var(--surface-3); border:1px solid var(--gold-line); box-shadow:0 16px 40px rgba(0,0,0,.5);
  opacity:0; pointer-events:none; transition:opacity .25s, transform .25s; z-index:200; }
.j-toast.show { opacity:1; transform:translateX(-50%) translateY(0); }
.j-toast.error { border-color:var(--red); }

/* ---------------- RESPONSIVE ---------------- */
@media (max-width:760px) {
  .j-hero { padding:22px 18px; }
  .j-grid2, .j-grid3, .j-swot { grid-template-columns:1fr; }
  .j-insights { grid-template-columns:1fr; }
  .j-goals { grid-template-columns:1fr; }
  .j-dash-hero { flex-direction:column; text-align:center; gap:14px; }
  .j-hero-controls { gap:8px; }
  .j-save { margin-left:0; order:5; width:100%; }
}
