:root{--ink:#1b2335;--muted:#5a6577;--line:#dde3ee;--accent:#1c46ad;--accent-strong:#15378d;--accent-soft:#e9effb;--bg:#f6f8fc;--danger:#c2402f;--danger-soft:#fdeeea;--radius:12px;--shadow:0 1px 3px rgba(27,35,53,0.07)}*{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{margin:0;background:var(--bg);color:var(--ink);font-family:Hiragino Sans,Noto Sans JP,system-ui,sans-serif;font-size:16px;line-height:1.7}.topbar{border-bottom:1px solid var(--line);background:#fff;padding:max(10px,env(safe-area-inset-top)) 16px 10px;justify-content:space-between;gap:12px;position:-webkit-sticky;position:sticky;top:0;z-index:60}.nav-links,.topbar{display:flex;align-items:center}.nav-links{gap:4px}.nav-link{display:inline-flex;align-items:center;gap:6px;padding:9px 14px;min-height:44px;border:none;background:none;border-radius:10px;color:var(--muted);font-size:14px;font-weight:600;text-decoration:none;cursor:pointer;transition:background-color .15s ease,color .15s ease}.nav-link:hover{border-color:transparent}.nav-link.active,.nav-link:hover{background:var(--accent-soft);color:var(--accent)}.nav-logout{color:var(--muted)}.hamburger{display:none;border:none;background:none;color:var(--ink);min-width:44px;min-height:44px;padding:8px;align-items:center;justify-content:center}.mobile-menu-backdrop{position:fixed;inset:0;background:rgba(27,35,53,.45);z-index:70}.mobile-menu{position:fixed;top:0;right:0;bottom:0;width:min(300px,84vw);background:#fff;z-index:80;padding:calc(16px + env(safe-area-inset-top)) 14px 16px;display:flex;flex-direction:column;gap:4px;box-shadow:-8px 0 32px rgba(27,35,53,.18);animation:menu-in .2s ease-out}@keyframes menu-in{0%{transform:translateX(24px);opacity:0}to{transform:translateX(0);opacity:1}}.mobile-menu-item{display:flex;align-items:center;gap:12px;padding:14px;min-height:52px;border:none;background:none;border-radius:10px;color:var(--ink);font-size:15px;font-weight:600;text-decoration:none;cursor:pointer;text-align:left}.mobile-menu-item.active,.mobile-menu-item:active{background:var(--accent-soft)}.mobile-menu-item.active{color:var(--accent)}.mobile-menu-item.logout{margin-top:auto;color:var(--muted);border-top:1px solid var(--line);border-radius:0}@media (max-width:720px){.nav-links{display:none}.hamburger{display:inline-flex}}.brand{display:inline-flex;align-items:center;text-decoration:none}.brand img{height:30px;width:auto;display:block}.brand .brand-sub{margin-left:10px;font-size:13px;font-weight:600;color:var(--muted);letter-spacing:.08em}.container{max-width:880px;margin:0 auto;padding:24px 16px 140px}@media (min-width:721px){.topbar{padding:14px 28px}.container{padding:36px 24px 80px}}h1{font-size:20px;font-weight:700;margin:0 0 20px}@media (min-width:721px){h1{font-size:22px}}.btn,button{font:inherit;font-size:15px;font-weight:500;border:1px solid var(--line);background:#fff;color:var(--ink);border-radius:10px;padding:10px 16px;min-height:44px;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;touch-action:manipulation;-webkit-tap-highlight-color:transparent;transition:background-color .15s ease,border-color .15s ease,opacity .15s ease}.btn:hover,button:hover{border-color:var(--accent)}.btn:active,button:active{background:var(--accent-soft)}button:disabled{opacity:.45;cursor:default}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:hover{border-color:var(--accent-strong)}.btn-primary:active,.btn-primary:hover{background:var(--accent-strong)}.btn-danger{color:var(--danger)}.btn-danger:hover{border-color:var(--danger)}.btn-danger:active{background:var(--danger-soft)}input[type=datetime-local],input[type=email],input[type=number],input[type=password],input[type=text],select,textarea{font:inherit;font-size:16px;width:100%;border:1px solid var(--line);border-radius:10px;padding:12px 14px;min-height:48px;background:#fff;color:var(--ink)}textarea{resize:vertical;line-height:1.7}.btn:focus-visible,button:focus-visible,input:focus,select:focus,textarea:focus{outline:2px solid var(--accent);outline-offset:1px}@media (min-width:721px){select{max-width:320px}input[type=number]{max-width:200px}input[type=datetime-local]{max-width:280px}}.list{border:1px solid var(--line);border-radius:var(--radius);background:#fff;overflow:hidden;box-shadow:var(--shadow)}.list a{display:flex;align-items:center;gap:12px;padding:16px;min-height:56px;color:inherit;text-decoration:none;border-bottom:1px solid var(--line);-webkit-tap-highlight-color:transparent;transition:background-color .15s ease}.list a:last-child{border-bottom:none}.list a:active,.list a:hover{background:var(--accent-soft)}.badge{font-size:12px;font-weight:600;border-radius:999px;padding:3px 12px;background:#edf0f6;color:var(--muted);white-space:nowrap}.badge.published,.badge.required{background:var(--accent-soft);color:var(--accent)}.row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.spread{justify-content:space-between}.meta{color:var(--muted);font-size:13px}.title-input{font-size:19px;font-weight:700;border:none;border-bottom:2px solid var(--line);border-radius:0;padding:10px 2px;min-height:48px;background:transparent}.title-input:focus{outline:none;border-bottom-color:var(--accent)}.editor{border:1px solid var(--line);border-radius:var(--radius);background:#fff;margin-top:14px;box-shadow:var(--shadow)}.editor-toolbar{display:flex;gap:6px;padding:8px;border-bottom:1px solid var(--line);flex-wrap:wrap;position:-webkit-sticky;position:sticky;top:0;background:#fff;border-radius:var(--radius) var(--radius) 0 0;z-index:10}.editor-toolbar button{padding:8px 12px;min-height:40px;font-size:14px;border-radius:8px}.editor-toolbar button.active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.tiptap{min-height:320px;padding:16px;outline:none}.tiptap img{max-width:100%;border-radius:8px}.tiptap h2{font-size:19px;border-bottom:2px solid var(--accent-soft);padding-bottom:6px}.tiptap blockquote{margin:14px 0;padding:4px 16px;border-left:4px solid var(--line);color:var(--muted)}.actions-bar{display:flex;gap:8px;align-items:center}@media (max-width:720px){.actions-bar{position:fixed;left:0;right:0;bottom:0;z-index:50;background:rgba(255,255,255,.96);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-top:1px solid var(--line);padding:10px 12px calc(10px + env(safe-area-inset-bottom))}.actions-bar button{flex:1 1;min-height:48px}.actions-bar .btn-danger{flex:0 0 auto;padding:10px 14px}}.login-card{max-width:400px;margin:48px auto;background:#fff;border:1px solid var(--line);border-radius:14px;padding:28px 22px;display:grid;grid-gap:14px;gap:14px;box-shadow:var(--shadow)}.login-card .login-logo{width:180px;margin:6px auto 4px;display:block}@media (min-width:721px){.login-card{padding:36px 32px;margin-top:72px}}.error{color:var(--danger);font-size:14px}.field-block{margin-top:22px}.field-label{gap:8px;font-weight:600;font-size:14px;margin-bottom:8px}.checkbox-label,.field-label{display:flex;align-items:center}.checkbox-label{gap:10px;cursor:pointer;min-height:44px}.checkbox-label input{width:20px;height:20px;accent-color:var(--accent)}.field-block .editor{margin-top:0}.field-block .tiptap{min-height:260px}.image-field{display:grid;grid-gap:10px;gap:10px;justify-items:start}.image-field img{max-width:min(320px,100%);border-radius:10px}.image-field img,.panel{border:1px solid var(--line)}.panel{background:#fff;border-radius:var(--radius);padding:18px 16px;margin-bottom:16px;box-shadow:var(--shadow)}@media (min-width:721px){.panel{padding:22px 24px}}.schema-grid{display:grid;grid-template-columns:1fr;grid-gap:14px;gap:14px;align-items:start}@media (min-width:540px){.schema-grid{grid-template-columns:1fr 1fr}}@media (min-width:900px){.schema-grid{grid-template-columns:1fr 1fr 1fr auto}}.schema-grid .field-label{margin-bottom:6px}.schema-row select{max-width:none;width:100%}.page-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap;margin-bottom:20px}.page-head h1{margin-bottom:4px}.breadcrumb{display:flex;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap}.breadcrumb a{display:inline-flex;align-items:center;gap:4px;color:var(--muted);text-decoration:none;font-size:14px;min-height:44px}.breadcrumb a:hover{color:var(--accent)}.stats-row{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:10px;gap:10px;margin-bottom:22px}.stat-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:14px;display:flex;align-items:center;gap:12px;box-shadow:var(--shadow)}.stat-icon{width:40px;height:40px;border-radius:10px;background:var(--accent-soft);color:var(--accent);display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto}.stat-value{font-size:22px;font-weight:700;line-height:1.2}.stat-label{font-size:12px;color:var(--muted)}@media (max-width:540px){.stats-row{grid-template-columns:repeat(3,1fr);gap:8px}.stat-card{flex-direction:column;align-items:flex-start;gap:8px;padding:12px}.stat-icon{width:32px;height:32px}.stat-value{font-size:19px}.stat-label{font-size:11px}}.api-grid{display:grid;grid-template-columns:1fr;grid-gap:14px;gap:14px}@media (min-width:721px){.api-grid{grid-template-columns:1fr 1fr}}.api-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column}.api-card-main{display:block;padding:18px 18px 14px;color:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent;transition:background-color .15s ease}.api-card-main:active,.api-card-main:hover{background:var(--accent-soft)}.api-card-head{display:flex;justify-content:space-between;align-items:center;color:var(--ink)}.api-card-head svg{color:var(--muted)}.api-card-name{font-size:17px;font-weight:700}.api-card-endpoint{display:inline-block;margin-top:2px;font-size:12.5px;color:var(--accent);background:var(--accent-soft);border-radius:6px;padding:2px 8px;font-family:SF Mono,Menlo,monospace}.api-card-stats{display:flex;gap:16px;margin-top:12px;font-size:13px;color:var(--muted)}.api-card-stats span{display:inline-flex;align-items:center;gap:5px}.api-card-fields{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}.api-card-foot{display:flex;gap:8px;padding:12px 18px;border-top:1px solid var(--line);background:#fafbfd}.api-card-foot .btn{flex:1 1}.chip{display:inline-flex;align-items:center;gap:5px;background:#f0f3f9;color:var(--ink);border-radius:999px;padding:3px 11px;font-size:12.5px;font-weight:500}.chip small{color:var(--muted);font-size:11px}.tabs{display:flex;gap:6px;margin-bottom:14px;overflow-x:auto;-webkit-overflow-scrolling:touch}.tab{border:1px solid var(--line);background:#fff;border-radius:999px;padding:8px 16px;min-height:44px;font-size:14px;white-space:nowrap}.tab.active{background:var(--accent);border-color:var(--accent);color:#fff}.tab-count{margin-left:6px;font-size:12px;opacity:.75}.panel-title{display:flex;align-items:center;gap:7px;font-size:15px;font-weight:700;margin:0 0 10px}.helper-text{font-size:13px;color:var(--muted);margin:6px 0 0;line-height:1.6}.breadcrumb code,.helper-text code,.page-head code{background:var(--accent-soft);color:var(--accent);border-radius:5px;padding:1px 6px;font-size:12.5px}.info-banner{background:var(--accent-soft);border-color:#c7d6f5;color:var(--ink);font-size:14px}.empty-state{text-align:center;padding:36px 20px}.empty-state .btn-primary,.empty-state button{margin:0 auto}.onboarding{list-style:none;counter-reset:ob;padding:0;margin:18px auto 22px;max-width:440px;text-align:left;display:grid;grid-gap:12px;gap:12px}.onboarding li{counter-increment:ob;position:relative;padding-left:44px}.onboarding li:before{content:counter(ob);position:absolute;left:0;top:2px;width:30px;height:30px;border-radius:50%;background:var(--accent);color:#fff;font-weight:700;font-size:14px;display:flex;align-items:center;justify-content:center}.onboarding b{display:block;font-size:15px}.onboarding span{font-size:13px;color:var(--muted)}.edit-layout{display:grid;grid-template-columns:1fr;grid-gap:22px;gap:22px}@media (min-width:900px){.edit-layout{grid-template-columns:1fr 300px;align-items:start}.edit-side{position:-webkit-sticky;position:sticky;top:16px}}.side-panel{margin-bottom:14px}.info-list{margin:0}.info-list div{display:flex;justify-content:space-between;gap:10px;padding:7px 0;border-bottom:1px solid var(--line);font-size:13.5px}.info-list div:last-child{border-bottom:none}.info-list dt{color:var(--muted)}.info-list dd{margin:0;text-align:right;word-break:break-all}.info-list code{font-size:12px}.draftkey-row{display:flex;gap:8px;align-items:center;margin-top:10px}.draftkey{flex:1 1;background:#f0f3f9;border-radius:8px;padding:9px 12px;font-size:12px;font-family:SF Mono,Menlo,monospace;word-break:break-all}.danger-zone{border-color:#f0ccc4}.danger-zone .panel-title{color:var(--danger)}.badge.unsaved{background:var(--warn-bg,#fff3d6);color:#8a6400}.btn-small{min-height:38px;padding:7px 12px;font-size:13.5px;gap:5px}.btn svg,button svg{flex:0 0 auto}button .btn-text{margin-left:2px}.toast{position:fixed;top:14px;left:50%;transform:translateX(-50%);z-index:100;background:var(--ink);color:#fff;border-radius:10px;padding:12px 20px;font-size:14px;box-shadow:0 6px 20px rgba(27,35,53,.25);max-width:calc(100vw - 32px);animation:toast-in .2s ease-out}.toast.err{background:var(--danger)}@keyframes toast-in{0%{opacity:0;transform:translate(-50%,-8px)}to{opacity:1;transform:translate(-50%)}}.skeleton-list{display:grid;grid-gap:12px;gap:12px}.skeleton{height:64px;border-radius:var(--radius);background:linear-gradient(90deg,#edf0f6 25%,#f6f8fc 50%,#edf0f6 75%);background-size:200% 100%;animation:shimmer 1.4s infinite}.skeleton.tall{height:220px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.list-title{flex:1 1;font-weight:500;min-width:0;overflow:hidden;text-overflow:ellipsis}.list-date,.list-title{white-space:nowrap}.list a>svg{color:var(--muted);flex:0 0 auto}@media (max-width:540px){.list-date{display:none}}.conn-row{display:flex;gap:14px;align-items:flex-start;padding:12px 0;border-bottom:1px solid var(--line);flex-wrap:wrap}.conn-row:last-of-type{border-bottom:none}.conn-label{flex:0 0 140px;font-size:13.5px;font-weight:600;color:var(--muted);padding-top:8px}.conn-value{display:flex;align-items:center;gap:8px;flex:1 1;min-width:0;margin-bottom:6px}.conn-value code{flex:1 1;min-width:0;background:#f0f3f9;border-radius:8px;padding:9px 12px;font-size:13px;font-family:SF Mono,Menlo,monospace;word-break:break-all}.conn-value code.keycode{letter-spacing:.02em}@media (max-width:540px){.conn-label{flex-basis:100%;padding-top:0}}.warn-box{margin-top:14px;background:#fff7e0;border:1px solid #e8d48a;color:#7a5d00;padding:12px 14px;font-size:13.5px}.code-block,.warn-box{border-radius:10px;line-height:1.7}.code-block{background:#21302f;background:#1f2937;color:#e7edf5;padding:14px 16px;overflow-x:auto;font-size:12.5px;font-family:SF Mono,Menlo,monospace;margin:8px 0 4px}.mini-table{box-shadow:none;margin:10px 0 0;width:100%;border-collapse:collapse}.mini-table td{padding:9px 10px;border-bottom:1px solid var(--line);font-size:13.5px;vertical-align:top}.mini-table tr:last-child td{border-bottom:none}.mini-table td:first-child{color:var(--muted);white-space:nowrap;font-weight:600}.mini-table code{background:#f0f3f9;border-radius:5px;padding:1px 6px;font-size:12px;word-break:break-all}.issued-panel{border-color:var(--accent);background:#f4f8ff}.tenant-card{margin-bottom:14px}.tenant-keys{display:grid;grid-gap:6px;gap:6px}@media (prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}