:root{--bg: #f4f6fb;--panel: #ffffff;--ink: #1b2230;--muted: #6b7480;--line: #e6e9f0;--accent: #2f6df6;--accent-ink: #ffffff;--warn: #fff7e6;--warn-line: #ffd591;--ok: #1aa260;--danger: #d64545;--radius: 14px;--shadow: 0 1px 3px rgba(20, 30, 60, .06), 0 8px 24px rgba(20, 30, 60, .06);font-family:system-ui,-apple-system,Hiragino Kaku Gothic ProN,Yu Gothic,Noto Sans JP,sans-serif}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--ink)}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.boot{display:grid;place-items:center;height:100vh;color:var(--muted)}.login-wrap{display:grid;place-items:center;min-height:100vh;padding:24px}.login-card{width:100%;max-width:380px;background:var(--panel);border-radius:var(--radius);box-shadow:var(--shadow);padding:28px;display:flex;flex-direction:column;gap:16px}.brand{display:flex;align-items:center;gap:12px}.brand h1{font-size:20px;margin:0}.brand p{margin:2px 0 0;color:var(--muted);font-size:13px}.brand-mark{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,#2f6df6,#7a3df6);color:#fff;font-weight:800;font-size:22px;display:grid;place-items:center}.brand-mark.sm{width:30px;height:30px;border-radius:8px;font-size:16px}.field{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--muted)}.field input{padding:11px 12px;border:1px solid var(--line);border-radius:10px;font-size:15px;color:var(--ink)}.field input:focus{outline:2px solid color-mix(in srgb,var(--accent) 35%,transparent);border-color:var(--accent)}.hint{font-size:12px;color:var(--muted);margin:0}.error{color:var(--danger);font-size:13px;margin:0}.btn{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line);background:var(--panel);color:var(--ink);padding:9px 14px;border-radius:10px;font-size:14px;cursor:pointer}.btn:hover{background:#f7f9fc}.btn.primary{background:var(--accent);color:var(--accent-ink);border-color:var(--accent);justify-content:center}.btn.primary:disabled{opacity:.6;cursor:default}.btn.ghost{border-color:transparent;background:transparent}.app{min-height:100vh}.topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:var(--panel);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10}.brand-inline{display:flex;align-items:center;gap:10px;background:none;border:none;cursor:pointer;font-size:16px;color:var(--ink)}.topbar-right{display:flex;align-items:center;gap:12px}.badge{font-size:12px;padding:4px 10px;border-radius:999px;background:#eef2ff;color:#3a4a8c}.role-admin{background:#eafaf0;color:#1a7a4a}.role-employee{background:#eef2ff;color:#3a4a8c}.content{max-width:960px;margin:0 auto;padding:24px 20px 64px}.home-head,.lp-bar h2{display:flex;align-items:center;gap:8px}.home-head h2{margin:4px 0 16px;font-size:18px}.tile-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}.tile{position:relative;display:flex;align-items:flex-start;gap:14px;text-align:left;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:18px;cursor:pointer;box-shadow:var(--shadow);transition:transform .08s ease,box-shadow .08s ease}.tile:hover:not(.soon){transform:translateY(-2px);box-shadow:0 4px 10px #141e3c1a,0 16px 36px #141e3c1a}.tile.soon{opacity:.6;cursor:default}.tile-icon{width:46px;height:46px;border-radius:12px;background:#eef3ff;color:var(--accent);display:grid;place-items:center;flex-shrink:0}.tile-body{display:flex;flex-direction:column;gap:4px}.tile-title{display:flex;align-items:center;gap:6px;font-weight:700}.tile-desc{font-size:13px;color:var(--muted)}.soon-badge{position:absolute;top:12px;right:12px;background:#f0f0f3;color:var(--muted)}.lp-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.lp-bar h2{margin:0;font-size:18px}.muted{color:var(--muted);font-size:13px}.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow);margin:14px 0}.panel h3{display:flex;align-items:center;gap:8px;margin:0 0 10px;font-size:15px}.panel.warn{background:var(--warn);border-color:var(--warn-line)}.cols{display:grid;grid-template-columns:1fr 1fr;gap:14px}.row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:9px 0;border-top:1px solid var(--line)}.row:first-of-type{border-top:none}.row b{font-weight:700}.sub{display:block;color:var(--muted);font-size:12px;margin-top:2px}.tag{display:inline-block;font-size:11px;padding:2px 8px;border-radius:999px;margin-right:8px;background:#eef2ff;color:#3a4a8c}.tag-publish{background:#eafaf0;color:var(--ok)}.tag-retire{background:#fdeaea;color:var(--danger)}.tag-rollback{background:#fff3e0;color:#b9770e}code{background:#f0f2f7;padding:1px 6px;border-radius:6px;font-size:12px}.spin{animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.module-head{display:flex;align-items:center;gap:12px;margin-bottom:8px}.module-head h2{display:flex;align-items:center;gap:8px;margin:0;font-size:18px}.module-head .spacer{flex:1}.tabs{display:flex;gap:6px;border-bottom:1px solid var(--line);margin-bottom:8px}.tab{background:none;border:none;border-bottom:2px solid transparent;padding:9px 14px;font-size:14px;color:var(--muted);cursor:pointer}.tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:700}.subtabs{display:flex;align-items:center;gap:4px;padding:4px;background:var(--panel);border:1px solid var(--line);border-radius:10px;margin:12px 0 0}.subtab{display:inline-flex;align-items:center;gap:6px;background:transparent;color:var(--muted);border:none;border-radius:7px;padding:7px 12px;font-size:13px;cursor:pointer}.subtab:hover{color:var(--ink)}.subtab.active{background:color-mix(in srgb,var(--accent) 12%,transparent);color:var(--accent);font-weight:700}.subtab .count{background:var(--accent);color:#fff;font-size:11px;font-weight:700;padding:1px 6px;border-radius:999px;min-width:18px;text-align:center}.subtabs .spacer{flex:1}.row-actions{display:inline-flex;align-items:center;gap:8px}.panel-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:8px 0}.dropzone{border:2px dashed var(--line);border-radius:var(--radius);background:var(--panel);padding:32px;display:flex;flex-direction:column;align-items:center;gap:10px;color:var(--muted);cursor:pointer;text-align:center}.dropzone:hover,.dropzone.over{border-color:var(--accent);background:#f6f9ff}.dropzone p{margin:0;color:var(--ink)}.report-head{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:var(--radius);margin:14px 0}.report-head.ok{background:#eafaf0;color:#137a45}.report-head.ng{background:#fdeaea;color:var(--danger)}.report-head .sub{color:inherit;opacity:.85}.prob{display:flex;align-items:baseline;gap:10px;padding:7px 0;border-top:1px solid var(--line);font-size:14px}.prob:first-of-type{border-top:none}.prob.err code{background:#fdeaea;color:var(--danger)}.prob.warn code{background:#fff3e0;color:#b9770e}.field2{display:flex;flex-direction:column;gap:6px;margin:12px 0;font-size:13px;color:var(--muted)}.field2>span:first-child{font-weight:600}.field2 input[type=text],.field2 .slug-row input{padding:9px 11px;border:1px solid var(--line);border-radius:9px;font-size:14px;color:var(--ink)}.slug-row{display:flex;align-items:center;gap:6px}.slug-row input{flex:1}.radios{display:flex;flex-wrap:wrap;gap:14px;color:var(--ink);font-size:14px}.radios label{display:inline-flex;align-items:center;gap:6px}@media(max-width:640px){.cols{grid-template-columns:1fr}}.brand-logo{height:28px;width:auto;display:block}.brand-logo-lg{height:56px;width:auto;display:block;margin:0 auto}.logo-on-dark{display:none}:root[data-theme=dark] .logo-on-light{display:none}:root[data-theme=dark] .logo-on-dark{display:block}.login-brand{justify-content:center}.theme-toggle{padding:8px}.login-wrap{position:relative}.login-theme{position:absolute;top:16px;right:16px}.brand{align-items:center}.field input,.field2 input,.slug-row input{background:var(--panel);color:var(--ink)}:root[data-theme=dark]{--bg: #0f141b;--panel: #161c25;--ink: #e7ebf2;--muted: #9aa4b2;--line: #2a323d;--accent: #5b8cff;--warn: #2a2310;--warn-line: #5c4a1e;--shadow: 0 1px 3px rgba(0, 0, 0, .45), 0 8px 24px rgba(0, 0, 0, .4)}:root[data-theme=dark] .btn:hover{background:#1d2530}:root[data-theme=dark] .badge{background:#22304d;color:#bcd0ff}:root[data-theme=dark] .role-admin{background:#16361f;color:#7fd39b}:root[data-theme=dark] .role-employee{background:#22304d;color:#bcd0ff}:root[data-theme=dark] .tile-icon{background:#1d2942;color:#8fb0ff}:root[data-theme=dark] .soon-badge{background:#222a35;color:var(--muted)}:root[data-theme=dark] code{background:#222a35}:root[data-theme=dark] .dropzone:hover,:root[data-theme=dark] .dropzone.over{background:#18202c}:root[data-theme=dark] .report-head.ok,:root[data-theme=dark] .tag-publish{background:#13311f;color:#7fd39b}:root[data-theme=dark] .report-head.ng,:root[data-theme=dark] .tag-retire,:root[data-theme=dark] .prob.err code{background:#3a1d1d;color:#f0a3a3}:root[data-theme=dark] .tag,:root[data-theme=dark] .tag-rollback,:root[data-theme=dark] .prob.warn code{background:#2a2310;color:#e0b15e}:root[data-theme=dark] .tag{background:#22304d;color:#bcd0ff}
