*{box-sizing:border-box}:root{--bg:#f4f7fb;--surface:#fff;--surface-soft:#f8fafc;--border:#d9e2ec;--text:#102033;--muted:#607089;--primary:#2357d5;--primary-dark:#183f9f;--shadow:0 16px 40px #10203314}body{background:var(--bg);color:var(--text);margin:0;font-family:Arial,Noto Sans JP,Noto Sans CJK JP,sans-serif}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}.app-shell{min-height:100vh;display:flex}.sidebar{color:#e7edf7;background:#0f1f35;width:260px;height:100vh;padding:24px 18px;position:sticky;top:0;overflow-y:auto}.sidebar-logo{border-bottom:1px solid #ffffff1f;align-items:center;gap:12px;padding-bottom:24px;display:flex}.logo-mark{color:#0f1f35;background:#fff;border-radius:12px;place-items:center;width:40px;height:40px;font-weight:700;display:grid}.logo-title,.logo-subtitle,.nav-group-label,.user-name,.user-role,.header-eyebrow,.kpi-label,.kpi-note,.card-header p,.page-header p,.empty-note{margin:0}.logo-title{font-size:18px;font-weight:700}.logo-subtitle{color:#9fb1cc;font-size:12px}.sidebar-nav{padding-top:20px}.nav-group{margin-bottom:22px}.nav-group-label{color:#8fa3c0;letter-spacing:.08em;margin-bottom:8px;font-size:12px;font-weight:700}.nav-link{color:#d7e2f2;border-radius:10px;padding:10px 12px;font-size:14px;display:block}.nav-link:hover,.nav-link-active{color:#fff;background:#ffffff1f}.app-main{flex:1;min-width:0}.app-header{border-bottom:1px solid var(--border);z-index:5;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#f4f7fbe0;justify-content:space-between;align-items:center;gap:24px;padding:20px 32px;display:flex;position:sticky;top:0}.header-eyebrow{color:var(--primary);letter-spacing:.08em;font-size:12px;font-weight:700}.app-header h1{margin:4px 0 0;font-size:20px}.header-user{background:var(--surface);border:1px solid var(--border);border-radius:999px;align-items:center;gap:10px;padding:8px 14px 8px 8px;display:flex}.user-avatar{background:var(--primary);color:#fff;border-radius:50%;place-items:center;width:34px;height:34px;font-weight:700;display:grid}.user-name{font-size:13px;font-weight:700}.user-role{color:var(--muted);font-size:11px}.app-content{padding:32px}.page-header{justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:24px;display:flex}.page-header h2{margin:0 0 8px;font-size:28px}.page-header p{color:var(--muted);line-height:1.7}.page-actions{flex-wrap:wrap;gap:10px;display:flex}.grid{gap:20px;display:grid}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.card,.kpi-card,.login-card{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:18px}.card-header{border-bottom:1px solid var(--border);padding:18px 20px}.card-header h3{margin:0 0 6px;font-size:16px}.card-header p{color:var(--muted);font-size:13px}.card-body,.kpi-card{padding:20px}.kpi-label{color:var(--muted);font-size:13px}.kpi-value{margin:10px 0;font-size:30px;font-weight:700}.kpi-note{color:var(--muted);font-size:12px}.button-link{background:var(--primary);color:#fff;border-radius:10px;justify-content:center;align-items:center;min-height:40px;padding:10px 14px;font-size:14px;font-weight:700;display:inline-flex}.button-link:hover{background:var(--primary-dark)}.button-secondary{color:var(--primary);background:#eef3ff}.button-secondary:hover{background:#dfe8ff}.table-wrap{width:100%;overflow-x:auto}.data-table{border-collapse:collapse;width:100%;min-width:760px}.data-table th,.data-table td{border-bottom:1px solid var(--border);text-align:left;vertical-align:top;padding:12px 10px;font-size:14px}.data-table th{color:var(--muted);background:var(--surface-soft);font-size:12px;font-weight:700}.status-badge{white-space:nowrap;border-radius:999px;padding:4px 9px;font-size:12px;font-weight:700;display:inline-flex}.status-gray{color:#475569;background:#eef2f7}.status-blue{color:#1d4ed8;background:#e8f1ff}.status-green{color:#047857;background:#e8f8ef}.status-yellow{color:#a16207;background:#fff7df}.status-red{color:#b91c1c;background:#ffe8e8}.status-purple{color:#6d28d9;background:#f1e8ff}.form-grid{gap:14px;display:grid}.form-row{gap:6px;display:grid}.form-row label{color:var(--muted);font-size:13px;font-weight:700}.form-row input,.form-row select,.form-row textarea{border:1px solid var(--border);background:#fff;border-radius:10px;width:100%;padding:11px 12px}.form-row textarea{resize:vertical;min-height:140px}.generated-message{background:var(--surface-soft);white-space:pre-wrap;border:1px dashed #afbdd0;border-radius:14px;min-height:320px;padding:16px;line-height:1.8}.task-layout{grid-template-columns:minmax(0,1fr) 360px;gap:20px;display:grid}.task-detail{position:sticky;top:96px}.empty-note{background:var(--surface-soft);color:var(--muted);border:1px dashed #afbdd0;border-radius:14px;padding:16px;line-height:1.7}.login-page{place-items:center;min-height:100vh;padding:24px;display:grid}.login-card{width:min(420px,100%);padding:28px}.login-card h1{margin:0 0 8px;font-size:24px}.login-card p{color:var(--muted);line-height:1.7}@media (max-width:980px){.app-shell{display:block}.sidebar{width:100%;height:auto;position:static}.grid-2,.grid-3,.task-layout{grid-template-columns:1fr}.app-header,.page-header{flex-direction:column;align-items:stretch}.app-content{padding:20px}}.button-link:disabled,.button-link[disabled]{cursor:not-allowed;opacity:.6}
