:root{--bg: #0f172a;--bg-elev: #1e293b;--bg-card: #1e293b;--border: #334155;--text: #e2e8f0;--text-muted: #94a3b8;--accent: #38bdf8;--accent-2: #a78bfa;--accent-3: #fb7185;--ok: #34d399;color-scheme:dark;font-family:system-ui,Hiragino Sans,Noto Sans JP,sans-serif;color:var(--text);background:var(--bg)}*{box-sizing:border-box}body{margin:0}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{display:flex;align-items:center;gap:24px;padding:12px 24px;background:var(--bg-elev);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}.app-header__brand{display:flex;align-items:baseline;gap:8px}.app-header__logo{font-size:20px}.app-header__title{font-size:18px;font-weight:700}.app-header__subtitle{font-size:12px;color:var(--text-muted)}.app-nav{display:flex;gap:4px}.nav-link{padding:6px 14px;border-radius:8px;color:var(--text-muted);text-decoration:none;font-size:14px;font-weight:600}.nav-link:hover{background:#94a3b81f;color:var(--text)}.nav-link--active{background:#38bdf826;color:var(--accent)}.app-header__badges{margin-left:auto;display:flex;gap:8px}.badge{font-size:11px;font-weight:700;letter-spacing:.04em;padding:3px 8px;border-radius:999px;border:1px solid var(--border)}.badge--env-dev{color:var(--ok);border-color:#34d39966}.badge--env-stg{color:#fbbf24;border-color:#fbbf2466}.badge--env-prod{color:var(--accent-3);border-color:#fb718566}.badge--mock{color:var(--accent-2);border-color:#a78bfa66}.app-main{flex:1;padding:24px;max-width:1200px;width:100%;margin:0 auto}.page-title{font-size:22px;font-weight:700;margin:0 0 4px}.page-subtitle{color:var(--text-muted);margin:0 0 24px;font-size:14px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:20px}.card__title{font-size:15px;font-weight:700;margin:0 0 16px}.grid{display:grid;gap:20px}.grid--2{grid-template-columns:repeat(auto-fit,minmax(420px,1fr))}.kpi-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:20px}.kpi{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:16px 18px}.kpi__label{font-size:12px;color:var(--text-muted)}.kpi__value{font-size:26px;font-weight:700;margin-top:4px}.kpi__sub{font-size:12px;color:var(--text-muted);margin-top:2px}.agent-layout{display:grid;gap:20px;grid-template-columns:minmax(0,1fr)}.agent-form{display:flex;flex-direction:column;gap:12px}.agent-textarea{width:100%;min-height:96px;resize:vertical;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:10px;padding:12px;font-size:14px;font-family:inherit}.agent-textarea:focus{outline:none;border-color:var(--accent)}.agent-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.btn{background:var(--accent);color:#04293a;border:none;border-radius:10px;padding:10px 18px;font-size:14px;font-weight:700;cursor:pointer}.btn:hover:not(:disabled){filter:brightness(1.08)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--ghost{background:transparent;color:var(--text-muted);border:1px solid var(--border)}.suggestions{display:flex;gap:8px;flex-wrap:wrap}.chip{background:transparent;border:1px solid var(--border);color:var(--text-muted);border-radius:999px;padding:6px 12px;font-size:12px;cursor:pointer}.chip:hover{border-color:var(--accent);color:var(--text)}.agent-answer{white-space:pre-wrap;line-height:1.7;font-size:14px}.agent-answer__meta{margin-top:16px;padding-top:12px;border-top:1px solid var(--border);font-size:12px;color:var(--text-muted)}.muted{color:var(--text-muted)}.code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.92em;background:#94a3b824;padding:1px 6px;border-radius:5px;color:#cbd5e1}.catalog-toolbar{display:flex;align-items:center;gap:12px;margin-bottom:16px}.catalog-search{flex:1;max-width:420px;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:10px;padding:9px 12px;font-size:14px;font-family:inherit}.catalog-search:focus{outline:none;border-color:var(--accent)}.catalog-list{display:flex;flex-direction:column;gap:12px}.catalog-table{padding:0}.catalog-table__summary{display:flex;align-items:center;gap:12px;padding:16px 20px;cursor:pointer;list-style:none}.catalog-table__summary::-webkit-details-marker{display:none}.catalog-table__summary:before{content:"▶";font-size:10px;color:var(--text-muted);transition:transform .15s}.catalog-table[open] .catalog-table__summary:before{transform:rotate(90deg)}.catalog-table__name{font-size:14px;font-weight:600}.catalog-table__count{margin-left:auto;font-size:12px}.catalog-table__desc{margin:0 20px 12px;font-size:13px;line-height:1.6;color:#cbd5e1}.catalog-table__meta{margin:0 20px 12px;font-size:12px;display:flex;flex-wrap:wrap;gap:16px}.catalog-cols-wrap{overflow-x:auto;margin:0 16px 16px;border:1px solid var(--border);border-radius:10px}.catalog-cols{width:100%;border-collapse:collapse;font-size:13px}.catalog-cols th,.catalog-cols td{text-align:left;padding:8px 12px;border-bottom:1px solid var(--border);vertical-align:top;white-space:nowrap}.catalog-cols td.muted{white-space:normal;max-width:320px}.catalog-cols th{background:#94a3b814;color:var(--text-muted);font-weight:600;position:sticky;top:0}.catalog-cols tbody tr:last-child td{border-bottom:none}.catalog-cols__type{color:var(--accent);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px}.catalog-cols__req{color:var(--accent-3);font-size:10px}.spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#04293a;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app-header__badges{align-items:center}.user-menu{display:flex;align-items:center;gap:10px;margin-left:4px}.user-menu__name{font-size:12px;color:var(--text-muted);max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu__logout{font-size:12px;font-weight:600;color:var(--text);background:transparent;border:1px solid var(--border);border-radius:999px;padding:4px 12px;cursor:pointer}.user-menu__logout:hover{border-color:var(--accent);color:var(--accent)}.auth-message{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.auth-message__card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:28px 32px;text-align:center;color:var(--text-muted);max-width:480px}.auth-message__detail{font-size:12px;color:var(--accent-3);word-break:break-word}.auth-message__button{margin-top:12px;font-weight:600;color:var(--text);background:transparent;border:1px solid var(--border);border-radius:8px;padding:8px 18px;cursor:pointer}.auth-message__button:hover{border-color:var(--accent);color:var(--accent)}
