:root{
  --bg:#1e1e1e; --bg2:#252526; --bg3:#2d2d30; --line:#3a3a3c;
  --fg:#e6e6e6; --fg2:#a8a8ad; --accent:#7c5cff; --accent2:#9b86ff;
  --danger:#ff6b6b; --ok:#4ec9b0;
  --top:env(safe-area-inset-top,0px);
  --bot:env(safe-area-inset-bottom,0px);
}
*{box-sizing:border-box}
/* hidden 属性は常に最優先で効かせる（.busy や .editorview の display:flex に負けて
   スピナー/エディタが消えなくなる不具合を防ぐ） */
[hidden]{display:none!important}
html,body{height:100%;margin:0}
body{
  background:var(--bg);color:var(--fg);
  font:16px/1.6 -apple-system,BlinkMacSystemFont,"Hiragino Kaku Gothic ProN","Yu Gothic",sans-serif;
  -webkit-text-size-adjust:100%;
  display:flex;flex-direction:column;overflow:hidden;
}
/* ---- topbar ---- */
.topbar{
  display:flex;align-items:center;gap:4px;
  padding:calc(var(--top) + 6px) 8px 6px;
  background:var(--bg2);border-bottom:1px solid var(--line);
  flex:0 0 auto;
}
.title{flex:1;font-weight:600;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.icon{
  background:none;border:none;color:var(--fg);font-size:22px;line-height:1;
  width:40px;height:40px;border-radius:8px;
}
.icon:active{background:var(--bg3)}
#btnBack{font-size:28px}
/* ---- main / views ---- */
main{flex:1;position:relative;overflow:hidden}
.view{position:absolute;inset:0;overflow:auto;-webkit-overflow-scrolling:touch;padding:12px;padding-bottom:calc(12px + var(--bot))}
.editorview{display:flex;flex-direction:column;padding:0}
h2{margin:.2em 0 .8em;font-size:18px}
/* ---- settings ---- */
label{display:block;margin:10px 0;color:var(--fg2);font-size:13px}
input{
  width:100%;margin-top:4px;padding:11px 12px;
  background:var(--bg3);border:1px solid var(--line);border-radius:8px;
  color:var(--fg);font-size:16px;
}
input:focus{outline:none;border-color:var(--accent)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:0 10px}
.row{display:flex;gap:10px;margin-top:14px}
button.primary,button:not(.icon):not(.tab){
  padding:11px 16px;border:1px solid var(--line);border-radius:8px;
  background:var(--bg3);color:var(--fg);font-size:15px;font-weight:600;
}
button.primary{background:var(--accent);border-color:var(--accent);color:#fff}
button:active{filter:brightness(1.15)}
.status{margin-top:10px;font-size:13px;min-height:1.4em}
.status.ok{color:var(--ok)} .status.err{color:var(--danger)}
.help{margin-top:18px;color:var(--fg2);font-size:13px}
.help summary{cursor:pointer;color:var(--accent2)}
.help code{background:var(--bg3);padding:1px 5px;border-radius:4px}
.help ol{padding-left:1.2em}
/* ---- breadcrumb ---- */
.breadcrumb{display:flex;flex-wrap:wrap;gap:2px;align-items:center;font-size:13px;color:var(--fg2);margin-bottom:8px}
.breadcrumb a{color:var(--accent2);text-decoration:none}
.breadcrumb .sep{opacity:.5}
/* ---- file list ---- */
.filelist{list-style:none;margin:0;padding:0}
.filelist li{
  display:flex;align-items:center;gap:10px;
  padding:13px 8px;border-bottom:1px solid var(--line);
}
.filelist li:active{background:var(--bg2)}
.filelist .ic{width:22px;text-align:center;flex:0 0 auto}
.filelist .nm{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.filelist .dir .nm{color:var(--accent2)}
.filelist .muted{color:var(--fg2);opacity:.6}
.empty{color:var(--fg2);text-align:center;padding:30px}
.fab{
  position:fixed;right:18px;bottom:calc(18px + var(--bot));
  width:54px;height:54px;border-radius:27px;border:none;
  background:var(--accent);color:#fff;font-size:28px;
  box-shadow:0 4px 14px rgba(0,0,0,.5);
}
/* ---- editor ---- */
.editorbar{display:flex;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid var(--line);background:var(--bg2)}
.editname{flex:1;font-size:13px;color:var(--fg2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tabs{display:flex;background:var(--bg3);border-radius:8px;overflow:hidden}
.tab{padding:7px 14px;border:none;background:none;color:var(--fg2);font-size:13px}
.tab.active{background:var(--accent);color:#fff}
#editor{
  flex:1;width:100%;border:none;resize:none;padding:14px;
  background:var(--bg);color:var(--fg);
  font:15px/1.7 ui-monospace,"SF Mono",Menlo,Consolas,monospace;
}
#editor:focus{outline:none}
.preview{flex:1;overflow:auto;padding:14px}
.savebar{display:flex;gap:8px;padding:8px 10px;padding-bottom:calc(8px + var(--bot));border-top:1px solid var(--line);background:var(--bg2)}
.savebar input{margin:0;flex:1}
.savebar button{flex:0 0 auto}
/* ---- markdown preview ---- */
.markdown h1,.markdown h2,.markdown h3{border-bottom:1px solid var(--line);padding-bottom:.2em}
.markdown code{background:var(--bg3);padding:1px 5px;border-radius:4px;font-size:.9em}
.markdown pre{background:var(--bg3);padding:12px;border-radius:8px;overflow:auto}
.markdown pre code{background:none;padding:0}
.markdown blockquote{border-left:3px solid var(--accent);margin:0;padding-left:12px;color:var(--fg2)}
.markdown a{color:var(--accent2)}
.markdown table{border-collapse:collapse}
.markdown th,.markdown td{border:1px solid var(--line);padding:6px 10px}
.markdown .wikilink{color:var(--accent2);background:rgba(124,92,255,.12);padding:1px 5px;border-radius:4px}
.markdown .frontmatter{background:var(--bg2);border:1px solid var(--line);border-radius:8px;padding:8px 12px;font-size:.85em;color:var(--fg2);white-space:pre-wrap;margin-bottom:12px}
.markdown .tag{color:var(--accent2)}
/* ---- toast / busy ---- */
.toast{
  position:fixed;left:50%;bottom:calc(80px + var(--bot));transform:translateX(-50%);
  background:#000d;color:#fff;padding:10px 16px;border-radius:10px;font-size:14px;
  max-width:86%;text-align:center;z-index:50;
}
.toast.err{background:#5a1a1ad9}
.busy{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:#0006;z-index:60}
.spinner{width:38px;height:38px;border:4px solid #fff3;border-top-color:var(--accent2);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
